{"version":3,"sources":["node_modules/browser-pack/_prelude.js","lib/colResizable-1.4.js","yasr.bundled.min.js","lib/jquery.csv-0.71.js","node_modules/codemirror/addon/edit/matchbrackets.js","node_modules/codemirror/addon/fold/brace-fold.js","node_modules/codemirror/addon/fold/foldcode.js","node_modules/codemirror/addon/fold/foldgutter.js","node_modules/codemirror/addon/fold/xml-fold.js","node_modules/codemirror/lib/codemirror.js","node_modules/codemirror/mode/javascript/javascript.js","node_modules/codemirror/mode/xml/xml.js","node_modules/d3/build/d3.js","node_modules/datatables.net/js/jquery.dataTables.js","node_modules/events/events.js","node_modules/jquery-ui/core.js","node_modules/jquery-ui/mouse.js","node_modules/jquery-ui/sortable.js","node_modules/jquery-ui/widget.js","node_modules/jquery/dist/jquery.js","node_modules/pivottable/dist/d3_renderers.js","node_modules/pivottable/dist/gchart_renderers.js","node_modules/pivottable/dist/pivot.js","node_modules/store/store.js","node_modules/yasgui-utils/package.json","node_modules/yasgui-utils/src/main.js","node_modules/yasgui-utils/src/storage.js","node_modules/yasgui-utils/src/svg.js","package.json","src/bindingsToCsv.js","src/boolean.js","src/defaults.js","src/entry.js","src/error.js","src/exceptions.js","src/gChartLoader.js","src/gchart.js","src/imgs.js","src/jquery/extendJquery.js","src/jquery/tableToCsv.js","src/main.js","src/parsers/csv.js","src/parsers/dlv.js","src/parsers/json.js","src/parsers/tsv.js","src/parsers/wrapper.js","src/parsers/xml.js","src/pivot.js","src/rawResponse.js","src/table.js","src/utils.js"],"names":["f","exports","module","define","amd","g","window","global","self","this","YASR","e","t","n","r","s","o","u","a","require","i","Error","code","l","call","length","1","S","$","d","document","h","drag","tables","count","ID","PX","SIGNATURE","I","parseInt","M","Math","ie","navigator","userAgent","indexOf","sessionStorage","append","init","tb","options","disable","destroy","id","attr","p","postbackSafe","is","addClass","before","opt","c","w","width","gc","prev","marginLeft","css","marginRight","cs","cellSpacing","currentStyle","borderSpacing","b","border","borderLeftWidth","createGrips","removeClass","remove","th","find","cg","ln","memento","each","lastChild","push","removeAttr","bind","onGripMouseDown","gripInnerHtml","hoverCursor","data","syncGrips","not","m","aux","flush","split","eq","left","offset","outerWidth","height","headerOnly","outerHeight","syncCols","isOver","inc","x","c2","w2","onGripDrag","originalEvent","touches","pageX","ox","mw","minWidth","max","position","min","liveDrag","cb","onDrag","currentTarget","onGripDragOver","unbind","draggingClass","onResize","dragCursor","round","fn","extend","colResizable","defaults","jquery","2","RegExp","escape","replace","csv","separator","delimiter","headers","hooks","castToScalar","value","state","hasDot","isNaN","test","parseFloat","integer","parsers","parse","endOfEntry","start","rowNum","entry","colNum","undefined","onParseEntry","hookVal","end","exit","endOfValue","onParseValue","hook","escSeparator","escDelimiter","match","matchSrc","source","m0","splitLines","endOfLine","entries","prevChar","substr","parseEntry","toArray","callback","config","toArrays","toObjects","lines","headerOptions","headerLine","len","object","j","fromArrays","arrays","escaper","experimental","output","fromObjects2CSV","objects","csvEntry2Array","csv2Array","csv2Dictionary","3","mod","CodeMirror","findMatchingBracket","cm","where","strict","line","getLineHandle","pos","ch","matching","text","charAt","dir","style","getTokenTypeAt","Pos","found","scanForBracket","from","to","forward","maxScanLen","maxScanLineLength","maxScanLines","stack","re","bracketRegex","lineEnd","lastLine","firstLine","lineNo","getLine","pop","matchBrackets","autoclear","maxHighlightLen","maxHighlightLineLength","marks","ranges","listSelections","empty","head","markText","className","ie_lt8","focused","focus","clear","operation","setTimeout","doMatchBrackets","currentlyHighlighted","documentMode","(",")","[","]","{","}","defineOption","val","old","Init","off","on","defineExtension","../../lib/codemirror","4","registerHelper","findOpening","openCh","at","pass","lineText","lastIndexOf","tokenType","startToken","endToken","startCh","endCh","outer","nextOpen","nextClose","hasImport","getTokenAt","string","type","semi","startLine","has","next","clipPos","hasInclude","slice","5","doFold","force","getRange","allowFolded","range","finder","minSize","findMarksAt","__isFold","cleared","getOption","myWidget","makeWidget","myRange","e_preventDefault","replacedWith","clearOnEnter","signal","widget","createTextNode","createElement","appendChild","name","editorOptions","foldOptions","defaultOptions","newFoldFunction","rangeFinder","commands","toggleFold","foldCode","getCursor","fold","unfold","foldAll","unfoldAll","funcs","Array","prototype","arguments","helpers","getHelpers","cur","auto","minFoldSize","scanUp","6","State","parseOptions","opts","gutter","indicatorOpen","indicatorFolded","isFolded","findMarks","marker","spec","elt","cloneNode","updateFoldInfo","foldGutter","foldOption","func","eachLine","mark","setGutterMarker","updateInViewport","vp","getViewport","onGutterClick","folded","onChange","clearTimeout","changeUpdate","foldOnChangeTimeSpan","onViewportChange","updateViewportTimeSpan","onFold","clearGutter","./foldcode","7","cmp","Iter","tagAt","iter","nextLine","prevLine","toTagEnd","gt","lastSlash","selfClose","toTagStart","lt","xmlTagStart","lastIndex","exec","index","toNextTag","toPrevTag","findMatchingClose","tag","findMatchingOpen","endLine","nameStartChar","nameChar","openTag","startPos","endPos","findMatchingTag","here","open","close","findEnclosingTag","scanForClosingTag","8","place","copyObj","setGuttersForLineNumbers","doc","Doc","mode","lineSeparator","input","inputStyles","inputStyle","display","Display","wrapper","updateGutters","themeChanged","lineWrapping","autofocus","mobile","initScrollbars","keyMaps","overlays","modeGen","overwrite","delayingBlurEvent","suppressEdits","pasteIncoming","cutIncoming","selectingText","draggingText","highlight","Delayed","keySeq","specialChars","ie_version","reset","registerEventHandlers","ensureGlobalHandlers","startOperation","curOp","forceUpdate","attachDoc","hasFocus","onFocus","onBlur","optionHandlers","hasOwnProperty","maybeUpdateLineNumberWidth","finishInit","initHooks","endOperation","webkit","getComputedStyle","lineDiv","textRendering","scrollbarFiller","setAttribute","gutterFiller","selectionDiv","cursorDiv","measure","lineMeasure","lineSpace","mover","sizer","sizerWidth","heightForcer","scrollerGap","gutters","lineGutter","scroller","zIndex","paddingRight","gecko","draggable","viewFrom","viewTo","first","reportedViewFrom","reportedViewTo","view","renderedView","externalMeasured","viewOffset","lastWrapHeight","lastWrapWidth","updateLineNumbers","nativeBarWidth","barHeight","barWidth","scrollbarsClipped","lineNumWidth","lineNumInnerWidth","lineNumChars","alignWidgets","cachedCharWidth","cachedTextHeight","cachedPaddingH","maxLine","maxLineLength","maxLineChanged","wheelDX","wheelDY","wheelStartX","wheelStartY","shift","selForContextMenu","activeTouch","loadMode","getMode","modeOption","resetModeState","stateAfter","styles","frontier","startWorker","regChange","wrappingChanged","rmClass","findMaxLine","estimateLineHeights","clearCaches","updateScrollbars","estimateHeight","textHeight","wrapping","perLine","clientWidth","charWidth","lineIsHidden","widgetsHeight","widgets","ceil","est","estHeight","updateLineHeight","theme","guttersChanged","alignHorizontally","specs","removeChildren","gutterClass","gElt","updateGutterSpace","offsetWidth","lineLength","merged","collapsedSpanAtStart","collapsedSpanAtEnd","lineNumbers","concat","splice","measureForScrollbars","gutterW","docH","paddingVert","clientHeight","viewHeight","scrollWidth","viewWidth","barLeft","fixedGutter","docHeight","scrollHeight","scrollGap","gutterWidth","NativeScrollbars","scroll","vert","horiz","scrollTop","scrollLeft","checkedZeroWidth","minHeight","NullScrollbars","scrollbars","scrollbarModel","scrollbarStyle","node","insertBefore","axis","setScrollLeft","setScrollTop","startWidth","startHeight","updateScrollbarsInner","updateHeightsInViewport","sizes","update","right","paddingBottom","bottom","borderBottom","coverGutterNextToScrollbar","visibleLines","viewport","top","floor","paddingTop","lineAtHeight","ensure","ensureFrom","ensureTo","heightAtLine","firstChild","comp","compensateForHScroll","hidden","align","alignable","last","lineNumberFor","size","innerW","padding","String","lineNumberFormatter","firstLineNumber","getBoundingClientRect","DisplayUpdate","visible","editorIsHidden","wrapperHeight","wrapperWidth","oldDisplayWidth","displayWidth","dims","getDimensions","events","maybeClipScrollbars","marginBottom","borderRightWidth","updateDisplayIfNeeded","resetView","countDirtyView","viewportMargin","sawCollapsedSpans","visualLineNo","visualLineEndNo","different","adjustView","toUpdate","activeElt","patchDisplay","offsetHeight","postUpdateDisplay","displayHeight","barMeasure","updateSelection","setDocumentHeight","updateDisplaySimple","finish","prevBottom","offsetTop","bot","box","diff","updateWidgetHeight","rest","parentNode","gutterLeft","clientLeft","nextSibling","offsetLeft","fixedPos","gutterTotalWidth","updateNumbersFrom","rm","mac","currentWheelTarget","removeChild","container","lineN","lineView","updateNumber","lineNumber","changes","updateLineForChanges","buildLineElement","updateLineText","updateLineGutter","updateLineClasses","updateLineWidgets","ensureLineWrapped","replaceChild","updateLineBackground","cls","bgClass","background","wrap","getLineContent","ext","built","buildLineContent","pre","textClass","wrapClass","gutterBackground","markers","gutterMarkers","gutterWrap","setUneditable","k","insertLineWidgets","insertLineWidgetsFor","allowAbove","ws","handleMouseEvents","positionLineWidget","above","signalLater","noHScroll","coverGutter","paddingLeft","copyPos","maxPos","minPos","ensureFocus","applyTextInput","inserted","deleted","sel","origin","paste","textLines","multiPaste","lastCopied","join","map","lst","lineWise","updateInput","changeEvent","makeChange","triggerElectric","ensureCursorVisible","typing","handlePaste","pasted","clipboardData","getData","preventDefault","isReadOnly","disableInput","runInOp","electricChars","smartIndent","getModeAt","indented","indentLine","electricInput","copyableRanges","lineRange","anchor","disableBrowserMagic","field","TextareaInput","prevInput","pollingFast","polling","inaccurateSelection","hasSelection","composing","hiddenTextarea","te","div","ios","ContentEditableInput","lastAnchorNode","lastAnchorOffset","lastFocusNode","lastFocusOffset","gracePeriod","posToDOM","findViewForLine","info","mapFromLineView","order","getOrder","side","partPos","getBidiPartAt","result","nodeAndOffsetInLineMap","collapse","badPos","bad","domToPos","lineNode","childNodes","locateNodeInLineView","textNode","topNode","maps","curNode","contains","nodeType","nodeValue","after","dist","textContent","previousSibling","domTextBetween","fromLine","toLine","recognizeMarker","walk","cmText","getAttribute","markerID","getBetween","lineSep","nodeName","closing","Selection","primIndex","Range","normalizeSelection","prim","sort","inv","simpleSelection","clipLine","clipToLen","linelen","isLine","clipPosArray","array","out","extendRange","other","posBefore","extendSelection","setSelection","primary","extendSelections","heads","newSel","replaceOneSelection","setSimpleSelection","filterSelectionChange","obj","setSelectionReplaceHistory","done","history","setSelectionNoUndo","addSelectionToHistory","NaN","hasHandler","bias","setSelectionInner","skipAtomicInSelection","equals","selectionChanged","signalCursorActivity","reCheckSelection","sel_dontScroll","mayClear","newAnchor","skipAtomic","newHead","skipAtomicInner","oldPos","markedSpans","sp","inclusiveLeft","inclusiveRight","explicitlyCleared","atomic","near","movePos","far","cantEdit","showSelection","prepareSelection","curFragment","cursors","createDocumentFragment","selFragment","selection","collapsed","showCursorWhenSelecting","drawSelectionCursor","drawSelectionRange","cursorCoords","singleCursorHeightPerLine","cursor","cursorHeight","otherCursor","add","fragment","rightSide","drawForLine","fromArg","toArg","coords","charCoords","lineObj","lineLen","iterateBidiSections","rightPos","leftPos","tmp","leftSide","paddingH","sFrom","sTo","singleVLine","visualLine","leftEnd","rightStart","restartBlink","clearInterval","blinker","visibility","cursorBlinkRate","setInterval","time","startState","set","highlightWorker","Date","workTime","copyState","getStateBefore","changedLines","oldStyles","tooLong","maxHighlightLength","highlighted","highlightLine","oldCls","styleClasses","newCls","classes","ischange","processLine","workDelay","regLineChange","findStartLine","precise","minindent","minline","lim","innerMode","search","countColumn","tabSize","save","removeChildrenAndAdd","ensureLineHeights","rect","curWidth","heights","rects","getClientRects","abs","cache","caches","updateExternalMeasurement","LineView","measureChar","measureCharPrepared","prepareMeasureForLine","findViewIndex","hasHeights","prepared","varHeight","key","measureCharInner","bogus","rtop","rbottom","mStart","mEnd","insertLeft","coverStart","coverEnd","getUsefulRect","nullRect","isExtendingChar","maybeUpdateRectForZooming","rSpan","rbot","mid","screen","logicalXDPI","deviceXDPI","hasBadZoomedRects","scaleX","scaleY","logicalYDPI","deviceYDPI","clearLineMeasurementCacheFor","clearLineMeasurementCache","externalMeasure","pageScrollX","pageXOffset","documentElement","body","pageScrollY","pageYOffset","intoCoordSystem","context","widgetHeight","yOff","lOff","xOff","fromCoordSystem","localBox","lineSpaceBox","preparedMeasure","get","getBidi","part","level","bidiLeft","bidiRight","bidiOther","estimateCoords","PosWithInfo","outside","xRel","coordsChar","y","coordsCharInner","mergedPos","getX","wrongLine","innerOff","adjust","bidi","lineLeft","lineRight","fromX","fromOutside","toX","toOutside","moveVisually","xDiff","charSize","step","middle","middleX","measureText","viewChanged","changeObjs","cursorActivityHandlers","cursorActivityCalled","updateMaxLine","scrollToPos","nextOpId","operationGroup","ops","ownsGroup","delayedCallbacks","fireCallbacksForOps","group","callbacks","op","endOperations","endOperation_R1","endOperation_W1","endOperation_R2","endOperation_W2","endOperation_finish","mustUpdate","updatedDisplay","adjustWidthTo","maxScrollLeft","preparedSelection","takeFocus","forceScroll","scrollPosIntoView","margin","isCursor","maybeScrollWindow","maybeHiddenMarkers","unhidden","maybeUnhiddenMarkers","apply","methodOp","docMethodOp","visualLineContinued","buildViewArray","nextPos","lendiff","cut","viewCuttingPoint","cutTop","cutBot","arr","oldN","newN","dirty","finishTouch","touchFinished","prevTouch","isMouseLikeTouchEvent","touch","radiusX","radiusY","farAway","dx","dy","onMouseDown","signalDOMEvent","posFromMouse","clickInGutter","eventInWidget","word","findWordAt","captureRightClick","onContextMenu","now","moved","pageY","onScrollWheel","dragFunctions","enter","e_stop","over","onDragOver","onDragStart","drop","onDrop","leave","clearDragCursor","inp","getField","onKeyUp","onKeyDown","onKeyPress","dragDropChanged","wasOn","toggle","setSize","e_target","liberal","forRect","space","clientX","clientY","colDiff","supportsTouch","shiftKey","e_button","leftButtonDown","lastMiddleDown","delayBlurEvent","lastDoubleClick","lastClick","contained","modifier","metaKey","ctrlKey","dragDrop","dragAndDrop","leftButtonStartDrag","leftButtonSelect","startTime","dragEnd","e2","copy","altKey","addNew","extendTo","lastPos","startCol","posCol","findColumn","startSel","ourIndex","scrollIntoView","oldRange","ourRange","sel_mouse","curCount","counter","editorSize","Infinity","move","up","lastSelOrigin","chromeOS","gutterEvent","prevent","mX","mY","lineBox","e_defaultPrevented","lastDrop","files","dataTransfer","FileReader","File","read","loadFile","file","allowDropFileTypes","reader","onload","content","change","changeEnd","readAsText","selected","replaceRange","replaceSelection","setData","getSelection","effectAllowed","setDragImage","safari","img","src","presto","_top","frag","isScroller","delta","wheelEventDelta","canScrollX","canScrollY","target","wheelPixelsPerUnit","pixels","wheelSamples","movedX","movedY","sample","doHandleBinding","bound","dropShift","ensurePolled","prevShift","Pass","lookupKeyForEditor","handle","lookupKey","extraKeys","keyMap","dispatchKey","seq","isModifierKey","stopSeq","handleKeyBinding","keyName","motion","handleCharBinding","keyCode","returnValue","handled","lastStoppedKey","hasCopyEvent","showCrossHair","charCode","which","fromCharCode","readOnly","receivedFocus","contextMenuInGutter","adjustForChange","computeSelAfterChange","offsetPos","nw","computeReplacedSel","hint","oldPrev","newPrev","filterChange","canceled","cancel","ignoreReadOnly","sawReadOnlySpans","removeReadOnlyRanges","makeChangeInner","selAfter","addChangeToHistory","makeChangeSingleDoc","stretchSpansOverChange","rebased","linkedDocs","sharedHist","rebaseHist","makeChangeFromHistory","allowSelectionOnly","event","hist","undone","dest","lastOrigin","pushSelectionToHistory","clearRedo","antiChanges","generation","maxGeneration","filter","historyChangeFromChange","mergeOldSpans","shiftDoc","distance","spans","removed","makeChangeSingleDocInEditor","updateDoc","recomputeMaxLength","checkWidthStart","full","isWholeLineUpdate","changesHandler","changeHandler","doScroll","innerHeight","phantom","scrollNode","limit","changed","endCoords","scrollPos","calculateScrollPos","startTop","startLeft","x1","y1","x2","y2","snapMargin","screentop","docBottom","atTop","atBottom","newTop","screenleft","screenw","tooWide","addToScrollPos","resolveScrollToPos","cursorScrollMargin","sPos","scrollTo","how","aggressive","indent","curSpace","indentation","curSpaceString","indentUnit","indentString","indentWithTabs","spaceStr","changeLine","changeType","no","deleteNearSelection","compute","kill","toKill","replaced","findPosH","unit","visually","findNextLine","moveOnce","boundToLine","moveLogically","origDir","sawType","helper","getHelper","isWordChar","hitSide","findPosV","pageSize","option","deflt","notOnInit","normalizeKeyName","alt","ctrl","cmd","parts","getKeyMap","shared","markTextShared","TextMarker","clearWhenEmpty","widgetNode","conflictingCollapsedRange","addToHistory","curLine","addMarkedSpan","MarkedSpan","clearHistory","nextMarkerId","title","startStyle","endStyle","linked","isParent","SharedTextMarker","findSharedMarkers","parent","copySharedMarkers","mFrom","mTo","subMark","detachSharedMarkers","subMarker","getMarkedSpanFor","span","removeMarkedSpan","attachLine","markedSpansBefore","isInsert","startsBefore","endsAfter","markedSpansAfter","oldFirst","oldLast","sameLine","clearEmptySpans","newMarkers","gapMarkers","gap","getOldSpans","stretched","oldCur","stretchCur","mk","newParts","dfrom","dto","detachMarkedSpans","detachLine","attachMarkedSpans","extraLeft","extraRight","compareCollapsedMarkers","lenDiff","aPos","bPos","fromCmp","toCmp","collapsedSpanAtSide","sps","vis","lineIsHiddenInner","adjustScrollWhenAboveVisible","parentStyle","addLineWidget","LineWidget","insertAt","aboveVisible","updateLine","cleanUpLine","extractLineClasses","lineClass","prop","callBlankLine","blankLine","inner","readToken","stream","token","takeToken","asArray","getObj","current","tokens","StringStream","eol","runMode","lineClasses","forceToEnd","flattenSpans","curStart","curStyle","addModeClass","mName","st","overlay","i_end","opaque","getLineStyles","updateFrontier","startAt","interpretTokenStyle","styleToClassCacheWithMode","styleToClassCache","builder","col","trailingSpace","splitSpaces","addToken","buildToken","hasBadBidiRects","buildTokenBadBidi","allowFrontierUpdate","insertLineContent","joinClasses","zeroWidthElement","querySelector","defaultSpecialCharPlaceholder","charCodeAt","toString","displayText","special","mustWrap","skipped","txt","tabWidth","specialCharPlaceholder","fullStyle","trailingBefore","spaceBefore","buildCollapsedSpan","ignoreWidget","needsContentAttribute","allText","spanStyle","spanEndStyle","spanStartStyle","nextChange","endStyles","foundBookmarks","upto","tokenText","wholeLineUpdateBefore","spansFor","linesFor","Line","lastText","lastSpans","nlines","insert","added","LeafChunk","BranchChunk","children","chunkSize","sharedHistOnly","propagate","skip","rel","chunk","child","sz","getLines","lh","bidiOrdering","History","startGen","undoDepth","lastModTime","lastSelTime","lastOp","lastSelOp","histChange","attachLocalSpans","clearSelectionEvents","lastChangeEvent","opId","historyEventDelay","selectionEventCanBeMerged","somethingSelected","existing","removeClearedSpans","copyHistoryArray","newGroup","instantiateSel","deepCopy","newChanges","Number","rebaseHistSelSingle","rebaseHistArray","sub","ok","copied","defaultPrevented","srcElement","button","getHandlers","emitter","_handlers","noHandlers","bnd","args","list","orphanDelayedCallbacks","fireOrphanDelayed","delayed","override","codemirrorIgnore","cursorActivity","eventMixin","ctor","spaceStrs","nothing","createObj","base","props","inst","Object","create","isWordCharBasic","isEmpty","extendingChars","cssText","activeElement","root","classTest","as","forEachCodeMirror","getElementsByClassName","byClass","globalsRegistered","registerGlobalHandlers","resizeTimer","zwspSupported","badBidiRects","r0","r1","badZoomedRects","normal","fromRange","lineStart","visual","lineStartSmart","firstNonWS","inWS","compareBidiLevel","linedir","moveInLine","byUnit","platform","ie_upto10","ie_11up","qtwebkit","chrome","vendor","mac_geMountainLion","windows","presto_version","flipCtrlCmd","needsH","needsV","sWidth","totalHeight","totalWidth","zeroWidthHack","disableHoriz","enableZeroWidthBar","disableVert","pointerEvents","bar","delay","maybeDisable","elementFromPoint","native","null","cmpPos","prepareCopyCut","getSelections","selectInput","lineWiseCopyCut","setSelections","textarea","poll","fastPoll","moveInputWithCursor","headPos","wrapOff","lineOff","teTop","teLeft","drawn","contextMenuPending","minimal","blur","resetPosition","slowPoll","pollInterval","missed","execCommand","same","prepareSelectAllHack","selectionStart","extval","selectionEnd","rehide","oldWrapperCSS","oldCSS","selectAll","detectingSelectAll","resetSelectionOnContextMenu","wrapperBox","oldScrollY","scrollY","mouseup","readOnlyChanged","onCopyCut","clearData","kludge","hadFocus","startData","ours","applyComposition","forceCompositionEnd","pollContent","showPrimarySelection","showMultipleSelections","curAnchor","anchorNode","anchorOffset","curFocus","focusNode","focusOffset","rangeCount","getRangeAt","rng","addRange","removeAllRanges","startGracePeriod","rememberSelection","selectionInEditor","commonAncestorContainer","pollSelection","fromIndex","fromNode","toIndex","toNode","newText","oldText","cutFront","cutEnd","oldTop","maxCutFront","newBot","oldBot","maxCutEnd","chFrom","chTo","contentEditable","contenteditable","there","wheelDeltaX","wheelDeltaY","detail","HORIZONTAL_AXIS","VERTICAL_AXIS","wheelDelta","wheelEventPixels","constructor","setOption","getDoc","addKeyMap","removeKeyMap","addOverlay","modeSpec","removeOverlay","indentSelection","newRanges","getLineTokens","help","helperType","_global","pred","getStateAfter","defaultTextHeight","defaultCharWidth","gutterID","lineInfo","addWidget","vspace","hspace","triggerOnKeyDown","triggerOnKeyPress","triggerOnKeyUp","amount","moveH","extendSelectionsBy","rtlMoveVisually","sel_move","deleteH","goalColumn","moveV","goals","startChar","check","toggleOverwrite","getScrollInfo","interpret","refresh","oldHeight","swapDoc","getInputField","getWrapperElement","getScrollerElement","getGutterElement","setValue","newBreaks","detach","attach","disabled","tabIndex","modes","mimeModes","defineMode","dependencies","defineMIME","mime","resolveMode","mfactory","modeObj","modeExtensions","exts","modeProps","skipToEnd","extendMode","properties","defineDocExtension","defineInitHook","registerGlobalHelper","predicate","nstate","a1","a2","singleSelection","killLine","deleteLine","delLineLeft","delWrappedLineLeft","delWrappedLineRight","undo","redo","undoSelection","redoSelection","goDocStart","goDocEnd","goLineStart","goLineStartSmart","goLineEnd","goLineRight","goLineLeft","goLineLeftSmart","goLineUp","goLineDown","goPageUp","goPageDown","goCharLeft","goCharRight","goColumnLeft","goColumnRight","goWordLeft","goGroupRight","goGroupLeft","goWordRight","delCharBefore","delCharAfter","delWordBefore","delWordAfter","delGroupBefore","delGroupAfter","indentAuto","indentMore","indentLess","insertTab","insertSoftTab","spaces","replaceSelections","defaultTab","transposeChars","newlineAndIndent","openLine","basic","Left","Right","Up","Down","End","Home","PageUp","PageDown","Delete","Backspace","Shift-Backspace","Tab","Shift-Tab","Enter","Insert","Esc","pcDefault","Ctrl-A","Ctrl-D","Ctrl-Z","Shift-Ctrl-Z","Ctrl-Y","Ctrl-Home","Ctrl-End","Ctrl-Up","Ctrl-Down","Ctrl-Left","Ctrl-Right","Alt-Left","Alt-Right","Ctrl-Backspace","Ctrl-Delete","Ctrl-S","Ctrl-F","Ctrl-G","Shift-Ctrl-G","Shift-Ctrl-F","Shift-Ctrl-R","Ctrl-[","Ctrl-]","Ctrl-U","Shift-Ctrl-U","Alt-U","fallthrough","emacsy","Ctrl-B","Ctrl-P","Ctrl-N","Alt-F","Alt-B","Ctrl-E","Ctrl-V","Shift-Ctrl-V","Ctrl-H","Alt-D","Alt-Backspace","Ctrl-K","Ctrl-T","Ctrl-O","macDefault","Cmd-A","Cmd-D","Cmd-Z","Shift-Cmd-Z","Cmd-Y","Cmd-Home","Cmd-Up","Cmd-End","Cmd-Down","Cmd-Left","Cmd-Right","Ctrl-Alt-Backspace","Alt-Delete","Cmd-S","Cmd-F","Cmd-G","Shift-Cmd-G","Cmd-Alt-F","Shift-Cmd-Alt-F","Cmd-[","Cmd-]","Cmd-Backspace","Cmd-Delete","Cmd-U","Shift-Cmd-U","normalizeKeyMap","keymap","keyname","keys","keyNames","noShift","altGraphKey","fromTextArea","getValue","tabindex","placeholder","form","leaveSubmitMethodAlone","realSubmit","submit","wrappedSubmit","getTextArea","toTextArea","lastColumnPos","lastColumnValue","sol","peek","eat","eatWhile","eatSpace","skipTo","backUp","column","pattern","consume","caseInsensitive","cased","str","toLowerCase","hideFirstChars","withOp","dHeight","oldH","removeInner","insertInner","iterN","remaining","leaf","maybeSpill","me","spilled","sibling","myIndex","used","nextDocId","cleanGeneration","getLineNumber","getLineHandleVisualStart","lineCount","setCursor","addSelection","dup","setExtending","getExtending","historySize","markClean","changeGeneration","forceSplit","isClean","gen","getHistory","setHistory","histData","addLineClass","removeLineClass","removeLineWidget","setBookmark","realOpts","getAllMarks","posFromIndex","sepSize","indexFromPos","copyHistory","linkedDoc","unlinkDoc","link","splitIds","iterLinkedDocs","getEditor","splitLinesAuto","dontDelegate","method","e_stopPropagation","stopPropagation","cancelBubble","addEventListener","attachEvent","removeEventListener","detachEvent","handlers","ms","startIndex","startValue","nextTab","goal","select","_e","nonASCIISingleCaseWordChar","toUpperCase","createRange","endNode","setEnd","setStart","createTextRange","moveToElementText","moveEnd","moveStart","host","nl","rt","ownerDocument","parentElement","compareEndPoints","oncopy","9","13","16","17","18","19","20","27","32","33","34","35","36","37","38","39","40","44","45","46","59","61","91","92","93","106","107","109","110","111","127","173","186","187","188","189","190","191","192","219","220","221","222","63232","63233","63234","63235","63272","63273","63275","63276","63277","63302","charType","lowTypes","arabicTypes","BidiSpan","bidiRE","isNeutral","isStrong","countsAsLeft","countsAsNum","outerType","types","nstart","unshift","version","expressionAllowed","lastType","parserConfig","readRegexp","escaped","inSet","ret","tp","cont","tokenBase","tokenize","tokenString","tokenComment","isOperatorChar","tokenQuasi","wordRE","known","keywords","propertyIsEnumerable","quote","jsonldMode","isJsonldKeyword","maybeEnd","findFatArrow","fatArrowAt","arrow","depth","sawSomething","bracket","brackets","JSLexical","inScope","varname","v","localVars","cx","vars","parseJS","cc","marked","lexical","combinator","jsonMode","expression","statement","lex","register","inList","globalVars","pushcontext","defaultVars","popcontext","pushlex","poplex","expect","wanted","exp","vardef","block","maybeelse","functiondef","forspec","maybelabel","funarg","afterExport","afterImport","expressionInner","expressionNoComma","noComma","arrowBodyNoComma","arrowBody","commasep","maybeop","maybeoperatorNoComma","maybeoperatorComma","atomicTypes","maybeexpressionNoComma","maybeexpression","arrayLiteral","contCommasep","objprop","quasi","maybeTarget","expr","property","continueQuasi","targetNoComma","_","getterSetter","afterprop","what","proceed","maybetype","isTS","typeexpr","maybedefault","afterType","maybeAssign","vardefCont","proppattern","_type","forspec1","forspec2","formaybeinof","forspec3","classNameAfter","classBody","classGetterSetter","maybeFrom","importSpec","maybeAs","isContinuedStatement","textAfter","statementIndent","jsonld","json","typescript","wordCharacters","kw","A","B","C","operator","atom","jsKeywords","if","while","with","else","do","try","finally","return","break","continue","new","delete","throw","debugger","var","const","let","function","catch","for","switch","case","default","in","typeof","instanceof","true","false","class","super","yield","export","import","extends","await","async","tsKeywords","interface","implements","namespace","enum","public","private","protected","abstract","number","boolean","any","variable","regexp","jsonld-keyword","basecolumn","firstChar","doubleIndentSwitch","blockCommentStart","blockCommentEnd","lineComment","closeBrackets","skipExpression","10","htmlConfig","autoSelfClosers","area","br","command","embed","frame","hr","keygen","meta","param","track","wbr","menuitem","implicitlyClosed","dd","li","optgroup","rp","tbody","td","tfoot","tr","contextGrabbers","dt","address","article","aside","blockquote","dl","fieldset","footer","h1","h2","h3","h4","h5","h6","header","hgroup","menu","nav","ol","section","table","ul","thead","doNotIndent","allowUnquoted","allowMissing","caseFold","xmlConfig","editorConf","config_","inText","chain","parser","inBlock","doctype","inTag","baseState","tagName","tagStart","inAttribute","stringStartCol","closure","isInAttribute","terminator","Context","startOfLine","noIndent","popContext","maybePopContext","nextTagName","parentTagName","tagNameState","closeTagNameState","setStyle","attrState","matchClosing","closeState","closeStateErr","_stream","attrEqState","attrValueState","attrContinuedState","htmlMode","isInText","baseIndent","fullLine","multilineTagIndentPastTag","multilineTagIndentFactor","alignCDATA","tagAfter","grabbers","configuration","skipAttribute","11","factory","d3","ascending","bisector","compare","ascendingComparator","lo","hi","descending","variance","deviation","sqrt","extent","constant","identity","stop","ticks","tickStep","step0","step1","pow","log","LN10","error","e10","e5","sturges","values","LN2","histogram","xz","domain","x0","tz","threshold","isArray","bin","bins","bisectRight","thresholds","freedmanDiaconis","scott","mean","median","numbers","merge","pairs","permute","indexes","permutes","scan","xi","xj","shuffle","i0","i1","random","sum","transpose","matrix","row","zip","Map","map$1","nest","createResult","setResult","rollup","sortValues","keyValue","valuesByKey","sortKey","sortKeys","createObject","setObject","createMap","setMap","Set","uniform","mu","sigma","logNormal","randomNormal","irwinHall","bates","randomIrwinHall","exponential","lambda","linear","quadIn","quadOut","quadInOut","cubicIn","cubicOut","easeCubicInOut","sinIn","cos","halfPi","sinOut","sin","sinInOut","pi","expIn","expOut","expInOut","circleIn","circleOut","circleInOut","bounceIn","bounceOut","b1","b0","b3","b2","b4","b6","b5","b7","b8","b9","bounceInOut","polygon","centroid","cross","lexicographicOrder","computeUpperHullIndexes","points","hull","sortedPoints","flippedPoints","upperIndexes","lowerIndexes","skipLeft","skipRight","point","y0","inside","length$1","xa","ya","xb","yb","perimeter","Path","_x0","_y0","_x1","_y1","path","tree_add","_x","_y","cover","tree","xm","ym","xp","yp","_root","addAll","yz","tree_cover","z","tree_data","visit","tree_extent","Quad","tree_find","radius","q","x3","y3","quads","d2","tree_remove","retainer","previous","removeAll","tree_root","tree_size","tree_visit","tree_visitAfter","defaultX","tree_x","defaultY","tree_y","quadtree","nodes","Quadtree","leaf_copy","Queue","_size","_call","_error","_tasks","_data","_waiting","_active","_ended","_start","poke","abort","noabort","maybeNotify","queue","concurrency","constant$1","arcInnerRadius","innerRadius","arcOuterRadius","outerRadius","arcStartAngle","startAngle","arcEndAngle","endAngle","arcPadAngle","padAngle","asin","halfPi$1","intersect","x10","y10","x32","y32","cornerTangents","rc","cw","x01","y01","oy","x11","y11","x00","y00","D","cx0","cy0","cx1","cy1","dx0","dy0","dx1","dy1","cy","arc","buffer","a0","da","epsilon$1","tau$2","moveTo","t0","t1","a01","a11","a00","a10","da0","da1","ap","padRadius","cornerRadius","rc0","rc1","p0","p1","pi$2","oc","ax","ay","bx","by","kc","acos","lc","atan2","lineTo","closePath","Linear","_context","curveLinear","defined0","curve","defined","x$$","y$$","area$1","x0z","y0z","areaStart","areaEnd","arealine","lineX0","lineY0","lineY1","lineX1","descending$1","identity$1","pie","arcs","pa","Radial","_curve","curveRadial","radial","radialLine","angle","radialLine$1","curveRadialLinear","radialArea","lineStartAngle","lineEndAngle","lineInnerRadius","lineOuterRadius","symbol","draw","circle","noop","that","bezierCurveTo","Basis","basis","BasisClosed","basisClosed","BasisOpen","basisOpen","Bundle","beta","_basis","_beta","point$1","_k","_x2","_y2","Cardinal","tension","CardinalClosed","CardinalOpen","point$2","_l01_a","_l01_2a","_l12_a","_l12_2a","_l23_a","_l23_2a","CatmullRom","alpha","_alpha","CatmullRomClosed","CatmullRomOpen","LinearClosed","linearClosed","sign","slope3","h0","s0","s1","slope2","point$3","MonotoneX","MonotoneY","ReflectContext","monotoneX","monotoneY","Natural","controlPoints","natural","Step","_t","stepBefore","stepAfter","none","series","none$1","stackValue","oz","kz","sij","ki","si","slice$2","expand","silhouette","wiggle","s2","sij0","sij1","s3","sk","skj0","skj1","ascending$1","sums","sum$1","descending$2","reverse","insideOut","tops","bottoms","definition","Color","color","format","trim","reHex3","Rgb","reHex6","rgbn","reRgbInteger","reRgbPercent","reRgbaInteger","rgba","reRgbaPercent","reHslPercent","hsla","reHslaPercent","named","rgbConvert","rgb","opacity","colorRgb","Hsl","hslConvert","colorHsl","hsl2rgb","m1","m2","labConvert","Lab","Hcl","deg2rad","rgb2xyz","xyz2lab","Xn","Yn","Zn","lab","t3","t2","lab2xyz","xyz2rgb","hclConvert","rad2deg","colorHcl","cubehelixConvert","Cubehelix","BC_DA","ED","EB","bl","E","cubehelix","basis$1","v0","v1","v2","v3","basis$2","basisClosed$1","constant$2","linear$1","exponential$1","hue","gamma","nogamma","rgbSpline","spline","colors","array$1","nb","na","interpolate","date","setTime","interpolateNumber","zero","one","interpolateString","am","bm","bs","bi","reA","reB","interpolateRgb","interpolateRound","decompose","skewX","translateX","translateY","rotate","degrees","atan","parseCss","identity$2","cssNode","cssRoot","cssView","defaultView","transform","getPropertyValue","parseSvg","svgNode","createElementNS","baseVal","consolidate","interpolateTransform","pxComma","pxParen","degParen","translate","scale","cosh","sinh","tanh","interpolateZoom","ux0","uy0","w0","ux1","uy1","w1","epsilon2","rho","d1","rho4","rho2","coshr0","duration","hsl","lab$1","hcl","cubehelix$1","cubehelixGamma","cubehelix$$","quantize","interpolator","samples","dispatch","Dispatch","parseTypenames","typenames","set$1","noop$1","objectConverter","columns","Function","JSON","stringify","customConverter","inferColumns","rows","columnSet","forEach","dsv","convert","parseRows","N","EOF","EOL","delimiterCode","formatValue","formatRows","formatRow","reFormat","request","url","respond","status","xhr","hasResponse","response","mimeType","responseType","XMLHttpRequest","user","password","timeout","XDomainRequest","onerror","ontimeout","onreadystatechange","readyState","onprogress","send","post","setRequestHeader","overrideMimeType","fixCallback","responseText","defaultMimeType","dsv$1","responseOf","clockNow","setFrame","clearNow","clock","clockSkew","Timer","_time","_next","timer","restart","timerFlush","taskHead","wake","clockLast","nap","poke$1","pokeDelay","taskTail","sleep","interval","timeout$1","elapsed","interval$1","total","tick","newInterval","floori","offseti","d0","t0$1","t1$1","every","isFinite","weekday","setDate","getDate","getDay","setHours","getTimezoneOffset","durationMinute","durationWeek","utcWeekday","setUTCDate","getUTCDate","getUTCDay","setUTCHours","formatDecimal","toExponential","coefficient","exponent$1","formatGroup","grouping","thousands","substring","formatDefault","toPrecision","formatPrefixAuto","exponent","prefixExponent","formatRounded","formatSpecifier","specifier","FormatSpecifier","fill","comma","precision","formatTypes","identity$3","formatLocale","locale","newFormat","valuePrefix","prefix","valueSuffix","suffix","formatType","valueNegative","prefixes","maybeSuffix","decimal","currency","formatPrefix","defaultLocale","precisionFixed","precisionPrefix","precisionRound","localDate","H","L","setFullYear","utcDate","UTC","setUTCFullYear","newYear","formatLocale$1","formats","pad","pads","newParse","newDate","parseSpecifier","day","W","U","Z","parses","parsePeriod","periodRe","periodLookup","parseShortWeekday","shortWeekdayRe","shortWeekdayLookup","parseWeekday","weekdayRe","weekdayLookup","parseShortMonth","shortMonthRe","shortMonthLookup","parseMonth","monthRe","monthLookup","parseLocaleDateTime","locale_dateTime","parseLocaleDate","locale_date","parseLocaleTime","locale_time","formatShortWeekday","locale_shortWeekdays","formatWeekday","locale_weekdays","formatShortMonth","locale_shortMonths","getMonth","formatMonth","locale_months","formatPeriod","locale_periods","getHours","formatUTCShortWeekday","formatUTCWeekday","formatUTCShortMonth","getUTCMonth","formatUTCMonth","formatUTCPeriod","getUTCHours","dateTime","periods","days","shortDays","months","shortMonths","formatRe","formatLookup","formatDayOfMonth","formatHour24","formatHour12","formatDayOfYear","formatMilliseconds","formatMonthNumber","formatMinutes","formatSeconds","formatWeekNumberSunday","formatWeekdayNumber","formatWeekNumberMonday","X","formatYear","Y","formatFullYear","formatZone","%","formatLiteralPercent","utcFormats","formatUTCDayOfMonth","formatUTCHour24","formatUTCHour12","formatUTCDayOfYear","formatUTCMilliseconds","formatUTCMonthNumber","formatUTCMinutes","formatUTCSeconds","formatUTCWeekNumberSunday","formatUTCWeekdayNumber","formatUTCWeekNumberMonday","formatUTCYear","formatUTCFullYear","formatUTCZone","parseDayOfMonth","parseHour24","parseDayOfYear","parseMilliseconds","parseMonthNumber","parseMinutes","parseSeconds","parseWeekNumberSunday","parseWeekdayNumber","parseWeekNumberMonday","parseYear","parseFullYear","parseZone","parseLiteralPercent","utcFormat","utcParse","requote","requoteRe","names","numberRe","percentRe","year","getMilliseconds","getMinutes","getSeconds","timeWeek","timeMonday","getFullYear","utcDay","utcYear","getUTCMilliseconds","getUTCMinutes","getUTCSeconds","utcWeek","utcMonday","getUTCFullYear","defaultLocale$1","locale$1","timeFormat","timeParse","formatIsoNative","toISOString","parseIsoNative","ordinal","unknown","implicit","slice$3","band","rescale","range$$","paddingInner","paddingOuter","bandwidth","ordinalRange","rangeRound","pointish","point$4","constant$3","number$1","deinterpolate","deinterpolateClamp","reinterpolateClamp","reinterpolate","bimap","polymap","clamp","continuous","deinterpolate$$","piecewise","interpolate$$","invert","map$2","tickFormat","linearish","nice","linear$2","identity$4","deinterpolate$1","pow10","powp","logp","log10","log2","reflect","logs","pows","raise","quantile","invertExtent","quantiles","quantize$1","threshold$1","date$1","number$2","calendar","month","week","hour","minute","second","millisecond","formatMillisecond","formatSecond","formatMinute","formatHour","formatDay","formatWeek","tickInterval","tickIntervals","durationYear","durationSecond$1","durationMinute$1","durationHour$1","durationDay$1","durationWeek$1","durationMonth","utcTime","utcMonth","utcHour","utcMinute","rainbow$1","ts","rainbow","ramp","sequential","namespaces","local","creatorInherit","uri","namespaceURI","xhtml","creatorFixed","fullname","creator","Local","nextId","filterContextListener","listener","contextListener","related","relatedTarget","compareDocumentPosition","event1","event0","__data__","parseTypenames$1","onRemove","typename","__on","capture","onAdd","filterEvents","selection_on","customEvent","sourceEvent","point$5","svg","ownerSVGElement","createSVGPoint","matrixTransform","getScreenCTM","inverse","clientTop","mouse","changedTouches","none$2","selector","selection_select","groups","_groups","subgroups","subnode","subgroup","_parents","selectorAll","querySelectorAll","selection_selectAll","parents","selection_filter","matcher$1","sparse","selection_enter","_enter","EnterNode","datum","_parent","constant$4","bindIndex","groupLength","dataLength","bindKey","nodeByKeyValue","keyValues","keyPrefix","selection_data","enterGroup","updateGroup","exitGroup","_exit","selection_exit","selection_merge","groups0","groups1","merges","group0","group1","selection_order","selection_sort","compareNode","ascending$2","sortgroups","sortgroup","selection_call","selection_nodes","selection_node","selection_size","selection_empty","selection_each","attrRemove","removeAttribute","attrRemoveNS","removeAttributeNS","attrConstant","attrConstantNS","setAttributeNS","attrFunction","attrFunctionNS","selection_attr","getAttributeNS","styleRemove","removeProperty","styleConstant","priority","setProperty","styleFunction","selection_style","propertyRemove","propertyConstant","propertyFunction","selection_property","classArray","classList","ClassList","_node","_names","classedAdd","classedRemove","classedTrue","classedFalse","classedFunction","selection_classed","textRemove","textConstant","textFunction","selection_text","htmlRemove","innerHTML","htmlConstant","htmlFunction","selection_html","raise$1","selection_raise","lower","selection_lower","selection_append","constantNull","selection_insert","selection_remove","selection_datum","dispatchEvent","params","window$$","CustomEvent","createEvent","initEvent","bubbles","cancelable","dispatchConstant","dispatchFunction","selection_dispatch","identifier","schedule","timing","schedules","__transition","emptyOn","tween","emptyTween","ease","CREATED","set$2","STARTING","get$1","SCHEDULED","STARTED","ENDED","ENDING","interrupt","active","selection_interrupt","tweenRemove","tween0","tween1","tweenFunction","transition_tween","_id","tweenValue","transition","interpolate$1","attrRemove$1","attrRemoveNS$1","attrConstant$1","value1","value00","interpolate0","value0","attrConstantNS$1","attrFunction$1","value10","attrFunctionNS$1","transition_attr","interpolateTransform$2","attrTween","attrTweenNS","_value","transition_attrTween","delayFunction","delayConstant","transition_delay","durationFunction","durationConstant","transition_duration","easeConstant","transition_ease","transition_filter","Transition","_name","transition_merge","start$1","onFunction","on0","on1","sit","transition_on","removeFunction","transition_remove","transition_select","transition_selectAll","inherit","transition_selection","Selection$1","styleRemove$1","styleRemoveEnd","styleConstant$1","styleFunction$1","transition_style","interpolateTransform$1","styleTween","transition_styleTween","textConstant$1","textFunction$1","transition_text","transition_transition","id0","id1","newId","defaultTiming","selection_transition","root$1","identity$5","scale0","scale1","center","entering","__axis","orient","tickValues","tickArguments","spacing","tickSizeInner","tickPadding","range0","range1","tickExit","tickEnter","epsilon$2","tickSizeOuter","slice$4","tickSize","axisTop","axisRight","axisBottom","axisLeft","defaultSeparation","meanX","reduce","meanXReduce","maxY","maxYReduce","leafLeft","leafRight","cluster","previousNode","eachAfter","separation","nodeSize","node_each","node_eachBefore","node_eachAfter","node_sum","node_sort","eachBefore","node_path","ancestor","leastCommonAncestor","aNodes","ancestors","bNodes","node_ancestors","node_descendants","node_leaves","leaves","node_links","links","hierarchy","childs","Node","valued","defaultChildren","computeHeight","node_copy","copyData","Node$2","shuffle$1","tail","enclose","circles","encloseN","encloses","dr","l2","l0","l1","enclose1","enclose2","enclose3","r2","x21","y21","r21","r3","a3","c3","ab","db","dc","intersects","distance2","Node$1","packEnclose","sj","aa","ba","ca","oa","pack","siblings","optional","required","constantZero","constant$5","defaultRadius","radiusLeaf","packChildren","translateChild","roundNode","treemapDice","partition","positionNode","defaultId","defaultParentId","parentId","stratify","nodeId","nodeKey","nodeByKey","keyPrefix$1","ambiguous","preroot","defaultSeparation$1","nextLeft","nextRight","moveSubtree","wm","wp","executeShifts","nextAncestor","vim","TreeNode","treeRoot","firstWalk","secondWalk","sizeNode","tx","kx","ky","midpoint","apportion","vip","vop","vom","sip","sop","sim","som","treemapSlice","squarifyRatio","ratio","sumValue","minValue","maxValue","newRatio","minRatio","dice","index$1","treemap","paddingStack","tile","squarify","binary","valueOffset","valueTarget","valueLeft","valueRight","yk","xk","sliceDice","center$1","sx","sy","initialize","constant$6","jiggle","x$1","vx","y$1","vy","collide","quad","rj","ri","yi","strength","ri2","iterations","visitAfter","prepare","radii","index$2","defaultStrength","distances","strengths","nodeById","initializeStrength","initializeDistance","x$2","y$2","simulation","alphaMin","stepper","alphaTarget","alphaDecay","forces","fx","velocityDecay","fy","initializeNodes","initialRadius","initialAngle","initializeForce","closest","manyBody","accumulate","theta2","distanceMax2","distanceMin2","distanceMin","distanceMax","theta","x$3","y$3","nopropagation","stopImmediatePropagation","noevent","dragDisable","__noselect","MozUserSelect","dragEnable","noclick","constant$7","DragEvent","subject","defaultFilter","defaultContainer","defaultSubject","mousedowned","touchstarted","touchmoved","touchended","touchending","gesture","beforestart","mousemoved","mouseupped","mousemoving","gestures","sublisteners","listeners","constant$8","x$4","y$4","RedBlackTree","RedBlackNode","R","P","RedBlackRotateLeft","RedBlackRotateRight","RedBlackFirst","createEdge","edge","edges","setEdgeEnd","cells","halfedges","createBorderEdge","vertex","clipEdge","connectEdge","fm","fb","lx","ly","rx","ry","clipEdges","epsilon$3","createCell","site","cellHalfedgeAngle","cell","va","vb","cellHalfedgeStart","cellHalfedgeEnd","sortCellHalfedges","clipCells","iCell","iHalfedge","nHalfedges","startX","startY","endX","endY","nCells","v00","v01","v11","v10","Circle","attachCircle","lArc","rArc","lSite","cSite","rSite","epsilon2$1","ha","hc","circlePool","firstCircle","detachCircle","Beach","createBeach","beach","beachPool","detachBeach","beaches","removeBeach","disappearing","iArc","nArcs","addBeach","dxl","dxr","directrix","leftBreakPoint","rightBreakPoint","newArc","hb","rfocx","rfocy","pby2","lfocx","lfocy","plby2","hl","aby2","triangleArea","lexicographic","Diagram","sites","voronoi","polygons","triangles","constant$9","ZoomEvent","Transform","__zoom","identity$6","nopropagation$1","noevent$1","defaultFilter$1","defaultExtent","SVGElement","defaultTransform","zoom","wheeled","dblclicked","k0","k1","constrain","invertX","invertY","Gesture","wheelidled","wheel","deltaY","deltaMode","wheelDelay","touch0","touch1","touchstarting","touchDelay","dp","collection","scaleBy","scaleTo","translateBy","emit","scaleExtent","translateExtent","constant$10","BrushEvent","nopropagation$2","noevent$2","type$1","defaultFilter$2","defaultExtent$1","local$1","__brush","empty$1","brushSelection","dim","brushX","brush$1","brushY","brush","XY","handles","redraw","started","handleSize","Emitter","point1","shifting","lockX","lockY","moving","point0","MODE_SPACE","MODE_DRAG","signX","e0","e1","signY","n0","n1","MODE_HANDLE","MODE_CENTER","flipX","flipY","ended","keydowned","keyupped","signsX","signsY","selection1","selection0","starting","compareValue","chord","groupSums","groupIndex","subgroupIndex","chords","sortGroups","sortSubgroups","max$1","tau$3","di","dj","subindex","sortChords","constant$11","defaultSource","defaultTarget","defaultRadius$1","defaultStartAngle","defaultEndAngle","ribbon","argv","slice$5","sr","sa0","halfPi$2","sa1","sx0","sy0","ta0","ta1","quadraticCurveTo","adder","Adder","add$1","bv","av","pi$4","asin$1","halfPi$3","haversin","sin$1","noop$2","streamGeometry","geometry","streamGeometryType","streamLine","coordinates","closed","coordinate","streamPolygon","polygonStart","polygonEnd","streamObjectType","areaRingStart","areaStream","areaPointFirst","areaRingEnd","areaPoint","lambda00","phi00","phi","radians","lambda0","cosPhi0","cos$1","quarterPi","sinPhi0","dLambda","sdLambda","adLambda","cosPhi","sinPhi","areaRingSum","area$2","areaSum","spherical","cartesian","cartesianDot","cartesianCross","cartesianAddInPlace","cartesianScale","vector","cartesianNormalizeInPlace","sqrt$1","boundsPoint","range$1","lambda0$1","lambda1","phi0","phi1","linePoint","equatorial","inflection","phii","lambda2","lambdai","degrees$1","antimeridian","boundsLineStart","boundsStream","boundsLineEnd","boundsRingPoint","deltaSum","lambda00$1","phi00$1","boundsRingStart","boundsRingEnd","epsilon$4","rangeCompare","rangeContains","bounds","feature","deltaMax","centroidPoint","centroidPointCartesian","W0","X0","Y0","Z0","centroidLineStart","centroidStream","centroidLinePointFirst","z0","centroidLinePoint","W1","X1","Y1","Z1","centroidLineEnd","centroidRingStart","centroidRingPointFirst","centroidRingEnd","centroidRingPoint","lambda00$2","phi00$2","cz","X2","Y2","Z2","centroid$1","epsilon2$2","constant$12","compose","rotationIdentity","tau$4","rotateRadians","deltaLambda","deltaPhi","deltaGamma","rotationLambda","rotationPhiGamma","forwardRotationLambda","rotation","cosDeltaPhi","sinDeltaPhi","cosDeltaGamma","sinDeltaGamma","circleStream","direction","cosRadius","sinRadius","circleRadius","circle$1","ring","clipBuffer","rejoin","pointEqual","Intersection","clipPolygon","segments","compareIntersection","startInside","clip","segment","link$1","isSubject","clipExtent","corner","comparePoint","activeStream","polygonInside","winding","bufferStream","clean","cleanInside","clipStream","v_","x_","y_","x__","y__","v__","clipMin","clipMax","extent$1","cacheStream","lengthLineStart","lengthStream","lengthPointFirst","lengthLineEnd","lambda0$2","sinPhi0$1","cosPhi0$1","lengthPoint","cosDelta","sinDelta","lengthSum","length$2","object$1","graticuleX","graticuleY","graticule","DX","DY","outline","extentMajor","extentMinor","stepMajor","stepMinor","interpolate$2","sy1","kx0","ky0","kx1","ky1","identity$7","areaRingStart$1","areaStream$1","areaPointFirst$1","areaPoint$1","x0$1","y0$1","areaRingSum$1","areaRingEnd$1","boundsPoint$1","x0$2","y0$2","centroidPoint$1","X0$1","Y0$1","Z0$1","centroidLineStart$1","centroidStream$1","centroidPointFirstLine","centroidPointLine","x0$3","y0$3","X1$1","Y1$1","Z1$1","centroidLineEnd$1","centroidRingStart$1","centroidPointFirstRing","centroidRingEnd$1","centroidPointRing","x00$1","y00$1","X2$1","Y2$1","Z2$1","PathContext","pointRadius","pointLineStart","pointLine","lineEndPolygon","PathString","pointCircle","circle$2","index$3","contextStream","projectionStream","projection","boundsStream$1","polygonContains","sinPhi1","cosPhi1","absDelta","sum$2","intersection","phiArc","pointVisible","sink","pointRing","ringSink","ringStart","ringEnd","ringSegments","ringBuffer","polygonStarted","validSegment","rotatedStart","sphere","clipAntimeridianLine","sign0","sign1","clipAntimeridianIntersect","sinLambda0Lambda1","clipAntimeridianInterpolate","clipCircle","cr","c0","point2","smallRadius","notHemisphere","two","pb","n2","n2n2","n1n2","determinant","c1","n1xn2","uu","polar","meridian","q1","transform$1","transform$2","T","Transform$1","resample","project","delta2","resample$1","resampleNone","resampleLineTo","phi2","dx2","dy2","dz","cosMinDistance","resampleStream","maxDepth","ringPoint","b00","c00","projectionMutator","projectAt","projectRotate","projectTransform","recenter","preclip","clipAntimeridian","postclip","projectResample","transformRadians","clipAngle","conicProjection","parallels","conicEqualAreaRaw","r0y","conicEqualArea","albers","multiplex","streams","albersUsa","lower48Point","alaskaPoint","hawaiiPoint","lower48","alaska","hawaii","pointStream","azimuthalRaw","azimuthalInvert","sc","azimuthalEqualArea","azimuthalEqualAreaRaw","azimuthalEquidistant","azimuthalEquidistantRaw","mercatorRaw","log$1","tan","mercator","mercatorProjection","clipAuto","tany","conicConformalRaw","pow$1","sign$1","conicConformal","equirectangularRaw","equirectangular","conicEquidistantRaw","gy","nx","conicEquidistant","gnomonicRaw","gnomonic","orthographicRaw","orthographic","stereographicRaw","stereographic","transverseMercatorRaw","transverseMercator","ascendingBisect","bisectLeft","proto","polyIn","custom","polyOut","polyInOut","PI","overshoot","backIn","backOut","backInOut","tau","amplitude","period","elasticIn","elasticOut","elasticInOut","pi$1","tau$1","epsilon","tauEpsilon","arcTo","l01_2","x20","y20","l21_2","l20_2","l21","l01","t01","t21","ccw","treeProto","slice$1","defer","results","awaitAll","_line","_point","cross$1","tan30","tan30_2","diamond","ka","kr","star","square","sqrt3","triangle","wye","symbols","_x3","_x4","_y3","_y4","bundle","cardinal","_x5","_y5","cardinalClosed","cardinalOpen","x23","y23","catmullRom","catmullRomClosed","catmullRomOpen","_t0","px","py","darker","brighter","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","green","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","displayable","Kn","rgbGamma","rgbBasis","rgbBasisClosed","SQRT2","hsl$1","hslLong","hcl$1","hclLong","cubehelix$2","interpolateCubehelixLong","csvParse","csvParseRows","csvFormat","csvFormatRows","tsv","tsvParse","tsvParseRows","tsvFormat","tsvFormatRows","html","createContextualFragment","xml","responseXML","csv$1","tsv$1","performance","requestAnimationFrame","TypeError","milliseconds","durationSecond","durationHour","durationDay","seconds","minutes","hours","tuesday","wednesday","thursday","friday","saturday","sundays","mondays","tuesdays","wednesdays","thursdays","fridays","saturdays","setMonth","years","setUTCSeconds","utcMinutes","setUTCMinutes","utcHours","utcDays","utcTuesday","utcWednesday","utcThursday","utcFriday","utcSaturday","utcSundays","utcMondays","utcTuesdays","utcWednesdays","utcThursdays","utcFridays","utcSaturdays","setUTCMonth","utcMonths","utcYears","","toFixed","-","0","isoSpecifier","formatIso","parseIso","array$2","category10","category20b","category20c","category20","cubehelix$3","warm","cool","viridis","magma","inferno","plasma","xlink","xmlns","matcher","matches","element","vendorMatches","webkitMatchesSelector","msMatchesSelector","mozMatchesSelector","oMatchesSelector","element$1","mouseenter","mouseleave","classed","selection_prototype","descendants","resquarify","_squarify","grandpa","uncle","applyX","applyY","location","rescaleX","rescaleY","xy","ne","se","sw","pi$3","temp","valueOf","Feature","FeatureCollection","features","Sphere","Point","MultiPoint","LineString","MultiLineString","Polygon","MultiPolygon","GeometryCollection","geometries","areaRing","areaSum$1","cxcy","bisect","thresholdFreedmanDiaconis","thresholdScott","thresholdSturges","randomUniform","randomLogNormal","randomBates","randomExponential","easeLinear","easeQuad","easeQuadIn","easeQuadOut","easeQuadInOut","easeCubic","easeCubicIn","easeCubicOut","easePoly","easePolyIn","easePolyOut","easePolyInOut","easeSin","easeSinIn","easeSinOut","easeSinInOut","easeExp","easeExpIn","easeExpOut","easeExpInOut","easeCircle","easeCircleIn","easeCircleOut","easeCircleInOut","easeBounce","easeBounceIn","easeBounceOut","easeBounceInOut","easeBack","easeBackIn","easeBackOut","easeBackInOut","easeElastic","easeElasticIn","easeElasticOut","easeElasticInOut","polygonArea","polygonCentroid","polygonHull","polygonLength","symbolCircle","symbolCross","symbolDiamond","symbolSquare","symbolStar","symbolTriangle","symbolWye","curveBasisClosed","curveBasisOpen","curveBasis","curveBundle","curveCardinalClosed","curveCardinalOpen","curveCardinal","curveCatmullRomClosed","curveCatmullRomOpen","curveCatmullRom","curveLinearClosed","curveMonotoneX","curveMonotoneY","curveNatural","curveStep","curveStepAfter","curveStepBefore","stackOffsetExpand","stackOffsetNone","stackOffsetSilhouette","stackOffsetWiggle","stackOrderAscending","stackOrderDescending","stackOrderInsideOut","stackOrderNone","stackOrderReverse","interpolateArray","interpolateDate","interpolateObject","interpolateTransformCss","interpolateTransformSvg","interpolateRgbBasis","interpolateRgbBasisClosed","interpolateHsl","interpolateHslLong","interpolateLab","interpolateHcl","interpolateHclLong","interpolateCubehelix","interpolateBasis","interpolateBasisClosed","dsvFormat","timeInterval","timeMillisecond","timeMilliseconds","timeSecond","timeSeconds","timeMinute","timeMinutes","timeHour","timeHours","timeDay","timeDays","timeWeeks","timeSunday","timeSundays","timeMondays","timeTuesday","timeTuesdays","timeWednesday","timeWednesdays","timeThursday","timeThursdays","timeFriday","timeFridays","timeSaturday","timeSaturdays","timeMonth","timeMonths","timeYear","timeYears","utcMillisecond","utcMilliseconds","utcSecond","utcSeconds","utcWeeks","utcSunday","formatDefaultLocale","isoFormat","isoParse","timeFormatLocale","timeFormatDefaultLocale","scaleBand","scalePoint","scaleIdentity","scaleLinear","scaleLog","scaleOrdinal","scaleImplicit","scalePow","scaleSqrt","scaleQuantile","scaleQuantize","scaleThreshold","scaleTime","scaleUtc","schemeCategory10","schemeCategory20b","schemeCategory20c","schemeCategory20","scaleSequential","interpolateCubehelixDefault","interpolateRainbow","interpolateWarm","interpolateCool","interpolateViridis","interpolateMagma","interpolateInferno","interpolatePlasma","packSiblings","treemapBinary","treemapSliceDice","treemapSquarify","treemapResquarify","forceCenter","forceCollide","forceLink","forceManyBody","forceSimulation","forceX","forceY","zoomIdentity","zoomTransform","geoAlbers","geoAlbersUsa","geoArea","geoAzimuthalEqualArea","geoAzimuthalEqualAreaRaw","geoAzimuthalEquidistant","geoAzimuthalEquidistantRaw","geoBounds","geoCentroid","geoCircle","geoClipExtent","geoConicConformal","geoConicConformalRaw","geoConicEqualArea","geoConicEqualAreaRaw","geoConicEquidistant","geoConicEquidistantRaw","geoDistance","geoEquirectangular","geoEquirectangularRaw","geoGnomonic","geoGnomonicRaw","geoGraticule","geoInterpolate","geoLength","geoMercator","geoMercatorRaw","geoOrthographic","geoOrthographicRaw","geoPath","geoProjection","geoProjectionMutator","geoRotation","geoStereographic","geoStereographicRaw","geoStream","geoTransform","geoTransverseMercator","geoTransverseMercatorRaw","defineProperty","12","jQuery","_fnHungarianMap","newKey","hungarian","_hungarianMap","_fnCamelToHungarian","hungarianKey","_fnLanguageCompat","lang","DataTable","oLanguage","zeroRecords","sZeroRecords","sEmptyTable","_fnMap","sLoadingRecords","sInfoThousands","sThousands","sDecimal","_addNumericSort","_fnCompatOpts","_fnCompatMap","sScrollX","scrollX","searchCols","aoSearchCols","ien","models","oSearch","_fnCompatCols","dataSort","aDataSort","_fnBrowserDetect","settings","__browser","browser","overflow","appendTo","bScrollOversize","bScrollbarLeft","bBounding","oBrowser","oScroll","iBarWidth","_fnReduce","isSet","_fnAddColumn","oSettings","nTh","oDefaults","iCol","aoColumns","oCol","oColumn","sTitle","mData","idx","aoPreSearchCols","_fnColumnOptions","oOptions","oClasses","sWidthOrig","mDataProp","sType","_sManualType","sClass","iDataSort","mDataSrc","_fnGetObjectDataFn","mRender","attrTest","_bAttrSrc","isPlainObject","_setter","fnGetData","rowData","innerData","fnSetData","_fnSetObjectDataFn","_rowReadObject","oFeatures","bSort","bSortable","sSortableNone","bAsc","inArray","asSorting","bDesc","sSortingClass","sSortableAsc","sSortingClassJUI","sSortJUIAscAllowed","sSortableDesc","sSortJUIDescAllowed","sSortable","sSortJUI","_fnAdjustColumnSizing","bAutoWidth","_fnCalculateColumnWidths","iLen","sY","sX","_fnScrollDraw","_fnCallbackFire","_fnVisibleToColumnIndex","iMatch","aiVis","_fnGetColumns","_fnColumnIndexToVisible","iPos","_fnVisbleColumns","bVisible","sParam","_fnColumnTypes","jen","ken","detectedType","aoData","detect","_fnGetCellData","_fnApplyColumnDefs","aoColDefs","aoCols","jLen","kLen","def","aTargets","targets","hasClass","_fnAddData","aDataIn","nTr","anTds","iRow","oData","oRow","_aData","aiDisplayMaster","rowIdFn","aIds","bDeferRender","_fnCreateTr","_fnAddTr","trs","el","_fnGetRowElements","_fnNodeToDataIndex","_DT_RowIndex","_fnNodeToColumnIndex","anCells","rowIdx","colIdx","iDraw","defaultContent","sDefaultContent","cellData","iDrawError","_fnLog","_fnSetCellData","_fnSplitObjNotation","mSource","fetchData","arrayNotation","funcNotation","innerSrc","__reArray","__reFn","aLast","_fnGetDataMaster","_pluck","_fnClearTable","aiDisplay","_fnDeleteIndex","iTarget","iTargetIndex","_fnInvalidate","cellWrite","_aSortData","_aFilterData","cols","_fnRowAttributes","contents","tds","objectRead","setter","cellProcess","rowNode","rowId","nTrIn","nTd","sCellType","_DT_CellIndex","fnCreatedCell","oInstance","DT_RowClass","__rowc","_unique","DT_RowAttr","DT_RowData","_fnBuildHead","nTHead","nTFoot","createHeader","iTabIndex","sTableId","_fnSortAttachListener","_fnRenderer","_fnDetectHeader","aoHeader","sHeaderTH","sFooterTH","aoFooter","nTf","_fnDrawHead","aoSource","bIncludeHidden","nLocalTr","iRowspan","iColspan","aoLocal","aApplied","iColumns","_fnDraw","aPreDraw","anRows","iRowCount","asStripeClasses","iStripes","oLang","aoOpenRows","iInitDisplayStart","bServerSide","_fnDataSource","bDrawing","_iDisplayStart","fnRecordsDisplay","iDisplayStart","iDisplayEnd","fnDisplayEnd","bDeferLoading","_fnProcessingDisplay","bDestroying","_fnAjaxUpdate","iStart","iEnd","iDataIndex","nRow","sStripe","_sRowStripe","sZero","fnRecordsTotal","valign","colSpan","sRowEmpty","nTBody","bSorted","bFiltered","_fnReDraw","holdPosition","bFilter","_fnSort","_fnFilterComplete","oPreviousSearch","_drawHold","_fnAddOptionsHtml","nTable","holding","sWrapper","sNoFooter","nHolding","nTableWrapper","nTableReinsertBefore","featureNode","cOption","nNewNode","cNext","sAttr","aDom","sDom","sJUIHeader","sJUIFooter","aSplit","bPaginate","bLengthChange","_fnFeatureHtmlLength","_fnFeatureHtmlFilter","bProcessing","_fnFeatureHtmlProcessing","_fnFeatureHtmlTable","bInfo","_fnFeatureHtmlInfo","_fnFeatureHtmlPaginate","aoFeatures","cFeature","fnInit","aanFeatures","replaceWith","aLayout","nThead","nCell","iColShifted","iColumn","bUnique","nTrs","fnShiftCol","unique","_fnGetUniqueThs","nHeader","aReturn","bSortCellsTop","_fnBuildAjax","rbracket","ajaxData","ajax","instance","jqXHR","newData","isFunction","baseAjax","success","sError","dataType","sServerMethod","thrown","oAjaxData","fnServerData","sAjaxSource","bAjaxDataGet","_fnAjaxParameters","_fnAjaxUpdateDraw","dataProp","columnSearch","columnCount","preSearch","preColSearch","_fnSortFlatten","displayStart","displayLength","_iDisplayLength","sSearch","regex","bRegex","sName","searchable","bSearchable","orderable","legacy","compat","modern","_fnAjaxDataSrc","recordsTotal","recordsFiltered","_iRecordsTotal","_iRecordsDisplay","_bInitComplete","_fnInitComplete","dataSrc","sAjaxDataProp","aaData","tableId","language","previousSearch","sFilterInput","sFilter","searchFn","bSmart","bCaseInsensitive","searchDelay","jqFilter","sSearchPlaceholder","_fnThrottle","ev","oInput","iForce","oPrevSearch","aoPrevSearch","fnSaveFilter","oFilter","fnRegex","bEscapeRegex","_fnFilter","_fnFilterColumn","_fnFilterCustom","filters","displayRows","searchStr","smart","rpSearch","_fnFilterCreateSearch","invalidated","prevSearch","displayMaster","_fnFilterData","_sFilterRow","_fnEscapeRegex","filterData","fomatters","wasInvalidated","__filter_div","__filter_div_textContent","innerText","_fnSearchToCamel","_fnSearchToHung","tid","sInfo","aoDrawCallback","_fnUpdateInfo","sInfoEmpty","sInfoFiltered","sInfoPostFix","_fnInfoMacros","fnInfoCallback","formatter","fnFormatNumber","all","_fnInitialise","iAjaxStart","deferLoading","bInitialised","_fnStringToCss","aData","oInit","_fnLengthChange","_fnLengthOverflow","aLengthMenu","lengths","aria-controls","sLengthSelect","Option","sLength","sLengthMenu","outerHTML","sPaginationType","plugin","pager","sPaging","visRecords","page","pages","buttons","fnUpdate","_fnPageChange","action","records","sProcessing","show","caption","captionSide","_captionSide","headerClone","footerClone","_div","sScrollWrapper","sScrollHead","sScrollHeadInner","box-sizing","sXInner","sScrollBody","sScrollFoot","sScrollFootInner","scrollHead","scrollBody","scrollFoot","bCollapse","nScrollHead","nScrollBody","nScrollFoot","headerTrgEls","footerTrgEls","headerSrcEls","footerSrcEls","headerCopy","footerCopy","correction","sanityWidth","scrollXInner","divHeader","divHeaderStyle","divHeaderInner","divHeaderInnerStyle","divHeaderTable","divBodyEl","divBody","divBodyStyle","divFooter","divFooterInner","divFooterTable","tableEl","tableStyle","ie67","dtHeaderCells","headerWidths","footerWidths","headerContent","footerContent","zeroOut","nSizer","borderTopWidth","borderBottomWidth","scrollBarVis","clone","prependTo","_fnApplyToChildren","nToSize","iOuterWidth","bScrolling","an1","an2","nNode1","nNode2","columnIdx","visibleColumns","headerCells","tableWidthAttr","tableContainer","userInputs","styleWidth","_fnConvertToWidth","tmpTable","_fnGetWidestNode","sContentPadding","holder","bounding","_reszEvt","bindResize","sInstance","_fnGetMaxLenString","maxIdx","__re_html_remove","srcCol","aSort","fixed","aaSortingFixed","fixedObj","nestedSort","aaSorting","_idx","sortCol","aiOrig","oExtSort","formatters","_fnSortData","dataA","dataB","_fnSortAria","label","nextSort","oAria","sSortAscending","sSortDescending","_fnSortListener","nextSortIdx","sorting","bSortMulti","sortIdx","attachTo","_fnBindAction","_fnSortingClasses","oldSort","aLastSort","sortClass","sSortColumn","bSortClasses","customData","customSort","sSortDataType","_fnSaveState","bStateSave","oSavedState","fnStateSaveCallback","_fnLoadState","fnStateLoadCallback","abStateLoad","iStateDuration","oLoadedState","_fnSettingsFromNode","msg","tn","console","sErrMode","errMode","alert","mappedName","_fnExtend","extender","breakRefs","_fnCallbackReg","sStore","callbackArr","eventName","Event","trigger","renderer","_numbers","extPagination","numbers_length","half","_range","DT_el","decimalPlace","num","__numericReplace","num-fmt","_re_formatted_numeric","html-num","_re_html","html-num-fmt","_ext","_fnExternApiFunc","iApiIndex","internal","_Api","_api_register","_api_registerPlural","sSelector","oOpts","api","traditional","fnAddData","flatten","fnAdjustColumnSizing","bRedraw","fnClearTable","fnClose","hide","fnDeleteRow","fnDestroy","fnDraw","complete","fnFilter","sInput","bShowGlobal","fnGetNodes","fnGetPosition","columnVisible","fnIsOpen","isShown","fnOpen","mHtml","fnPageChange","mAction","fnSetColumnVis","bShow","fnSettings","fnSort","aaSort","fnSortListener","nNode","fnCallback","mRow","bAction","fnVersionCheck","_that","emptyInit","oApi","sId","bInitHandedOff","$this","allSettings","bRetrieve","bDestroy","sDestroyWidth","dataTable","iDisplayLength","fnDrawCallback","fnServerParams","fnStateSaveParams","fnStateLoadParams","fnStateLoaded","fnRowCallback","fnCreatedRow","fnHeaderCallback","fnFooterCallback","fnInitComplete","fnPreDrawCallback","bJQueryUI","oJUIClasses","sTable","iDeferLoading","sUrl","sStripeOdd","sStripeEven","stripeClasses","rowOne","asDestroyStripes","aoColumnsInit","anThs","getElementsByTagName","aoColumnDefs","oDef","sortedColumns","captions","_re_dic","_re_new_lines","_re_date_start","_re_date_end","_re_escape_regex","_empty","_intVal","_numToDecimal","decimalPoint","_isNumber","formatted","strType","_isHtml","_htmlNumeric","_stripHtml","prop2","_pluck_order","_removeEmpty","again","util","throttle","freq","frequency","escapeRegex","knew","__apiStruct","__arrayProto","_toSettings","mixed","jq","ctxSettings","Api","ctx","iterator","alwaysNew","items","item","apiInst","_selector_row_indexes","apiSelector","pluck","reduceRight","to$","toJQuery","scope","__dt_wrapper","struct","methodScoping","struc","methodExt","propExt","heir","registerPlural","pluralName","singularName","__table_selector","paging","recordsDisplay","serverSide","__reload","resetPaging","_selector_run","selectFn","res","selectorType","_selector_opts","_selector_first","displayFiltered","__row_selector","run","selInt","rowObj","hash","thatIdx","loopRow","loopCells","newRows","modRows","__details_add","klass","addRow","created","_details","_detailsShow","insertAfter","__details_remove","__details_display","__details_events","drawEvent","colvisEvent","destroyEvent","_emp","_child_obj","_child_mth","__re_column_selector","__columnData","__column_selector","visColumns","jqResult","__setColumnVis","calc","__cell_selector","allCells","fnSelector","rowSelector","columnSelector","caseInsen","versionCheck","iThis","iThat","aThis","aThat","isDataTable","fnIsDataTable","foot","fnTables","camelToHungarian","jqRows","orig","jqTable","jqTbody","jqWrapper","bJUI","sSortIcon","sSortJUIWrapper","removedMethod","arg1","arg2","arg3","arg4","plural","resolved","bScrollCollapse","toFormat","localStorage","getItem","pathname","setItem","oPaginate","sFirst","sLast","sNext","sPrevious","sScrollXInner","sScrollY","aoRowCallback","aoHeaderCallback","aoFooterCallback","aoRowCreatedCallback","aoPreDrawCallback","aoInitComplete","aoStateSaveParams","aoStateLoadParams","aoStateLoaded","aoStateSave","aoStateLoad","aoServerParams","aoDestroyCallback","paginate","oPlugins","pageButton","sVersion","afnFiltering","aTypes","ofnSearch","oSort","afnSortData","oStdClasses","oPagination","sPageButton","sPageButtonActive","sPageButtonDisabled","sSortAsc","sSortDesc","sSortJUIAsc","sSortJUIDesc","_stateDefault","_sortIcon","_headerFooter","simple","simple_numbers","full_numbers","btnDisplay","btnClass","activeEl","aria","clickHandler","aria-label","data-dt-idx","parsed","re1","re2","date-pre","html-pre","string-pre","string-asc","string-desc","jqueryui","__htmlEscapeEntities","render","postfix","negative","flo","intPart","floatPart","_fnCalculateEnd","dataTableSettings","dataTableExt","EventEmitter","_events","_maxListeners","arg","isNumber","isObject","isUndefined","defaultMaxListeners","setMaxListeners","er","handler","err","addListener","newListener","warned","trace","once","removeListener","fired","removeAllListeners","listenerCount","evlistener","14","focusable","isTabIndexNotNaN","mapName","href","addBack","uuid","runiqueId","ui","BACKSPACE","COMMA","DELETE","DOWN","END","ENTER","ESCAPE","HOME","LEFT","NUMPAD_ADD","NUMPAD_DECIMAL","NUMPAD_DIVIDE","NUMPAD_ENTER","NUMPAD_MULTIPLY","NUMPAD_SUBTRACT","PAGE_DOWN","PAGE_UP","PERIOD","RIGHT","SPACE","TAB","UP","elem","scrollParent","uniqueId","removeUniqueId","createPseudo","dataName","tabbable","isTabIndexNaN","innerWidth","prevObject","removeData","camelCase","support","selectstart","disableSelection","enableSelection","plugins","hasScroll","15","mouseHandled","_mouseInit","widgetName","_mouseDown","_mouseDestroy","_mouseMoveDelegate","_mouseUpDelegate","_mouseStarted","_mouseUp","_mouseDownEvent","btnIsLeft","elIsCancel","_mouseCapture","mouseDelayMet","_mouseDelayTimer","_mouseDistanceMet","_mouseDelayMet","_mouseStart","_mouseMove","_mouseDrag","_mouseStop","./widget","isOverAxis","reference","isFloating","widgetEventPrefix","ready","connectWith","containment","cursorAt","dropOnEmpty","forcePlaceholderSize","forceHelperSize","grid","revert","scrollSensitivity","scrollSpeed","tolerance","activate","beforeStop","deactivate","receive","_create","containerCache","floating","_destroy","_setOption","toggleClass","Widget","overrideHandle","currentItem","validHandle","reverting","_refreshItems","_removeCurrentsFromItems","noActivation","currentContainer","refreshPositions","_createHelper","_cacheHelperProportions","_cacheMargins","margins","click","_getParentOffset","relative","_getRelativeOffset","cssPosition","originalPosition","_generatePosition","originalPageX","originalPageY","_adjustOffsetFromHelper","domPosition","_createPlaceholder","_setContainment","storedCursor","storedStylesheet","_storedOpacity","_storedZIndex","overflowOffset","_trigger","_uiHash","_preserveHelperProportions","containers","ddmanager","dropBehaviour","prepareOffsets","dragging","itemElement","scrolled","positionAbs","_convertPositionTo","lastPositionAbs","_intersectsWithPointer","_intersectsWithSides","_rearrange","_contactContainers","noPropagation","animation","offsetParent","animate","_clear","_storedCSS","_noFinalSort","prepend","serialize","_getItemsAsjQuery","connected","attribute","_intersectsWith","helperProportions","dyClick","dxClick","isOverElementHeight","isOverElementWidth","isOverElement","forcePointerForContainers","verticalDirection","_getDragVerticalDirection","horizontalDirection","_getDragHorizontalDirection","isOverBottomHalf","isOverRightHalf","_connectWith","addItems","queries","widgetFullName","grep","targetData","_queries","queriesLength","fast","toleranceElement","refreshContainers","itemWithLeastDistance","posProperty","sizeProperty","nearBottom","innermostContainer","innermostIndex","po","ce","co","scrollIsRootNode","hardRefresh","_delay","delayEvent","delayedTriggers","cancelHelperRemoval","_inst","sender","./core","./mouse","_cleanData","cleanData","elems","triggerHandler","fullName","existingConstructor","basePrototype","proxiedPrototype","_createWidget","_proto","_childConstructors","_super","_superApply","__super","__superApply","childPrototype","bridge","inputIndex","inputLength","isMethodCall","methodValue","pushStack","_init","defaultElement","eventNamespace","_getCreateOptions","bindings","hoverable","_on","parentWindow","_getCreateEventData","curOption","_setOptions","enable","suppressDisabledCheck","delegateElement","handlerProxy","guid","delegate","_off","undelegate","_hoverable","_focusable","focusin","focusout","isDefaultPrevented","defaultEffect","effect","hasOptions","effectName","isEmptyObject","effects","easing","noGlobal","isArrayLike","isWindow","winnow","elements","qualifier","risSimple","createOptions","rnotwhite","flag","completed","Data","expando","uid","dataAttr","rmultiDash","rbrace","parseJSON","dataUser","adjustCSS","valueParts","adjusted","maxIterations","currentValue","initial","cssNumber","initialInUnit","rcssNum","getAll","setGlobalEval","refElements","dataPriv","buildFragment","scripts","ignored","rhtml","rtagName","wrapMap","_default","htmlPrefilter","rscriptType","returnTrue","returnFalse","safeActiveElement","origFn","manipulationTarget","disableScript","restoreScript","rscriptTypeMasked","cloneCopyEvent","pdataOld","pdataCur","udataOld","udataCur","hasData","access","fixInput","rcheckableType","checked","defaultValue","domManip","hasScripts","iNoClone","checkClone","rchecked","_evalUrl","globalEval","rcleanScript","keepData","actualDisplay","defaultDisplay","elemdisplay","iframe","contentDocument","write","curCSS","computed","maxWidth","getStyles","pixelMarginRight","rnumnonpx","rmargin","addGetHookIf","conditionFn","hookFn","vendorPropName","emptyStyle","capName","cssPrefixes","setPositiveNumber","subtract","augmentWidthOrHeight","extra","isBorderBox","cssExpand","getWidthOrHeight","valueIsBorderBox","boxSizingReliable","showHide","isHidden","Tween","createFxNow","fxNow","genFx","includeWidth","attrs","createTween","Animation","tweeners","defaultPrefilter","oldfire","checkDisplay","anim","dataShow","_queueHooks","unqueued","fire","always","overflowX","overflowY","rfxtypes","propFilter","specialEasing","cssHooks","stopped","prefilters","deferred","Deferred","currentTime","percent","tweens","notifyWith","resolveWith","promise","originalProperties","originalOptions","gotoEnd","rejectWith","proxy","progress","fail","getClass","addToPrefiltersOrTransports","structure","dataTypeExpression","dataTypes","inspectPrefiltersOrTransports","inspect","inspected","prefilterOrFactory","dataTypeOrTransport","seekingTransport","transports","ajaxExtend","deep","flatOptions","ajaxSettings","ajaxHandleResponses","responses","ct","finalDataType","firstDataType","getResponseHeader","converters","ajaxConvert","isSuccess","conv2","conv","responseFields","dataFilter","buildParams","getWindow","class2type","hasOwn","rtrim","rmsPrefix","rdashAlpha","fcamelCase","letter","copyIsArray","isReady","isNumeric","realStringObj","script","indirect","eval","makeArray","callbackInverse","callbackExpect","Symbol","Sizzle","seed","nid","nidselect","newSelector","newContext","preferredDoc","setDocument","documentIsHTML","rquickExpr","getElementById","qsa","compilerCache","rbuggyQSA","rescape","ridentifier","toSelector","rsibling","testContext","qsaError","createCache","Expr","cacheLength","markFunction","assert","addHandle","attrHandle","siblingCheck","sourceIndex","MAX_NEGATIVE","createInputPseudo","createButtonPseudo","createPositionalPseudo","argument","matchIndexes","setFilters","addCombinator","checkNonElements","doneName","oldCache","uniqueCache","outerCache","newCache","dirruns","uniqueID","elementMatcher","matchers","multipleContexts","contexts","condense","unmatched","newUnmatched","mapped","setMatcher","preFilter","postFilter","postFinder","postSelector","preMap","postMap","preexisting","matcherIn","matcherOut","matcherFromTokens","checkContext","leadingRelative","implicitRelative","matchContext","matchAnyContext","outermostContext","matcherFromGroupMatchers","elementMatchers","setMatchers","bySet","byElement","superMatcher","outermost","matchedCount","setMatched","contextBackup","dirrunsUnique","uniqueSort","getText","isXML","compile","sortInput","hasDuplicate","docElem","rbuggyMatches","classCache","tokenCache","sortOrder","push_native","booleans","whitespace","attributes","pseudos","rwhitespace","rcomma","rcombinators","rattributeQuotes","rpseudo","matchExpr","CLASS","TAG","ATTR","PSEUDO","CHILD","bool","needsContext","rinputs","rheader","rnative","runescape","funescape","escapedWhitespace","high","unloadHandler","els","hasCompare","createComment","getById","getElementsByName","attrId","getAttributeNode","matchesSelector","disconnectedMatch","adown","bup","sortDetached","aup","bp","specified","duplicates","detectDuplicates","sortStable","selectors",">"," ","+","~","excess","unquoted","nodeNameSelector","ofType","nodeIndex","useCache","pseudo","matched","elemLang","enabled","selectedIndex","even","odd","radio","checkbox","image","parseOnly","soFar","preFilters","cached","compiled","div1","isXMLDoc","until","truncate","rneedsContext","rsingleTag","rootjQuery","parseHTML","rparentsprev","guaranteedUnique","prevAll","parentsUntil","nextAll","nextUntil","prevUntil","Callbacks","firing","memory","locked","firingIndex","stopOnFalse","lock","fireWith","tuples","then","fns","newDefer","tuple","returned","notify","resolve","reject","pipe","stateString","when","subordinate","progressValues","progressContexts","resolveContexts","resolveValues","updateFunc","readyList","readyWait","holdReady","hold","wait","chainable","emptyGet","raw","bulk","acceptData","owner","writable","configurable","stored","camel","_removeData","camelKey","dequeue","startLength","clearQueue","pnum","colgroup","noCloneChecked","rkeyEvent","rmouseEvent","rtypenamespace","handleObjIn","eventHandle","handleObj","origType","elemData","triggered","delegateType","bindType","delegateCount","setup","mappedTypes","origCount","teardown","removeEvent","fix","handlerQueue","delegateTarget","preDispatch","isPropagationStopped","isImmediatePropagationStopped","rnamespace","postDispatch","fixHooks","keyHooks","original","mouseHooks","eventDoc","fixHook","load","noBubble","beforeunload","timeStamp","isSimulated","pointerenter","pointerleave","rxhtmlTag","rnoInnerhtml","dataAndEvents","deepDataAndEvents","srcElements","destElements","inPage","replaceAll","HTML","BODY","opener","swap","computeStyleTests","divStyle","pixelPositionVal","reliableMarginLeftVal","boxSizingReliableVal","pixelMarginRightVal","backgroundClip","clearCloneStyle","pixelPosition","reliableMarginLeft","reliableMarginRight","marginDiv","rdisplayswap","cssShow","cssNormalTransform","letterSpacing","fontWeight","animationIterationCount","fillOpacity","flexGrow","flexShrink","lineHeight","orphans","widows","cssProps","float","origName","expanded","propHooks","eased","swing","timerId","rrun","*","tweener","prefilter","speed","speeds","fadeTo","optall","doAnimation","stopQueue","timers","cssFn","slideDown","slideUp","slideToggle","fadeIn","fadeOut","fadeToggle","slow","checkOn","optSelected","optDisabled","radioValue","boolHook","nType","attrHooks","propName","attrNames","propFix","getter","rfocusable","rclickable","removeProp","rclass","curValue","clazz","finalValue","stateVal","classNames","rreturn","rspaces","valHooks","optionSet","rfocusMorph","onlyHandlers","bubbleType","ontype","eventPath","isTrigger","simulate","hover","fnOver","fnOut","attaches","nonce","rquery","parseXML","DOMParser","parseFromString","rhash","rts","rheaders","rlocalProtocol","rnoContent","rprotocol","allTypes","originAnchor","lastModified","etag","isLocal","protocol","processData","contentType","accepts","* text","text html","text json","text xml","ajaxSetup","ajaxPrefilter","ajaxTransport","nativeStatusText","modified","statusText","timeoutTimer","transport","responseHeadersString","ifModified","cacheURL","callbackContext","statusCode","fireGlobals","globalEventContext","completeDeferred","responseHeaders","urlAnchor","requestHeaders","requestHeadersNames","strAbort","getAllResponseHeaders","lname","finalText","crossDomain","hasContent","beforeSend","getJSON","getScript","throws","wrapAll","firstElementChild","wrapInner","unwrap","r20","rCRLF","rsubmitterTypes","rsubmittable","encodeURIComponent","serializeArray","xhrSuccessStatus","1223","xhrSupported","cors","errorCallback","username","xhrFields","onabort","text script","charset","scriptCharset","evt","oldCallbacks","rjsonp","jsonp","jsonpCallback","originalSettings","callbackName","overwritten","responseContainer","jsonProp","keepScripts","_load","animated","setOffset","curPosition","curLeft","curCSSTop","curTop","curOffset","curCSSLeft","calculatePosition","curElem","using","win","parentOffset","Height","Width","defaultExtra","funcName","andSelf","_jQuery","_$","noConflict","callWithJQuery","pivotModule","pivotUtilities","d3_renderers","Treemap","pivotData","addToTree","ref","rowKey","localeStrings","newChild","getRowKeys","getAggregator","layout","sticky","makeGoogleChart","chartType","extraOptions","agg","base1","colKey","colKeys","dataArray","fullAggName","groupByTitle","hAxisTitle","len1","numCharsInHAxis","rowKeys","tree2","vAxisTitle","vs","gchart","getColKeys","aggregatorName","valAttrs","google","visualization","addColumn","colAttrs","rowAttrs","role","addRows","arrayToDataTable","hAxis","slantedText","vAxis","tooltip","textStyle","fontName","fontSize","legend","chartArea","ChartWrapper","editor","ChartEditor","getChartWrapper","openDialog","gchart_renderers","Line Chart","Bar Chart","Stacked Bar Chart","isStacked","Area Chart","Scatter Chart","21","hasProp","PivotData","addSeparators","aggregatorTemplates","aggregators","dayNamesEn","derivers","getSort","locales","mthNamesEn","naturalSort","numberFormat","pivotTableRenderer","renderers","sortAs","usFmt","usFmtInt","usFmtPct","zeroPad","nStr","thousandsSep","decimalSep","rgx","digitsAfterDecimal","scaler","showZero","countUnique","uniq","record","numInputs","listUnique","sep","average","sumOverSum","denom","sumNum","sumDenom","sumOverSumBound80","upper","fractionOf","wrapped","tpl","Count","Count Unique Values","List Unique Values","Sum","Integer Sum","Average","Minimum","Maximum","Sum over Sum","80% Upper Bound","80% Lower Bound","Sum as Fraction of Total","Sum as Fraction of Rows","Sum as Fraction of Columns","Count as Fraction of Total","Count as Fraction of Rows","Count as Fraction of Columns","Table","Table Barchart","barchart","Heatmap","heatmap","Row Heatmap","Col Heatmap","en","renderError","computeError","uiRenderError","selectNone","tooMany","filterResults","totals","binWidth","dateFormat","formatString","utcOutput","mthNames","dayNames","utc","_this","rd","rz","mapping","sorters","arrSort","aggregator","vals","rowTotals","colTotals","allTotal","sorted","forEachRecord","derivedAttributes","processRecord","addRecord","compactRecord","results1","tblCols","convertToArray","sortersArr","comparison","sorter","flatColKey","flatRowKey","len2","ref1","ref2","ref3","spanSize","totalAggregator","noDraw","pivot","error1","dataClass","rendererOptions","hasChildNodes","pivotUI","inputOpts","attrLength","axisValues","colList","existingOpts","initialRender","len3","len4","pivotTable","ref4","refreshDelayed","rendererControl","shownAttributes","tr1","tr2","uiTable","unusedAttrsVerticalAutoCutoff","unusedAttrsVerticalAutoOverride","hiddenAttributes","menuLimit","exclusions","inclusions","unusedAttrsVertical","autoSortUnusedAttrs","onRefresh","attrElem","btns","checkContainer","filterItem","filterItemExcluded","hasExcludedItem","showFilterList","triangleLink","updateFilter","valueList","testString","unselectedCount","clickLeft","clickTop","rendererName","len5","newDropdown","numInputsToProcess","pivotUIOptions","pvtVals","ref5","ref6","subopts","unusedAttrsContainer","excludedItems","ref7","inclusionsInfo","sortable","colorScaleGenerator","heatmapper","numCols","numRows","nonRed","colorScale","forEachCell","barcharter","background-color","padding-left","padding-right","padding-top","text-align","22","store","isLocalStorageNameSupported","localStorageName","storage","scriptTag","defaultVal","transact","transactionFn","deserialize","removeItem","addBehavior","storageOwner","storageContainer","ActiveXObject","frames","withIEStorage","storeFunction","forbiddenCharsRegex","ieKeyFix","XMLDocument","testKey","23","_args","escapedName","rawSpec","_from","_inCache","_installable","_location","_npmUser","email","_npmVersion","_phantomChildren","_requested","_requiredBy","_resolved","_shasum","_shrinkwrap","_spec","_where","author","bugs","description","devDependencies","directories","shasum","tarball","homepage","licenses","main","maintainers","optionalDependencies","readme","repository","24","yasgui-utils","nestedExists","../package.json","./storage.js","./svg.js","25","times","XMLSerializer","serializeToString","getTime","26","svgString","getElement","dom","svgContainer","license","bootstrap-sass","browserify","browserify-shim","browserify-transform-tools","exorcist","gulp","gulp-autoprefixer","gulp-bump","gulp-clean-css","gulp-concat","gulp-connect","gulp-cssimport","gulp-embedlr","gulp-filter","gulp-git","gulp-html-replace","gulp-jsvalidate","gulp-livereload","gulp-minify-css","gulp-notify","gulp-rename","gulp-sass","gulp-sourcemaps","gulp-streamify","gulp-tag-version","gulp-uglify","node-sass","require-dir","run-sequence","vinyl-buffer","vinyl-source-stream","vinyl-transform","watchify","yasgui-yasqe","dev","build","patch","minor","major","web","codemirror","datatables.net","datatables.net-dt","jquery-ui","pivottable","optionalShim","datatables","jquery-ui/sortable","28","lineBreak","variables","querySolutions","addValueToString","csvString","createBody","addQuerySolutionToString","querySolution","needToQuoteString","needQuoting","29","yasr","resultsContainer","booleanVal","getBoolean","imgId","textVal","canHandleResults","hideFromSelection","getPriority","YASR-boolean","./imgs.js","30","useGoogleCharts","outputPlugins","drawOutputSelector","drawDownloadIcon","getUsedPrefixes","persistency","outputSelector","maxSize","31","./main.js","$container","getTryBtn","$tryBtn","tryQueryLink","getException","$header","corsMessage","GoogleTypeException","foundTypes","varName","toHtml","loadingMain","loadingFailed","loader","loadScript","maxTimeout","checkAndWait","googleLoad","packages","utils","chartWrapper","initEditor","getDataTable","setDataTable","chartConfig","toJSON","containerId","wrapperId","$wrapper","updateHeader","getPersistentSettings","motionChartState","setPersistentSettings","persSettings","getVariables","getDownloadInfo","svgEl","getContent","filename","buttonTitle","$table","tableToCsv","getEmbedHtml","htmlString","doDraw","jsonResults","getAsJson","getGoogleTypeForBindings","warn","usedPrefixes","binding","columnId","castGoogleType","getColumnType","getChartType","motionChart","getChart","getState","persistencyId","./exceptions.js","./gChartLoader.js","./utils.js","unsorted","sortDesc","sortAsc","download","fullscreen","smallscreen","./tableToCsv.js","addRowToString","rowArray","$el","rowspans","totalColCount","$tr","htmlColId","actualColId","rowSpan","$cell","colspan","rowspan","queryResults","getPersistencyId","pluginName","downloadIcon","embedButton","outputPlugin","selectedOutput","selectedOutputPriority","unsupportedOutputs","tryOutput","disableOutputs","outputToDraw","outputs","outputName","somethingDrawn","setResponse","dataOrJqXhr","textStatus","jqXhrOrErrorString","exception","resultsId","getOriginalResponseAsString","getAsStoreObject","$toggableWarning","$toggableWarningClose","$toggableWarningMsg","warning","blobDownloadSupported","checkBlobDownloadSupported","windowUrl","URL","webkitURL","mozURL","msURL","Blob","embedBtn","drawHeader","btnGroup","stringToUrl","blob","createObjectURL","currentPlugin","downloadInfo","downloadUrl","downloadMockLink","fireClick","drawFullscreenButton","drawSmallscreenButton","drawEmbedButton","embedLink","popup","prePopup","positions","persistentId","fromStorage","deprId","registerOutput","./boolean.js","./defaults.js","./error.js","./gchart.js","./jquery/extendJquery.js","./parsers/wrapper.js","./pivot.js","./rawResponse.js","./table.js","queryResponse","./dlv.js","41","detectType","getBindings","rowIt","colIt","isBoolean","varsFetched","../../lib/jquery.csv-0.71.js","42","43","origResponse","errorString","getParserFromContentType","doLuckyGuess","getOriginalResponse","responseString","getType","getOriginalContentType","./csv.js","./json.js","./tsv.js","./xml.js","parseHead","headNodeIt","headNode","parseResults","resultIt","resultNode","jsonResult","bindingIt","bindingNode","bindingInfIt","bindingInf","datatype","parseBoolean","mainXml","yUtils","imgs","useD3Chart","$pivotWrapper","mergeLabelPostfix","getShownVariables","mergeLabelsWithUris","shownVariables","formatForPivot","uriToPrefixed","validatePivotTableOptions","pivotOptions","keepColsAndRows","pivotOptionse","pivotObj","openGchartBtn","dblclick","originalRefresh","icon","newSettings","YASR-rawResponse","pivottable/dist/d3_renderers.js","pivottable/dist/gchart_renderers.js","47","cmOptions","codemirror/addon/edit/matchbrackets.js","codemirror/addon/fold/brace-fold.js","codemirror/addon/fold/foldcode.js","codemirror/addon/fold/foldgutter.js","codemirror/addon/fold/xml-fold.js","codemirror/mode/javascript/javascript.js","codemirror/mode/xml/xml.js","48","yutils","tableLengthPersistencyId","tableLength","getRows","colId","sparqlVar","getCellContent","addEvents","drawSvgIcons","onCellClick","onCellMouseEnter","tdEl","fetchTitlesFromPreflabel","addPrefLabel","onCellMouseLeave","dataTableConfig","datatable","getColumns","pLength","pageLength","sortings","sorting_asc","sorting_desc","svgDiv","formatLiteral","literalBinding","stringRepresentation","escapeHtmlEntities","xmlSchemaNs","visibleString","postFix","addEmptyTitle","includeVariable","variableToCheck","autoWidth","lengthMenu","lengthChange","pagingType","drawCallback","activePaginateButton","columnDefs","YASR-table","jquery-datatables","../lib/colResizable-1.4.js","./bindingsToCsv.js","49","unescaped","getGoogleTypeForBinding","typeCount","googleType","parseXmlSchemaDate","$els","oEvent","initMouseEvent","fireEvent","dateString"],"mappings":"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","file":"yasr.bundled.min.js","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/**\n _ _____ _ _ _ \n | | __ \\ (_) | | | | \n ___ ___ | | |__) |___ ___ _ ______ _| |__ | | ___ \n / __/ _ \\| | _ // _ \\/ __| |_ / _` | '_ \\| |/ _ \\\n | (_| (_) | | | \\ \\ __/\\__ \\ |/ / (_| | |_) | | __/\n \\___\\___/|_|_| \\_\\___||___/_/___\\__,_|_.__/|_|\\___|\n\t \n\tv 1.4 - a jQuery plugin by Alvaro Prieto Lauroba\n\t\n\tLicences: MIT & GPL\n\tFeel free to use or modify this plugin as far as my full name is kept\t\n\t\n\tIf you are going to use this plugin in production environments it is \n\tstrongly recomended to use its minified version: colResizable.min.js\n\n*/\n\nvar $ = require('jquery');\t\n\tvar d = $(document); \t\t//window object\n\tvar h = $(\"head\");\t\t\t//head object\n\tvar drag = null;\t\t\t//reference to the current grip that is being dragged\n\tvar tables = [];\t\t\t//array of the already processed tables (table.id as key)\n\tvar\tcount = 0;\t\t\t\t//internal count to create unique IDs when needed.\t\n\t\n\t//common strings for minification\t(in the minified version there are plenty more)\n\tvar ID = \"id\";\t\n\tvar PX = \"px\";\n\tvar SIGNATURE =\"JColResizer\";\n\t\n\t//shortcuts\n\tvar I = parseInt;\n\tvar M = Math;\n\tvar ie = navigator.userAgent.indexOf('Trident/4.0')>0;\n\tvar S;\n\ttry{S = sessionStorage;}catch(e){}\t//Firefox crashes when executed as local file system\n\t\n\t//append required CSS rules \n\th.append(\"<style type='text/css'> .JColResizer{table-layout:fixed;} .JColResizer td, .JColResizer th{overflow:hidden;padding-left:0!important; padding-right:0!important;} .JCLRgrips{ height:0px; position:relative;} .JCLRgrip{margin-left:-5px; position:absolute; z-index:5; } .JCLRgrip .JColResizer{position:absolute;background-color:red;filter:alpha(opacity=1);opacity:0;width:10px;height:100%;top:0px} .JCLRLastGrip{position:absolute; width:1px; } .JCLRgripDrag{ border-left:1px dotted black;\t}</style>\");\n\n\t\n\t/**\n\t * Function to allow column resizing for table objects. It is the starting point to apply the plugin.\n\t * @param {DOM node} tb - refrence to the DOM table object to be enhanced\n\t * @param {Object} options\t- some customization values\n\t */\n\tvar init = function( tb, options){\t\n\t\tvar t = $(tb);\t\t\t\t\t\t\t\t\t\t//the table object is wrapped\n\t\tif(options.disable) return destroy(t);\t\t\t\t//the user is asking to destroy a previously colResized table\n\t\tvar\tid = t.id = t.attr(ID) || SIGNATURE+count++;\t//its id is obtained, if null new one is generated\t\t\n\t\tt.p = options.postbackSafe; \t\t\t\t\t\t//shortcut to detect postback safe \t\t\n\t\tif(!t.is(\"table\") || tables[id]) return; \t\t\t//if the object is not a table or if it was already processed then it is ignored.\n\t\tt.addClass(SIGNATURE).attr(ID, id).before('<div class=\"JCLRgrips\"/>');\t//the grips container object is added. Signature class forces table rendering in fixed-layout mode to prevent column's min-width\n\t\tt.opt = options; t.g = []; t.c = []; t.w = t.width(); t.gc = t.prev();\t//t.c and t.g are arrays of columns and grips respectively\t\t\t\t\n\t\tif(options.marginLeft) t.gc.css(\"marginLeft\", options.marginLeft); \t//if the table contains margins, it must be specified\n\t\tif(options.marginRight) t.gc.css(\"marginRight\", options.marginRight); \t//since there is no (direct) way to obtain margin values in its original units (%, em, ...)\n\t\tt.cs = I(ie? tb.cellSpacing || tb.currentStyle.borderSpacing :t.css('border-spacing'))||2;\t//table cellspacing (not even jQuery is fully cross-browser)\n\t\tt.b = I(ie? tb.border || tb.currentStyle.borderLeftWidth :t.css('border-left-width'))||1;\t//outer border width (again cross-browser isues)\n\t\t// if(!(tb.style.width || tb.width)) t.width(t.width()); //I am not an IE fan at all, but it is a pitty that only IE has the currentStyle attribute working as expected. For this reason I can not check easily if the table has an explicit width or if it is rendered as \"auto\"\n\t\ttables[id] = t; \t//the table object is stored using its id as key\t\n\t\tcreateGrips(t);\t\t//grips are created\n\t\n\t};\n\n\n\t/**\n\t * This function allows to remove any enhancements performed by this plugin on a previously processed table.\n\t * @param {jQuery ref} t - table object\n\t */\n\tvar destroy = function(t){\n\t\tvar id=t.attr(ID), t=tables[id];\t\t//its table object is found\n\t\tif(!t||!t.is(\"table\")) return;\t\t\t//if none, then it wasnt processed\t \n\t\tt.removeClass(SIGNATURE).gc.remove();\t//class and grips are removed\n\t\tdelete tables[id];\t\t\t\t\t\t//clean up data\n\t};\n\n\n\t/**\n\t * Function to create all the grips associated with the table given by parameters \n\t * @param {jQuery ref} t - table object\n\t */\n\tvar createGrips = function(t){\t\n\t\n\t\tvar th = t.find(\">thead>tr>th,>thead>tr>td\");\t//if table headers are specified in its semantically correct tag, are obtained\n\t\tif(!th.length) th = t.find(\">tbody>tr:first>th,>tr:first>th,>tbody>tr:first>td, >tr:first>td\");\t //but headers can also be included in different ways\n\t\tt.cg = t.find(\"col\"); \t\t\t\t\t\t//a table can also contain a colgroup with col elements\t\t\n\t\tt.ln = th.length;\t\t\t\t\t\t\t//table length is stored\t\n\t\tif(t.p && S && S[t.id])memento(t,th);\t\t//if 'postbackSafe' is enabled and there is data for the current table, its coloumn layout is restored\n\t\tth.each(function(i){\t\t\t\t\t\t//iterate through the table column headers\t\t\t\n\t\t\tvar c = $(this); \t\t\t\t\t\t//jquery wrap for the current column\t\t\t\n\t\t\tvar g = $(t.gc.append('<div class=\"JCLRgrip\"></div>')[0].lastChild); //add the visual node to be used as grip\n\t\t\tg.t = t; g.i = i; g.c = c;\tc.w =c.width();\t\t//some values are stored in the grip's node data\n\t\t\tt.g.push(g); t.c.push(c);\t\t\t\t\t\t//the current grip and column are added to its table object\n\t\t\tc.width(c.w).removeAttr(\"width\");\t\t\t\t//the width of the column is converted into pixel-based measurements\n\t\t\tif (i < t.ln-1) {\n\t\t\t\tg.bind('touchstart mousedown', onGripMouseDown).append(t.opt.gripInnerHtml).append('<div class=\"'+SIGNATURE+'\" style=\"cursor:'+t.opt.hoverCursor+'\"></div>'); //bind the mousedown event to start dragging \n\t\t\t} else g.addClass(\"JCLRLastGrip\").removeClass(\"JCLRgrip\");\t//the last grip is used only to store data\t\t\t\n\t\t\tg.data(SIGNATURE, {i:i, t:t.attr(ID)});\t\t\t\t\t\t//grip index and its table name are stored in the HTML \t\t\t\t\t\t\t\t\t\t\t\t\n\t\t}); \t\n\t\tt.cg.removeAttr(\"width\");\t//remove the width attribute from elements in the colgroup (in any)\n\t\tsyncGrips(t); \t\t\t\t//the grips are positioned according to the current table layout\t\t\t\n\t\t//there is a small problem, some cells in the table could contain dimension values interfering with the \n\t\t//width value set by this plugin. Those values are removed\n\t\tt.find('td, th').not(th).not('table th, table td').each(function(){ \n\t\t\t$(this).removeAttr('width');\t//the width attribute is removed from all table cells which are not nested in other tables and dont belong to the header\n\t\t});\t\t\n\n\t\t\n\t};\n\t\n\n\t/**\n\t * Function to allow the persistence of columns dimensions after a browser postback. It is based in\n\t * the HTML5 sessionStorage object, which can be emulated for older browsers using sessionstorage.js\n\t * @param {jQuery ref} t - table object\n\t * @param {jQuery ref} th - reference to the first row elements (only set in deserialization)\n\t */\n\tvar memento = function(t, th){ \n\t\tvar w,m=0,i=0,aux =[];\n\t\tif(th){\t\t\t\t\t\t\t\t\t\t//in deserialization mode (after a postback)\n\t\t\tt.cg.removeAttr(\"width\");\n\t\t\tif(t.opt.flush){ S[t.id] =\"\"; return;} \t//if flush is activated, stored data is removed\n\t\t\tw = S[t.id].split(\";\");\t\t\t\t\t//column widths is obtained\n\t\t\tfor(;i<t.ln;i++){\t\t\t\t\t\t//for each column\n\t\t\t\taux.push(100*w[i]/w[t.ln]+\"%\"); \t//width is stored in an array since it will be required again a couple of lines ahead\n\t\t\t\tth.eq(i).css(\"width\", aux[i] ); \t//each column width in % is resotred\n\t\t\t}\t\t\t\n\t\t\tfor(i=0;i<t.ln;i++)\n\t\t\t\tt.cg.eq(i).css(\"width\", aux[i]);\t//this code is required in order to create an inline CSS rule with higher precedence than an existing CSS class in the \"col\" elements\n\t\t}else{\t\t\t\t\t\t\t//in serialization mode (after resizing a column)\n\t\t\tS[t.id] =\"\";\t\t\t\t//clean up previous data\n\t\t\tfor(;i < t.c.length; i++){\t\t//iterate through columns\n\t\t\t\n\t\t\t\tw = t.c[i].width();\t\t//width is obtained\n\t\t\t\tS[t.id] += w+\";\";\t\t//width is appended to the sessionStorage object using ID as key\n\t\t\t\tm+=w;\t\t\t\t\t//carriage is updated to obtain the full size used by columns\n\t\t\t}\n\t\t\tS[t.id]+=m;\t\t\t\t\t//the last item of the serialized string is the table's active area (width), \n\t\t\t\t\t\t\t\t\t\t//to be able to obtain % width value of each columns while deserializing\n\t\t}\t\n\t};\n\t\n\t\n\t/**\n\t * Function that places each grip in the correct position according to the current table layout\t * \n\t * @param {jQuery ref} t - table object\n\t */\n\tvar syncGrips = function (t){\t\n\t\tt.gc.width(t.w);\t\t\t//the grip's container width is updated\t\t\t\t\n\t\tfor(var i=0; i<t.ln; i++){\t//for each column\n\t\t\tvar c = t.c[i]; \t\t\t\n\t\t\tt.g[i].css({\t\t\t//height and position of the grip is updated according to the table layout\n\t\t\t\tleft: c.offset().left - t.offset().left + c.outerWidth(false) + t.cs / 2 + PX,\n\t\t\t\theight: t.opt.headerOnly? t.c[0].outerHeight(false) : t.outerHeight(false)\t\t\t\t\n\t\t\t});\t\t\t\n\t\t} \t\n\t};\n\t\n\t\n\t\n\t/**\n\t* This function updates column's width according to the horizontal position increment of the grip being\n\t* dragged. The function can be called while dragging if liveDragging is enabled and also from the onGripDragOver\n\t* event handler to synchronize grip's position with their related columns.\n\t* @param {jQuery ref} t - table object\n\t* @param {nunmber} i - index of the grip being dragged\n\t* @param {bool} isOver - to identify when the function is being called from the onGripDragOver event\t\n\t*/\n\tvar syncCols = function(t,i,isOver){\n\t\tvar inc = drag.x-drag.l, c = t.c[i], c2 = t.c[i+1]; \t\t\t\n\t\tvar w = c.w + inc;\tvar w2= c2.w- inc;\t//their new width is obtained\t\t\t\t\t\n\t\tc.width( w + PX);\tc2.width(w2 + PX);\t//and set\t\n\t\tt.cg.eq(i).width( w + PX); t.cg.eq(i+1).width( w2 + PX);\n\t\tif(isOver){c.w=w; c2.w=w2;}\n\t};\n\n\t\n\t/**\n\t * Event handler used while dragging a grip. It checks if the next grip's position is valid and updates it. \n\t * @param {event} e - mousemove event binded to the window object\n\t */\n\tvar onGripDrag = function(e){\t\n\t\tif(!drag) return; var t = drag.t;\t\t//table object reference \n\t\t\n\t\tif (e.originalEvent.touches) {\n\t\t\tvar x = e.originalEvent.touches[0].pageX - drag.ox + drag.l;\t\t//next position according to horizontal mouse position increment\n\t\t} else {\n\t\t\tvar x = e.pageX - drag.ox + drag.l;\t\t//next position according to horizontal mouse position increment\n\t\t}\n\t\t\n\t\t\n\t\t\t\n\t\tvar mw = t.opt.minWidth, i = drag.i ;\t//cell's min width\n\t\tvar l = t.cs*1.5 + mw + t.b;\n\n\t\tvar max = i == t.ln-1? t.w-l: t.g[i+1].position().left-t.cs-mw; //max position according to the contiguous cells\n\t\tvar min = i? t.g[i-1].position().left+t.cs+mw: l;\t\t\t\t//min position according to the contiguous cells\n\t\t\n\t\tx = M.max(min, M.min(max, x));\t\t\t\t\t\t//apply boundings\t\t\n\t\tdrag.x = x;\t drag.css(\"left\", x + PX); \t\t\t//apply position increment\t\t\n\t\t\t\n\t\tif(t.opt.liveDrag){ \t\t\t\t\t\t\t\t//if liveDrag is enabled\n\t\t\tsyncCols(t,i); syncGrips(t);\t\t\t\t\t//columns and grips are synchronized\n\t\t\tvar cb = t.opt.onDrag;\t\t\t\t\t\t\t//check if there is an onDrag callback\n\t\t\tif (cb) { e.currentTarget = t[0]; cb(e); }\t\t//if any, it is fired\t\t\t\n\t\t}\n\t\t\n\t\treturn false; \t//prevent text selection\t\t\t\t\n\t};\n\t\n\n\t/**\n\t * Event handler fired when the dragging is over, updating table layout\n\t */\n\tvar onGripDragOver = function(e){\t\n\t\t\n\t\td.unbind('touchend.'+SIGNATURE+' mouseup.'+SIGNATURE).unbind('touchmove.'+SIGNATURE+' mousemove.'+SIGNATURE);\n\t\t$(\"head :last-child\").remove(); \t\t\t\t//remove the dragging cursor style\t\n\t\tif(!drag) return;\n\t\tdrag.removeClass(drag.t.opt.draggingClass);\t\t//remove the grip's dragging css-class\n\t\tvar t = drag.t;\n\t\tvar cb = t.opt.onResize; \t\t\t//get some values\t\n\t\tif(drag.x){ \t\t\t\t\t\t\t\t\t//only if the column width has been changed\n\t\t\tsyncCols(t,drag.i, true);\tsyncGrips(t);\t//the columns and grips are updated\n\t\t\tif (cb) { e.currentTarget = t[0]; cb(e); }\t//if there is a callback function, it is fired\n\t\t}\n\t\tif(t.p && S) memento(t); \t\t\t\t\t\t//if postbackSafe is enabled and there is sessionStorage support, the new layout is serialized and stored\n\t\tdrag = null;\t\t\t\t\t\t\t\t\t//since the grip's dragging is over\t\t\t\t\t\t\t\t\t\n\t};\t\n\t\n\n\t/**\n\t * Event handler fired when the grip's dragging is about to start. Its main goal is to set up events \n\t * and store some values used while dragging.\n\t * @param {event} e - grip's mousedown event\n\t */\n\tvar onGripMouseDown = function(e){\n\t\tvar o = $(this).data(SIGNATURE);\t\t\t//retrieve grip's data\n\t\tvar t = tables[o.t], g = t.g[o.i];\t\t\t//shortcuts for the table and grip objects\n\t\tif (e.originalEvent.touches) {\n\t\t\tg.ox = e.originalEvent.touches[0].pageX;\n\t\t} else {\n\t\t\tg.ox = e.pageX;\t//the initial position is kept\n\t\t}\n\t\tg.l = g.position().left;\n\t\td.bind('touchmove.'+SIGNATURE+' mousemove.'+SIGNATURE, onGripDrag).bind('touchend.'+SIGNATURE+' mouseup.'+SIGNATURE,onGripDragOver);\t//mousemove and mouseup events are bound\n\t\th.append(\"<style type='text/css'>*{cursor:\"+ t.opt.dragCursor +\"!important}</style>\"); \t//change the mouse cursor\n\t\tg.addClass(t.opt.draggingClass); \t//add the dragging class (to allow some visual feedback)\t\t\t\t\n\t\tdrag = g;\t\t\t\t\t\t\t//the current grip is stored as the current dragging object\n\t\tif(t.c[o.i].l) for(var i=0,c; i<t.ln; i++){ c=t.c[i]; c.l = false; c.w= c.width(); } \t//if the colum is locked (after browser resize), then c.w must be updated\t\t\n\t\treturn false; \t//prevent text selection\n\t};\n\t\n\t/**\n\t * Event handler fired when the browser is resized. The main purpose of this function is to update\n\t * table layout according to the browser's size synchronizing related grips \n\t */\n\tvar onResize = function(){\n\t\tfor(t in tables){\t\t\n\t\t\tvar t = tables[t], i, mw=0;\t\t\t\t\n\t\t\tt.removeClass(SIGNATURE);\t\t\t\t\t\t//firefox doesnt like layout-fixed in some cases\n\t\t\tif (t.w != t.width()) {\t\t\t\t\t\t\t//if the the table's width has changed\n\t\t\t\tt.w = t.width();\t\t\t\t\t\t\t//its new value is kept\n\t\t\t\tfor(i=0; i<t.ln; i++) mw+= t.c[i].w;\t\t//the active cells area is obtained\n\t\t\t\t//cell rendering is not as trivial as it might seem, and it is slightly different for\n\t\t\t\t//each browser. In the begining i had a big switch for each browser, but since the code\n\t\t\t\t//was extremelly ugly now I use a different approach with several reflows. This works \n\t\t\t\t//pretty well but it's a bit slower. For now, lets keep things simple... \n\t\t\t\tfor(i=0; i<t.ln; i++) t.c[i].css(\"width\", M.round(1000*t.c[i].w/mw)/10 + \"%\").l=true; \n\t\t\t\t//c.l locks the column, telling us that its c.w is outdated\t\t\t\t\t\t\t\t\t\n\t\t\t}\n\t\t\tsyncGrips(t.addClass(SIGNATURE));\n\t\t}\n\t};\t\t\n\n\n\t//bind resize event, to update grips position \n\t$(window).bind('resize.'+SIGNATURE, onResize); \n\n\n\t/**\n\t * The plugin is added to the jQuery library\n\t * @param {Object} options - an object containg some basic customization values \n\t */\n $.fn.extend({ \n colResizable: function(options) { \n var defaults = {\n\t\t\t\n\t\t\t\t//attributes:\n draggingClass: 'JCLRgripDrag',\t//css-class used when a grip is being dragged (for visual feedback purposes)\n\t\t\t\tgripInnerHtml: '',\t\t\t\t//if it is required to use a custom grip it can be done using some custom HTML\t\t\t\t\n\t\t\t\tliveDrag: false,\t\t\t\t//enables table-layout updaing while dragging\t\t\t\n\t\t\t\tminWidth: 15, \t\t\t\t\t//minimum width value in pixels allowed for a column \n\t\t\t\theaderOnly: false,\t\t\t\t//specifies that the size of the the column resizing anchors will be bounded to the size of the first row \n\t\t\t\thoverCursor: \"e-resize\", \t\t//cursor to be used on grip hover\n\t\t\t\tdragCursor: \"e-resize\", \t\t//cursor to be used while dragging\n\t\t\t\tpostbackSafe: false, \t\t\t//when it is enabled, table layout can persist after postback. It requires browsers with sessionStorage support (it can be emulated with sessionStorage.js). Some browsers ony \n\t\t\t\tflush: false, \t\t\t\t\t//when postbakSafe is enabled, and it is required to prevent layout restoration after postback, 'flush' will remove its associated layout data \n\t\t\t\tmarginLeft: null,\t\t\t\t//in case the table contains any margins, colResizable needs to know the values used, e.g. \"10%\", \"15em\", \"5px\" ...\n\t\t\t\tmarginRight: null, \t\t\t\t//in case the table contains any margins, colResizable needs to know the values used, e.g. \"10%\", \"15em\", \"5px\" ...\n\t\t\t\tdisable: false,\t\t\t\t\t//disables all the enhancements performed in a previously colResized table\t\n\t\t\t\t\n\t\t\t\t//events:\n\t\t\t\tonDrag: null, \t\t\t\t\t//callback function to be fired during the column resizing process if liveDrag is enabled\n\t\t\t\tonResize: null\t\t\t\t\t//callback function fired when the dragging process is over\n }\t\t\t\n\t\t\tvar options = $.extend(defaults, options);\t\t\t\n return this.each(function() {\t\t\t\t\n \tinit( this, options); \n });\n }\n });\n\n","(function(f){if(typeof exports===\"object\"&&typeof module!==\"undefined\"){module.exports=f()}else if(typeof define===\"function\"&&define.amd){define([],f)}else{var g;if(typeof window!==\"undefined\"){g=window}else if(typeof global!==\"undefined\"){g=global}else if(typeof self!==\"undefined\"){g=self}else{g=this}g.YASR = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){\n/**\n _ _____ _ _ _ \n | | __ \\ (_) | | | | \n ___ ___ | | |__) |___ ___ _ ______ _| |__ | | ___ \n / __/ _ \\| | _ // _ \\/ __| |_ / _` | '_ \\| |/ _ \\\n | (_| (_) | | | \\ \\ __/\\__ \\ |/ / (_| | |_) | | __/\n \\___\\___/|_|_| \\_\\___||___/_/___\\__,_|_.__/|_|\\___|\n\t \n\tv 1.4 - a jQuery plugin by Alvaro Prieto Lauroba\n\t\n\tLicences: MIT & GPL\n\tFeel free to use or modify this plugin as far as my full name is kept\t\n\t\n\tIf you are going to use this plugin in production environments it is \n\tstrongly recomended to use its minified version: colResizable.min.js\n\n*/\n\nvar $ = require('jquery');\t\n\tvar d = $(document); \t\t//window object\n\tvar h = $(\"head\");\t\t\t//head object\n\tvar drag = null;\t\t\t//reference to the current grip that is being dragged\n\tvar tables = [];\t\t\t//array of the already processed tables (table.id as key)\n\tvar\tcount = 0;\t\t\t\t//internal count to create unique IDs when needed.\t\n\t\n\t//common strings for minification\t(in the minified version there are plenty more)\n\tvar ID = \"id\";\t\n\tvar PX = \"px\";\n\tvar SIGNATURE =\"JColResizer\";\n\t\n\t//shortcuts\n\tvar I = parseInt;\n\tvar M = Math;\n\tvar ie = navigator.userAgent.indexOf('Trident/4.0')>0;\n\tvar S;\n\ttry{S = sessionStorage;}catch(e){}\t//Firefox crashes when executed as local file system\n\t\n\t//append required CSS rules \n\th.append(\"<style type='text/css'> .JColResizer{table-layout:fixed;} .JColResizer td, .JColResizer th{overflow:hidden;padding-left:0!important; padding-right:0!important;} .JCLRgrips{ height:0px; position:relative;} .JCLRgrip{margin-left:-5px; position:absolute; z-index:5; } .JCLRgrip .JColResizer{position:absolute;background-color:red;filter:alpha(opacity=1);opacity:0;width:10px;height:100%;top:0px} .JCLRLastGrip{position:absolute; width:1px; } .JCLRgripDrag{ border-left:1px dotted black;\t}</style>\");\n\n\t\n\t/**\n\t * Function to allow column resizing for table objects. It is the starting point to apply the plugin.\n\t * @param {DOM node} tb - refrence to the DOM table object to be enhanced\n\t * @param {Object} options\t- some customization values\n\t */\n\tvar init = function( tb, options){\t\n\t\tvar t = $(tb);\t\t\t\t\t\t\t\t\t\t//the table object is wrapped\n\t\tif(options.disable) return destroy(t);\t\t\t\t//the user is asking to destroy a previously colResized table\n\t\tvar\tid = t.id = t.attr(ID) || SIGNATURE+count++;\t//its id is obtained, if null new one is generated\t\t\n\t\tt.p = options.postbackSafe; \t\t\t\t\t\t//shortcut to detect postback safe \t\t\n\t\tif(!t.is(\"table\") || tables[id]) return; \t\t\t//if the object is not a table or if it was already processed then it is ignored.\n\t\tt.addClass(SIGNATURE).attr(ID, id).before('<div class=\"JCLRgrips\"/>');\t//the grips container object is added. Signature class forces table rendering in fixed-layout mode to prevent column's min-width\n\t\tt.opt = options; t.g = []; t.c = []; t.w = t.width(); t.gc = t.prev();\t//t.c and t.g are arrays of columns and grips respectively\t\t\t\t\n\t\tif(options.marginLeft) t.gc.css(\"marginLeft\", options.marginLeft); \t//if the table contains margins, it must be specified\n\t\tif(options.marginRight) t.gc.css(\"marginRight\", options.marginRight); \t//since there is no (direct) way to obtain margin values in its original units (%, em, ...)\n\t\tt.cs = I(ie? tb.cellSpacing || tb.currentStyle.borderSpacing :t.css('border-spacing'))||2;\t//table cellspacing (not even jQuery is fully cross-browser)\n\t\tt.b = I(ie? tb.border || tb.currentStyle.borderLeftWidth :t.css('border-left-width'))||1;\t//outer border width (again cross-browser isues)\n\t\t// if(!(tb.style.width || tb.width)) t.width(t.width()); //I am not an IE fan at all, but it is a pitty that only IE has the currentStyle attribute working as expected. For this reason I can not check easily if the table has an explicit width or if it is rendered as \"auto\"\n\t\ttables[id] = t; \t//the table object is stored using its id as key\t\n\t\tcreateGrips(t);\t\t//grips are created\n\t\n\t};\n\n\n\t/**\n\t * This function allows to remove any enhancements performed by this plugin on a previously processed table.\n\t * @param {jQuery ref} t - table object\n\t */\n\tvar destroy = function(t){\n\t\tvar id=t.attr(ID), t=tables[id];\t\t//its table object is found\n\t\tif(!t||!t.is(\"table\")) return;\t\t\t//if none, then it wasnt processed\t \n\t\tt.removeClass(SIGNATURE).gc.remove();\t//class and grips are removed\n\t\tdelete tables[id];\t\t\t\t\t\t//clean up data\n\t};\n\n\n\t/**\n\t * Function to create all the grips associated with the table given by parameters \n\t * @param {jQuery ref} t - table object\n\t */\n\tvar createGrips = function(t){\t\n\t\n\t\tvar th = t.find(\">thead>tr>th,>thead>tr>td\");\t//if table headers are specified in its semantically correct tag, are obtained\n\t\tif(!th.length) th = t.find(\">tbody>tr:first>th,>tr:first>th,>tbody>tr:first>td, >tr:first>td\");\t //but headers can also be included in different ways\n\t\tt.cg = t.find(\"col\"); \t\t\t\t\t\t//a table can also contain a colgroup with col elements\t\t\n\t\tt.ln = th.length;\t\t\t\t\t\t\t//table length is stored\t\n\t\tif(t.p && S && S[t.id])memento(t,th);\t\t//if 'postbackSafe' is enabled and there is data for the current table, its coloumn layout is restored\n\t\tth.each(function(i){\t\t\t\t\t\t//iterate through the table column headers\t\t\t\n\t\t\tvar c = $(this); \t\t\t\t\t\t//jquery wrap for the current column\t\t\t\n\t\t\tvar g = $(t.gc.append('<div class=\"JCLRgrip\"></div>')[0].lastChild); //add the visual node to be used as grip\n\t\t\tg.t = t; g.i = i; g.c = c;\tc.w =c.width();\t\t//some values are stored in the grip's node data\n\t\t\tt.g.push(g); t.c.push(c);\t\t\t\t\t\t//the current grip and column are added to its table object\n\t\t\tc.width(c.w).removeAttr(\"width\");\t\t\t\t//the width of the column is converted into pixel-based measurements\n\t\t\tif (i < t.ln-1) {\n\t\t\t\tg.bind('touchstart mousedown', onGripMouseDown).append(t.opt.gripInnerHtml).append('<div class=\"'+SIGNATURE+'\" style=\"cursor:'+t.opt.hoverCursor+'\"></div>'); //bind the mousedown event to start dragging \n\t\t\t} else g.addClass(\"JCLRLastGrip\").removeClass(\"JCLRgrip\");\t//the last grip is used only to store data\t\t\t\n\t\t\tg.data(SIGNATURE, {i:i, t:t.attr(ID)});\t\t\t\t\t\t//grip index and its table name are stored in the HTML \t\t\t\t\t\t\t\t\t\t\t\t\n\t\t}); \t\n\t\tt.cg.removeAttr(\"width\");\t//remove the width attribute from elements in the colgroup (in any)\n\t\tsyncGrips(t); \t\t\t\t//the grips are positioned according to the current table layout\t\t\t\n\t\t//there is a small problem, some cells in the table could contain dimension values interfering with the \n\t\t//width value set by this plugin. Those values are removed\n\t\tt.find('td, th').not(th).not('table th, table td').each(function(){ \n\t\t\t$(this).removeAttr('width');\t//the width attribute is removed from all table cells which are not nested in other tables and dont belong to the header\n\t\t});\t\t\n\n\t\t\n\t};\n\t\n\n\t/**\n\t * Function to allow the persistence of columns dimensions after a browser postback. It is based in\n\t * the HTML5 sessionStorage object, which can be emulated for older browsers using sessionstorage.js\n\t * @param {jQuery ref} t - table object\n\t * @param {jQuery ref} th - reference to the first row elements (only set in deserialization)\n\t */\n\tvar memento = function(t, th){ \n\t\tvar w,m=0,i=0,aux =[];\n\t\tif(th){\t\t\t\t\t\t\t\t\t\t//in deserialization mode (after a postback)\n\t\t\tt.cg.removeAttr(\"width\");\n\t\t\tif(t.opt.flush){ S[t.id] =\"\"; return;} \t//if flush is activated, stored data is removed\n\t\t\tw = S[t.id].split(\";\");\t\t\t\t\t//column widths is obtained\n\t\t\tfor(;i<t.ln;i++){\t\t\t\t\t\t//for each column\n\t\t\t\taux.push(100*w[i]/w[t.ln]+\"%\"); \t//width is stored in an array since it will be required again a couple of lines ahead\n\t\t\t\tth.eq(i).css(\"width\", aux[i] ); \t//each column width in % is resotred\n\t\t\t}\t\t\t\n\t\t\tfor(i=0;i<t.ln;i++)\n\t\t\t\tt.cg.eq(i).css(\"width\", aux[i]);\t//this code is required in order to create an inline CSS rule with higher precedence than an existing CSS class in the \"col\" elements\n\t\t}else{\t\t\t\t\t\t\t//in serialization mode (after resizing a column)\n\t\t\tS[t.id] =\"\";\t\t\t\t//clean up previous data\n\t\t\tfor(;i < t.c.length; i++){\t\t//iterate through columns\n\t\t\t\n\t\t\t\tw = t.c[i].width();\t\t//width is obtained\n\t\t\t\tS[t.id] += w+\";\";\t\t//width is appended to the sessionStorage object using ID as key\n\t\t\t\tm+=w;\t\t\t\t\t//carriage is updated to obtain the full size used by columns\n\t\t\t}\n\t\t\tS[t.id]+=m;\t\t\t\t\t//the last item of the serialized string is the table's active area (width), \n\t\t\t\t\t\t\t\t\t\t//to be able to obtain % width value of each columns while deserializing\n\t\t}\t\n\t};\n\t\n\t\n\t/**\n\t * Function that places each grip in the correct position according to the current table layout\t * \n\t * @param {jQuery ref} t - table object\n\t */\n\tvar syncGrips = function (t){\t\n\t\tt.gc.width(t.w);\t\t\t//the grip's container width is updated\t\t\t\t\n\t\tfor(var i=0; i<t.ln; i++){\t//for each column\n\t\t\tvar c = t.c[i]; \t\t\t\n\t\t\tt.g[i].css({\t\t\t//height and position of the grip is updated according to the table layout\n\t\t\t\tleft: c.offset().left - t.offset().left + c.outerWidth(false) + t.cs / 2 + PX,\n\t\t\t\theight: t.opt.headerOnly? t.c[0].outerHeight(false) : t.outerHeight(false)\t\t\t\t\n\t\t\t});\t\t\t\n\t\t} \t\n\t};\n\t\n\t\n\t\n\t/**\n\t* This function updates column's width according to the horizontal position increment of the grip being\n\t* dragged. The function can be called while dragging if liveDragging is enabled and also from the onGripDragOver\n\t* event handler to synchronize grip's position with their related columns.\n\t* @param {jQuery ref} t - table object\n\t* @param {nunmber} i - index of the grip being dragged\n\t* @param {bool} isOver - to identify when the function is being called from the onGripDragOver event\t\n\t*/\n\tvar syncCols = function(t,i,isOver){\n\t\tvar inc = drag.x-drag.l, c = t.c[i], c2 = t.c[i+1]; \t\t\t\n\t\tvar w = c.w + inc;\tvar w2= c2.w- inc;\t//their new width is obtained\t\t\t\t\t\n\t\tc.width( w + PX);\tc2.width(w2 + PX);\t//and set\t\n\t\tt.cg.eq(i).width( w + PX); t.cg.eq(i+1).width( w2 + PX);\n\t\tif(isOver){c.w=w; c2.w=w2;}\n\t};\n\n\t\n\t/**\n\t * Event handler used while dragging a grip. It checks if the next grip's position is valid and updates it. \n\t * @param {event} e - mousemove event binded to the window object\n\t */\n\tvar onGripDrag = function(e){\t\n\t\tif(!drag) return; var t = drag.t;\t\t//table object reference \n\t\t\n\t\tif (e.originalEvent.touches) {\n\t\t\tvar x = e.originalEvent.touches[0].pageX - drag.ox + drag.l;\t\t//next position according to horizontal mouse position increment\n\t\t} else {\n\t\t\tvar x = e.pageX - drag.ox + drag.l;\t\t//next position according to horizontal mouse position increment\n\t\t}\n\t\t\n\t\t\n\t\t\t\n\t\tvar mw = t.opt.minWidth, i = drag.i ;\t//cell's min width\n\t\tvar l = t.cs*1.5 + mw + t.b;\n\n\t\tvar max = i == t.ln-1? t.w-l: t.g[i+1].position().left-t.cs-mw; //max position according to the contiguous cells\n\t\tvar min = i? t.g[i-1].position().left+t.cs+mw: l;\t\t\t\t//min position according to the contiguous cells\n\t\t\n\t\tx = M.max(min, M.min(max, x));\t\t\t\t\t\t//apply boundings\t\t\n\t\tdrag.x = x;\t drag.css(\"left\", x + PX); \t\t\t//apply position increment\t\t\n\t\t\t\n\t\tif(t.opt.liveDrag){ \t\t\t\t\t\t\t\t//if liveDrag is enabled\n\t\t\tsyncCols(t,i); syncGrips(t);\t\t\t\t\t//columns and grips are synchronized\n\t\t\tvar cb = t.opt.onDrag;\t\t\t\t\t\t\t//check if there is an onDrag callback\n\t\t\tif (cb) { e.currentTarget = t[0]; cb(e); }\t\t//if any, it is fired\t\t\t\n\t\t}\n\t\t\n\t\treturn false; \t//prevent text selection\t\t\t\t\n\t};\n\t\n\n\t/**\n\t * Event handler fired when the dragging is over, updating table layout\n\t */\n\tvar onGripDragOver = function(e){\t\n\t\t\n\t\td.unbind('touchend.'+SIGNATURE+' mouseup.'+SIGNATURE).unbind('touchmove.'+SIGNATURE+' mousemove.'+SIGNATURE);\n\t\t$(\"head :last-child\").remove(); \t\t\t\t//remove the dragging cursor style\t\n\t\tif(!drag) return;\n\t\tdrag.removeClass(drag.t.opt.draggingClass);\t\t//remove the grip's dragging css-class\n\t\tvar t = drag.t;\n\t\tvar cb = t.opt.onResize; \t\t\t//get some values\t\n\t\tif(drag.x){ \t\t\t\t\t\t\t\t\t//only if the column width has been changed\n\t\t\tsyncCols(t,drag.i, true);\tsyncGrips(t);\t//the columns and grips are updated\n\t\t\tif (cb) { e.currentTarget = t[0]; cb(e); }\t//if there is a callback function, it is fired\n\t\t}\n\t\tif(t.p && S) memento(t); \t\t\t\t\t\t//if postbackSafe is enabled and there is sessionStorage support, the new layout is serialized and stored\n\t\tdrag = null;\t\t\t\t\t\t\t\t\t//since the grip's dragging is over\t\t\t\t\t\t\t\t\t\n\t};\t\n\t\n\n\t/**\n\t * Event handler fired when the grip's dragging is about to start. Its main goal is to set up events \n\t * and store some values used while dragging.\n\t * @param {event} e - grip's mousedown event\n\t */\n\tvar onGripMouseDown = function(e){\n\t\tvar o = $(this).data(SIGNATURE);\t\t\t//retrieve grip's data\n\t\tvar t = tables[o.t], g = t.g[o.i];\t\t\t//shortcuts for the table and grip objects\n\t\tif (e.originalEvent.touches) {\n\t\t\tg.ox = e.originalEvent.touches[0].pageX;\n\t\t} else {\n\t\t\tg.ox = e.pageX;\t//the initial position is kept\n\t\t}\n\t\tg.l = g.position().left;\n\t\td.bind('touchmove.'+SIGNATURE+' mousemove.'+SIGNATURE, onGripDrag).bind('touchend.'+SIGNATURE+' mouseup.'+SIGNATURE,onGripDragOver);\t//mousemove and mouseup events are bound\n\t\th.append(\"<style type='text/css'>*{cursor:\"+ t.opt.dragCursor +\"!important}</style>\"); \t//change the mouse cursor\n\t\tg.addClass(t.opt.draggingClass); \t//add the dragging class (to allow some visual feedback)\t\t\t\t\n\t\tdrag = g;\t\t\t\t\t\t\t//the current grip is stored as the current dragging object\n\t\tif(t.c[o.i].l) for(var i=0,c; i<t.ln; i++){ c=t.c[i]; c.l = false; c.w= c.width(); } \t//if the colum is locked (after browser resize), then c.w must be updated\t\t\n\t\treturn false; \t//prevent text selection\n\t};\n\t\n\t/**\n\t * Event handler fired when the browser is resized. The main purpose of this function is to update\n\t * table layout according to the browser's size synchronizing related grips \n\t */\n\tvar onResize = function(){\n\t\tfor(t in tables){\t\t\n\t\t\tvar t = tables[t], i, mw=0;\t\t\t\t\n\t\t\tt.removeClass(SIGNATURE);\t\t\t\t\t\t//firefox doesnt like layout-fixed in some cases\n\t\t\tif (t.w != t.width()) {\t\t\t\t\t\t\t//if the the table's width has changed\n\t\t\t\tt.w = t.width();\t\t\t\t\t\t\t//its new value is kept\n\t\t\t\tfor(i=0; i<t.ln; i++) mw+= t.c[i].w;\t\t//the active cells area is obtained\n\t\t\t\t//cell rendering is not as trivial as it might seem, and it is slightly different for\n\t\t\t\t//each browser. In the begining i had a big switch for each browser, but since the code\n\t\t\t\t//was extremelly ugly now I use a different approach with several reflows. This works \n\t\t\t\t//pretty well but it's a bit slower. For now, lets keep things simple... \n\t\t\t\tfor(i=0; i<t.ln; i++) t.c[i].css(\"width\", M.round(1000*t.c[i].w/mw)/10 + \"%\").l=true; \n\t\t\t\t//c.l locks the column, telling us that its c.w is outdated\t\t\t\t\t\t\t\t\t\n\t\t\t}\n\t\t\tsyncGrips(t.addClass(SIGNATURE));\n\t\t}\n\t};\t\t\n\n\n\t//bind resize event, to update grips position \n\t$(window).bind('resize.'+SIGNATURE, onResize); \n\n\n\t/**\n\t * The plugin is added to the jQuery library\n\t * @param {Object} options - an object containg some basic customization values \n\t */\n $.fn.extend({ \n colResizable: function(options) { \n var defaults = {\n\t\t\t\n\t\t\t\t//attributes:\n draggingClass: 'JCLRgripDrag',\t//css-class used when a grip is being dragged (for visual feedback purposes)\n\t\t\t\tgripInnerHtml: '',\t\t\t\t//if it is required to use a custom grip it can be done using some custom HTML\t\t\t\t\n\t\t\t\tliveDrag: false,\t\t\t\t//enables table-layout updaing while dragging\t\t\t\n\t\t\t\tminWidth: 15, \t\t\t\t\t//minimum width value in pixels allowed for a column \n\t\t\t\theaderOnly: false,\t\t\t\t//specifies that the size of the the column resizing anchors will be bounded to the size of the first row \n\t\t\t\thoverCursor: \"e-resize\", \t\t//cursor to be used on grip hover\n\t\t\t\tdragCursor: \"e-resize\", \t\t//cursor to be used while dragging\n\t\t\t\tpostbackSafe: false, \t\t\t//when it is enabled, table layout can persist after postback. It requires browsers with sessionStorage support (it can be emulated with sessionStorage.js). Some browsers ony \n\t\t\t\tflush: false, \t\t\t\t\t//when postbakSafe is enabled, and it is required to prevent layout restoration after postback, 'flush' will remove its associated layout data \n\t\t\t\tmarginLeft: null,\t\t\t\t//in case the table contains any margins, colResizable needs to know the values used, e.g. \"10%\", \"15em\", \"5px\" ...\n\t\t\t\tmarginRight: null, \t\t\t\t//in case the table contains any margins, colResizable needs to know the values used, e.g. \"10%\", \"15em\", \"5px\" ...\n\t\t\t\tdisable: false,\t\t\t\t\t//disables all the enhancements performed in a previously colResized table\t\n\t\t\t\t\n\t\t\t\t//events:\n\t\t\t\tonDrag: null, \t\t\t\t\t//callback function to be fired during the column resizing process if liveDrag is enabled\n\t\t\t\tonResize: null\t\t\t\t\t//callback function fired when the dragging process is over\n }\t\t\t\n\t\t\tvar options = $.extend(defaults, options);\t\t\t\n return this.each(function() {\t\t\t\t\n \tinit( this, options); \n });\n }\n });\n\n\n},{\"jquery\":18}],2:[function(require,module,exports){\n/**\n * jQuery-csv (jQuery Plugin)\n * version: 0.71 (2012-11-19)\n *\n * This document is licensed as free software under the terms of the\n * MIT License: http://www.opensource.org/licenses/mit-license.php\n *\n * Acknowledgements:\n * The original design and influence to implement this library as a jquery\n * plugin is influenced by jquery-json (http://code.google.com/p/jquery-json/).\n * If you're looking to use native JSON.Stringify but want additional backwards\n * compatibility for browsers that don't support it, I highly recommend you\n * check it out.\n *\n * A special thanks goes out to rwk@acm.org for providing a lot of valuable\n * feedback to the project including the core for the new FSM\n * (Finite State Machine) parsers. If you're looking for a stable TSV parser\n * be sure to take a look at jquery-tsv (http://code.google.com/p/jquery-tsv/).\n\n * For legal purposes I'll include the \"NO WARRANTY EXPRESSED OR IMPLIED.\n * USE AT YOUR OWN RISK.\". Which, in 'layman's terms' means, by using this\n * library you are accepting responsibility if it breaks your code.\n *\n * Legal jargon aside, I will do my best to provide a useful and stable core\n * that can effectively be built on.\n *\n * Copyrighted 2012 by Evan Plaice.\n */\n\nRegExp.escape= function(s) {\n return s.replace(/[-\\/\\\\^$*+?.()|[\\]{}]/g, '\\\\$&');\n};\n\n 'use strict'\n var $ = require('jquery');\n /**\n * jQuery.csv.defaults\n * Encapsulates the method paramater defaults for the CSV plugin module.\n */\n\n $.csv = {\n defaults: {\n separator:',',\n delimiter:'\"',\n headers:true\n },\n\n hooks: {\n castToScalar: function(value, state) {\n var hasDot = /\\./;\n if (isNaN(value)) {\n return value;\n } else {\n if (hasDot.test(value)) {\n return parseFloat(value);\n } else {\n var integer = parseInt(value);\n if(isNaN(integer)) {\n return null;\n } else {\n return integer;\n }\n }\n }\n }\n },\n\n parsers: {\n parse: function(csv, options) {\n // cache settings\n var separator = options.separator;\n var delimiter = options.delimiter;\n\n // set initial state if it's missing\n if(!options.state.rowNum) {\n options.state.rowNum = 1;\n }\n if(!options.state.colNum) {\n options.state.colNum = 1;\n }\n\n // clear initial state\n var data = [];\n var entry = [];\n var state = 0;\n var value = ''\n var exit = false;\n\n function endOfEntry() {\n // reset the state\n state = 0;\n value = '';\n\n // if 'start' hasn't been met, don't output\n if(options.start && options.state.rowNum < options.start) {\n // update global state\n entry = [];\n options.state.rowNum++;\n options.state.colNum = 1;\n return;\n }\n \n if(options.onParseEntry === undefined) {\n // onParseEntry hook not set\n data.push(entry);\n } else {\n var hookVal = options.onParseEntry(entry, options.state); // onParseEntry Hook\n // false skips the row, configurable through a hook\n if(hookVal !== false) {\n data.push(hookVal);\n }\n }\n //console.log('entry:' + entry);\n \n // cleanup\n entry = [];\n\n // if 'end' is met, stop parsing\n if(options.end && options.state.rowNum >= options.end) {\n exit = true;\n }\n \n // update global state\n options.state.rowNum++;\n options.state.colNum = 1;\n }\n\n function endOfValue() {\n if(options.onParseValue === undefined) {\n // onParseValue hook not set\n entry.push(value);\n } else {\n var hook = options.onParseValue(value, options.state); // onParseValue Hook\n // false skips the row, configurable through a hook\n if(hook !== false) {\n entry.push(hook);\n }\n }\n //console.log('value:' + value);\n // reset the state\n value = '';\n state = 0;\n // update global state\n options.state.colNum++;\n }\n\n // escape regex-specific control chars\n var escSeparator = RegExp.escape(separator);\n var escDelimiter = RegExp.escape(delimiter);\n\n // compile the regEx str using the custom delimiter/separator\n var match = /(D|S|\\n|\\r|[^DS\\r\\n]+)/;\n var matchSrc = match.source;\n matchSrc = matchSrc.replace(/S/g, escSeparator);\n matchSrc = matchSrc.replace(/D/g, escDelimiter);\n match = RegExp(matchSrc, 'gm');\n\n // put on your fancy pants...\n // process control chars individually, use look-ahead on non-control chars\n csv.replace(match, function (m0) {\n if(exit) {\n return;\n }\n switch (state) {\n // the start of a value\n case 0:\n // null last value\n if (m0 === separator) {\n value += '';\n endOfValue();\n break;\n }\n // opening delimiter\n if (m0 === delimiter) {\n state = 1;\n break;\n }\n // null last value\n if (m0 === '\\n') {\n endOfValue();\n endOfEntry();\n break;\n }\n // phantom carriage return\n if (/^\\r$/.test(m0)) {\n break;\n }\n // un-delimited value\n value += m0;\n state = 3;\n break;\n\n // delimited input\n case 1:\n // second delimiter? check further\n if (m0 === delimiter) {\n state = 2;\n break;\n }\n // delimited data\n value += m0;\n state = 1;\n break;\n\n // delimiter found in delimited input\n case 2:\n // escaped delimiter?\n if (m0 === delimiter) {\n value += m0;\n state = 1;\n break;\n }\n // null value\n if (m0 === separator) {\n endOfValue();\n break;\n }\n // end of entry\n if (m0 === '\\n') {\n endOfValue();\n endOfEntry();\n break;\n }\n // phantom carriage return\n if (/^\\r$/.test(m0)) {\n break;\n }\n // broken paser?\n throw new Error('CSVDataError: Illegal State [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n\n // un-delimited input\n case 3:\n // null last value\n if (m0 === separator) {\n endOfValue();\n break;\n }\n // end of entry\n if (m0 === '\\n') {\n endOfValue();\n endOfEntry();\n break;\n }\n // phantom carriage return\n if (/^\\r$/.test(m0)) {\n break;\n }\n if (m0 === delimiter) {\n // non-compliant data\n throw new Error('CSVDataError: Illegal Quote [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n }\n // broken parser?\n throw new Error('CSVDataError: Illegal Data [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n default:\n // shenanigans\n throw new Error('CSVDataError: Unknown State [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n }\n //console.log('val:' + m0 + ' state:' + state);\n });\n\n // submit the last entry\n // ignore null last line\n if(entry.length !== 0) {\n endOfValue();\n endOfEntry();\n }\n\n return data;\n },\n\n // a csv-specific line splitter\n splitLines: function(csv, options) {\n // cache settings\n var separator = options.separator;\n var delimiter = options.delimiter;\n\n // set initial state if it's missing\n if(!options.state.rowNum) {\n options.state.rowNum = 1;\n }\n\n // clear initial state\n var entries = [];\n var state = 0;\n var entry = '';\n var exit = false;\n\n function endOfLine() { \n // reset the state\n state = 0;\n \n // if 'start' hasn't been met, don't output\n if(options.start && options.state.rowNum < options.start) {\n // update global state\n entry = '';\n options.state.rowNum++;\n return;\n }\n \n if(options.onParseEntry === undefined) {\n // onParseEntry hook not set\n entries.push(entry);\n } else {\n var hookVal = options.onParseEntry(entry, options.state); // onParseEntry Hook\n // false skips the row, configurable through a hook\n if(hookVal !== false) {\n entries.push(hookVal);\n }\n }\n\n // cleanup\n entry = '';\n\n // if 'end' is met, stop parsing\n if(options.end && options.state.rowNum >= options.end) {\n exit = true;\n }\n \n // update global state\n options.state.rowNum++;\n }\n\n // escape regex-specific control chars\n var escSeparator = RegExp.escape(separator);\n var escDelimiter = RegExp.escape(delimiter);\n\n // compile the regEx str using the custom delimiter/separator\n var match = /(D|S|\\n|\\r|[^DS\\r\\n]+)/;\n var matchSrc = match.source;\n matchSrc = matchSrc.replace(/S/g, escSeparator);\n matchSrc = matchSrc.replace(/D/g, escDelimiter);\n match = RegExp(matchSrc, 'gm');\n \n // put on your fancy pants...\n // process control chars individually, use look-ahead on non-control chars\n csv.replace(match, function (m0) {\n if(exit) {\n return;\n }\n switch (state) {\n // the start of a value/entry\n case 0:\n // null value\n if (m0 === separator) {\n entry += m0;\n state = 0;\n break;\n }\n // opening delimiter\n if (m0 === delimiter) {\n entry += m0;\n state = 1;\n break;\n }\n // end of line\n if (m0 === '\\n') {\n endOfLine();\n break;\n }\n // phantom carriage return\n if (/^\\r$/.test(m0)) {\n break;\n }\n // un-delimit value\n entry += m0;\n state = 3;\n break;\n\n // delimited input\n case 1:\n // second delimiter? check further\n if (m0 === delimiter) {\n entry += m0;\n state = 2;\n break;\n }\n // delimited data\n entry += m0;\n state = 1;\n break;\n\n // delimiter found in delimited input\n case 2:\n // escaped delimiter?\n var prevChar = entry.substr(entry.length - 1);\n if (m0 === delimiter && prevChar === delimiter) {\n entry += m0;\n state = 1;\n break;\n }\n // end of value\n if (m0 === separator) {\n entry += m0;\n state = 0;\n break;\n }\n // end of line\n if (m0 === '\\n') {\n endOfLine();\n break;\n }\n // phantom carriage return\n if (m0 === '\\r') {\n break;\n }\n // broken paser?\n throw new Error('CSVDataError: Illegal state [Row:' + options.state.rowNum + ']');\n\n // un-delimited input\n case 3:\n // null value\n if (m0 === separator) {\n entry += m0;\n state = 0;\n break;\n }\n // end of line\n if (m0 === '\\n') {\n endOfLine();\n break;\n }\n // phantom carriage return\n if (m0 === '\\r') {\n break;\n }\n // non-compliant data\n if (m0 === delimiter) {\n throw new Error('CSVDataError: Illegal quote [Row:' + options.state.rowNum + ']');\n }\n // broken parser?\n throw new Error('CSVDataError: Illegal state [Row:' + options.state.rowNum + ']');\n default:\n // shenanigans\n throw new Error('CSVDataError: Unknown state [Row:' + options.state.rowNum + ']');\n }\n //console.log('val:' + m0 + ' state:' + state);\n });\n\n // submit the last entry\n // ignore null last line\n if(entry !== '') {\n endOfLine();\n }\n\n return entries;\n },\n\n // a csv entry parser\n parseEntry: function(csv, options) {\n // cache settings\n var separator = options.separator;\n var delimiter = options.delimiter;\n \n // set initial state if it's missing\n if(!options.state.rowNum) {\n options.state.rowNum = 1;\n }\n if(!options.state.colNum) {\n options.state.colNum = 1;\n }\n\n // clear initial state\n var entry = [];\n var state = 0;\n var value = '';\n\n function endOfValue() {\n if(options.onParseValue === undefined) {\n // onParseValue hook not set\n entry.push(value);\n } else {\n var hook = options.onParseValue(value, options.state); // onParseValue Hook\n // false skips the value, configurable through a hook\n if(hook !== false) {\n entry.push(hook);\n }\n }\n // reset the state\n value = '';\n state = 0;\n // update global state\n options.state.colNum++;\n }\n\n // checked for a cached regEx first\n if(!options.match) {\n // escape regex-specific control chars\n var escSeparator = RegExp.escape(separator);\n var escDelimiter = RegExp.escape(delimiter);\n \n // compile the regEx str using the custom delimiter/separator\n var match = /(D|S|\\n|\\r|[^DS\\r\\n]+)/;\n var matchSrc = match.source;\n matchSrc = matchSrc.replace(/S/g, escSeparator);\n matchSrc = matchSrc.replace(/D/g, escDelimiter);\n options.match = RegExp(matchSrc, 'gm');\n }\n\n // put on your fancy pants...\n // process control chars individually, use look-ahead on non-control chars\n csv.replace(options.match, function (m0) {\n switch (state) {\n // the start of a value\n case 0:\n // null last value\n if (m0 === separator) {\n value += '';\n endOfValue();\n break;\n }\n // opening delimiter\n if (m0 === delimiter) {\n state = 1;\n break;\n }\n // skip un-delimited new-lines\n if (m0 === '\\n' || m0 === '\\r') {\n break;\n }\n // un-delimited value\n value += m0;\n state = 3;\n break;\n\n // delimited input\n case 1:\n // second delimiter? check further\n if (m0 === delimiter) {\n state = 2;\n break;\n }\n // delimited data\n value += m0;\n state = 1;\n break;\n\n // delimiter found in delimited input\n case 2:\n // escaped delimiter?\n if (m0 === delimiter) {\n value += m0;\n state = 1;\n break;\n }\n // null value\n if (m0 === separator) {\n endOfValue();\n break;\n }\n // skip un-delimited new-lines\n if (m0 === '\\n' || m0 === '\\r') {\n break;\n }\n // broken paser?\n throw new Error('CSVDataError: Illegal State [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n\n // un-delimited input\n case 3:\n // null last value\n if (m0 === separator) {\n endOfValue();\n break;\n }\n // skip un-delimited new-lines\n if (m0 === '\\n' || m0 === '\\r') {\n break;\n }\n // non-compliant data\n if (m0 === delimiter) {\n throw new Error('CSVDataError: Illegal Quote [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n }\n // broken parser?\n throw new Error('CSVDataError: Illegal Data [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n default:\n // shenanigans\n throw new Error('CSVDataError: Unknown State [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n }\n //console.log('val:' + m0 + ' state:' + state);\n });\n\n // submit the last value\n endOfValue();\n\n return entry;\n }\n },\n\n /**\n * $.csv.toArray(csv)\n * Converts a CSV entry string to a javascript array.\n *\n * @param {Array} csv The string containing the CSV data.\n * @param {Object} [options] An object containing user-defined options.\n * @param {Character} [separator] An override for the separator character. Defaults to a comma(,).\n * @param {Character} [delimiter] An override for the delimiter character. Defaults to a double-quote(\").\n *\n * This method deals with simple CSV strings only. It's useful if you only\n * need to parse a single entry. If you need to parse more than one line,\n * use $.csv2Array instead.\n */\n toArray: function(csv, options, callback) {\n var options = (options !== undefined ? options : {});\n var config = {};\n config.callback = ((callback !== undefined && typeof(callback) === 'function') ? callback : false);\n config.separator = 'separator' in options ? options.separator : $.csv.defaults.separator;\n config.delimiter = 'delimiter' in options ? options.delimiter : $.csv.defaults.delimiter;\n var state = (options.state !== undefined ? options.state : {});\n\n // setup\n var options = {\n delimiter: config.delimiter,\n separator: config.separator,\n onParseEntry: options.onParseEntry,\n onParseValue: options.onParseValue,\n state: state\n }\n\n var entry = $.csv.parsers.parseEntry(csv, options);\n\n // push the value to a callback if one is defined\n if(!config.callback) {\n return entry;\n } else {\n config.callback('', entry);\n }\n },\n\n /**\n * $.csv.toArrays(csv)\n * Converts a CSV string to a javascript array.\n *\n * @param {String} csv The string containing the raw CSV data.\n * @param {Object} [options] An object containing user-defined options.\n * @param {Character} [separator] An override for the separator character. Defaults to a comma(,).\n * @param {Character} [delimiter] An override for the delimiter character. Defaults to a double-quote(\").\n *\n * This method deals with multi-line CSV. The breakdown is simple. The first\n * dimension of the array represents the line (or entry/row) while the second\n * dimension contains the values (or values/columns).\n */\n toArrays: function(csv, options, callback) {\n var options = (options !== undefined ? options : {});\n var config = {};\n config.callback = ((callback !== undefined && typeof(callback) === 'function') ? callback : false);\n config.separator = 'separator' in options ? options.separator : $.csv.defaults.separator;\n config.delimiter = 'delimiter' in options ? options.delimiter : $.csv.defaults.delimiter;\n \n // setup\n var data = [];\n var options = {\n delimiter: config.delimiter,\n separator: config.separator,\n onParseEntry: options.onParseEntry,\n onParseValue: options.onParseValue,\n start: options.start,\n end: options.end,\n state: {\n rowNum: 1,\n colNum: 1\n }\n };\n\n // break the data down to lines\n data = $.csv.parsers.parse(csv, options);\n\n // push the value to a callback if one is defined\n if(!config.callback) {\n return data;\n } else {\n config.callback('', data);\n }\n },\n\n /**\n * $.csv.toObjects(csv)\n * Converts a CSV string to a javascript object.\n * @param {String} csv The string containing the raw CSV data.\n * @param {Object} [options] An object containing user-defined options.\n * @param {Character} [separator] An override for the separator character. Defaults to a comma(,).\n * @param {Character} [delimiter] An override for the delimiter character. Defaults to a double-quote(\").\n * @param {Boolean} [headers] Indicates whether the data contains a header line. Defaults to true.\n *\n * This method deals with multi-line CSV strings. Where the headers line is\n * used as the key for each value per entry.\n */\n toObjects: function(csv, options, callback) {\n var options = (options !== undefined ? options : {});\n var config = {};\n config.callback = ((callback !== undefined && typeof(callback) === 'function') ? callback : false);\n config.separator = 'separator' in options ? options.separator : $.csv.defaults.separator;\n config.delimiter = 'delimiter' in options ? options.delimiter : $.csv.defaults.delimiter;\n config.headers = 'headers' in options ? options.headers : $.csv.defaults.headers;\n options.start = 'start' in options ? options.start : 1;\n \n // account for headers\n if(config.headers) {\n options.start++;\n }\n if(options.end && config.headers) {\n options.end++;\n }\n \n // setup\n var lines = [];\n var data = [];\n \n var options = {\n delimiter: config.delimiter,\n separator: config.separator,\n onParseEntry: options.onParseEntry,\n onParseValue: options.onParseValue,\n start: options.start,\n end: options.end,\n state: {\n rowNum: 1,\n colNum: 1\n },\n match: false\n };\n\n // fetch the headers\n var headerOptions = {\n delimiter: config.delimiter,\n separator: config.separator,\n start: 1,\n end: 1,\n state: {\n rowNum:1,\n colNum:1\n }\n }\n var headerLine = $.csv.parsers.splitLines(csv, headerOptions);\n var headers = $.csv.toArray(headerLine[0], options);\n\n // fetch the data\n var lines = $.csv.parsers.splitLines(csv, options);\n \n // reset the state for re-use\n options.state.colNum = 1;\n if(headers){\n options.state.rowNum = 2;\n } else {\n options.state.rowNum = 1;\n }\n \n // convert data to objects\n for(var i=0, len=lines.length; i<len; i++) {\n var entry = $.csv.toArray(lines[i], options);\n var object = {};\n for(var j in headers) {\n object[headers[j]] = entry[j];\n }\n data.push(object);\n \n // update row state\n options.state.rowNum++;\n }\n\n // push the value to a callback if one is defined\n if(!config.callback) {\n return data;\n } else {\n config.callback('', data);\n }\n },\n\n /**\n * $.csv.fromArrays(arrays)\n * Converts a javascript array to a CSV String.\n *\n * @param {Array} array An array containing an array of CSV entries.\n * @param {Object} [options] An object containing user-defined options.\n * @param {Character} [separator] An override for the separator character. Defaults to a comma(,).\n * @param {Character} [delimiter] An override for the delimiter character. Defaults to a double-quote(\").\n *\n * This method generates a CSV file from an array of arrays (representing entries).\n */\n fromArrays: function(arrays, options, callback) {\n var options = (options !== undefined ? options : {});\n var config = {};\n config.callback = ((callback !== undefined && typeof(callback) === 'function') ? callback : false);\n config.separator = 'separator' in options ? options.separator : $.csv.defaults.separator;\n config.delimiter = 'delimiter' in options ? options.delimiter : $.csv.defaults.delimiter;\n config.escaper = 'escaper' in options ? options.escaper : $.csv.defaults.escaper;\n config.experimental = 'experimental' in options ? options.experimental : false;\n\n if(!config.experimental) {\n throw new Error('not implemented');\n }\n\n var output = [];\n for(i in arrays) {\n output.push(arrays[i]);\n }\n\n // push the value to a callback if one is defined\n if(!config.callback) {\n return output;\n } else {\n config.callback('', output);\n }\n },\n\n /**\n * $.csv.fromObjects(objects)\n * Converts a javascript dictionary to a CSV string.\n * @param {Object} objects An array of objects containing the data.\n * @param {Object} [options] An object containing user-defined options.\n * @param {Character} [separator] An override for the separator character. Defaults to a comma(,).\n * @param {Character} [delimiter] An override for the delimiter character. Defaults to a double-quote(\").\n *\n * This method generates a CSV file from an array of objects (name:value pairs).\n * It starts by detecting the headers and adding them as the first line of\n * the CSV file, followed by a structured dump of the data.\n */\n fromObjects2CSV: function(objects, options, callback) {\n var options = (options !== undefined ? options : {});\n var config = {};\n config.callback = ((callback !== undefined && typeof(callback) === 'function') ? callback : false);\n config.separator = 'separator' in options ? options.separator : $.csv.defaults.separator;\n config.delimiter = 'delimiter' in options ? options.delimiter : $.csv.defaults.delimiter;\n config.experimental = 'experimental' in options ? options.experimental : false;\n\n if(!config.experimental) {\n throw new Error('not implemented');\n }\n\n var output = [];\n for(i in objects) {\n output.push(arrays[i]);\n }\n\n // push the value to a callback if one is defined\n if(!config.callback) {\n return output;\n } else {\n config.callback('', output);\n }\n }\n };\n\n // Maintenance code to maintain backward-compatibility\n // Will be removed in release 1.0\n $.csvEntry2Array = $.csv.toArray;\n $.csv2Array = $.csv.toArrays;\n $.csv2Dictionary = $.csv.toObjects;\n\n\n\n},{\"jquery\":18}],3:[function(require,module,exports){\n// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n var ie_lt8 = /MSIE \\d/.test(navigator.userAgent) &&\n (document.documentMode == null || document.documentMode < 8);\n\n var Pos = CodeMirror.Pos;\n\n var matching = {\"(\": \")>\", \")\": \"(<\", \"[\": \"]>\", \"]\": \"[<\", \"{\": \"}>\", \"}\": \"{<\"};\n\n function findMatchingBracket(cm, where, strict, config) {\n var line = cm.getLineHandle(where.line), pos = where.ch - 1;\n var match = (pos >= 0 && matching[line.text.charAt(pos)]) || matching[line.text.charAt(++pos)];\n if (!match) return null;\n var dir = match.charAt(1) == \">\" ? 1 : -1;\n if (strict && (dir > 0) != (pos == where.ch)) return null;\n var style = cm.getTokenTypeAt(Pos(where.line, pos + 1));\n\n var found = scanForBracket(cm, Pos(where.line, pos + (dir > 0 ? 1 : 0)), dir, style || null, config);\n if (found == null) return null;\n return {from: Pos(where.line, pos), to: found && found.pos,\n match: found && found.ch == match.charAt(0), forward: dir > 0};\n }\n\n // bracketRegex is used to specify which type of bracket to scan\n // should be a regexp, e.g. /[[\\]]/\n //\n // Note: If \"where\" is on an open bracket, then this bracket is ignored.\n //\n // Returns false when no bracket was found, null when it reached\n // maxScanLines and gave up\n function scanForBracket(cm, where, dir, style, config) {\n var maxScanLen = (config && config.maxScanLineLength) || 10000;\n var maxScanLines = (config && config.maxScanLines) || 1000;\n\n var stack = [];\n var re = config && config.bracketRegex ? config.bracketRegex : /[(){}[\\]]/;\n var lineEnd = dir > 0 ? Math.min(where.line + maxScanLines, cm.lastLine() + 1)\n : Math.max(cm.firstLine() - 1, where.line - maxScanLines);\n for (var lineNo = where.line; lineNo != lineEnd; lineNo += dir) {\n var line = cm.getLine(lineNo);\n if (!line) continue;\n var pos = dir > 0 ? 0 : line.length - 1, end = dir > 0 ? line.length : -1;\n if (line.length > maxScanLen) continue;\n if (lineNo == where.line) pos = where.ch - (dir < 0 ? 1 : 0);\n for (; pos != end; pos += dir) {\n var ch = line.charAt(pos);\n if (re.test(ch) && (style === undefined || cm.getTokenTypeAt(Pos(lineNo, pos + 1)) == style)) {\n var match = matching[ch];\n if ((match.charAt(1) == \">\") == (dir > 0)) stack.push(ch);\n else if (!stack.length) return {pos: Pos(lineNo, pos), ch: ch};\n else stack.pop();\n }\n }\n }\n return lineNo - dir == (dir > 0 ? cm.lastLine() : cm.firstLine()) ? false : null;\n }\n\n function matchBrackets(cm, autoclear, config) {\n // Disable brace matching in long lines, since it'll cause hugely slow updates\n var maxHighlightLen = cm.state.matchBrackets.maxHighlightLineLength || 1000;\n var marks = [], ranges = cm.listSelections();\n for (var i = 0; i < ranges.length; i++) {\n var match = ranges[i].empty() && findMatchingBracket(cm, ranges[i].head, false, config);\n if (match && cm.getLine(match.from.line).length <= maxHighlightLen) {\n var style = match.match ? \"CodeMirror-matchingbracket\" : \"CodeMirror-nonmatchingbracket\";\n marks.push(cm.markText(match.from, Pos(match.from.line, match.from.ch + 1), {className: style}));\n if (match.to && cm.getLine(match.to.line).length <= maxHighlightLen)\n marks.push(cm.markText(match.to, Pos(match.to.line, match.to.ch + 1), {className: style}));\n }\n }\n\n if (marks.length) {\n // Kludge to work around the IE bug from issue #1193, where text\n // input stops going to the textare whever this fires.\n if (ie_lt8 && cm.state.focused) cm.focus();\n\n var clear = function() {\n cm.operation(function() {\n for (var i = 0; i < marks.length; i++) marks[i].clear();\n });\n };\n if (autoclear) setTimeout(clear, 800);\n else return clear;\n }\n }\n\n var currentlyHighlighted = null;\n function doMatchBrackets(cm) {\n cm.operation(function() {\n if (currentlyHighlighted) {currentlyHighlighted(); currentlyHighlighted = null;}\n currentlyHighlighted = matchBrackets(cm, false, cm.state.matchBrackets);\n });\n }\n\n CodeMirror.defineOption(\"matchBrackets\", false, function(cm, val, old) {\n if (old && old != CodeMirror.Init)\n cm.off(\"cursorActivity\", doMatchBrackets);\n if (val) {\n cm.state.matchBrackets = typeof val == \"object\" ? val : {};\n cm.on(\"cursorActivity\", doMatchBrackets);\n }\n });\n\n CodeMirror.defineExtension(\"matchBrackets\", function() {matchBrackets(this, true);});\n CodeMirror.defineExtension(\"findMatchingBracket\", function(pos, strict, config){\n return findMatchingBracket(this, pos, strict, config);\n });\n CodeMirror.defineExtension(\"scanForBracket\", function(pos, dir, style, config){\n return scanForBracket(this, pos, dir, style, config);\n });\n});\n\n},{\"../../lib/codemirror\":8}],4:[function(require,module,exports){\n// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n\"use strict\";\n\nCodeMirror.registerHelper(\"fold\", \"brace\", function(cm, start) {\n var line = start.line, lineText = cm.getLine(line);\n var tokenType;\n\n function findOpening(openCh) {\n for (var at = start.ch, pass = 0;;) {\n var found = at <= 0 ? -1 : lineText.lastIndexOf(openCh, at - 1);\n if (found == -1) {\n if (pass == 1) break;\n pass = 1;\n at = lineText.length;\n continue;\n }\n if (pass == 1 && found < start.ch) break;\n tokenType = cm.getTokenTypeAt(CodeMirror.Pos(line, found + 1));\n if (!/^(comment|string)/.test(tokenType)) return found + 1;\n at = found - 1;\n }\n }\n\n var startToken = \"{\", endToken = \"}\", startCh = findOpening(\"{\");\n if (startCh == null) {\n startToken = \"[\", endToken = \"]\";\n startCh = findOpening(\"[\");\n }\n\n if (startCh == null) return;\n var count = 1, lastLine = cm.lastLine(), end, endCh;\n outer: for (var i = line; i <= lastLine; ++i) {\n var text = cm.getLine(i), pos = i == line ? startCh : 0;\n for (;;) {\n var nextOpen = text.indexOf(startToken, pos), nextClose = text.indexOf(endToken, pos);\n if (nextOpen < 0) nextOpen = text.length;\n if (nextClose < 0) nextClose = text.length;\n pos = Math.min(nextOpen, nextClose);\n if (pos == text.length) break;\n if (cm.getTokenTypeAt(CodeMirror.Pos(i, pos + 1)) == tokenType) {\n if (pos == nextOpen) ++count;\n else if (!--count) { end = i; endCh = pos; break outer; }\n }\n ++pos;\n }\n }\n if (end == null || line == end && endCh == startCh) return;\n return {from: CodeMirror.Pos(line, startCh),\n to: CodeMirror.Pos(end, endCh)};\n});\n\nCodeMirror.registerHelper(\"fold\", \"import\", function(cm, start) {\n function hasImport(line) {\n if (line < cm.firstLine() || line > cm.lastLine()) return null;\n var start = cm.getTokenAt(CodeMirror.Pos(line, 1));\n if (!/\\S/.test(start.string)) start = cm.getTokenAt(CodeMirror.Pos(line, start.end + 1));\n if (start.type != \"keyword\" || start.string != \"import\") return null;\n // Now find closing semicolon, return its position\n for (var i = line, e = Math.min(cm.lastLine(), line + 10); i <= e; ++i) {\n var text = cm.getLine(i), semi = text.indexOf(\";\");\n if (semi != -1) return {startCh: start.end, end: CodeMirror.Pos(i, semi)};\n }\n }\n\n var startLine = start.line, has = hasImport(startLine), prev;\n if (!has || hasImport(startLine - 1) || ((prev = hasImport(startLine - 2)) && prev.end.line == startLine - 1))\n return null;\n for (var end = has.end;;) {\n var next = hasImport(end.line + 1);\n if (next == null) break;\n end = next.end;\n }\n return {from: cm.clipPos(CodeMirror.Pos(startLine, has.startCh + 1)), to: end};\n});\n\nCodeMirror.registerHelper(\"fold\", \"include\", function(cm, start) {\n function hasInclude(line) {\n if (line < cm.firstLine() || line > cm.lastLine()) return null;\n var start = cm.getTokenAt(CodeMirror.Pos(line, 1));\n if (!/\\S/.test(start.string)) start = cm.getTokenAt(CodeMirror.Pos(line, start.end + 1));\n if (start.type == \"meta\" && start.string.slice(0, 8) == \"#include\") return start.start + 8;\n }\n\n var startLine = start.line, has = hasInclude(startLine);\n if (has == null || hasInclude(startLine - 1) != null) return null;\n for (var end = startLine;;) {\n var next = hasInclude(end + 1);\n if (next == null) break;\n ++end;\n }\n return {from: CodeMirror.Pos(startLine, has + 1),\n to: cm.clipPos(CodeMirror.Pos(end))};\n});\n\n});\n\n},{\"../../lib/codemirror\":8}],5:[function(require,module,exports){\n// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n \"use strict\";\n\n function doFold(cm, pos, options, force) {\n if (options && options.call) {\n var finder = options;\n options = null;\n } else {\n var finder = getOption(cm, options, \"rangeFinder\");\n }\n if (typeof pos == \"number\") pos = CodeMirror.Pos(pos, 0);\n var minSize = getOption(cm, options, \"minFoldSize\");\n\n function getRange(allowFolded) {\n var range = finder(cm, pos);\n if (!range || range.to.line - range.from.line < minSize) return null;\n var marks = cm.findMarksAt(range.from);\n for (var i = 0; i < marks.length; ++i) {\n if (marks[i].__isFold && force !== \"fold\") {\n if (!allowFolded) return null;\n range.cleared = true;\n marks[i].clear();\n }\n }\n return range;\n }\n\n var range = getRange(true);\n if (getOption(cm, options, \"scanUp\")) while (!range && pos.line > cm.firstLine()) {\n pos = CodeMirror.Pos(pos.line - 1, 0);\n range = getRange(false);\n }\n if (!range || range.cleared || force === \"unfold\") return;\n\n var myWidget = makeWidget(cm, options);\n CodeMirror.on(myWidget, \"mousedown\", function(e) {\n myRange.clear();\n CodeMirror.e_preventDefault(e);\n });\n var myRange = cm.markText(range.from, range.to, {\n replacedWith: myWidget,\n clearOnEnter: getOption(cm, options, \"clearOnEnter\"),\n __isFold: true\n });\n myRange.on(\"clear\", function(from, to) {\n CodeMirror.signal(cm, \"unfold\", cm, from, to);\n });\n CodeMirror.signal(cm, \"fold\", cm, range.from, range.to);\n }\n\n function makeWidget(cm, options) {\n var widget = getOption(cm, options, \"widget\");\n if (typeof widget == \"string\") {\n var text = document.createTextNode(widget);\n widget = document.createElement(\"span\");\n widget.appendChild(text);\n widget.className = \"CodeMirror-foldmarker\";\n }\n return widget;\n }\n\n // Clumsy backwards-compatible interface\n CodeMirror.newFoldFunction = function(rangeFinder, widget) {\n return function(cm, pos) { doFold(cm, pos, {rangeFinder: rangeFinder, widget: widget}); };\n };\n\n // New-style interface\n CodeMirror.defineExtension(\"foldCode\", function(pos, options, force) {\n doFold(this, pos, options, force);\n });\n\n CodeMirror.defineExtension(\"isFolded\", function(pos) {\n var marks = this.findMarksAt(pos);\n for (var i = 0; i < marks.length; ++i)\n if (marks[i].__isFold) return true;\n });\n\n CodeMirror.commands.toggleFold = function(cm) {\n cm.foldCode(cm.getCursor());\n };\n CodeMirror.commands.fold = function(cm) {\n cm.foldCode(cm.getCursor(), null, \"fold\");\n };\n CodeMirror.commands.unfold = function(cm) {\n cm.foldCode(cm.getCursor(), null, \"unfold\");\n };\n CodeMirror.commands.foldAll = function(cm) {\n cm.operation(function() {\n for (var i = cm.firstLine(), e = cm.lastLine(); i <= e; i++)\n cm.foldCode(CodeMirror.Pos(i, 0), null, \"fold\");\n });\n };\n CodeMirror.commands.unfoldAll = function(cm) {\n cm.operation(function() {\n for (var i = cm.firstLine(), e = cm.lastLine(); i <= e; i++)\n cm.foldCode(CodeMirror.Pos(i, 0), null, \"unfold\");\n });\n };\n\n CodeMirror.registerHelper(\"fold\", \"combine\", function() {\n var funcs = Array.prototype.slice.call(arguments, 0);\n return function(cm, start) {\n for (var i = 0; i < funcs.length; ++i) {\n var found = funcs[i](cm, start);\n if (found) return found;\n }\n };\n });\n\n CodeMirror.registerHelper(\"fold\", \"auto\", function(cm, start) {\n var helpers = cm.getHelpers(start, \"fold\");\n for (var i = 0; i < helpers.length; i++) {\n var cur = helpers[i](cm, start);\n if (cur) return cur;\n }\n });\n\n var defaultOptions = {\n rangeFinder: CodeMirror.fold.auto,\n widget: \"\\u2194\",\n minFoldSize: 0,\n scanUp: false,\n clearOnEnter: true\n };\n\n CodeMirror.defineOption(\"foldOptions\", null);\n\n function getOption(cm, options, name) {\n if (options && options[name] !== undefined)\n return options[name];\n var editorOptions = cm.options.foldOptions;\n if (editorOptions && editorOptions[name] !== undefined)\n return editorOptions[name];\n return defaultOptions[name];\n }\n\n CodeMirror.defineExtension(\"foldOption\", function(options, name) {\n return getOption(this, options, name);\n });\n});\n\n},{\"../../lib/codemirror\":8}],6:[function(require,module,exports){\n// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"), require(\"./foldcode\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\", \"./foldcode\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n \"use strict\";\n\n CodeMirror.defineOption(\"foldGutter\", false, function(cm, val, old) {\n if (old && old != CodeMirror.Init) {\n cm.clearGutter(cm.state.foldGutter.options.gutter);\n cm.state.foldGutter = null;\n cm.off(\"gutterClick\", onGutterClick);\n cm.off(\"change\", onChange);\n cm.off(\"viewportChange\", onViewportChange);\n cm.off(\"fold\", onFold);\n cm.off(\"unfold\", onFold);\n cm.off(\"swapDoc\", onChange);\n }\n if (val) {\n cm.state.foldGutter = new State(parseOptions(val));\n updateInViewport(cm);\n cm.on(\"gutterClick\", onGutterClick);\n cm.on(\"change\", onChange);\n cm.on(\"viewportChange\", onViewportChange);\n cm.on(\"fold\", onFold);\n cm.on(\"unfold\", onFold);\n cm.on(\"swapDoc\", onChange);\n }\n });\n\n var Pos = CodeMirror.Pos;\n\n function State(options) {\n this.options = options;\n this.from = this.to = 0;\n }\n\n function parseOptions(opts) {\n if (opts === true) opts = {};\n if (opts.gutter == null) opts.gutter = \"CodeMirror-foldgutter\";\n if (opts.indicatorOpen == null) opts.indicatorOpen = \"CodeMirror-foldgutter-open\";\n if (opts.indicatorFolded == null) opts.indicatorFolded = \"CodeMirror-foldgutter-folded\";\n return opts;\n }\n\n function isFolded(cm, line) {\n var marks = cm.findMarks(Pos(line, 0), Pos(line + 1, 0));\n for (var i = 0; i < marks.length; ++i)\n if (marks[i].__isFold && marks[i].find().from.line == line) return marks[i];\n }\n\n function marker(spec) {\n if (typeof spec == \"string\") {\n var elt = document.createElement(\"div\");\n elt.className = spec + \" CodeMirror-guttermarker-subtle\";\n return elt;\n } else {\n return spec.cloneNode(true);\n }\n }\n\n function updateFoldInfo(cm, from, to) {\n var opts = cm.state.foldGutter.options, cur = from;\n var minSize = cm.foldOption(opts, \"minFoldSize\");\n var func = cm.foldOption(opts, \"rangeFinder\");\n cm.eachLine(from, to, function(line) {\n var mark = null;\n if (isFolded(cm, cur)) {\n mark = marker(opts.indicatorFolded);\n } else {\n var pos = Pos(cur, 0);\n var range = func && func(cm, pos);\n if (range && range.to.line - range.from.line >= minSize)\n mark = marker(opts.indicatorOpen);\n }\n cm.setGutterMarker(line, opts.gutter, mark);\n ++cur;\n });\n }\n\n function updateInViewport(cm) {\n var vp = cm.getViewport(), state = cm.state.foldGutter;\n if (!state) return;\n cm.operation(function() {\n updateFoldInfo(cm, vp.from, vp.to);\n });\n state.from = vp.from; state.to = vp.to;\n }\n\n function onGutterClick(cm, line, gutter) {\n var state = cm.state.foldGutter;\n if (!state) return;\n var opts = state.options;\n if (gutter != opts.gutter) return;\n var folded = isFolded(cm, line);\n if (folded) folded.clear();\n else cm.foldCode(Pos(line, 0), opts.rangeFinder);\n }\n\n function onChange(cm) {\n var state = cm.state.foldGutter;\n if (!state) return;\n var opts = state.options;\n state.from = state.to = 0;\n clearTimeout(state.changeUpdate);\n state.changeUpdate = setTimeout(function() { updateInViewport(cm); }, opts.foldOnChangeTimeSpan || 600);\n }\n\n function onViewportChange(cm) {\n var state = cm.state.foldGutter;\n if (!state) return;\n var opts = state.options;\n clearTimeout(state.changeUpdate);\n state.changeUpdate = setTimeout(function() {\n var vp = cm.getViewport();\n if (state.from == state.to || vp.from - state.to > 20 || state.from - vp.to > 20) {\n updateInViewport(cm);\n } else {\n cm.operation(function() {\n if (vp.from < state.from) {\n updateFoldInfo(cm, vp.from, state.from);\n state.from = vp.from;\n }\n if (vp.to > state.to) {\n updateFoldInfo(cm, state.to, vp.to);\n state.to = vp.to;\n }\n });\n }\n }, opts.updateViewportTimeSpan || 400);\n }\n\n function onFold(cm, from) {\n var state = cm.state.foldGutter;\n if (!state) return;\n var line = from.line;\n if (line >= state.from && line < state.to)\n updateFoldInfo(cm, line, line + 1);\n }\n});\n\n},{\"../../lib/codemirror\":8,\"./foldcode\":5}],7:[function(require,module,exports){\n// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n \"use strict\";\n\n var Pos = CodeMirror.Pos;\n function cmp(a, b) { return a.line - b.line || a.ch - b.ch; }\n\n var nameStartChar = \"A-Z_a-z\\\\u00C0-\\\\u00D6\\\\u00D8-\\\\u00F6\\\\u00F8-\\\\u02FF\\\\u0370-\\\\u037D\\\\u037F-\\\\u1FFF\\\\u200C-\\\\u200D\\\\u2070-\\\\u218F\\\\u2C00-\\\\u2FEF\\\\u3001-\\\\uD7FF\\\\uF900-\\\\uFDCF\\\\uFDF0-\\\\uFFFD\";\n var nameChar = nameStartChar + \"\\-\\:\\.0-9\\\\u00B7\\\\u0300-\\\\u036F\\\\u203F-\\\\u2040\";\n var xmlTagStart = new RegExp(\"<(/?)([\" + nameStartChar + \"][\" + nameChar + \"]*)\", \"g\");\n\n function Iter(cm, line, ch, range) {\n this.line = line; this.ch = ch;\n this.cm = cm; this.text = cm.getLine(line);\n this.min = range ? range.from : cm.firstLine();\n this.max = range ? range.to - 1 : cm.lastLine();\n }\n\n function tagAt(iter, ch) {\n var type = iter.cm.getTokenTypeAt(Pos(iter.line, ch));\n return type && /\\btag\\b/.test(type);\n }\n\n function nextLine(iter) {\n if (iter.line >= iter.max) return;\n iter.ch = 0;\n iter.text = iter.cm.getLine(++iter.line);\n return true;\n }\n function prevLine(iter) {\n if (iter.line <= iter.min) return;\n iter.text = iter.cm.getLine(--iter.line);\n iter.ch = iter.text.length;\n return true;\n }\n\n function toTagEnd(iter) {\n for (;;) {\n var gt = iter.text.indexOf(\">\", iter.ch);\n if (gt == -1) { if (nextLine(iter)) continue; else return; }\n if (!tagAt(iter, gt + 1)) { iter.ch = gt + 1; continue; }\n var lastSlash = iter.text.lastIndexOf(\"/\", gt);\n var selfClose = lastSlash > -1 && !/\\S/.test(iter.text.slice(lastSlash + 1, gt));\n iter.ch = gt + 1;\n return selfClose ? \"selfClose\" : \"regular\";\n }\n }\n function toTagStart(iter) {\n for (;;) {\n var lt = iter.ch ? iter.text.lastIndexOf(\"<\", iter.ch - 1) : -1;\n if (lt == -1) { if (prevLine(iter)) continue; else return; }\n if (!tagAt(iter, lt + 1)) { iter.ch = lt; continue; }\n xmlTagStart.lastIndex = lt;\n iter.ch = lt;\n var match = xmlTagStart.exec(iter.text);\n if (match && match.index == lt) return match;\n }\n }\n\n function toNextTag(iter) {\n for (;;) {\n xmlTagStart.lastIndex = iter.ch;\n var found = xmlTagStart.exec(iter.text);\n if (!found) { if (nextLine(iter)) continue; else return; }\n if (!tagAt(iter, found.index + 1)) { iter.ch = found.index + 1; continue; }\n iter.ch = found.index + found[0].length;\n return found;\n }\n }\n function toPrevTag(iter) {\n for (;;) {\n var gt = iter.ch ? iter.text.lastIndexOf(\">\", iter.ch - 1) : -1;\n if (gt == -1) { if (prevLine(iter)) continue; else return; }\n if (!tagAt(iter, gt + 1)) { iter.ch = gt; continue; }\n var lastSlash = iter.text.lastIndexOf(\"/\", gt);\n var selfClose = lastSlash > -1 && !/\\S/.test(iter.text.slice(lastSlash + 1, gt));\n iter.ch = gt + 1;\n return selfClose ? \"selfClose\" : \"regular\";\n }\n }\n\n function findMatchingClose(iter, tag) {\n var stack = [];\n for (;;) {\n var next = toNextTag(iter), end, startLine = iter.line, startCh = iter.ch - (next ? next[0].length : 0);\n if (!next || !(end = toTagEnd(iter))) return;\n if (end == \"selfClose\") continue;\n if (next[1]) { // closing tag\n for (var i = stack.length - 1; i >= 0; --i) if (stack[i] == next[2]) {\n stack.length = i;\n break;\n }\n if (i < 0 && (!tag || tag == next[2])) return {\n tag: next[2],\n from: Pos(startLine, startCh),\n to: Pos(iter.line, iter.ch)\n };\n } else { // opening tag\n stack.push(next[2]);\n }\n }\n }\n function findMatchingOpen(iter, tag) {\n var stack = [];\n for (;;) {\n var prev = toPrevTag(iter);\n if (!prev) return;\n if (prev == \"selfClose\") { toTagStart(iter); continue; }\n var endLine = iter.line, endCh = iter.ch;\n var start = toTagStart(iter);\n if (!start) return;\n if (start[1]) { // closing tag\n stack.push(start[2]);\n } else { // opening tag\n for (var i = stack.length - 1; i >= 0; --i) if (stack[i] == start[2]) {\n stack.length = i;\n break;\n }\n if (i < 0 && (!tag || tag == start[2])) return {\n tag: start[2],\n from: Pos(iter.line, iter.ch),\n to: Pos(endLine, endCh)\n };\n }\n }\n }\n\n CodeMirror.registerHelper(\"fold\", \"xml\", function(cm, start) {\n var iter = new Iter(cm, start.line, 0);\n for (;;) {\n var openTag = toNextTag(iter), end;\n if (!openTag || iter.line != start.line || !(end = toTagEnd(iter))) return;\n if (!openTag[1] && end != \"selfClose\") {\n var startPos = Pos(iter.line, iter.ch);\n var endPos = findMatchingClose(iter, openTag[2]);\n return endPos && {from: startPos, to: endPos.from};\n }\n }\n });\n CodeMirror.findMatchingTag = function(cm, pos, range) {\n var iter = new Iter(cm, pos.line, pos.ch, range);\n if (iter.text.indexOf(\">\") == -1 && iter.text.indexOf(\"<\") == -1) return;\n var end = toTagEnd(iter), to = end && Pos(iter.line, iter.ch);\n var start = end && toTagStart(iter);\n if (!end || !start || cmp(iter, pos) > 0) return;\n var here = {from: Pos(iter.line, iter.ch), to: to, tag: start[2]};\n if (end == \"selfClose\") return {open: here, close: null, at: \"open\"};\n\n if (start[1]) { // closing tag\n return {open: findMatchingOpen(iter, start[2]), close: here, at: \"close\"};\n } else { // opening tag\n iter = new Iter(cm, to.line, to.ch, range);\n return {open: here, close: findMatchingClose(iter, start[2]), at: \"open\"};\n }\n };\n\n CodeMirror.findEnclosingTag = function(cm, pos, range) {\n var iter = new Iter(cm, pos.line, pos.ch, range);\n for (;;) {\n var open = findMatchingOpen(iter);\n if (!open) break;\n var forward = new Iter(cm, pos.line, pos.ch, range);\n var close = findMatchingClose(forward, open.tag);\n if (close) return {open: open, close: close};\n }\n };\n\n // Used by addon/edit/closetag.js\n CodeMirror.scanForClosingTag = function(cm, pos, name, end) {\n var iter = new Iter(cm, pos.line, pos.ch, end ? {from: 0, to: end} : null);\n return findMatchingClose(iter, name);\n };\n});\n\n},{\"../../lib/codemirror\":8}],8:[function(require,module,exports){\n// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n// This is CodeMirror (http://codemirror.net), a code editor\n// implemented in JavaScript on top of the browser's DOM.\n//\n// You can find some technical background for some of the code below\n// at http://marijnhaverbeke.nl/blog/#cm-internals .\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n module.exports = mod();\n else if (typeof define == \"function\" && define.amd) // AMD\n return define([], mod);\n else // Plain browser env\n (this || window).CodeMirror = mod();\n})(function() {\n \"use strict\";\n\n // BROWSER SNIFFING\n\n // Kludges for bugs and behavior differences that can't be feature\n // detected are enabled based on userAgent etc sniffing.\n var userAgent = navigator.userAgent;\n var platform = navigator.platform;\n\n var gecko = /gecko\\/\\d/i.test(userAgent);\n var ie_upto10 = /MSIE \\d/.test(userAgent);\n var ie_11up = /Trident\\/(?:[7-9]|\\d{2,})\\..*rv:(\\d+)/.exec(userAgent);\n var ie = ie_upto10 || ie_11up;\n var ie_version = ie && (ie_upto10 ? document.documentMode || 6 : ie_11up[1]);\n var webkit = /WebKit\\//.test(userAgent);\n var qtwebkit = webkit && /Qt\\/\\d+\\.\\d+/.test(userAgent);\n var chrome = /Chrome\\//.test(userAgent);\n var presto = /Opera\\//.test(userAgent);\n var safari = /Apple Computer/.test(navigator.vendor);\n var mac_geMountainLion = /Mac OS X 1\\d\\D([8-9]|\\d\\d)\\D/.test(userAgent);\n var phantom = /PhantomJS/.test(userAgent);\n\n var ios = /AppleWebKit/.test(userAgent) && /Mobile\\/\\w+/.test(userAgent);\n // This is woefully incomplete. Suggestions for alternative methods welcome.\n var mobile = ios || /Android|webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(userAgent);\n var mac = ios || /Mac/.test(platform);\n var chromeOS = /\\bCrOS\\b/.test(userAgent);\n var windows = /win/i.test(platform);\n\n var presto_version = presto && userAgent.match(/Version\\/(\\d*\\.\\d*)/);\n if (presto_version) presto_version = Number(presto_version[1]);\n if (presto_version && presto_version >= 15) { presto = false; webkit = true; }\n // Some browsers use the wrong event properties to signal cmd/ctrl on OS X\n var flipCtrlCmd = mac && (qtwebkit || presto && (presto_version == null || presto_version < 12.11));\n var captureRightClick = gecko || (ie && ie_version >= 9);\n\n // Optimize some code when these features are not used.\n var sawReadOnlySpans = false, sawCollapsedSpans = false;\n\n // EDITOR CONSTRUCTOR\n\n // A CodeMirror instance represents an editor. This is the object\n // that user code is usually dealing with.\n\n function CodeMirror(place, options) {\n if (!(this instanceof CodeMirror)) return new CodeMirror(place, options);\n\n this.options = options = options ? copyObj(options) : {};\n // Determine effective options based on given values and defaults.\n copyObj(defaults, options, false);\n setGuttersForLineNumbers(options);\n\n var doc = options.value;\n if (typeof doc == \"string\") doc = new Doc(doc, options.mode, null, options.lineSeparator);\n this.doc = doc;\n\n var input = new CodeMirror.inputStyles[options.inputStyle](this);\n var display = this.display = new Display(place, doc, input);\n display.wrapper.CodeMirror = this;\n updateGutters(this);\n themeChanged(this);\n if (options.lineWrapping)\n this.display.wrapper.className += \" CodeMirror-wrap\";\n if (options.autofocus && !mobile) display.input.focus();\n initScrollbars(this);\n\n this.state = {\n keyMaps: [], // stores maps added by addKeyMap\n overlays: [], // highlighting overlays, as added by addOverlay\n modeGen: 0, // bumped when mode/overlay changes, used to invalidate highlighting info\n overwrite: false,\n delayingBlurEvent: false,\n focused: false,\n suppressEdits: false, // used to disable editing during key handlers when in readOnly mode\n pasteIncoming: false, cutIncoming: false, // help recognize paste/cut edits in input.poll\n selectingText: false,\n draggingText: false,\n highlight: new Delayed(), // stores highlight worker timeout\n keySeq: null, // Unfinished key sequence\n specialChars: null\n };\n\n var cm = this;\n\n // Override magic textarea content restore that IE sometimes does\n // on our hidden textarea on reload\n if (ie && ie_version < 11) setTimeout(function() { cm.display.input.reset(true); }, 20);\n\n registerEventHandlers(this);\n ensureGlobalHandlers();\n\n startOperation(this);\n this.curOp.forceUpdate = true;\n attachDoc(this, doc);\n\n if ((options.autofocus && !mobile) || cm.hasFocus())\n setTimeout(bind(onFocus, this), 20);\n else\n onBlur(this);\n\n for (var opt in optionHandlers) if (optionHandlers.hasOwnProperty(opt))\n optionHandlers[opt](this, options[opt], Init);\n maybeUpdateLineNumberWidth(this);\n if (options.finishInit) options.finishInit(this);\n for (var i = 0; i < initHooks.length; ++i) initHooks[i](this);\n endOperation(this);\n // Suppress optimizelegibility in Webkit, since it breaks text\n // measuring on line wrapping boundaries.\n if (webkit && options.lineWrapping &&\n getComputedStyle(display.lineDiv).textRendering == \"optimizelegibility\")\n display.lineDiv.style.textRendering = \"auto\";\n }\n\n // DISPLAY CONSTRUCTOR\n\n // The display handles the DOM integration, both for input reading\n // and content drawing. It holds references to DOM nodes and\n // display-related state.\n\n function Display(place, doc, input) {\n var d = this;\n this.input = input;\n\n // Covers bottom-right square when both scrollbars are present.\n d.scrollbarFiller = elt(\"div\", null, \"CodeMirror-scrollbar-filler\");\n d.scrollbarFiller.setAttribute(\"cm-not-content\", \"true\");\n // Covers bottom of gutter when coverGutterNextToScrollbar is on\n // and h scrollbar is present.\n d.gutterFiller = elt(\"div\", null, \"CodeMirror-gutter-filler\");\n d.gutterFiller.setAttribute(\"cm-not-content\", \"true\");\n // Will contain the actual code, positioned to cover the viewport.\n d.lineDiv = elt(\"div\", null, \"CodeMirror-code\");\n // Elements are added to these to represent selection and cursors.\n d.selectionDiv = elt(\"div\", null, null, \"position: relative; z-index: 1\");\n d.cursorDiv = elt(\"div\", null, \"CodeMirror-cursors\");\n // A visibility: hidden element used to find the size of things.\n d.measure = elt(\"div\", null, \"CodeMirror-measure\");\n // When lines outside of the viewport are measured, they are drawn in this.\n d.lineMeasure = elt(\"div\", null, \"CodeMirror-measure\");\n // Wraps everything that needs to exist inside the vertically-padded coordinate system\n d.lineSpace = elt(\"div\", [d.measure, d.lineMeasure, d.selectionDiv, d.cursorDiv, d.lineDiv],\n null, \"position: relative; outline: none\");\n // Moved around its parent to cover visible view.\n d.mover = elt(\"div\", [elt(\"div\", [d.lineSpace], \"CodeMirror-lines\")], null, \"position: relative\");\n // Set to the height of the document, allowing scrolling.\n d.sizer = elt(\"div\", [d.mover], \"CodeMirror-sizer\");\n d.sizerWidth = null;\n // Behavior of elts with overflow: auto and padding is\n // inconsistent across browsers. This is used to ensure the\n // scrollable area is big enough.\n d.heightForcer = elt(\"div\", null, null, \"position: absolute; height: \" + scrollerGap + \"px; width: 1px;\");\n // Will contain the gutters, if any.\n d.gutters = elt(\"div\", null, \"CodeMirror-gutters\");\n d.lineGutter = null;\n // Actual scrollable element.\n d.scroller = elt(\"div\", [d.sizer, d.heightForcer, d.gutters], \"CodeMirror-scroll\");\n d.scroller.setAttribute(\"tabIndex\", \"-1\");\n // The element in which the editor lives.\n d.wrapper = elt(\"div\", [d.scrollbarFiller, d.gutterFiller, d.scroller], \"CodeMirror\");\n\n // Work around IE7 z-index bug (not perfect, hence IE7 not really being supported)\n if (ie && ie_version < 8) { d.gutters.style.zIndex = -1; d.scroller.style.paddingRight = 0; }\n if (!webkit && !(gecko && mobile)) d.scroller.draggable = true;\n\n if (place) {\n if (place.appendChild) place.appendChild(d.wrapper);\n else place(d.wrapper);\n }\n\n // Current rendered range (may be bigger than the view window).\n d.viewFrom = d.viewTo = doc.first;\n d.reportedViewFrom = d.reportedViewTo = doc.first;\n // Information about the rendered lines.\n d.view = [];\n d.renderedView = null;\n // Holds info about a single rendered line when it was rendered\n // for measurement, while not in view.\n d.externalMeasured = null;\n // Empty space (in pixels) above the view\n d.viewOffset = 0;\n d.lastWrapHeight = d.lastWrapWidth = 0;\n d.updateLineNumbers = null;\n\n d.nativeBarWidth = d.barHeight = d.barWidth = 0;\n d.scrollbarsClipped = false;\n\n // Used to only resize the line number gutter when necessary (when\n // the amount of lines crosses a boundary that makes its width change)\n d.lineNumWidth = d.lineNumInnerWidth = d.lineNumChars = null;\n // Set to true when a non-horizontal-scrolling line widget is\n // added. As an optimization, line widget aligning is skipped when\n // this is false.\n d.alignWidgets = false;\n\n d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;\n\n // Tracks the maximum line length so that the horizontal scrollbar\n // can be kept static when scrolling.\n d.maxLine = null;\n d.maxLineLength = 0;\n d.maxLineChanged = false;\n\n // Used for measuring wheel scrolling granularity\n d.wheelDX = d.wheelDY = d.wheelStartX = d.wheelStartY = null;\n\n // True when shift is held down.\n d.shift = false;\n\n // Used to track whether anything happened since the context menu\n // was opened.\n d.selForContextMenu = null;\n\n d.activeTouch = null;\n\n input.init(d);\n }\n\n // STATE UPDATES\n\n // Used to get the editor into a consistent state again when options change.\n\n function loadMode(cm) {\n cm.doc.mode = CodeMirror.getMode(cm.options, cm.doc.modeOption);\n resetModeState(cm);\n }\n\n function resetModeState(cm) {\n cm.doc.iter(function(line) {\n if (line.stateAfter) line.stateAfter = null;\n if (line.styles) line.styles = null;\n });\n cm.doc.frontier = cm.doc.first;\n startWorker(cm, 100);\n cm.state.modeGen++;\n if (cm.curOp) regChange(cm);\n }\n\n function wrappingChanged(cm) {\n if (cm.options.lineWrapping) {\n addClass(cm.display.wrapper, \"CodeMirror-wrap\");\n cm.display.sizer.style.minWidth = \"\";\n cm.display.sizerWidth = null;\n } else {\n rmClass(cm.display.wrapper, \"CodeMirror-wrap\");\n findMaxLine(cm);\n }\n estimateLineHeights(cm);\n regChange(cm);\n clearCaches(cm);\n setTimeout(function(){updateScrollbars(cm);}, 100);\n }\n\n // Returns a function that estimates the height of a line, to use as\n // first approximation until the line becomes visible (and is thus\n // properly measurable).\n function estimateHeight(cm) {\n var th = textHeight(cm.display), wrapping = cm.options.lineWrapping;\n var perLine = wrapping && Math.max(5, cm.display.scroller.clientWidth / charWidth(cm.display) - 3);\n return function(line) {\n if (lineIsHidden(cm.doc, line)) return 0;\n\n var widgetsHeight = 0;\n if (line.widgets) for (var i = 0; i < line.widgets.length; i++) {\n if (line.widgets[i].height) widgetsHeight += line.widgets[i].height;\n }\n\n if (wrapping)\n return widgetsHeight + (Math.ceil(line.text.length / perLine) || 1) * th;\n else\n return widgetsHeight + th;\n };\n }\n\n function estimateLineHeights(cm) {\n var doc = cm.doc, est = estimateHeight(cm);\n doc.iter(function(line) {\n var estHeight = est(line);\n if (estHeight != line.height) updateLineHeight(line, estHeight);\n });\n }\n\n function themeChanged(cm) {\n cm.display.wrapper.className = cm.display.wrapper.className.replace(/\\s*cm-s-\\S+/g, \"\") +\n cm.options.theme.replace(/(^|\\s)\\s*/g, \" cm-s-\");\n clearCaches(cm);\n }\n\n function guttersChanged(cm) {\n updateGutters(cm);\n regChange(cm);\n setTimeout(function(){alignHorizontally(cm);}, 20);\n }\n\n // Rebuild the gutter elements, ensure the margin to the left of the\n // code matches their width.\n function updateGutters(cm) {\n var gutters = cm.display.gutters, specs = cm.options.gutters;\n removeChildren(gutters);\n for (var i = 0; i < specs.length; ++i) {\n var gutterClass = specs[i];\n var gElt = gutters.appendChild(elt(\"div\", null, \"CodeMirror-gutter \" + gutterClass));\n if (gutterClass == \"CodeMirror-linenumbers\") {\n cm.display.lineGutter = gElt;\n gElt.style.width = (cm.display.lineNumWidth || 1) + \"px\";\n }\n }\n gutters.style.display = i ? \"\" : \"none\";\n updateGutterSpace(cm);\n }\n\n function updateGutterSpace(cm) {\n var width = cm.display.gutters.offsetWidth;\n cm.display.sizer.style.marginLeft = width + \"px\";\n }\n\n // Compute the character length of a line, taking into account\n // collapsed ranges (see markText) that might hide parts, and join\n // other lines onto it.\n function lineLength(line) {\n if (line.height == 0) return 0;\n var len = line.text.length, merged, cur = line;\n while (merged = collapsedSpanAtStart(cur)) {\n var found = merged.find(0, true);\n cur = found.from.line;\n len += found.from.ch - found.to.ch;\n }\n cur = line;\n while (merged = collapsedSpanAtEnd(cur)) {\n var found = merged.find(0, true);\n len -= cur.text.length - found.from.ch;\n cur = found.to.line;\n len += cur.text.length - found.to.ch;\n }\n return len;\n }\n\n // Find the longest line in the document.\n function findMaxLine(cm) {\n var d = cm.display, doc = cm.doc;\n d.maxLine = getLine(doc, doc.first);\n d.maxLineLength = lineLength(d.maxLine);\n d.maxLineChanged = true;\n doc.iter(function(line) {\n var len = lineLength(line);\n if (len > d.maxLineLength) {\n d.maxLineLength = len;\n d.maxLine = line;\n }\n });\n }\n\n // Make sure the gutters options contains the element\n // \"CodeMirror-linenumbers\" when the lineNumbers option is true.\n function setGuttersForLineNumbers(options) {\n var found = indexOf(options.gutters, \"CodeMirror-linenumbers\");\n if (found == -1 && options.lineNumbers) {\n options.gutters = options.gutters.concat([\"CodeMirror-linenumbers\"]);\n } else if (found > -1 && !options.lineNumbers) {\n options.gutters = options.gutters.slice(0);\n options.gutters.splice(found, 1);\n }\n }\n\n // SCROLLBARS\n\n // Prepare DOM reads needed to update the scrollbars. Done in one\n // shot to minimize update/measure roundtrips.\n function measureForScrollbars(cm) {\n var d = cm.display, gutterW = d.gutters.offsetWidth;\n var docH = Math.round(cm.doc.height + paddingVert(cm.display));\n return {\n clientHeight: d.scroller.clientHeight,\n viewHeight: d.wrapper.clientHeight,\n scrollWidth: d.scroller.scrollWidth, clientWidth: d.scroller.clientWidth,\n viewWidth: d.wrapper.clientWidth,\n barLeft: cm.options.fixedGutter ? gutterW : 0,\n docHeight: docH,\n scrollHeight: docH + scrollGap(cm) + d.barHeight,\n nativeBarWidth: d.nativeBarWidth,\n gutterWidth: gutterW\n };\n }\n\n function NativeScrollbars(place, scroll, cm) {\n this.cm = cm;\n var vert = this.vert = elt(\"div\", [elt(\"div\", null, null, \"min-width: 1px\")], \"CodeMirror-vscrollbar\");\n var horiz = this.horiz = elt(\"div\", [elt(\"div\", null, null, \"height: 100%; min-height: 1px\")], \"CodeMirror-hscrollbar\");\n place(vert); place(horiz);\n\n on(vert, \"scroll\", function() {\n if (vert.clientHeight) scroll(vert.scrollTop, \"vertical\");\n });\n on(horiz, \"scroll\", function() {\n if (horiz.clientWidth) scroll(horiz.scrollLeft, \"horizontal\");\n });\n\n this.checkedZeroWidth = false;\n // Need to set a minimum width to see the scrollbar on IE7 (but must not set it on IE8).\n if (ie && ie_version < 8) this.horiz.style.minHeight = this.vert.style.minWidth = \"18px\";\n }\n\n NativeScrollbars.prototype = copyObj({\n update: function(measure) {\n var needsH = measure.scrollWidth > measure.clientWidth + 1;\n var needsV = measure.scrollHeight > measure.clientHeight + 1;\n var sWidth = measure.nativeBarWidth;\n\n if (needsV) {\n this.vert.style.display = \"block\";\n this.vert.style.bottom = needsH ? sWidth + \"px\" : \"0\";\n var totalHeight = measure.viewHeight - (needsH ? sWidth : 0);\n // A bug in IE8 can cause this value to be negative, so guard it.\n this.vert.firstChild.style.height =\n Math.max(0, measure.scrollHeight - measure.clientHeight + totalHeight) + \"px\";\n } else {\n this.vert.style.display = \"\";\n this.vert.firstChild.style.height = \"0\";\n }\n\n if (needsH) {\n this.horiz.style.display = \"block\";\n this.horiz.style.right = needsV ? sWidth + \"px\" : \"0\";\n this.horiz.style.left = measure.barLeft + \"px\";\n var totalWidth = measure.viewWidth - measure.barLeft - (needsV ? sWidth : 0);\n this.horiz.firstChild.style.width =\n (measure.scrollWidth - measure.clientWidth + totalWidth) + \"px\";\n } else {\n this.horiz.style.display = \"\";\n this.horiz.firstChild.style.width = \"0\";\n }\n\n if (!this.checkedZeroWidth && measure.clientHeight > 0) {\n if (sWidth == 0) this.zeroWidthHack();\n this.checkedZeroWidth = true;\n }\n\n return {right: needsV ? sWidth : 0, bottom: needsH ? sWidth : 0};\n },\n setScrollLeft: function(pos) {\n if (this.horiz.scrollLeft != pos) this.horiz.scrollLeft = pos;\n if (this.disableHoriz) this.enableZeroWidthBar(this.horiz, this.disableHoriz);\n },\n setScrollTop: function(pos) {\n if (this.vert.scrollTop != pos) this.vert.scrollTop = pos;\n if (this.disableVert) this.enableZeroWidthBar(this.vert, this.disableVert);\n },\n zeroWidthHack: function() {\n var w = mac && !mac_geMountainLion ? \"12px\" : \"18px\";\n this.horiz.style.height = this.vert.style.width = w;\n this.horiz.style.pointerEvents = this.vert.style.pointerEvents = \"none\";\n this.disableHoriz = new Delayed;\n this.disableVert = new Delayed;\n },\n enableZeroWidthBar: function(bar, delay) {\n bar.style.pointerEvents = \"auto\";\n function maybeDisable() {\n // To find out whether the scrollbar is still visible, we\n // check whether the element under the pixel in the bottom\n // left corner of the scrollbar box is the scrollbar box\n // itself (when the bar is still visible) or its filler child\n // (when the bar is hidden). If it is still visible, we keep\n // it enabled, if it's hidden, we disable pointer events.\n var box = bar.getBoundingClientRect();\n var elt = document.elementFromPoint(box.left + 1, box.bottom - 1);\n if (elt != bar) bar.style.pointerEvents = \"none\";\n else delay.set(1000, maybeDisable);\n }\n delay.set(1000, maybeDisable);\n },\n clear: function() {\n var parent = this.horiz.parentNode;\n parent.removeChild(this.horiz);\n parent.removeChild(this.vert);\n }\n }, NativeScrollbars.prototype);\n\n function NullScrollbars() {}\n\n NullScrollbars.prototype = copyObj({\n update: function() { return {bottom: 0, right: 0}; },\n setScrollLeft: function() {},\n setScrollTop: function() {},\n clear: function() {}\n }, NullScrollbars.prototype);\n\n CodeMirror.scrollbarModel = {\"native\": NativeScrollbars, \"null\": NullScrollbars};\n\n function initScrollbars(cm) {\n if (cm.display.scrollbars) {\n cm.display.scrollbars.clear();\n if (cm.display.scrollbars.addClass)\n rmClass(cm.display.wrapper, cm.display.scrollbars.addClass);\n }\n\n cm.display.scrollbars = new CodeMirror.scrollbarModel[cm.options.scrollbarStyle](function(node) {\n cm.display.wrapper.insertBefore(node, cm.display.scrollbarFiller);\n // Prevent clicks in the scrollbars from killing focus\n on(node, \"mousedown\", function() {\n if (cm.state.focused) setTimeout(function() { cm.display.input.focus(); }, 0);\n });\n node.setAttribute(\"cm-not-content\", \"true\");\n }, function(pos, axis) {\n if (axis == \"horizontal\") setScrollLeft(cm, pos);\n else setScrollTop(cm, pos);\n }, cm);\n if (cm.display.scrollbars.addClass)\n addClass(cm.display.wrapper, cm.display.scrollbars.addClass);\n }\n\n function updateScrollbars(cm, measure) {\n if (!measure) measure = measureForScrollbars(cm);\n var startWidth = cm.display.barWidth, startHeight = cm.display.barHeight;\n updateScrollbarsInner(cm, measure);\n for (var i = 0; i < 4 && startWidth != cm.display.barWidth || startHeight != cm.display.barHeight; i++) {\n if (startWidth != cm.display.barWidth && cm.options.lineWrapping)\n updateHeightsInViewport(cm);\n updateScrollbarsInner(cm, measureForScrollbars(cm));\n startWidth = cm.display.barWidth; startHeight = cm.display.barHeight;\n }\n }\n\n // Re-synchronize the fake scrollbars with the actual size of the\n // content.\n function updateScrollbarsInner(cm, measure) {\n var d = cm.display;\n var sizes = d.scrollbars.update(measure);\n\n d.sizer.style.paddingRight = (d.barWidth = sizes.right) + \"px\";\n d.sizer.style.paddingBottom = (d.barHeight = sizes.bottom) + \"px\";\n d.heightForcer.style.borderBottom = sizes.bottom + \"px solid transparent\"\n\n if (sizes.right && sizes.bottom) {\n d.scrollbarFiller.style.display = \"block\";\n d.scrollbarFiller.style.height = sizes.bottom + \"px\";\n d.scrollbarFiller.style.width = sizes.right + \"px\";\n } else d.scrollbarFiller.style.display = \"\";\n if (sizes.bottom && cm.options.coverGutterNextToScrollbar && cm.options.fixedGutter) {\n d.gutterFiller.style.display = \"block\";\n d.gutterFiller.style.height = sizes.bottom + \"px\";\n d.gutterFiller.style.width = measure.gutterWidth + \"px\";\n } else d.gutterFiller.style.display = \"\";\n }\n\n // Compute the lines that are visible in a given viewport (defaults\n // the the current scroll position). viewport may contain top,\n // height, and ensure (see op.scrollToPos) properties.\n function visibleLines(display, doc, viewport) {\n var top = viewport && viewport.top != null ? Math.max(0, viewport.top) : display.scroller.scrollTop;\n top = Math.floor(top - paddingTop(display));\n var bottom = viewport && viewport.bottom != null ? viewport.bottom : top + display.wrapper.clientHeight;\n\n var from = lineAtHeight(doc, top), to = lineAtHeight(doc, bottom);\n // Ensure is a {from: {line, ch}, to: {line, ch}} object, and\n // forces those lines into the viewport (if possible).\n if (viewport && viewport.ensure) {\n var ensureFrom = viewport.ensure.from.line, ensureTo = viewport.ensure.to.line;\n if (ensureFrom < from) {\n from = ensureFrom;\n to = lineAtHeight(doc, heightAtLine(getLine(doc, ensureFrom)) + display.wrapper.clientHeight);\n } else if (Math.min(ensureTo, doc.lastLine()) >= to) {\n from = lineAtHeight(doc, heightAtLine(getLine(doc, ensureTo)) - display.wrapper.clientHeight);\n to = ensureTo;\n }\n }\n return {from: from, to: Math.max(to, from + 1)};\n }\n\n // LINE NUMBERS\n\n // Re-align line numbers and gutter marks to compensate for\n // horizontal scrolling.\n function alignHorizontally(cm) {\n var display = cm.display, view = display.view;\n if (!display.alignWidgets && (!display.gutters.firstChild || !cm.options.fixedGutter)) return;\n var comp = compensateForHScroll(display) - display.scroller.scrollLeft + cm.doc.scrollLeft;\n var gutterW = display.gutters.offsetWidth, left = comp + \"px\";\n for (var i = 0; i < view.length; i++) if (!view[i].hidden) {\n if (cm.options.fixedGutter && view[i].gutter)\n view[i].gutter.style.left = left;\n var align = view[i].alignable;\n if (align) for (var j = 0; j < align.length; j++)\n align[j].style.left = left;\n }\n if (cm.options.fixedGutter)\n display.gutters.style.left = (comp + gutterW) + \"px\";\n }\n\n // Used to ensure that the line number gutter is still the right\n // size for the current document size. Returns true when an update\n // is needed.\n function maybeUpdateLineNumberWidth(cm) {\n if (!cm.options.lineNumbers) return false;\n var doc = cm.doc, last = lineNumberFor(cm.options, doc.first + doc.size - 1), display = cm.display;\n if (last.length != display.lineNumChars) {\n var test = display.measure.appendChild(elt(\"div\", [elt(\"div\", last)],\n \"CodeMirror-linenumber CodeMirror-gutter-elt\"));\n var innerW = test.firstChild.offsetWidth, padding = test.offsetWidth - innerW;\n display.lineGutter.style.width = \"\";\n display.lineNumInnerWidth = Math.max(innerW, display.lineGutter.offsetWidth - padding) + 1;\n display.lineNumWidth = display.lineNumInnerWidth + padding;\n display.lineNumChars = display.lineNumInnerWidth ? last.length : -1;\n display.lineGutter.style.width = display.lineNumWidth + \"px\";\n updateGutterSpace(cm);\n return true;\n }\n return false;\n }\n\n function lineNumberFor(options, i) {\n return String(options.lineNumberFormatter(i + options.firstLineNumber));\n }\n\n // Computes display.scroller.scrollLeft + display.gutters.offsetWidth,\n // but using getBoundingClientRect to get a sub-pixel-accurate\n // result.\n function compensateForHScroll(display) {\n return display.scroller.getBoundingClientRect().left - display.sizer.getBoundingClientRect().left;\n }\n\n // DISPLAY DRAWING\n\n function DisplayUpdate(cm, viewport, force) {\n var display = cm.display;\n\n this.viewport = viewport;\n // Store some values that we'll need later (but don't want to force a relayout for)\n this.visible = visibleLines(display, cm.doc, viewport);\n this.editorIsHidden = !display.wrapper.offsetWidth;\n this.wrapperHeight = display.wrapper.clientHeight;\n this.wrapperWidth = display.wrapper.clientWidth;\n this.oldDisplayWidth = displayWidth(cm);\n this.force = force;\n this.dims = getDimensions(cm);\n this.events = [];\n }\n\n DisplayUpdate.prototype.signal = function(emitter, type) {\n if (hasHandler(emitter, type))\n this.events.push(arguments);\n };\n DisplayUpdate.prototype.finish = function() {\n for (var i = 0; i < this.events.length; i++)\n signal.apply(null, this.events[i]);\n };\n\n function maybeClipScrollbars(cm) {\n var display = cm.display;\n if (!display.scrollbarsClipped && display.scroller.offsetWidth) {\n display.nativeBarWidth = display.scroller.offsetWidth - display.scroller.clientWidth;\n display.heightForcer.style.height = scrollGap(cm) + \"px\";\n display.sizer.style.marginBottom = -display.nativeBarWidth + \"px\";\n display.sizer.style.borderRightWidth = scrollGap(cm) + \"px\";\n display.scrollbarsClipped = true;\n }\n }\n\n // Does the actual updating of the line display. Bails out\n // (returning false) when there is nothing to be done and forced is\n // false.\n function updateDisplayIfNeeded(cm, update) {\n var display = cm.display, doc = cm.doc;\n\n if (update.editorIsHidden) {\n resetView(cm);\n return false;\n }\n\n // Bail out if the visible area is already rendered and nothing changed.\n if (!update.force &&\n update.visible.from >= display.viewFrom && update.visible.to <= display.viewTo &&\n (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo) &&\n display.renderedView == display.view && countDirtyView(cm) == 0)\n return false;\n\n if (maybeUpdateLineNumberWidth(cm)) {\n resetView(cm);\n update.dims = getDimensions(cm);\n }\n\n // Compute a suitable new viewport (from & to)\n var end = doc.first + doc.size;\n var from = Math.max(update.visible.from - cm.options.viewportMargin, doc.first);\n var to = Math.min(end, update.visible.to + cm.options.viewportMargin);\n if (display.viewFrom < from && from - display.viewFrom < 20) from = Math.max(doc.first, display.viewFrom);\n if (display.viewTo > to && display.viewTo - to < 20) to = Math.min(end, display.viewTo);\n if (sawCollapsedSpans) {\n from = visualLineNo(cm.doc, from);\n to = visualLineEndNo(cm.doc, to);\n }\n\n var different = from != display.viewFrom || to != display.viewTo ||\n display.lastWrapHeight != update.wrapperHeight || display.lastWrapWidth != update.wrapperWidth;\n adjustView(cm, from, to);\n\n display.viewOffset = heightAtLine(getLine(cm.doc, display.viewFrom));\n // Position the mover div to align with the current scroll position\n cm.display.mover.style.top = display.viewOffset + \"px\";\n\n var toUpdate = countDirtyView(cm);\n if (!different && toUpdate == 0 && !update.force && display.renderedView == display.view &&\n (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo))\n return false;\n\n // For big changes, we hide the enclosing element during the\n // update, since that speeds up the operations on most browsers.\n var focused = activeElt();\n if (toUpdate > 4) display.lineDiv.style.display = \"none\";\n patchDisplay(cm, display.updateLineNumbers, update.dims);\n if (toUpdate > 4) display.lineDiv.style.display = \"\";\n display.renderedView = display.view;\n // There might have been a widget with a focused element that got\n // hidden or updated, if so re-focus it.\n if (focused && activeElt() != focused && focused.offsetHeight) focused.focus();\n\n // Prevent selection and cursors from interfering with the scroll\n // width and height.\n removeChildren(display.cursorDiv);\n removeChildren(display.selectionDiv);\n display.gutters.style.height = display.sizer.style.minHeight = 0;\n\n if (different) {\n display.lastWrapHeight = update.wrapperHeight;\n display.lastWrapWidth = update.wrapperWidth;\n startWorker(cm, 400);\n }\n\n display.updateLineNumbers = null;\n\n return true;\n }\n\n function postUpdateDisplay(cm, update) {\n var viewport = update.viewport;\n\n for (var first = true;; first = false) {\n if (!first || !cm.options.lineWrapping || update.oldDisplayWidth == displayWidth(cm)) {\n // Clip forced viewport to actual scrollable area.\n if (viewport && viewport.top != null)\n viewport = {top: Math.min(cm.doc.height + paddingVert(cm.display) - displayHeight(cm), viewport.top)};\n // Updated line heights might result in the drawn area not\n // actually covering the viewport. Keep looping until it does.\n update.visible = visibleLines(cm.display, cm.doc, viewport);\n if (update.visible.from >= cm.display.viewFrom && update.visible.to <= cm.display.viewTo)\n break;\n }\n if (!updateDisplayIfNeeded(cm, update)) break;\n updateHeightsInViewport(cm);\n var barMeasure = measureForScrollbars(cm);\n updateSelection(cm);\n updateScrollbars(cm, barMeasure);\n setDocumentHeight(cm, barMeasure);\n }\n\n update.signal(cm, \"update\", cm);\n if (cm.display.viewFrom != cm.display.reportedViewFrom || cm.display.viewTo != cm.display.reportedViewTo) {\n update.signal(cm, \"viewportChange\", cm, cm.display.viewFrom, cm.display.viewTo);\n cm.display.reportedViewFrom = cm.display.viewFrom; cm.display.reportedViewTo = cm.display.viewTo;\n }\n }\n\n function updateDisplaySimple(cm, viewport) {\n var update = new DisplayUpdate(cm, viewport);\n if (updateDisplayIfNeeded(cm, update)) {\n updateHeightsInViewport(cm);\n postUpdateDisplay(cm, update);\n var barMeasure = measureForScrollbars(cm);\n updateSelection(cm);\n updateScrollbars(cm, barMeasure);\n setDocumentHeight(cm, barMeasure);\n update.finish();\n }\n }\n\n function setDocumentHeight(cm, measure) {\n cm.display.sizer.style.minHeight = measure.docHeight + \"px\";\n cm.display.heightForcer.style.top = measure.docHeight + \"px\";\n cm.display.gutters.style.height = (measure.docHeight + cm.display.barHeight + scrollGap(cm)) + \"px\";\n }\n\n // Read the actual heights of the rendered lines, and update their\n // stored heights to match.\n function updateHeightsInViewport(cm) {\n var display = cm.display;\n var prevBottom = display.lineDiv.offsetTop;\n for (var i = 0; i < display.view.length; i++) {\n var cur = display.view[i], height;\n if (cur.hidden) continue;\n if (ie && ie_version < 8) {\n var bot = cur.node.offsetTop + cur.node.offsetHeight;\n height = bot - prevBottom;\n prevBottom = bot;\n } else {\n var box = cur.node.getBoundingClientRect();\n height = box.bottom - box.top;\n }\n var diff = cur.line.height - height;\n if (height < 2) height = textHeight(display);\n if (diff > .001 || diff < -.001) {\n updateLineHeight(cur.line, height);\n updateWidgetHeight(cur.line);\n if (cur.rest) for (var j = 0; j < cur.rest.length; j++)\n updateWidgetHeight(cur.rest[j]);\n }\n }\n }\n\n // Read and store the height of line widgets associated with the\n // given line.\n function updateWidgetHeight(line) {\n if (line.widgets) for (var i = 0; i < line.widgets.length; ++i)\n line.widgets[i].height = line.widgets[i].node.parentNode.offsetHeight;\n }\n\n // Do a bulk-read of the DOM positions and sizes needed to draw the\n // view, so that we don't interleave reading and writing to the DOM.\n function getDimensions(cm) {\n var d = cm.display, left = {}, width = {};\n var gutterLeft = d.gutters.clientLeft;\n for (var n = d.gutters.firstChild, i = 0; n; n = n.nextSibling, ++i) {\n left[cm.options.gutters[i]] = n.offsetLeft + n.clientLeft + gutterLeft;\n width[cm.options.gutters[i]] = n.clientWidth;\n }\n return {fixedPos: compensateForHScroll(d),\n gutterTotalWidth: d.gutters.offsetWidth,\n gutterLeft: left,\n gutterWidth: width,\n wrapperWidth: d.wrapper.clientWidth};\n }\n\n // Sync the actual display DOM structure with display.view, removing\n // nodes for lines that are no longer in view, and creating the ones\n // that are not there yet, and updating the ones that are out of\n // date.\n function patchDisplay(cm, updateNumbersFrom, dims) {\n var display = cm.display, lineNumbers = cm.options.lineNumbers;\n var container = display.lineDiv, cur = container.firstChild;\n\n function rm(node) {\n var next = node.nextSibling;\n // Works around a throw-scroll bug in OS X Webkit\n if (webkit && mac && cm.display.currentWheelTarget == node)\n node.style.display = \"none\";\n else\n node.parentNode.removeChild(node);\n return next;\n }\n\n var view = display.view, lineN = display.viewFrom;\n // Loop over the elements in the view, syncing cur (the DOM nodes\n // in display.lineDiv) with the view as we go.\n for (var i = 0; i < view.length; i++) {\n var lineView = view[i];\n if (lineView.hidden) {\n } else if (!lineView.node || lineView.node.parentNode != container) { // Not drawn yet\n var node = buildLineElement(cm, lineView, lineN, dims);\n container.insertBefore(node, cur);\n } else { // Already drawn\n while (cur != lineView.node) cur = rm(cur);\n var updateNumber = lineNumbers && updateNumbersFrom != null &&\n updateNumbersFrom <= lineN && lineView.lineNumber;\n if (lineView.changes) {\n if (indexOf(lineView.changes, \"gutter\") > -1) updateNumber = false;\n updateLineForChanges(cm, lineView, lineN, dims);\n }\n if (updateNumber) {\n removeChildren(lineView.lineNumber);\n lineView.lineNumber.appendChild(document.createTextNode(lineNumberFor(cm.options, lineN)));\n }\n cur = lineView.node.nextSibling;\n }\n lineN += lineView.size;\n }\n while (cur) cur = rm(cur);\n }\n\n // When an aspect of a line changes, a string is added to\n // lineView.changes. This updates the relevant part of the line's\n // DOM structure.\n function updateLineForChanges(cm, lineView, lineN, dims) {\n for (var j = 0; j < lineView.changes.length; j++) {\n var type = lineView.changes[j];\n if (type == \"text\") updateLineText(cm, lineView);\n else if (type == \"gutter\") updateLineGutter(cm, lineView, lineN, dims);\n else if (type == \"class\") updateLineClasses(lineView);\n else if (type == \"widget\") updateLineWidgets(cm, lineView, dims);\n }\n lineView.changes = null;\n }\n\n // Lines with gutter elements, widgets or a background class need to\n // be wrapped, and have the extra elements added to the wrapper div\n function ensureLineWrapped(lineView) {\n if (lineView.node == lineView.text) {\n lineView.node = elt(\"div\", null, null, \"position: relative\");\n if (lineView.text.parentNode)\n lineView.text.parentNode.replaceChild(lineView.node, lineView.text);\n lineView.node.appendChild(lineView.text);\n if (ie && ie_version < 8) lineView.node.style.zIndex = 2;\n }\n return lineView.node;\n }\n\n function updateLineBackground(lineView) {\n var cls = lineView.bgClass ? lineView.bgClass + \" \" + (lineView.line.bgClass || \"\") : lineView.line.bgClass;\n if (cls) cls += \" CodeMirror-linebackground\";\n if (lineView.background) {\n if (cls) lineView.background.className = cls;\n else { lineView.background.parentNode.removeChild(lineView.background); lineView.background = null; }\n } else if (cls) {\n var wrap = ensureLineWrapped(lineView);\n lineView.background = wrap.insertBefore(elt(\"div\", null, cls), wrap.firstChild);\n }\n }\n\n // Wrapper around buildLineContent which will reuse the structure\n // in display.externalMeasured when possible.\n function getLineContent(cm, lineView) {\n var ext = cm.display.externalMeasured;\n if (ext && ext.line == lineView.line) {\n cm.display.externalMeasured = null;\n lineView.measure = ext.measure;\n return ext.built;\n }\n return buildLineContent(cm, lineView);\n }\n\n // Redraw the line's text. Interacts with the background and text\n // classes because the mode may output tokens that influence these\n // classes.\n function updateLineText(cm, lineView) {\n var cls = lineView.text.className;\n var built = getLineContent(cm, lineView);\n if (lineView.text == lineView.node) lineView.node = built.pre;\n lineView.text.parentNode.replaceChild(built.pre, lineView.text);\n lineView.text = built.pre;\n if (built.bgClass != lineView.bgClass || built.textClass != lineView.textClass) {\n lineView.bgClass = built.bgClass;\n lineView.textClass = built.textClass;\n updateLineClasses(lineView);\n } else if (cls) {\n lineView.text.className = cls;\n }\n }\n\n function updateLineClasses(lineView) {\n updateLineBackground(lineView);\n if (lineView.line.wrapClass)\n ensureLineWrapped(lineView).className = lineView.line.wrapClass;\n else if (lineView.node != lineView.text)\n lineView.node.className = \"\";\n var textClass = lineView.textClass ? lineView.textClass + \" \" + (lineView.line.textClass || \"\") : lineView.line.textClass;\n lineView.text.className = textClass || \"\";\n }\n\n function updateLineGutter(cm, lineView, lineN, dims) {\n if (lineView.gutter) {\n lineView.node.removeChild(lineView.gutter);\n lineView.gutter = null;\n }\n if (lineView.gutterBackground) {\n lineView.node.removeChild(lineView.gutterBackground);\n lineView.gutterBackground = null;\n }\n if (lineView.line.gutterClass) {\n var wrap = ensureLineWrapped(lineView);\n lineView.gutterBackground = elt(\"div\", null, \"CodeMirror-gutter-background \" + lineView.line.gutterClass,\n \"left: \" + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) +\n \"px; width: \" + dims.gutterTotalWidth + \"px\");\n wrap.insertBefore(lineView.gutterBackground, lineView.text);\n }\n var markers = lineView.line.gutterMarkers;\n if (cm.options.lineNumbers || markers) {\n var wrap = ensureLineWrapped(lineView);\n var gutterWrap = lineView.gutter = elt(\"div\", null, \"CodeMirror-gutter-wrapper\", \"left: \" +\n (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + \"px\");\n cm.display.input.setUneditable(gutterWrap);\n wrap.insertBefore(gutterWrap, lineView.text);\n if (lineView.line.gutterClass)\n gutterWrap.className += \" \" + lineView.line.gutterClass;\n if (cm.options.lineNumbers && (!markers || !markers[\"CodeMirror-linenumbers\"]))\n lineView.lineNumber = gutterWrap.appendChild(\n elt(\"div\", lineNumberFor(cm.options, lineN),\n \"CodeMirror-linenumber CodeMirror-gutter-elt\",\n \"left: \" + dims.gutterLeft[\"CodeMirror-linenumbers\"] + \"px; width: \"\n + cm.display.lineNumInnerWidth + \"px\"));\n if (markers) for (var k = 0; k < cm.options.gutters.length; ++k) {\n var id = cm.options.gutters[k], found = markers.hasOwnProperty(id) && markers[id];\n if (found)\n gutterWrap.appendChild(elt(\"div\", [found], \"CodeMirror-gutter-elt\", \"left: \" +\n dims.gutterLeft[id] + \"px; width: \" + dims.gutterWidth[id] + \"px\"));\n }\n }\n }\n\n function updateLineWidgets(cm, lineView, dims) {\n if (lineView.alignable) lineView.alignable = null;\n for (var node = lineView.node.firstChild, next; node; node = next) {\n var next = node.nextSibling;\n if (node.className == \"CodeMirror-linewidget\")\n lineView.node.removeChild(node);\n }\n insertLineWidgets(cm, lineView, dims);\n }\n\n // Build a line's DOM representation from scratch\n function buildLineElement(cm, lineView, lineN, dims) {\n var built = getLineContent(cm, lineView);\n lineView.text = lineView.node = built.pre;\n if (built.bgClass) lineView.bgClass = built.bgClass;\n if (built.textClass) lineView.textClass = built.textClass;\n\n updateLineClasses(lineView);\n updateLineGutter(cm, lineView, lineN, dims);\n insertLineWidgets(cm, lineView, dims);\n return lineView.node;\n }\n\n // A lineView may contain multiple logical lines (when merged by\n // collapsed spans). The widgets for all of them need to be drawn.\n function insertLineWidgets(cm, lineView, dims) {\n insertLineWidgetsFor(cm, lineView.line, lineView, dims, true);\n if (lineView.rest) for (var i = 0; i < lineView.rest.length; i++)\n insertLineWidgetsFor(cm, lineView.rest[i], lineView, dims, false);\n }\n\n function insertLineWidgetsFor(cm, line, lineView, dims, allowAbove) {\n if (!line.widgets) return;\n var wrap = ensureLineWrapped(lineView);\n for (var i = 0, ws = line.widgets; i < ws.length; ++i) {\n var widget = ws[i], node = elt(\"div\", [widget.node], \"CodeMirror-linewidget\");\n if (!widget.handleMouseEvents) node.setAttribute(\"cm-ignore-events\", \"true\");\n positionLineWidget(widget, node, lineView, dims);\n cm.display.input.setUneditable(node);\n if (allowAbove && widget.above)\n wrap.insertBefore(node, lineView.gutter || lineView.text);\n else\n wrap.appendChild(node);\n signalLater(widget, \"redraw\");\n }\n }\n\n function positionLineWidget(widget, node, lineView, dims) {\n if (widget.noHScroll) {\n (lineView.alignable || (lineView.alignable = [])).push(node);\n var width = dims.wrapperWidth;\n node.style.left = dims.fixedPos + \"px\";\n if (!widget.coverGutter) {\n width -= dims.gutterTotalWidth;\n node.style.paddingLeft = dims.gutterTotalWidth + \"px\";\n }\n node.style.width = width + \"px\";\n }\n if (widget.coverGutter) {\n node.style.zIndex = 5;\n node.style.position = \"relative\";\n if (!widget.noHScroll) node.style.marginLeft = -dims.gutterTotalWidth + \"px\";\n }\n }\n\n // POSITION OBJECT\n\n // A Pos instance represents a position within the text.\n var Pos = CodeMirror.Pos = function(line, ch) {\n if (!(this instanceof Pos)) return new Pos(line, ch);\n this.line = line; this.ch = ch;\n };\n\n // Compare two positions, return 0 if they are the same, a negative\n // number when a is less, and a positive number otherwise.\n var cmp = CodeMirror.cmpPos = function(a, b) { return a.line - b.line || a.ch - b.ch; };\n\n function copyPos(x) {return Pos(x.line, x.ch);}\n function maxPos(a, b) { return cmp(a, b) < 0 ? b : a; }\n function minPos(a, b) { return cmp(a, b) < 0 ? a : b; }\n\n // INPUT HANDLING\n\n function ensureFocus(cm) {\n if (!cm.state.focused) { cm.display.input.focus(); onFocus(cm); }\n }\n\n // This will be set to a {lineWise: bool, text: [string]} object, so\n // that, when pasting, we know what kind of selections the copied\n // text was made out of.\n var lastCopied = null;\n\n function applyTextInput(cm, inserted, deleted, sel, origin) {\n var doc = cm.doc;\n cm.display.shift = false;\n if (!sel) sel = doc.sel;\n\n var paste = cm.state.pasteIncoming || origin == \"paste\";\n var textLines = doc.splitLines(inserted), multiPaste = null\n // When pasing N lines into N selections, insert one line per selection\n if (paste && sel.ranges.length > 1) {\n if (lastCopied && lastCopied.text.join(\"\\n\") == inserted) {\n if (sel.ranges.length % lastCopied.text.length == 0) {\n multiPaste = [];\n for (var i = 0; i < lastCopied.text.length; i++)\n multiPaste.push(doc.splitLines(lastCopied.text[i]));\n }\n } else if (textLines.length == sel.ranges.length) {\n multiPaste = map(textLines, function(l) { return [l]; });\n }\n }\n\n // Normal behavior is to insert the new text into every selection\n for (var i = sel.ranges.length - 1; i >= 0; i--) {\n var range = sel.ranges[i];\n var from = range.from(), to = range.to();\n if (range.empty()) {\n if (deleted && deleted > 0) // Handle deletion\n from = Pos(from.line, from.ch - deleted);\n else if (cm.state.overwrite && !paste) // Handle overwrite\n to = Pos(to.line, Math.min(getLine(doc, to.line).text.length, to.ch + lst(textLines).length));\n else if (lastCopied && lastCopied.lineWise && lastCopied.text.join(\"\\n\") == inserted)\n from = to = Pos(from.line, 0)\n }\n var updateInput = cm.curOp.updateInput;\n var changeEvent = {from: from, to: to, text: multiPaste ? multiPaste[i % multiPaste.length] : textLines,\n origin: origin || (paste ? \"paste\" : cm.state.cutIncoming ? \"cut\" : \"+input\")};\n makeChange(cm.doc, changeEvent);\n signalLater(cm, \"inputRead\", cm, changeEvent);\n }\n if (inserted && !paste)\n triggerElectric(cm, inserted);\n\n ensureCursorVisible(cm);\n cm.curOp.updateInput = updateInput;\n cm.curOp.typing = true;\n cm.state.pasteIncoming = cm.state.cutIncoming = false;\n }\n\n function handlePaste(e, cm) {\n var pasted = e.clipboardData && e.clipboardData.getData(\"text/plain\");\n if (pasted) {\n e.preventDefault();\n if (!cm.isReadOnly() && !cm.options.disableInput)\n runInOp(cm, function() { applyTextInput(cm, pasted, 0, null, \"paste\"); });\n return true;\n }\n }\n\n function triggerElectric(cm, inserted) {\n // When an 'electric' character is inserted, immediately trigger a reindent\n if (!cm.options.electricChars || !cm.options.smartIndent) return;\n var sel = cm.doc.sel;\n\n for (var i = sel.ranges.length - 1; i >= 0; i--) {\n var range = sel.ranges[i];\n if (range.head.ch > 100 || (i && sel.ranges[i - 1].head.line == range.head.line)) continue;\n var mode = cm.getModeAt(range.head);\n var indented = false;\n if (mode.electricChars) {\n for (var j = 0; j < mode.electricChars.length; j++)\n if (inserted.indexOf(mode.electricChars.charAt(j)) > -1) {\n indented = indentLine(cm, range.head.line, \"smart\");\n break;\n }\n } else if (mode.electricInput) {\n if (mode.electricInput.test(getLine(cm.doc, range.head.line).text.slice(0, range.head.ch)))\n indented = indentLine(cm, range.head.line, \"smart\");\n }\n if (indented) signalLater(cm, \"electricInput\", cm, range.head.line);\n }\n }\n\n function copyableRanges(cm) {\n var text = [], ranges = [];\n for (var i = 0; i < cm.doc.sel.ranges.length; i++) {\n var line = cm.doc.sel.ranges[i].head.line;\n var lineRange = {anchor: Pos(line, 0), head: Pos(line + 1, 0)};\n ranges.push(lineRange);\n text.push(cm.getRange(lineRange.anchor, lineRange.head));\n }\n return {text: text, ranges: ranges};\n }\n\n function disableBrowserMagic(field) {\n field.setAttribute(\"autocorrect\", \"off\");\n field.setAttribute(\"autocapitalize\", \"off\");\n field.setAttribute(\"spellcheck\", \"false\");\n }\n\n // TEXTAREA INPUT STYLE\n\n function TextareaInput(cm) {\n this.cm = cm;\n // See input.poll and input.reset\n this.prevInput = \"\";\n\n // Flag that indicates whether we expect input to appear real soon\n // now (after some event like 'keypress' or 'input') and are\n // polling intensively.\n this.pollingFast = false;\n // Self-resetting timeout for the poller\n this.polling = new Delayed();\n // Tracks when input.reset has punted to just putting a short\n // string into the textarea instead of the full selection.\n this.inaccurateSelection = false;\n // Used to work around IE issue with selection being forgotten when focus moves away from textarea\n this.hasSelection = false;\n this.composing = null;\n };\n\n function hiddenTextarea() {\n var te = elt(\"textarea\", null, null, \"position: absolute; bottom: -1em; padding: 0; width: 1px; height: 1em; outline: none\");\n var div = elt(\"div\", [te], null, \"overflow: hidden; position: relative; width: 3px; height: 0px;\");\n // The textarea is kept positioned near the cursor to prevent the\n // fact that it'll be scrolled into view on input from scrolling\n // our fake cursor out of view. On webkit, when wrap=off, paste is\n // very slow. So make the area wide instead.\n if (webkit) te.style.width = \"1000px\";\n else te.setAttribute(\"wrap\", \"off\");\n // If border: 0; -- iOS fails to open keyboard (issue #1287)\n if (ios) te.style.border = \"1px solid black\";\n disableBrowserMagic(te);\n return div;\n }\n\n TextareaInput.prototype = copyObj({\n init: function(display) {\n var input = this, cm = this.cm;\n\n // Wraps and hides input textarea\n var div = this.wrapper = hiddenTextarea();\n // The semihidden textarea that is focused when the editor is\n // focused, and receives input.\n var te = this.textarea = div.firstChild;\n display.wrapper.insertBefore(div, display.wrapper.firstChild);\n\n // Needed to hide big blue blinking cursor on Mobile Safari (doesn't seem to work in iOS 8 anymore)\n if (ios) te.style.width = \"0px\";\n\n on(te, \"input\", function() {\n if (ie && ie_version >= 9 && input.hasSelection) input.hasSelection = null;\n input.poll();\n });\n\n on(te, \"paste\", function(e) {\n if (signalDOMEvent(cm, e) || handlePaste(e, cm)) return\n\n cm.state.pasteIncoming = true;\n input.fastPoll();\n });\n\n function prepareCopyCut(e) {\n if (signalDOMEvent(cm, e)) return\n if (cm.somethingSelected()) {\n lastCopied = {lineWise: false, text: cm.getSelections()};\n if (input.inaccurateSelection) {\n input.prevInput = \"\";\n input.inaccurateSelection = false;\n te.value = lastCopied.text.join(\"\\n\");\n selectInput(te);\n }\n } else if (!cm.options.lineWiseCopyCut) {\n return;\n } else {\n var ranges = copyableRanges(cm);\n lastCopied = {lineWise: true, text: ranges.text};\n if (e.type == \"cut\") {\n cm.setSelections(ranges.ranges, null, sel_dontScroll);\n } else {\n input.prevInput = \"\";\n te.value = ranges.text.join(\"\\n\");\n selectInput(te);\n }\n }\n if (e.type == \"cut\") cm.state.cutIncoming = true;\n }\n on(te, \"cut\", prepareCopyCut);\n on(te, \"copy\", prepareCopyCut);\n\n on(display.scroller, \"paste\", function(e) {\n if (eventInWidget(display, e) || signalDOMEvent(cm, e)) return;\n cm.state.pasteIncoming = true;\n input.focus();\n });\n\n // Prevent normal selection in the editor (we handle our own)\n on(display.lineSpace, \"selectstart\", function(e) {\n if (!eventInWidget(display, e)) e_preventDefault(e);\n });\n\n on(te, \"compositionstart\", function() {\n var start = cm.getCursor(\"from\");\n if (input.composing) input.composing.range.clear()\n input.composing = {\n start: start,\n range: cm.markText(start, cm.getCursor(\"to\"), {className: \"CodeMirror-composing\"})\n };\n });\n on(te, \"compositionend\", function() {\n if (input.composing) {\n input.poll();\n input.composing.range.clear();\n input.composing = null;\n }\n });\n },\n\n prepareSelection: function() {\n // Redraw the selection and/or cursor\n var cm = this.cm, display = cm.display, doc = cm.doc;\n var result = prepareSelection(cm);\n\n // Move the hidden textarea near the cursor to prevent scrolling artifacts\n if (cm.options.moveInputWithCursor) {\n var headPos = cursorCoords(cm, doc.sel.primary().head, \"div\");\n var wrapOff = display.wrapper.getBoundingClientRect(), lineOff = display.lineDiv.getBoundingClientRect();\n result.teTop = Math.max(0, Math.min(display.wrapper.clientHeight - 10,\n headPos.top + lineOff.top - wrapOff.top));\n result.teLeft = Math.max(0, Math.min(display.wrapper.clientWidth - 10,\n headPos.left + lineOff.left - wrapOff.left));\n }\n\n return result;\n },\n\n showSelection: function(drawn) {\n var cm = this.cm, display = cm.display;\n removeChildrenAndAdd(display.cursorDiv, drawn.cursors);\n removeChildrenAndAdd(display.selectionDiv, drawn.selection);\n if (drawn.teTop != null) {\n this.wrapper.style.top = drawn.teTop + \"px\";\n this.wrapper.style.left = drawn.teLeft + \"px\";\n }\n },\n\n // Reset the input to correspond to the selection (or to be empty,\n // when not typing and nothing is selected)\n reset: function(typing) {\n if (this.contextMenuPending) return;\n var minimal, selected, cm = this.cm, doc = cm.doc;\n if (cm.somethingSelected()) {\n this.prevInput = \"\";\n var range = doc.sel.primary();\n minimal = hasCopyEvent &&\n (range.to().line - range.from().line > 100 || (selected = cm.getSelection()).length > 1000);\n var content = minimal ? \"-\" : selected || cm.getSelection();\n this.textarea.value = content;\n if (cm.state.focused) selectInput(this.textarea);\n if (ie && ie_version >= 9) this.hasSelection = content;\n } else if (!typing) {\n this.prevInput = this.textarea.value = \"\";\n if (ie && ie_version >= 9) this.hasSelection = null;\n }\n this.inaccurateSelection = minimal;\n },\n\n getField: function() { return this.textarea; },\n\n supportsTouch: function() { return false; },\n\n focus: function() {\n if (this.cm.options.readOnly != \"nocursor\" && (!mobile || activeElt() != this.textarea)) {\n try { this.textarea.focus(); }\n catch (e) {} // IE8 will throw if the textarea is display: none or not in DOM\n }\n },\n\n blur: function() { this.textarea.blur(); },\n\n resetPosition: function() {\n this.wrapper.style.top = this.wrapper.style.left = 0;\n },\n\n receivedFocus: function() { this.slowPoll(); },\n\n // Poll for input changes, using the normal rate of polling. This\n // runs as long as the editor is focused.\n slowPoll: function() {\n var input = this;\n if (input.pollingFast) return;\n input.polling.set(this.cm.options.pollInterval, function() {\n input.poll();\n if (input.cm.state.focused) input.slowPoll();\n });\n },\n\n // When an event has just come in that is likely to add or change\n // something in the input textarea, we poll faster, to ensure that\n // the change appears on the screen quickly.\n fastPoll: function() {\n var missed = false, input = this;\n input.pollingFast = true;\n function p() {\n var changed = input.poll();\n if (!changed && !missed) {missed = true; input.polling.set(60, p);}\n else {input.pollingFast = false; input.slowPoll();}\n }\n input.polling.set(20, p);\n },\n\n // Read input from the textarea, and update the document to match.\n // When something is selected, it is present in the textarea, and\n // selected (unless it is huge, in which case a placeholder is\n // used). When nothing is selected, the cursor sits after previously\n // seen text (can be empty), which is stored in prevInput (we must\n // not reset the textarea when typing, because that breaks IME).\n poll: function() {\n var cm = this.cm, input = this.textarea, prevInput = this.prevInput;\n // Since this is called a *lot*, try to bail out as cheaply as\n // possible when it is clear that nothing happened. hasSelection\n // will be the case when there is a lot of text in the textarea,\n // in which case reading its value would be expensive.\n if (this.contextMenuPending || !cm.state.focused ||\n (hasSelection(input) && !prevInput && !this.composing) ||\n cm.isReadOnly() || cm.options.disableInput || cm.state.keySeq)\n return false;\n\n var text = input.value;\n // If nothing changed, bail.\n if (text == prevInput && !cm.somethingSelected()) return false;\n // Work around nonsensical selection resetting in IE9/10, and\n // inexplicable appearance of private area unicode characters on\n // some key combos in Mac (#2689).\n if (ie && ie_version >= 9 && this.hasSelection === text ||\n mac && /[\\uf700-\\uf7ff]/.test(text)) {\n cm.display.input.reset();\n return false;\n }\n\n if (cm.doc.sel == cm.display.selForContextMenu) {\n var first = text.charCodeAt(0);\n if (first == 0x200b && !prevInput) prevInput = \"\\u200b\";\n if (first == 0x21da) { this.reset(); return this.cm.execCommand(\"undo\"); }\n }\n // Find the part of the input that is actually new\n var same = 0, l = Math.min(prevInput.length, text.length);\n while (same < l && prevInput.charCodeAt(same) == text.charCodeAt(same)) ++same;\n\n var self = this;\n runInOp(cm, function() {\n applyTextInput(cm, text.slice(same), prevInput.length - same,\n null, self.composing ? \"*compose\" : null);\n\n // Don't leave long text in the textarea, since it makes further polling slow\n if (text.length > 1000 || text.indexOf(\"\\n\") > -1) input.value = self.prevInput = \"\";\n else self.prevInput = text;\n\n if (self.composing) {\n self.composing.range.clear();\n self.composing.range = cm.markText(self.composing.start, cm.getCursor(\"to\"),\n {className: \"CodeMirror-composing\"});\n }\n });\n return true;\n },\n\n ensurePolled: function() {\n if (this.pollingFast && this.poll()) this.pollingFast = false;\n },\n\n onKeyPress: function() {\n if (ie && ie_version >= 9) this.hasSelection = null;\n this.fastPoll();\n },\n\n onContextMenu: function(e) {\n var input = this, cm = input.cm, display = cm.display, te = input.textarea;\n var pos = posFromMouse(cm, e), scrollPos = display.scroller.scrollTop;\n if (!pos || presto) return; // Opera is difficult.\n\n // Reset the current text selection only if the click is done outside of the selection\n // and 'resetSelectionOnContextMenu' option is true.\n var reset = cm.options.resetSelectionOnContextMenu;\n if (reset && cm.doc.sel.contains(pos) == -1)\n operation(cm, setSelection)(cm.doc, simpleSelection(pos), sel_dontScroll);\n\n var oldCSS = te.style.cssText, oldWrapperCSS = input.wrapper.style.cssText;\n input.wrapper.style.cssText = \"position: absolute\"\n var wrapperBox = input.wrapper.getBoundingClientRect()\n te.style.cssText = \"position: absolute; width: 30px; height: 30px; top: \" + (e.clientY - wrapperBox.top - 5) +\n \"px; left: \" + (e.clientX - wrapperBox.left - 5) + \"px; z-index: 1000; background: \" +\n (ie ? \"rgba(255, 255, 255, .05)\" : \"transparent\") +\n \"; outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);\";\n if (webkit) var oldScrollY = window.scrollY; // Work around Chrome issue (#2712)\n display.input.focus();\n if (webkit) window.scrollTo(null, oldScrollY);\n display.input.reset();\n // Adds \"Select all\" to context menu in FF\n if (!cm.somethingSelected()) te.value = input.prevInput = \" \";\n input.contextMenuPending = true;\n display.selForContextMenu = cm.doc.sel;\n clearTimeout(display.detectingSelectAll);\n\n // Select-all will be greyed out if there's nothing to select, so\n // this adds a zero-width space so that we can later check whether\n // it got selected.\n function prepareSelectAllHack() {\n if (te.selectionStart != null) {\n var selected = cm.somethingSelected();\n var extval = \"\\u200b\" + (selected ? te.value : \"\");\n te.value = \"\\u21da\"; // Used to catch context-menu undo\n te.value = extval;\n input.prevInput = selected ? \"\" : \"\\u200b\";\n te.selectionStart = 1; te.selectionEnd = extval.length;\n // Re-set this, in case some other handler touched the\n // selection in the meantime.\n display.selForContextMenu = cm.doc.sel;\n }\n }\n function rehide() {\n input.contextMenuPending = false;\n input.wrapper.style.cssText = oldWrapperCSS\n te.style.cssText = oldCSS;\n if (ie && ie_version < 9) display.scrollbars.setScrollTop(display.scroller.scrollTop = scrollPos);\n\n // Try to detect the user choosing select-all\n if (te.selectionStart != null) {\n if (!ie || (ie && ie_version < 9)) prepareSelectAllHack();\n var i = 0, poll = function() {\n if (display.selForContextMenu == cm.doc.sel && te.selectionStart == 0 &&\n te.selectionEnd > 0 && input.prevInput == \"\\u200b\")\n operation(cm, commands.selectAll)(cm);\n else if (i++ < 10) display.detectingSelectAll = setTimeout(poll, 500);\n else display.input.reset();\n };\n display.detectingSelectAll = setTimeout(poll, 200);\n }\n }\n\n if (ie && ie_version >= 9) prepareSelectAllHack();\n if (captureRightClick) {\n e_stop(e);\n var mouseup = function() {\n off(window, \"mouseup\", mouseup);\n setTimeout(rehide, 20);\n };\n on(window, \"mouseup\", mouseup);\n } else {\n setTimeout(rehide, 50);\n }\n },\n\n readOnlyChanged: function(val) {\n if (!val) this.reset();\n },\n\n setUneditable: nothing,\n\n needsContentAttribute: false\n }, TextareaInput.prototype);\n\n // CONTENTEDITABLE INPUT STYLE\n\n function ContentEditableInput(cm) {\n this.cm = cm;\n this.lastAnchorNode = this.lastAnchorOffset = this.lastFocusNode = this.lastFocusOffset = null;\n this.polling = new Delayed();\n this.gracePeriod = false;\n }\n\n ContentEditableInput.prototype = copyObj({\n init: function(display) {\n var input = this, cm = input.cm;\n var div = input.div = display.lineDiv;\n disableBrowserMagic(div);\n\n on(div, \"paste\", function(e) {\n if (!signalDOMEvent(cm, e)) handlePaste(e, cm);\n })\n\n on(div, \"compositionstart\", function(e) {\n var data = e.data;\n input.composing = {sel: cm.doc.sel, data: data, startData: data};\n if (!data) return;\n var prim = cm.doc.sel.primary();\n var line = cm.getLine(prim.head.line);\n var found = line.indexOf(data, Math.max(0, prim.head.ch - data.length));\n if (found > -1 && found <= prim.head.ch)\n input.composing.sel = simpleSelection(Pos(prim.head.line, found),\n Pos(prim.head.line, found + data.length));\n });\n on(div, \"compositionupdate\", function(e) {\n input.composing.data = e.data;\n });\n on(div, \"compositionend\", function(e) {\n var ours = input.composing;\n if (!ours) return;\n if (e.data != ours.startData && !/\\u200b/.test(e.data))\n ours.data = e.data;\n // Need a small delay to prevent other code (input event,\n // selection polling) from doing damage when fired right after\n // compositionend.\n setTimeout(function() {\n if (!ours.handled)\n input.applyComposition(ours);\n if (input.composing == ours)\n input.composing = null;\n }, 50);\n });\n\n on(div, \"touchstart\", function() {\n input.forceCompositionEnd();\n });\n\n on(div, \"input\", function() {\n if (input.composing) return;\n if (cm.isReadOnly() || !input.pollContent())\n runInOp(input.cm, function() {regChange(cm);});\n });\n\n function onCopyCut(e) {\n if (signalDOMEvent(cm, e)) return\n if (cm.somethingSelected()) {\n lastCopied = {lineWise: false, text: cm.getSelections()};\n if (e.type == \"cut\") cm.replaceSelection(\"\", null, \"cut\");\n } else if (!cm.options.lineWiseCopyCut) {\n return;\n } else {\n var ranges = copyableRanges(cm);\n lastCopied = {lineWise: true, text: ranges.text};\n if (e.type == \"cut\") {\n cm.operation(function() {\n cm.setSelections(ranges.ranges, 0, sel_dontScroll);\n cm.replaceSelection(\"\", null, \"cut\");\n });\n }\n }\n // iOS exposes the clipboard API, but seems to discard content inserted into it\n if (e.clipboardData && !ios) {\n e.preventDefault();\n e.clipboardData.clearData();\n e.clipboardData.setData(\"text/plain\", lastCopied.text.join(\"\\n\"));\n } else {\n // Old-fashioned briefly-focus-a-textarea hack\n var kludge = hiddenTextarea(), te = kludge.firstChild;\n cm.display.lineSpace.insertBefore(kludge, cm.display.lineSpace.firstChild);\n te.value = lastCopied.text.join(\"\\n\");\n var hadFocus = document.activeElement;\n selectInput(te);\n setTimeout(function() {\n cm.display.lineSpace.removeChild(kludge);\n hadFocus.focus();\n }, 50);\n }\n }\n on(div, \"copy\", onCopyCut);\n on(div, \"cut\", onCopyCut);\n },\n\n prepareSelection: function() {\n var result = prepareSelection(this.cm, false);\n result.focus = this.cm.state.focused;\n return result;\n },\n\n showSelection: function(info, takeFocus) {\n if (!info || !this.cm.display.view.length) return;\n if (info.focus || takeFocus) this.showPrimarySelection();\n this.showMultipleSelections(info);\n },\n\n showPrimarySelection: function() {\n var sel = window.getSelection(), prim = this.cm.doc.sel.primary();\n var curAnchor = domToPos(this.cm, sel.anchorNode, sel.anchorOffset);\n var curFocus = domToPos(this.cm, sel.focusNode, sel.focusOffset);\n if (curAnchor && !curAnchor.bad && curFocus && !curFocus.bad &&\n cmp(minPos(curAnchor, curFocus), prim.from()) == 0 &&\n cmp(maxPos(curAnchor, curFocus), prim.to()) == 0)\n return;\n\n var start = posToDOM(this.cm, prim.from());\n var end = posToDOM(this.cm, prim.to());\n if (!start && !end) return;\n\n var view = this.cm.display.view;\n var old = sel.rangeCount && sel.getRangeAt(0);\n if (!start) {\n start = {node: view[0].measure.map[2], offset: 0};\n } else if (!end) { // FIXME dangerously hacky\n var measure = view[view.length - 1].measure;\n var map = measure.maps ? measure.maps[measure.maps.length - 1] : measure.map;\n end = {node: map[map.length - 1], offset: map[map.length - 2] - map[map.length - 3]};\n }\n\n try { var rng = range(start.node, start.offset, end.offset, end.node); }\n catch(e) {} // Our model of the DOM might be outdated, in which case the range we try to set can be impossible\n if (rng) {\n if (!gecko && this.cm.state.focused) {\n sel.collapse(start.node, start.offset);\n if (!rng.collapsed) sel.addRange(rng);\n } else {\n sel.removeAllRanges();\n sel.addRange(rng);\n }\n if (old && sel.anchorNode == null) sel.addRange(old);\n else if (gecko) this.startGracePeriod();\n }\n this.rememberSelection();\n },\n\n startGracePeriod: function() {\n var input = this;\n clearTimeout(this.gracePeriod);\n this.gracePeriod = setTimeout(function() {\n input.gracePeriod = false;\n if (input.selectionChanged())\n input.cm.operation(function() { input.cm.curOp.selectionChanged = true; });\n }, 20);\n },\n\n showMultipleSelections: function(info) {\n removeChildrenAndAdd(this.cm.display.cursorDiv, info.cursors);\n removeChildrenAndAdd(this.cm.display.selectionDiv, info.selection);\n },\n\n rememberSelection: function() {\n var sel = window.getSelection();\n this.lastAnchorNode = sel.anchorNode; this.lastAnchorOffset = sel.anchorOffset;\n this.lastFocusNode = sel.focusNode; this.lastFocusOffset = sel.focusOffset;\n },\n\n selectionInEditor: function() {\n var sel = window.getSelection();\n if (!sel.rangeCount) return false;\n var node = sel.getRangeAt(0).commonAncestorContainer;\n return contains(this.div, node);\n },\n\n focus: function() {\n if (this.cm.options.readOnly != \"nocursor\") this.div.focus();\n },\n blur: function() { this.div.blur(); },\n getField: function() { return this.div; },\n\n supportsTouch: function() { return true; },\n\n receivedFocus: function() {\n var input = this;\n if (this.selectionInEditor())\n this.pollSelection();\n else\n runInOp(this.cm, function() { input.cm.curOp.selectionChanged = true; });\n\n function poll() {\n if (input.cm.state.focused) {\n input.pollSelection();\n input.polling.set(input.cm.options.pollInterval, poll);\n }\n }\n this.polling.set(this.cm.options.pollInterval, poll);\n },\n\n selectionChanged: function() {\n var sel = window.getSelection();\n return sel.anchorNode != this.lastAnchorNode || sel.anchorOffset != this.lastAnchorOffset ||\n sel.focusNode != this.lastFocusNode || sel.focusOffset != this.lastFocusOffset;\n },\n\n pollSelection: function() {\n if (!this.composing && !this.gracePeriod && this.selectionChanged()) {\n var sel = window.getSelection(), cm = this.cm;\n this.rememberSelection();\n var anchor = domToPos(cm, sel.anchorNode, sel.anchorOffset);\n var head = domToPos(cm, sel.focusNode, sel.focusOffset);\n if (anchor && head) runInOp(cm, function() {\n setSelection(cm.doc, simpleSelection(anchor, head), sel_dontScroll);\n if (anchor.bad || head.bad) cm.curOp.selectionChanged = true;\n });\n }\n },\n\n pollContent: function() {\n var cm = this.cm, display = cm.display, sel = cm.doc.sel.primary();\n var from = sel.from(), to = sel.to();\n if (from.line < display.viewFrom || to.line > display.viewTo - 1) return false;\n\n var fromIndex;\n if (from.line == display.viewFrom || (fromIndex = findViewIndex(cm, from.line)) == 0) {\n var fromLine = lineNo(display.view[0].line);\n var fromNode = display.view[0].node;\n } else {\n var fromLine = lineNo(display.view[fromIndex].line);\n var fromNode = display.view[fromIndex - 1].node.nextSibling;\n }\n var toIndex = findViewIndex(cm, to.line);\n if (toIndex == display.view.length - 1) {\n var toLine = display.viewTo - 1;\n var toNode = display.lineDiv.lastChild;\n } else {\n var toLine = lineNo(display.view[toIndex + 1].line) - 1;\n var toNode = display.view[toIndex + 1].node.previousSibling;\n }\n\n var newText = cm.doc.splitLines(domTextBetween(cm, fromNode, toNode, fromLine, toLine));\n var oldText = getBetween(cm.doc, Pos(fromLine, 0), Pos(toLine, getLine(cm.doc, toLine).text.length));\n while (newText.length > 1 && oldText.length > 1) {\n if (lst(newText) == lst(oldText)) { newText.pop(); oldText.pop(); toLine--; }\n else if (newText[0] == oldText[0]) { newText.shift(); oldText.shift(); fromLine++; }\n else break;\n }\n\n var cutFront = 0, cutEnd = 0;\n var newTop = newText[0], oldTop = oldText[0], maxCutFront = Math.min(newTop.length, oldTop.length);\n while (cutFront < maxCutFront && newTop.charCodeAt(cutFront) == oldTop.charCodeAt(cutFront))\n ++cutFront;\n var newBot = lst(newText), oldBot = lst(oldText);\n var maxCutEnd = Math.min(newBot.length - (newText.length == 1 ? cutFront : 0),\n oldBot.length - (oldText.length == 1 ? cutFront : 0));\n while (cutEnd < maxCutEnd &&\n newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1))\n ++cutEnd;\n\n newText[newText.length - 1] = newBot.slice(0, newBot.length - cutEnd);\n newText[0] = newText[0].slice(cutFront);\n\n var chFrom = Pos(fromLine, cutFront);\n var chTo = Pos(toLine, oldText.length ? lst(oldText).length - cutEnd : 0);\n if (newText.length > 1 || newText[0] || cmp(chFrom, chTo)) {\n replaceRange(cm.doc, newText, chFrom, chTo, \"+input\");\n return true;\n }\n },\n\n ensurePolled: function() {\n this.forceCompositionEnd();\n },\n reset: function() {\n this.forceCompositionEnd();\n },\n forceCompositionEnd: function() {\n if (!this.composing || this.composing.handled) return;\n this.applyComposition(this.composing);\n this.composing.handled = true;\n this.div.blur();\n this.div.focus();\n },\n applyComposition: function(composing) {\n if (this.cm.isReadOnly())\n operation(this.cm, regChange)(this.cm)\n else if (composing.data && composing.data != composing.startData)\n operation(this.cm, applyTextInput)(this.cm, composing.data, 0, composing.sel);\n },\n\n setUneditable: function(node) {\n node.contentEditable = \"false\"\n },\n\n onKeyPress: function(e) {\n e.preventDefault();\n if (!this.cm.isReadOnly())\n operation(this.cm, applyTextInput)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0);\n },\n\n readOnlyChanged: function(val) {\n this.div.contentEditable = String(val != \"nocursor\")\n },\n\n onContextMenu: nothing,\n resetPosition: nothing,\n\n needsContentAttribute: true\n }, ContentEditableInput.prototype);\n\n function posToDOM(cm, pos) {\n var view = findViewForLine(cm, pos.line);\n if (!view || view.hidden) return null;\n var line = getLine(cm.doc, pos.line);\n var info = mapFromLineView(view, line, pos.line);\n\n var order = getOrder(line), side = \"left\";\n if (order) {\n var partPos = getBidiPartAt(order, pos.ch);\n side = partPos % 2 ? \"right\" : \"left\";\n }\n var result = nodeAndOffsetInLineMap(info.map, pos.ch, side);\n result.offset = result.collapse == \"right\" ? result.end : result.start;\n return result;\n }\n\n function badPos(pos, bad) { if (bad) pos.bad = true; return pos; }\n\n function domToPos(cm, node, offset) {\n var lineNode;\n if (node == cm.display.lineDiv) {\n lineNode = cm.display.lineDiv.childNodes[offset];\n if (!lineNode) return badPos(cm.clipPos(Pos(cm.display.viewTo - 1)), true);\n node = null; offset = 0;\n } else {\n for (lineNode = node;; lineNode = lineNode.parentNode) {\n if (!lineNode || lineNode == cm.display.lineDiv) return null;\n if (lineNode.parentNode && lineNode.parentNode == cm.display.lineDiv) break;\n }\n }\n for (var i = 0; i < cm.display.view.length; i++) {\n var lineView = cm.display.view[i];\n if (lineView.node == lineNode)\n return locateNodeInLineView(lineView, node, offset);\n }\n }\n\n function locateNodeInLineView(lineView, node, offset) {\n var wrapper = lineView.text.firstChild, bad = false;\n if (!node || !contains(wrapper, node)) return badPos(Pos(lineNo(lineView.line), 0), true);\n if (node == wrapper) {\n bad = true;\n node = wrapper.childNodes[offset];\n offset = 0;\n if (!node) {\n var line = lineView.rest ? lst(lineView.rest) : lineView.line;\n return badPos(Pos(lineNo(line), line.text.length), bad);\n }\n }\n\n var textNode = node.nodeType == 3 ? node : null, topNode = node;\n if (!textNode && node.childNodes.length == 1 && node.firstChild.nodeType == 3) {\n textNode = node.firstChild;\n if (offset) offset = textNode.nodeValue.length;\n }\n while (topNode.parentNode != wrapper) topNode = topNode.parentNode;\n var measure = lineView.measure, maps = measure.maps;\n\n function find(textNode, topNode, offset) {\n for (var i = -1; i < (maps ? maps.length : 0); i++) {\n var map = i < 0 ? measure.map : maps[i];\n for (var j = 0; j < map.length; j += 3) {\n var curNode = map[j + 2];\n if (curNode == textNode || curNode == topNode) {\n var line = lineNo(i < 0 ? lineView.line : lineView.rest[i]);\n var ch = map[j] + offset;\n if (offset < 0 || curNode != textNode) ch = map[j + (offset ? 1 : 0)];\n return Pos(line, ch);\n }\n }\n }\n }\n var found = find(textNode, topNode, offset);\n if (found) return badPos(found, bad);\n\n // FIXME this is all really shaky. might handle the few cases it needs to handle, but likely to cause problems\n for (var after = topNode.nextSibling, dist = textNode ? textNode.nodeValue.length - offset : 0; after; after = after.nextSibling) {\n found = find(after, after.firstChild, 0);\n if (found)\n return badPos(Pos(found.line, found.ch - dist), bad);\n else\n dist += after.textContent.length;\n }\n for (var before = topNode.previousSibling, dist = offset; before; before = before.previousSibling) {\n found = find(before, before.firstChild, -1);\n if (found)\n return badPos(Pos(found.line, found.ch + dist), bad);\n else\n dist += after.textContent.length;\n }\n }\n\n function domTextBetween(cm, from, to, fromLine, toLine) {\n var text = \"\", closing = false, lineSep = cm.doc.lineSeparator();\n function recognizeMarker(id) { return function(marker) { return marker.id == id; }; }\n function walk(node) {\n if (node.nodeType == 1) {\n var cmText = node.getAttribute(\"cm-text\");\n if (cmText != null) {\n if (cmText == \"\") cmText = node.textContent.replace(/\\u200b/g, \"\");\n text += cmText;\n return;\n }\n var markerID = node.getAttribute(\"cm-marker\"), range;\n if (markerID) {\n var found = cm.findMarks(Pos(fromLine, 0), Pos(toLine + 1, 0), recognizeMarker(+markerID));\n if (found.length && (range = found[0].find()))\n text += getBetween(cm.doc, range.from, range.to).join(lineSep);\n return;\n }\n if (node.getAttribute(\"contenteditable\") == \"false\") return;\n for (var i = 0; i < node.childNodes.length; i++)\n walk(node.childNodes[i]);\n if (/^(pre|div|p)$/i.test(node.nodeName))\n closing = true;\n } else if (node.nodeType == 3) {\n var val = node.nodeValue;\n if (!val) return;\n if (closing) {\n text += lineSep;\n closing = false;\n }\n text += val;\n }\n }\n for (;;) {\n walk(from);\n if (from == to) break;\n from = from.nextSibling;\n }\n return text;\n }\n\n CodeMirror.inputStyles = {\"textarea\": TextareaInput, \"contenteditable\": ContentEditableInput};\n\n // SELECTION / CURSOR\n\n // Selection objects are immutable. A new one is created every time\n // the selection changes. A selection is one or more non-overlapping\n // (and non-touching) ranges, sorted, and an integer that indicates\n // which one is the primary selection (the one that's scrolled into\n // view, that getCursor returns, etc).\n function Selection(ranges, primIndex) {\n this.ranges = ranges;\n this.primIndex = primIndex;\n }\n\n Selection.prototype = {\n primary: function() { return this.ranges[this.primIndex]; },\n equals: function(other) {\n if (other == this) return true;\n if (other.primIndex != this.primIndex || other.ranges.length != this.ranges.length) return false;\n for (var i = 0; i < this.ranges.length; i++) {\n var here = this.ranges[i], there = other.ranges[i];\n if (cmp(here.anchor, there.anchor) != 0 || cmp(here.head, there.head) != 0) return false;\n }\n return true;\n },\n deepCopy: function() {\n for (var out = [], i = 0; i < this.ranges.length; i++)\n out[i] = new Range(copyPos(this.ranges[i].anchor), copyPos(this.ranges[i].head));\n return new Selection(out, this.primIndex);\n },\n somethingSelected: function() {\n for (var i = 0; i < this.ranges.length; i++)\n if (!this.ranges[i].empty()) return true;\n return false;\n },\n contains: function(pos, end) {\n if (!end) end = pos;\n for (var i = 0; i < this.ranges.length; i++) {\n var range = this.ranges[i];\n if (cmp(end, range.from()) >= 0 && cmp(pos, range.to()) <= 0)\n return i;\n }\n return -1;\n }\n };\n\n function Range(anchor, head) {\n this.anchor = anchor; this.head = head;\n }\n\n Range.prototype = {\n from: function() { return minPos(this.anchor, this.head); },\n to: function() { return maxPos(this.anchor, this.head); },\n empty: function() {\n return this.head.line == this.anchor.line && this.head.ch == this.anchor.ch;\n }\n };\n\n // Take an unsorted, potentially overlapping set of ranges, and\n // build a selection out of it. 'Consumes' ranges array (modifying\n // it).\n function normalizeSelection(ranges, primIndex) {\n var prim = ranges[primIndex];\n ranges.sort(function(a, b) { return cmp(a.from(), b.from()); });\n primIndex = indexOf(ranges, prim);\n for (var i = 1; i < ranges.length; i++) {\n var cur = ranges[i], prev = ranges[i - 1];\n if (cmp(prev.to(), cur.from()) >= 0) {\n var from = minPos(prev.from(), cur.from()), to = maxPos(prev.to(), cur.to());\n var inv = prev.empty() ? cur.from() == cur.head : prev.from() == prev.head;\n if (i <= primIndex) --primIndex;\n ranges.splice(--i, 2, new Range(inv ? to : from, inv ? from : to));\n }\n }\n return new Selection(ranges, primIndex);\n }\n\n function simpleSelection(anchor, head) {\n return new Selection([new Range(anchor, head || anchor)], 0);\n }\n\n // Most of the external API clips given positions to make sure they\n // actually exist within the document.\n function clipLine(doc, n) {return Math.max(doc.first, Math.min(n, doc.first + doc.size - 1));}\n function clipPos(doc, pos) {\n if (pos.line < doc.first) return Pos(doc.first, 0);\n var last = doc.first + doc.size - 1;\n if (pos.line > last) return Pos(last, getLine(doc, last).text.length);\n return clipToLen(pos, getLine(doc, pos.line).text.length);\n }\n function clipToLen(pos, linelen) {\n var ch = pos.ch;\n if (ch == null || ch > linelen) return Pos(pos.line, linelen);\n else if (ch < 0) return Pos(pos.line, 0);\n else return pos;\n }\n function isLine(doc, l) {return l >= doc.first && l < doc.first + doc.size;}\n function clipPosArray(doc, array) {\n for (var out = [], i = 0; i < array.length; i++) out[i] = clipPos(doc, array[i]);\n return out;\n }\n\n // SELECTION UPDATES\n\n // The 'scroll' parameter given to many of these indicated whether\n // the new cursor position should be scrolled into view after\n // modifying the selection.\n\n // If shift is held or the extend flag is set, extends a range to\n // include a given position (and optionally a second position).\n // Otherwise, simply returns the range between the given positions.\n // Used for cursor motion and such.\n function extendRange(doc, range, head, other) {\n if (doc.cm && doc.cm.display.shift || doc.extend) {\n var anchor = range.anchor;\n if (other) {\n var posBefore = cmp(head, anchor) < 0;\n if (posBefore != (cmp(other, anchor) < 0)) {\n anchor = head;\n head = other;\n } else if (posBefore != (cmp(head, other) < 0)) {\n head = other;\n }\n }\n return new Range(anchor, head);\n } else {\n return new Range(other || head, head);\n }\n }\n\n // Extend the primary selection range, discard the rest.\n function extendSelection(doc, head, other, options) {\n setSelection(doc, new Selection([extendRange(doc, doc.sel.primary(), head, other)], 0), options);\n }\n\n // Extend all selections (pos is an array of selections with length\n // equal the number of selections)\n function extendSelections(doc, heads, options) {\n for (var out = [], i = 0; i < doc.sel.ranges.length; i++)\n out[i] = extendRange(doc, doc.sel.ranges[i], heads[i], null);\n var newSel = normalizeSelection(out, doc.sel.primIndex);\n setSelection(doc, newSel, options);\n }\n\n // Updates a single range in the selection.\n function replaceOneSelection(doc, i, range, options) {\n var ranges = doc.sel.ranges.slice(0);\n ranges[i] = range;\n setSelection(doc, normalizeSelection(ranges, doc.sel.primIndex), options);\n }\n\n // Reset the selection to a single range.\n function setSimpleSelection(doc, anchor, head, options) {\n setSelection(doc, simpleSelection(anchor, head), options);\n }\n\n // Give beforeSelectionChange handlers a change to influence a\n // selection update.\n function filterSelectionChange(doc, sel, options) {\n var obj = {\n ranges: sel.ranges,\n update: function(ranges) {\n this.ranges = [];\n for (var i = 0; i < ranges.length; i++)\n this.ranges[i] = new Range(clipPos(doc, ranges[i].anchor),\n clipPos(doc, ranges[i].head));\n },\n origin: options && options.origin\n };\n signal(doc, \"beforeSelectionChange\", doc, obj);\n if (doc.cm) signal(doc.cm, \"beforeSelectionChange\", doc.cm, obj);\n if (obj.ranges != sel.ranges) return normalizeSelection(obj.ranges, obj.ranges.length - 1);\n else return sel;\n }\n\n function setSelectionReplaceHistory(doc, sel, options) {\n var done = doc.history.done, last = lst(done);\n if (last && last.ranges) {\n done[done.length - 1] = sel;\n setSelectionNoUndo(doc, sel, options);\n } else {\n setSelection(doc, sel, options);\n }\n }\n\n // Set a new selection.\n function setSelection(doc, sel, options) {\n setSelectionNoUndo(doc, sel, options);\n addSelectionToHistory(doc, doc.sel, doc.cm ? doc.cm.curOp.id : NaN, options);\n }\n\n function setSelectionNoUndo(doc, sel, options) {\n if (hasHandler(doc, \"beforeSelectionChange\") || doc.cm && hasHandler(doc.cm, \"beforeSelectionChange\"))\n sel = filterSelectionChange(doc, sel, options);\n\n var bias = options && options.bias ||\n (cmp(sel.primary().head, doc.sel.primary().head) < 0 ? -1 : 1);\n setSelectionInner(doc, skipAtomicInSelection(doc, sel, bias, true));\n\n if (!(options && options.scroll === false) && doc.cm)\n ensureCursorVisible(doc.cm);\n }\n\n function setSelectionInner(doc, sel) {\n if (sel.equals(doc.sel)) return;\n\n doc.sel = sel;\n\n if (doc.cm) {\n doc.cm.curOp.updateInput = doc.cm.curOp.selectionChanged = true;\n signalCursorActivity(doc.cm);\n }\n signalLater(doc, \"cursorActivity\", doc);\n }\n\n // Verify that the selection does not partially select any atomic\n // marked ranges.\n function reCheckSelection(doc) {\n setSelectionInner(doc, skipAtomicInSelection(doc, doc.sel, null, false), sel_dontScroll);\n }\n\n // Return a selection that does not partially select any atomic\n // ranges.\n function skipAtomicInSelection(doc, sel, bias, mayClear) {\n var out;\n for (var i = 0; i < sel.ranges.length; i++) {\n var range = sel.ranges[i];\n var old = sel.ranges.length == doc.sel.ranges.length && doc.sel.ranges[i];\n var newAnchor = skipAtomic(doc, range.anchor, old && old.anchor, bias, mayClear);\n var newHead = skipAtomic(doc, range.head, old && old.head, bias, mayClear);\n if (out || newAnchor != range.anchor || newHead != range.head) {\n if (!out) out = sel.ranges.slice(0, i);\n out[i] = new Range(newAnchor, newHead);\n }\n }\n return out ? normalizeSelection(out, sel.primIndex) : sel;\n }\n\n function skipAtomicInner(doc, pos, oldPos, dir, mayClear) {\n var line = getLine(doc, pos.line);\n if (line.markedSpans) for (var i = 0; i < line.markedSpans.length; ++i) {\n var sp = line.markedSpans[i], m = sp.marker;\n if ((sp.from == null || (m.inclusiveLeft ? sp.from <= pos.ch : sp.from < pos.ch)) &&\n (sp.to == null || (m.inclusiveRight ? sp.to >= pos.ch : sp.to > pos.ch))) {\n if (mayClear) {\n signal(m, \"beforeCursorEnter\");\n if (m.explicitlyCleared) {\n if (!line.markedSpans) break;\n else {--i; continue;}\n }\n }\n if (!m.atomic) continue;\n\n if (oldPos) {\n var near = m.find(dir < 0 ? 1 : -1), diff;\n if (dir < 0 ? m.inclusiveRight : m.inclusiveLeft)\n near = movePos(doc, near, -dir, near && near.line == pos.line ? line : null);\n if (near && near.line == pos.line && (diff = cmp(near, oldPos)) && (dir < 0 ? diff < 0 : diff > 0))\n return skipAtomicInner(doc, near, pos, dir, mayClear);\n }\n\n var far = m.find(dir < 0 ? -1 : 1);\n if (dir < 0 ? m.inclusiveLeft : m.inclusiveRight)\n far = movePos(doc, far, dir, far.line == pos.line ? line : null);\n return far ? skipAtomicInner(doc, far, pos, dir, mayClear) : null;\n }\n }\n return pos;\n }\n\n // Ensure a given position is not inside an atomic range.\n function skipAtomic(doc, pos, oldPos, bias, mayClear) {\n var dir = bias || 1;\n var found = skipAtomicInner(doc, pos, oldPos, dir, mayClear) ||\n (!mayClear && skipAtomicInner(doc, pos, oldPos, dir, true)) ||\n skipAtomicInner(doc, pos, oldPos, -dir, mayClear) ||\n (!mayClear && skipAtomicInner(doc, pos, oldPos, -dir, true));\n if (!found) {\n doc.cantEdit = true;\n return Pos(doc.first, 0);\n }\n return found;\n }\n\n function movePos(doc, pos, dir, line) {\n if (dir < 0 && pos.ch == 0) {\n if (pos.line > doc.first) return clipPos(doc, Pos(pos.line - 1));\n else return null;\n } else if (dir > 0 && pos.ch == (line || getLine(doc, pos.line)).text.length) {\n if (pos.line < doc.first + doc.size - 1) return Pos(pos.line + 1, 0);\n else return null;\n } else {\n return new Pos(pos.line, pos.ch + dir);\n }\n }\n\n // SELECTION DRAWING\n\n function updateSelection(cm) {\n cm.display.input.showSelection(cm.display.input.prepareSelection());\n }\n\n function prepareSelection(cm, primary) {\n var doc = cm.doc, result = {};\n var curFragment = result.cursors = document.createDocumentFragment();\n var selFragment = result.selection = document.createDocumentFragment();\n\n for (var i = 0; i < doc.sel.ranges.length; i++) {\n if (primary === false && i == doc.sel.primIndex) continue;\n var range = doc.sel.ranges[i];\n if (range.from().line >= cm.display.viewTo || range.to().line < cm.display.viewFrom) continue;\n var collapsed = range.empty();\n if (collapsed || cm.options.showCursorWhenSelecting)\n drawSelectionCursor(cm, range.head, curFragment);\n if (!collapsed)\n drawSelectionRange(cm, range, selFragment);\n }\n return result;\n }\n\n // Draws a cursor for the given range\n function drawSelectionCursor(cm, head, output) {\n var pos = cursorCoords(cm, head, \"div\", null, null, !cm.options.singleCursorHeightPerLine);\n\n var cursor = output.appendChild(elt(\"div\", \"\\u00a0\", \"CodeMirror-cursor\"));\n cursor.style.left = pos.left + \"px\";\n cursor.style.top = pos.top + \"px\";\n cursor.style.height = Math.max(0, pos.bottom - pos.top) * cm.options.cursorHeight + \"px\";\n\n if (pos.other) {\n // Secondary cursor, shown when on a 'jump' in bi-directional text\n var otherCursor = output.appendChild(elt(\"div\", \"\\u00a0\", \"CodeMirror-cursor CodeMirror-secondarycursor\"));\n otherCursor.style.display = \"\";\n otherCursor.style.left = pos.other.left + \"px\";\n otherCursor.style.top = pos.other.top + \"px\";\n otherCursor.style.height = (pos.other.bottom - pos.other.top) * .85 + \"px\";\n }\n }\n\n // Draws the given range as a highlighted selection\n function drawSelectionRange(cm, range, output) {\n var display = cm.display, doc = cm.doc;\n var fragment = document.createDocumentFragment();\n var padding = paddingH(cm.display), leftSide = padding.left;\n var rightSide = Math.max(display.sizerWidth, displayWidth(cm) - display.sizer.offsetLeft) - padding.right;\n\n function add(left, top, width, bottom) {\n if (top < 0) top = 0;\n top = Math.round(top);\n bottom = Math.round(bottom);\n fragment.appendChild(elt(\"div\", null, \"CodeMirror-selected\", \"position: absolute; left: \" + left +\n \"px; top: \" + top + \"px; width: \" + (width == null ? rightSide - left : width) +\n \"px; height: \" + (bottom - top) + \"px\"));\n }\n\n function drawForLine(line, fromArg, toArg) {\n var lineObj = getLine(doc, line);\n var lineLen = lineObj.text.length;\n var start, end;\n function coords(ch, bias) {\n return charCoords(cm, Pos(line, ch), \"div\", lineObj, bias);\n }\n\n iterateBidiSections(getOrder(lineObj), fromArg || 0, toArg == null ? lineLen : toArg, function(from, to, dir) {\n var leftPos = coords(from, \"left\"), rightPos, left, right;\n if (from == to) {\n rightPos = leftPos;\n left = right = leftPos.left;\n } else {\n rightPos = coords(to - 1, \"right\");\n if (dir == \"rtl\") { var tmp = leftPos; leftPos = rightPos; rightPos = tmp; }\n left = leftPos.left;\n right = rightPos.right;\n }\n if (fromArg == null && from == 0) left = leftSide;\n if (rightPos.top - leftPos.top > 3) { // Different lines, draw top part\n add(left, leftPos.top, null, leftPos.bottom);\n left = leftSide;\n if (leftPos.bottom < rightPos.top) add(left, leftPos.bottom, null, rightPos.top);\n }\n if (toArg == null && to == lineLen) right = rightSide;\n if (!start || leftPos.top < start.top || leftPos.top == start.top && leftPos.left < start.left)\n start = leftPos;\n if (!end || rightPos.bottom > end.bottom || rightPos.bottom == end.bottom && rightPos.right > end.right)\n end = rightPos;\n if (left < leftSide + 1) left = leftSide;\n add(left, rightPos.top, right - left, rightPos.bottom);\n });\n return {start: start, end: end};\n }\n\n var sFrom = range.from(), sTo = range.to();\n if (sFrom.line == sTo.line) {\n drawForLine(sFrom.line, sFrom.ch, sTo.ch);\n } else {\n var fromLine = getLine(doc, sFrom.line), toLine = getLine(doc, sTo.line);\n var singleVLine = visualLine(fromLine) == visualLine(toLine);\n var leftEnd = drawForLine(sFrom.line, sFrom.ch, singleVLine ? fromLine.text.length + 1 : null).end;\n var rightStart = drawForLine(sTo.line, singleVLine ? 0 : null, sTo.ch).start;\n if (singleVLine) {\n if (leftEnd.top < rightStart.top - 2) {\n add(leftEnd.right, leftEnd.top, null, leftEnd.bottom);\n add(leftSide, rightStart.top, rightStart.left, rightStart.bottom);\n } else {\n add(leftEnd.right, leftEnd.top, rightStart.left - leftEnd.right, leftEnd.bottom);\n }\n }\n if (leftEnd.bottom < rightStart.top)\n add(leftSide, leftEnd.bottom, null, rightStart.top);\n }\n\n output.appendChild(fragment);\n }\n\n // Cursor-blinking\n function restartBlink(cm) {\n if (!cm.state.focused) return;\n var display = cm.display;\n clearInterval(display.blinker);\n var on = true;\n display.cursorDiv.style.visibility = \"\";\n if (cm.options.cursorBlinkRate > 0)\n display.blinker = setInterval(function() {\n display.cursorDiv.style.visibility = (on = !on) ? \"\" : \"hidden\";\n }, cm.options.cursorBlinkRate);\n else if (cm.options.cursorBlinkRate < 0)\n display.cursorDiv.style.visibility = \"hidden\";\n }\n\n // HIGHLIGHT WORKER\n\n function startWorker(cm, time) {\n if (cm.doc.mode.startState && cm.doc.frontier < cm.display.viewTo)\n cm.state.highlight.set(time, bind(highlightWorker, cm));\n }\n\n function highlightWorker(cm) {\n var doc = cm.doc;\n if (doc.frontier < doc.first) doc.frontier = doc.first;\n if (doc.frontier >= cm.display.viewTo) return;\n var end = +new Date + cm.options.workTime;\n var state = copyState(doc.mode, getStateBefore(cm, doc.frontier));\n var changedLines = [];\n\n doc.iter(doc.frontier, Math.min(doc.first + doc.size, cm.display.viewTo + 500), function(line) {\n if (doc.frontier >= cm.display.viewFrom) { // Visible\n var oldStyles = line.styles, tooLong = line.text.length > cm.options.maxHighlightLength;\n var highlighted = highlightLine(cm, line, tooLong ? copyState(doc.mode, state) : state, true);\n line.styles = highlighted.styles;\n var oldCls = line.styleClasses, newCls = highlighted.classes;\n if (newCls) line.styleClasses = newCls;\n else if (oldCls) line.styleClasses = null;\n var ischange = !oldStyles || oldStyles.length != line.styles.length ||\n oldCls != newCls && (!oldCls || !newCls || oldCls.bgClass != newCls.bgClass || oldCls.textClass != newCls.textClass);\n for (var i = 0; !ischange && i < oldStyles.length; ++i) ischange = oldStyles[i] != line.styles[i];\n if (ischange) changedLines.push(doc.frontier);\n line.stateAfter = tooLong ? state : copyState(doc.mode, state);\n } else {\n if (line.text.length <= cm.options.maxHighlightLength)\n processLine(cm, line.text, state);\n line.stateAfter = doc.frontier % 5 == 0 ? copyState(doc.mode, state) : null;\n }\n ++doc.frontier;\n if (+new Date > end) {\n startWorker(cm, cm.options.workDelay);\n return true;\n }\n });\n if (changedLines.length) runInOp(cm, function() {\n for (var i = 0; i < changedLines.length; i++)\n regLineChange(cm, changedLines[i], \"text\");\n });\n }\n\n // Finds the line to start with when starting a parse. Tries to\n // find a line with a stateAfter, so that it can start with a\n // valid state. If that fails, it returns the line with the\n // smallest indentation, which tends to need the least context to\n // parse correctly.\n function findStartLine(cm, n, precise) {\n var minindent, minline, doc = cm.doc;\n var lim = precise ? -1 : n - (cm.doc.mode.innerMode ? 1000 : 100);\n for (var search = n; search > lim; --search) {\n if (search <= doc.first) return doc.first;\n var line = getLine(doc, search - 1);\n if (line.stateAfter && (!precise || search <= doc.frontier)) return search;\n var indented = countColumn(line.text, null, cm.options.tabSize);\n if (minline == null || minindent > indented) {\n minline = search - 1;\n minindent = indented;\n }\n }\n return minline;\n }\n\n function getStateBefore(cm, n, precise) {\n var doc = cm.doc, display = cm.display;\n if (!doc.mode.startState) return true;\n var pos = findStartLine(cm, n, precise), state = pos > doc.first && getLine(doc, pos-1).stateAfter;\n if (!state) state = startState(doc.mode);\n else state = copyState(doc.mode, state);\n doc.iter(pos, n, function(line) {\n processLine(cm, line.text, state);\n var save = pos == n - 1 || pos % 5 == 0 || pos >= display.viewFrom && pos < display.viewTo;\n line.stateAfter = save ? copyState(doc.mode, state) : null;\n ++pos;\n });\n if (precise) doc.frontier = pos;\n return state;\n }\n\n // POSITION MEASUREMENT\n\n function paddingTop(display) {return display.lineSpace.offsetTop;}\n function paddingVert(display) {return display.mover.offsetHeight - display.lineSpace.offsetHeight;}\n function paddingH(display) {\n if (display.cachedPaddingH) return display.cachedPaddingH;\n var e = removeChildrenAndAdd(display.measure, elt(\"pre\", \"x\"));\n var style = window.getComputedStyle ? window.getComputedStyle(e) : e.currentStyle;\n var data = {left: parseInt(style.paddingLeft), right: parseInt(style.paddingRight)};\n if (!isNaN(data.left) && !isNaN(data.right)) display.cachedPaddingH = data;\n return data;\n }\n\n function scrollGap(cm) { return scrollerGap - cm.display.nativeBarWidth; }\n function displayWidth(cm) {\n return cm.display.scroller.clientWidth - scrollGap(cm) - cm.display.barWidth;\n }\n function displayHeight(cm) {\n return cm.display.scroller.clientHeight - scrollGap(cm) - cm.display.barHeight;\n }\n\n // Ensure the lineView.wrapping.heights array is populated. This is\n // an array of bottom offsets for the lines that make up a drawn\n // line. When lineWrapping is on, there might be more than one\n // height.\n function ensureLineHeights(cm, lineView, rect) {\n var wrapping = cm.options.lineWrapping;\n var curWidth = wrapping && displayWidth(cm);\n if (!lineView.measure.heights || wrapping && lineView.measure.width != curWidth) {\n var heights = lineView.measure.heights = [];\n if (wrapping) {\n lineView.measure.width = curWidth;\n var rects = lineView.text.firstChild.getClientRects();\n for (var i = 0; i < rects.length - 1; i++) {\n var cur = rects[i], next = rects[i + 1];\n if (Math.abs(cur.bottom - next.bottom) > 2)\n heights.push((cur.bottom + next.top) / 2 - rect.top);\n }\n }\n heights.push(rect.bottom - rect.top);\n }\n }\n\n // Find a line map (mapping character offsets to text nodes) and a\n // measurement cache for the given line number. (A line view might\n // contain multiple lines when collapsed ranges are present.)\n function mapFromLineView(lineView, line, lineN) {\n if (lineView.line == line)\n return {map: lineView.measure.map, cache: lineView.measure.cache};\n for (var i = 0; i < lineView.rest.length; i++)\n if (lineView.rest[i] == line)\n return {map: lineView.measure.maps[i], cache: lineView.measure.caches[i]};\n for (var i = 0; i < lineView.rest.length; i++)\n if (lineNo(lineView.rest[i]) > lineN)\n return {map: lineView.measure.maps[i], cache: lineView.measure.caches[i], before: true};\n }\n\n // Render a line into the hidden node display.externalMeasured. Used\n // when measurement is needed for a line that's not in the viewport.\n function updateExternalMeasurement(cm, line) {\n line = visualLine(line);\n var lineN = lineNo(line);\n var view = cm.display.externalMeasured = new LineView(cm.doc, line, lineN);\n view.lineN = lineN;\n var built = view.built = buildLineContent(cm, view);\n view.text = built.pre;\n removeChildrenAndAdd(cm.display.lineMeasure, built.pre);\n return view;\n }\n\n // Get a {top, bottom, left, right} box (in line-local coordinates)\n // for a given character.\n function measureChar(cm, line, ch, bias) {\n return measureCharPrepared(cm, prepareMeasureForLine(cm, line), ch, bias);\n }\n\n // Find a line view that corresponds to the given line number.\n function findViewForLine(cm, lineN) {\n if (lineN >= cm.display.viewFrom && lineN < cm.display.viewTo)\n return cm.display.view[findViewIndex(cm, lineN)];\n var ext = cm.display.externalMeasured;\n if (ext && lineN >= ext.lineN && lineN < ext.lineN + ext.size)\n return ext;\n }\n\n // Measurement can be split in two steps, the set-up work that\n // applies to the whole line, and the measurement of the actual\n // character. Functions like coordsChar, that need to do a lot of\n // measurements in a row, can thus ensure that the set-up work is\n // only done once.\n function prepareMeasureForLine(cm, line) {\n var lineN = lineNo(line);\n var view = findViewForLine(cm, lineN);\n if (view && !view.text) {\n view = null;\n } else if (view && view.changes) {\n updateLineForChanges(cm, view, lineN, getDimensions(cm));\n cm.curOp.forceUpdate = true;\n }\n if (!view)\n view = updateExternalMeasurement(cm, line);\n\n var info = mapFromLineView(view, line, lineN);\n return {\n line: line, view: view, rect: null,\n map: info.map, cache: info.cache, before: info.before,\n hasHeights: false\n };\n }\n\n // Given a prepared measurement object, measures the position of an\n // actual character (or fetches it from the cache).\n function measureCharPrepared(cm, prepared, ch, bias, varHeight) {\n if (prepared.before) ch = -1;\n var key = ch + (bias || \"\"), found;\n if (prepared.cache.hasOwnProperty(key)) {\n found = prepared.cache[key];\n } else {\n if (!prepared.rect)\n prepared.rect = prepared.view.text.getBoundingClientRect();\n if (!prepared.hasHeights) {\n ensureLineHeights(cm, prepared.view, prepared.rect);\n prepared.hasHeights = true;\n }\n found = measureCharInner(cm, prepared, ch, bias);\n if (!found.bogus) prepared.cache[key] = found;\n }\n return {left: found.left, right: found.right,\n top: varHeight ? found.rtop : found.top,\n bottom: varHeight ? found.rbottom : found.bottom};\n }\n\n var nullRect = {left: 0, right: 0, top: 0, bottom: 0};\n\n function nodeAndOffsetInLineMap(map, ch, bias) {\n var node, start, end, collapse;\n // First, search the line map for the text node corresponding to,\n // or closest to, the target character.\n for (var i = 0; i < map.length; i += 3) {\n var mStart = map[i], mEnd = map[i + 1];\n if (ch < mStart) {\n start = 0; end = 1;\n collapse = \"left\";\n } else if (ch < mEnd) {\n start = ch - mStart;\n end = start + 1;\n } else if (i == map.length - 3 || ch == mEnd && map[i + 3] > ch) {\n end = mEnd - mStart;\n start = end - 1;\n if (ch >= mEnd) collapse = \"right\";\n }\n if (start != null) {\n node = map[i + 2];\n if (mStart == mEnd && bias == (node.insertLeft ? \"left\" : \"right\"))\n collapse = bias;\n if (bias == \"left\" && start == 0)\n while (i && map[i - 2] == map[i - 3] && map[i - 1].insertLeft) {\n node = map[(i -= 3) + 2];\n collapse = \"left\";\n }\n if (bias == \"right\" && start == mEnd - mStart)\n while (i < map.length - 3 && map[i + 3] == map[i + 4] && !map[i + 5].insertLeft) {\n node = map[(i += 3) + 2];\n collapse = \"right\";\n }\n break;\n }\n }\n return {node: node, start: start, end: end, collapse: collapse, coverStart: mStart, coverEnd: mEnd};\n }\n\n function getUsefulRect(rects, bias) {\n var rect = nullRect\n if (bias == \"left\") for (var i = 0; i < rects.length; i++) {\n if ((rect = rects[i]).left != rect.right) break\n } else for (var i = rects.length - 1; i >= 0; i--) {\n if ((rect = rects[i]).left != rect.right) break\n }\n return rect\n }\n\n function measureCharInner(cm, prepared, ch, bias) {\n var place = nodeAndOffsetInLineMap(prepared.map, ch, bias);\n var node = place.node, start = place.start, end = place.end, collapse = place.collapse;\n\n var rect;\n if (node.nodeType == 3) { // If it is a text node, use a range to retrieve the coordinates.\n for (var i = 0; i < 4; i++) { // Retry a maximum of 4 times when nonsense rectangles are returned\n while (start && isExtendingChar(prepared.line.text.charAt(place.coverStart + start))) --start;\n while (place.coverStart + end < place.coverEnd && isExtendingChar(prepared.line.text.charAt(place.coverStart + end))) ++end;\n if (ie && ie_version < 9 && start == 0 && end == place.coverEnd - place.coverStart)\n rect = node.parentNode.getBoundingClientRect();\n else\n rect = getUsefulRect(range(node, start, end).getClientRects(), bias)\n if (rect.left || rect.right || start == 0) break;\n end = start;\n start = start - 1;\n collapse = \"right\";\n }\n if (ie && ie_version < 11) rect = maybeUpdateRectForZooming(cm.display.measure, rect);\n } else { // If it is a widget, simply get the box for the whole widget.\n if (start > 0) collapse = bias = \"right\";\n var rects;\n if (cm.options.lineWrapping && (rects = node.getClientRects()).length > 1)\n rect = rects[bias == \"right\" ? rects.length - 1 : 0];\n else\n rect = node.getBoundingClientRect();\n }\n if (ie && ie_version < 9 && !start && (!rect || !rect.left && !rect.right)) {\n var rSpan = node.parentNode.getClientRects()[0];\n if (rSpan)\n rect = {left: rSpan.left, right: rSpan.left + charWidth(cm.display), top: rSpan.top, bottom: rSpan.bottom};\n else\n rect = nullRect;\n }\n\n var rtop = rect.top - prepared.rect.top, rbot = rect.bottom - prepared.rect.top;\n var mid = (rtop + rbot) / 2;\n var heights = prepared.view.measure.heights;\n for (var i = 0; i < heights.length - 1; i++)\n if (mid < heights[i]) break;\n var top = i ? heights[i - 1] : 0, bot = heights[i];\n var result = {left: (collapse == \"right\" ? rect.right : rect.left) - prepared.rect.left,\n right: (collapse == \"left\" ? rect.left : rect.right) - prepared.rect.left,\n top: top, bottom: bot};\n if (!rect.left && !rect.right) result.bogus = true;\n if (!cm.options.singleCursorHeightPerLine) { result.rtop = rtop; result.rbottom = rbot; }\n\n return result;\n }\n\n // Work around problem with bounding client rects on ranges being\n // returned incorrectly when zoomed on IE10 and below.\n function maybeUpdateRectForZooming(measure, rect) {\n if (!window.screen || screen.logicalXDPI == null ||\n screen.logicalXDPI == screen.deviceXDPI || !hasBadZoomedRects(measure))\n return rect;\n var scaleX = screen.logicalXDPI / screen.deviceXDPI;\n var scaleY = screen.logicalYDPI / screen.deviceYDPI;\n return {left: rect.left * scaleX, right: rect.right * scaleX,\n top: rect.top * scaleY, bottom: rect.bottom * scaleY};\n }\n\n function clearLineMeasurementCacheFor(lineView) {\n if (lineView.measure) {\n lineView.measure.cache = {};\n lineView.measure.heights = null;\n if (lineView.rest) for (var i = 0; i < lineView.rest.length; i++)\n lineView.measure.caches[i] = {};\n }\n }\n\n function clearLineMeasurementCache(cm) {\n cm.display.externalMeasure = null;\n removeChildren(cm.display.lineMeasure);\n for (var i = 0; i < cm.display.view.length; i++)\n clearLineMeasurementCacheFor(cm.display.view[i]);\n }\n\n function clearCaches(cm) {\n clearLineMeasurementCache(cm);\n cm.display.cachedCharWidth = cm.display.cachedTextHeight = cm.display.cachedPaddingH = null;\n if (!cm.options.lineWrapping) cm.display.maxLineChanged = true;\n cm.display.lineNumChars = null;\n }\n\n function pageScrollX() { return window.pageXOffset || (document.documentElement || document.body).scrollLeft; }\n function pageScrollY() { return window.pageYOffset || (document.documentElement || document.body).scrollTop; }\n\n // Converts a {top, bottom, left, right} box from line-local\n // coordinates into another coordinate system. Context may be one of\n // \"line\", \"div\" (display.lineDiv), \"local\"/null (editor), \"window\",\n // or \"page\".\n function intoCoordSystem(cm, lineObj, rect, context) {\n if (lineObj.widgets) for (var i = 0; i < lineObj.widgets.length; ++i) if (lineObj.widgets[i].above) {\n var size = widgetHeight(lineObj.widgets[i]);\n rect.top += size; rect.bottom += size;\n }\n if (context == \"line\") return rect;\n if (!context) context = \"local\";\n var yOff = heightAtLine(lineObj);\n if (context == \"local\") yOff += paddingTop(cm.display);\n else yOff -= cm.display.viewOffset;\n if (context == \"page\" || context == \"window\") {\n var lOff = cm.display.lineSpace.getBoundingClientRect();\n yOff += lOff.top + (context == \"window\" ? 0 : pageScrollY());\n var xOff = lOff.left + (context == \"window\" ? 0 : pageScrollX());\n rect.left += xOff; rect.right += xOff;\n }\n rect.top += yOff; rect.bottom += yOff;\n return rect;\n }\n\n // Coverts a box from \"div\" coords to another coordinate system.\n // Context may be \"window\", \"page\", \"div\", or \"local\"/null.\n function fromCoordSystem(cm, coords, context) {\n if (context == \"div\") return coords;\n var left = coords.left, top = coords.top;\n // First move into \"page\" coordinate system\n if (context == \"page\") {\n left -= pageScrollX();\n top -= pageScrollY();\n } else if (context == \"local\" || !context) {\n var localBox = cm.display.sizer.getBoundingClientRect();\n left += localBox.left;\n top += localBox.top;\n }\n\n var lineSpaceBox = cm.display.lineSpace.getBoundingClientRect();\n return {left: left - lineSpaceBox.left, top: top - lineSpaceBox.top};\n }\n\n function charCoords(cm, pos, context, lineObj, bias) {\n if (!lineObj) lineObj = getLine(cm.doc, pos.line);\n return intoCoordSystem(cm, lineObj, measureChar(cm, lineObj, pos.ch, bias), context);\n }\n\n // Returns a box for a given cursor position, which may have an\n // 'other' property containing the position of the secondary cursor\n // on a bidi boundary.\n function cursorCoords(cm, pos, context, lineObj, preparedMeasure, varHeight) {\n lineObj = lineObj || getLine(cm.doc, pos.line);\n if (!preparedMeasure) preparedMeasure = prepareMeasureForLine(cm, lineObj);\n function get(ch, right) {\n var m = measureCharPrepared(cm, preparedMeasure, ch, right ? \"right\" : \"left\", varHeight);\n if (right) m.left = m.right; else m.right = m.left;\n return intoCoordSystem(cm, lineObj, m, context);\n }\n function getBidi(ch, partPos) {\n var part = order[partPos], right = part.level % 2;\n if (ch == bidiLeft(part) && partPos && part.level < order[partPos - 1].level) {\n part = order[--partPos];\n ch = bidiRight(part) - (part.level % 2 ? 0 : 1);\n right = true;\n } else if (ch == bidiRight(part) && partPos < order.length - 1 && part.level < order[partPos + 1].level) {\n part = order[++partPos];\n ch = bidiLeft(part) - part.level % 2;\n right = false;\n }\n if (right && ch == part.to && ch > part.from) return get(ch - 1);\n return get(ch, right);\n }\n var order = getOrder(lineObj), ch = pos.ch;\n if (!order) return get(ch);\n var partPos = getBidiPartAt(order, ch);\n var val = getBidi(ch, partPos);\n if (bidiOther != null) val.other = getBidi(ch, bidiOther);\n return val;\n }\n\n // Used to cheaply estimate the coordinates for a position. Used for\n // intermediate scroll updates.\n function estimateCoords(cm, pos) {\n var left = 0, pos = clipPos(cm.doc, pos);\n if (!cm.options.lineWrapping) left = charWidth(cm.display) * pos.ch;\n var lineObj = getLine(cm.doc, pos.line);\n var top = heightAtLine(lineObj) + paddingTop(cm.display);\n return {left: left, right: left, top: top, bottom: top + lineObj.height};\n }\n\n // Positions returned by coordsChar contain some extra information.\n // xRel is the relative x position of the input coordinates compared\n // to the found position (so xRel > 0 means the coordinates are to\n // the right of the character position, for example). When outside\n // is true, that means the coordinates lie outside the line's\n // vertical range.\n function PosWithInfo(line, ch, outside, xRel) {\n var pos = Pos(line, ch);\n pos.xRel = xRel;\n if (outside) pos.outside = true;\n return pos;\n }\n\n // Compute the character position closest to the given coordinates.\n // Input must be lineSpace-local (\"div\" coordinate system).\n function coordsChar(cm, x, y) {\n var doc = cm.doc;\n y += cm.display.viewOffset;\n if (y < 0) return PosWithInfo(doc.first, 0, true, -1);\n var lineN = lineAtHeight(doc, y), last = doc.first + doc.size - 1;\n if (lineN > last)\n return PosWithInfo(doc.first + doc.size - 1, getLine(doc, last).text.length, true, 1);\n if (x < 0) x = 0;\n\n var lineObj = getLine(doc, lineN);\n for (;;) {\n var found = coordsCharInner(cm, lineObj, lineN, x, y);\n var merged = collapsedSpanAtEnd(lineObj);\n var mergedPos = merged && merged.find(0, true);\n if (merged && (found.ch > mergedPos.from.ch || found.ch == mergedPos.from.ch && found.xRel > 0))\n lineN = lineNo(lineObj = mergedPos.to.line);\n else\n return found;\n }\n }\n\n function coordsCharInner(cm, lineObj, lineNo, x, y) {\n var innerOff = y - heightAtLine(lineObj);\n var wrongLine = false, adjust = 2 * cm.display.wrapper.clientWidth;\n var preparedMeasure = prepareMeasureForLine(cm, lineObj);\n\n function getX(ch) {\n var sp = cursorCoords(cm, Pos(lineNo, ch), \"line\", lineObj, preparedMeasure);\n wrongLine = true;\n if (innerOff > sp.bottom) return sp.left - adjust;\n else if (innerOff < sp.top) return sp.left + adjust;\n else wrongLine = false;\n return sp.left;\n }\n\n var bidi = getOrder(lineObj), dist = lineObj.text.length;\n var from = lineLeft(lineObj), to = lineRight(lineObj);\n var fromX = getX(from), fromOutside = wrongLine, toX = getX(to), toOutside = wrongLine;\n\n if (x > toX) return PosWithInfo(lineNo, to, toOutside, 1);\n // Do a binary search between these bounds.\n for (;;) {\n if (bidi ? to == from || to == moveVisually(lineObj, from, 1) : to - from <= 1) {\n var ch = x < fromX || x - fromX <= toX - x ? from : to;\n var outside = ch == from ? fromOutside : toOutside\n var xDiff = x - (ch == from ? fromX : toX);\n // This is a kludge to handle the case where the coordinates\n // are after a line-wrapped line. We should replace it with a\n // more general handling of cursor positions around line\n // breaks. (Issue #4078)\n if (toOutside && !bidi && !/\\s/.test(lineObj.text.charAt(ch)) && xDiff > 0 &&\n ch < lineObj.text.length && preparedMeasure.view.measure.heights.length > 1) {\n var charSize = measureCharPrepared(cm, preparedMeasure, ch, \"right\");\n if (innerOff <= charSize.bottom && innerOff >= charSize.top && Math.abs(x - charSize.right) < xDiff) {\n outside = false\n ch++\n xDiff = x - charSize.right\n }\n }\n while (isExtendingChar(lineObj.text.charAt(ch))) ++ch;\n var pos = PosWithInfo(lineNo, ch, outside, xDiff < -1 ? -1 : xDiff > 1 ? 1 : 0);\n return pos;\n }\n var step = Math.ceil(dist / 2), middle = from + step;\n if (bidi) {\n middle = from;\n for (var i = 0; i < step; ++i) middle = moveVisually(lineObj, middle, 1);\n }\n var middleX = getX(middle);\n if (middleX > x) {to = middle; toX = middleX; if (toOutside = wrongLine) toX += 1000; dist = step;}\n else {from = middle; fromX = middleX; fromOutside = wrongLine; dist -= step;}\n }\n }\n\n var measureText;\n // Compute the default text height.\n function textHeight(display) {\n if (display.cachedTextHeight != null) return display.cachedTextHeight;\n if (measureText == null) {\n measureText = elt(\"pre\");\n // Measure a bunch of lines, for browsers that compute\n // fractional heights.\n for (var i = 0; i < 49; ++i) {\n measureText.appendChild(document.createTextNode(\"x\"));\n measureText.appendChild(elt(\"br\"));\n }\n measureText.appendChild(document.createTextNode(\"x\"));\n }\n removeChildrenAndAdd(display.measure, measureText);\n var height = measureText.offsetHeight / 50;\n if (height > 3) display.cachedTextHeight = height;\n removeChildren(display.measure);\n return height || 1;\n }\n\n // Compute the default character width.\n function charWidth(display) {\n if (display.cachedCharWidth != null) return display.cachedCharWidth;\n var anchor = elt(\"span\", \"xxxxxxxxxx\");\n var pre = elt(\"pre\", [anchor]);\n removeChildrenAndAdd(display.measure, pre);\n var rect = anchor.getBoundingClientRect(), width = (rect.right - rect.left) / 10;\n if (width > 2) display.cachedCharWidth = width;\n return width || 10;\n }\n\n // OPERATIONS\n\n // Operations are used to wrap a series of changes to the editor\n // state in such a way that each change won't have to update the\n // cursor and display (which would be awkward, slow, and\n // error-prone). Instead, display updates are batched and then all\n // combined and executed at once.\n\n var operationGroup = null;\n\n var nextOpId = 0;\n // Start a new operation.\n function startOperation(cm) {\n cm.curOp = {\n cm: cm,\n viewChanged: false, // Flag that indicates that lines might need to be redrawn\n startHeight: cm.doc.height, // Used to detect need to update scrollbar\n forceUpdate: false, // Used to force a redraw\n updateInput: null, // Whether to reset the input textarea\n typing: false, // Whether this reset should be careful to leave existing text (for compositing)\n changeObjs: null, // Accumulated changes, for firing change events\n cursorActivityHandlers: null, // Set of handlers to fire cursorActivity on\n cursorActivityCalled: 0, // Tracks which cursorActivity handlers have been called already\n selectionChanged: false, // Whether the selection needs to be redrawn\n updateMaxLine: false, // Set when the widest line needs to be determined anew\n scrollLeft: null, scrollTop: null, // Intermediate scroll position, not pushed to DOM yet\n scrollToPos: null, // Used to scroll to a specific position\n focus: false,\n id: ++nextOpId // Unique ID\n };\n if (operationGroup) {\n operationGroup.ops.push(cm.curOp);\n } else {\n cm.curOp.ownsGroup = operationGroup = {\n ops: [cm.curOp],\n delayedCallbacks: []\n };\n }\n }\n\n function fireCallbacksForOps(group) {\n // Calls delayed callbacks and cursorActivity handlers until no\n // new ones appear\n var callbacks = group.delayedCallbacks, i = 0;\n do {\n for (; i < callbacks.length; i++)\n callbacks[i].call(null);\n for (var j = 0; j < group.ops.length; j++) {\n var op = group.ops[j];\n if (op.cursorActivityHandlers)\n while (op.cursorActivityCalled < op.cursorActivityHandlers.length)\n op.cursorActivityHandlers[op.cursorActivityCalled++].call(null, op.cm);\n }\n } while (i < callbacks.length);\n }\n\n // Finish an operation, updating the display and signalling delayed events\n function endOperation(cm) {\n var op = cm.curOp, group = op.ownsGroup;\n if (!group) return;\n\n try { fireCallbacksForOps(group); }\n finally {\n operationGroup = null;\n for (var i = 0; i < group.ops.length; i++)\n group.ops[i].cm.curOp = null;\n endOperations(group);\n }\n }\n\n // The DOM updates done when an operation finishes are batched so\n // that the minimum number of relayouts are required.\n function endOperations(group) {\n var ops = group.ops;\n for (var i = 0; i < ops.length; i++) // Read DOM\n endOperation_R1(ops[i]);\n for (var i = 0; i < ops.length; i++) // Write DOM (maybe)\n endOperation_W1(ops[i]);\n for (var i = 0; i < ops.length; i++) // Read DOM\n endOperation_R2(ops[i]);\n for (var i = 0; i < ops.length; i++) // Write DOM (maybe)\n endOperation_W2(ops[i]);\n for (var i = 0; i < ops.length; i++) // Read DOM\n endOperation_finish(ops[i]);\n }\n\n function endOperation_R1(op) {\n var cm = op.cm, display = cm.display;\n maybeClipScrollbars(cm);\n if (op.updateMaxLine) findMaxLine(cm);\n\n op.mustUpdate = op.viewChanged || op.forceUpdate || op.scrollTop != null ||\n op.scrollToPos && (op.scrollToPos.from.line < display.viewFrom ||\n op.scrollToPos.to.line >= display.viewTo) ||\n display.maxLineChanged && cm.options.lineWrapping;\n op.update = op.mustUpdate &&\n new DisplayUpdate(cm, op.mustUpdate && {top: op.scrollTop, ensure: op.scrollToPos}, op.forceUpdate);\n }\n\n function endOperation_W1(op) {\n op.updatedDisplay = op.mustUpdate && updateDisplayIfNeeded(op.cm, op.update);\n }\n\n function endOperation_R2(op) {\n var cm = op.cm, display = cm.display;\n if (op.updatedDisplay) updateHeightsInViewport(cm);\n\n op.barMeasure = measureForScrollbars(cm);\n\n // If the max line changed since it was last measured, measure it,\n // and ensure the document's width matches it.\n // updateDisplay_W2 will use these properties to do the actual resizing\n if (display.maxLineChanged && !cm.options.lineWrapping) {\n op.adjustWidthTo = measureChar(cm, display.maxLine, display.maxLine.text.length).left + 3;\n cm.display.sizerWidth = op.adjustWidthTo;\n op.barMeasure.scrollWidth =\n Math.max(display.scroller.clientWidth, display.sizer.offsetLeft + op.adjustWidthTo + scrollGap(cm) + cm.display.barWidth);\n op.maxScrollLeft = Math.max(0, display.sizer.offsetLeft + op.adjustWidthTo - displayWidth(cm));\n }\n\n if (op.updatedDisplay || op.selectionChanged)\n op.preparedSelection = display.input.prepareSelection(op.focus);\n }\n\n function endOperation_W2(op) {\n var cm = op.cm;\n\n if (op.adjustWidthTo != null) {\n cm.display.sizer.style.minWidth = op.adjustWidthTo + \"px\";\n if (op.maxScrollLeft < cm.doc.scrollLeft)\n setScrollLeft(cm, Math.min(cm.display.scroller.scrollLeft, op.maxScrollLeft), true);\n cm.display.maxLineChanged = false;\n }\n\n var takeFocus = op.focus && op.focus == activeElt() && (!document.hasFocus || document.hasFocus())\n if (op.preparedSelection)\n cm.display.input.showSelection(op.preparedSelection, takeFocus);\n if (op.updatedDisplay || op.startHeight != cm.doc.height)\n updateScrollbars(cm, op.barMeasure);\n if (op.updatedDisplay)\n setDocumentHeight(cm, op.barMeasure);\n\n if (op.selectionChanged) restartBlink(cm);\n\n if (cm.state.focused && op.updateInput)\n cm.display.input.reset(op.typing);\n if (takeFocus) ensureFocus(op.cm);\n }\n\n function endOperation_finish(op) {\n var cm = op.cm, display = cm.display, doc = cm.doc;\n\n if (op.updatedDisplay) postUpdateDisplay(cm, op.update);\n\n // Abort mouse wheel delta measurement, when scrolling explicitly\n if (display.wheelStartX != null && (op.scrollTop != null || op.scrollLeft != null || op.scrollToPos))\n display.wheelStartX = display.wheelStartY = null;\n\n // Propagate the scroll position to the actual DOM scroller\n if (op.scrollTop != null && (display.scroller.scrollTop != op.scrollTop || op.forceScroll)) {\n doc.scrollTop = Math.max(0, Math.min(display.scroller.scrollHeight - display.scroller.clientHeight, op.scrollTop));\n display.scrollbars.setScrollTop(doc.scrollTop);\n display.scroller.scrollTop = doc.scrollTop;\n }\n if (op.scrollLeft != null && (display.scroller.scrollLeft != op.scrollLeft || op.forceScroll)) {\n doc.scrollLeft = Math.max(0, Math.min(display.scroller.scrollWidth - display.scroller.clientWidth, op.scrollLeft));\n display.scrollbars.setScrollLeft(doc.scrollLeft);\n display.scroller.scrollLeft = doc.scrollLeft;\n alignHorizontally(cm);\n }\n // If we need to scroll a specific position into view, do so.\n if (op.scrollToPos) {\n var coords = scrollPosIntoView(cm, clipPos(doc, op.scrollToPos.from),\n clipPos(doc, op.scrollToPos.to), op.scrollToPos.margin);\n if (op.scrollToPos.isCursor && cm.state.focused) maybeScrollWindow(cm, coords);\n }\n\n // Fire events for markers that are hidden/unidden by editing or\n // undoing\n var hidden = op.maybeHiddenMarkers, unhidden = op.maybeUnhiddenMarkers;\n if (hidden) for (var i = 0; i < hidden.length; ++i)\n if (!hidden[i].lines.length) signal(hidden[i], \"hide\");\n if (unhidden) for (var i = 0; i < unhidden.length; ++i)\n if (unhidden[i].lines.length) signal(unhidden[i], \"unhide\");\n\n if (display.wrapper.offsetHeight)\n doc.scrollTop = cm.display.scroller.scrollTop;\n\n // Fire change events, and delayed event handlers\n if (op.changeObjs)\n signal(cm, \"changes\", cm, op.changeObjs);\n if (op.update)\n op.update.finish();\n }\n\n // Run the given function in an operation\n function runInOp(cm, f) {\n if (cm.curOp) return f();\n startOperation(cm);\n try { return f(); }\n finally { endOperation(cm); }\n }\n // Wraps a function in an operation. Returns the wrapped function.\n function operation(cm, f) {\n return function() {\n if (cm.curOp) return f.apply(cm, arguments);\n startOperation(cm);\n try { return f.apply(cm, arguments); }\n finally { endOperation(cm); }\n };\n }\n // Used to add methods to editor and doc instances, wrapping them in\n // operations.\n function methodOp(f) {\n return function() {\n if (this.curOp) return f.apply(this, arguments);\n startOperation(this);\n try { return f.apply(this, arguments); }\n finally { endOperation(this); }\n };\n }\n function docMethodOp(f) {\n return function() {\n var cm = this.cm;\n if (!cm || cm.curOp) return f.apply(this, arguments);\n startOperation(cm);\n try { return f.apply(this, arguments); }\n finally { endOperation(cm); }\n };\n }\n\n // VIEW TRACKING\n\n // These objects are used to represent the visible (currently drawn)\n // part of the document. A LineView may correspond to multiple\n // logical lines, if those are connected by collapsed ranges.\n function LineView(doc, line, lineN) {\n // The starting line\n this.line = line;\n // Continuing lines, if any\n this.rest = visualLineContinued(line);\n // Number of logical lines in this visual line\n this.size = this.rest ? lineNo(lst(this.rest)) - lineN + 1 : 1;\n this.node = this.text = null;\n this.hidden = lineIsHidden(doc, line);\n }\n\n // Create a range of LineView objects for the given lines.\n function buildViewArray(cm, from, to) {\n var array = [], nextPos;\n for (var pos = from; pos < to; pos = nextPos) {\n var view = new LineView(cm.doc, getLine(cm.doc, pos), pos);\n nextPos = pos + view.size;\n array.push(view);\n }\n return array;\n }\n\n // Updates the display.view data structure for a given change to the\n // document. From and to are in pre-change coordinates. Lendiff is\n // the amount of lines added or subtracted by the change. This is\n // used for changes that span multiple lines, or change the way\n // lines are divided into visual lines. regLineChange (below)\n // registers single-line changes.\n function regChange(cm, from, to, lendiff) {\n if (from == null) from = cm.doc.first;\n if (to == null) to = cm.doc.first + cm.doc.size;\n if (!lendiff) lendiff = 0;\n\n var display = cm.display;\n if (lendiff && to < display.viewTo &&\n (display.updateLineNumbers == null || display.updateLineNumbers > from))\n display.updateLineNumbers = from;\n\n cm.curOp.viewChanged = true;\n\n if (from >= display.viewTo) { // Change after\n if (sawCollapsedSpans && visualLineNo(cm.doc, from) < display.viewTo)\n resetView(cm);\n } else if (to <= display.viewFrom) { // Change before\n if (sawCollapsedSpans && visualLineEndNo(cm.doc, to + lendiff) > display.viewFrom) {\n resetView(cm);\n } else {\n display.viewFrom += lendiff;\n display.viewTo += lendiff;\n }\n } else if (from <= display.viewFrom && to >= display.viewTo) { // Full overlap\n resetView(cm);\n } else if (from <= display.viewFrom) { // Top overlap\n var cut = viewCuttingPoint(cm, to, to + lendiff, 1);\n if (cut) {\n display.view = display.view.slice(cut.index);\n display.viewFrom = cut.lineN;\n display.viewTo += lendiff;\n } else {\n resetView(cm);\n }\n } else if (to >= display.viewTo) { // Bottom overlap\n var cut = viewCuttingPoint(cm, from, from, -1);\n if (cut) {\n display.view = display.view.slice(0, cut.index);\n display.viewTo = cut.lineN;\n } else {\n resetView(cm);\n }\n } else { // Gap in the middle\n var cutTop = viewCuttingPoint(cm, from, from, -1);\n var cutBot = viewCuttingPoint(cm, to, to + lendiff, 1);\n if (cutTop && cutBot) {\n display.view = display.view.slice(0, cutTop.index)\n .concat(buildViewArray(cm, cutTop.lineN, cutBot.lineN))\n .concat(display.view.slice(cutBot.index));\n display.viewTo += lendiff;\n } else {\n resetView(cm);\n }\n }\n\n var ext = display.externalMeasured;\n if (ext) {\n if (to < ext.lineN)\n ext.lineN += lendiff;\n else if (from < ext.lineN + ext.size)\n display.externalMeasured = null;\n }\n }\n\n // Register a change to a single line. Type must be one of \"text\",\n // \"gutter\", \"class\", \"widget\"\n function regLineChange(cm, line, type) {\n cm.curOp.viewChanged = true;\n var display = cm.display, ext = cm.display.externalMeasured;\n if (ext && line >= ext.lineN && line < ext.lineN + ext.size)\n display.externalMeasured = null;\n\n if (line < display.viewFrom || line >= display.viewTo) return;\n var lineView = display.view[findViewIndex(cm, line)];\n if (lineView.node == null) return;\n var arr = lineView.changes || (lineView.changes = []);\n if (indexOf(arr, type) == -1) arr.push(type);\n }\n\n // Clear the view.\n function resetView(cm) {\n cm.display.viewFrom = cm.display.viewTo = cm.doc.first;\n cm.display.view = [];\n cm.display.viewOffset = 0;\n }\n\n // Find the view element corresponding to a given line. Return null\n // when the line isn't visible.\n function findViewIndex(cm, n) {\n if (n >= cm.display.viewTo) return null;\n n -= cm.display.viewFrom;\n if (n < 0) return null;\n var view = cm.display.view;\n for (var i = 0; i < view.length; i++) {\n n -= view[i].size;\n if (n < 0) return i;\n }\n }\n\n function viewCuttingPoint(cm, oldN, newN, dir) {\n var index = findViewIndex(cm, oldN), diff, view = cm.display.view;\n if (!sawCollapsedSpans || newN == cm.doc.first + cm.doc.size)\n return {index: index, lineN: newN};\n for (var i = 0, n = cm.display.viewFrom; i < index; i++)\n n += view[i].size;\n if (n != oldN) {\n if (dir > 0) {\n if (index == view.length - 1) return null;\n diff = (n + view[index].size) - oldN;\n index++;\n } else {\n diff = n - oldN;\n }\n oldN += diff; newN += diff;\n }\n while (visualLineNo(cm.doc, newN) != newN) {\n if (index == (dir < 0 ? 0 : view.length - 1)) return null;\n newN += dir * view[index - (dir < 0 ? 1 : 0)].size;\n index += dir;\n }\n return {index: index, lineN: newN};\n }\n\n // Force the view to cover a given range, adding empty view element\n // or clipping off existing ones as needed.\n function adjustView(cm, from, to) {\n var display = cm.display, view = display.view;\n if (view.length == 0 || from >= display.viewTo || to <= display.viewFrom) {\n display.view = buildViewArray(cm, from, to);\n display.viewFrom = from;\n } else {\n if (display.viewFrom > from)\n display.view = buildViewArray(cm, from, display.viewFrom).concat(display.view);\n else if (display.viewFrom < from)\n display.view = display.view.slice(findViewIndex(cm, from));\n display.viewFrom = from;\n if (display.viewTo < to)\n display.view = display.view.concat(buildViewArray(cm, display.viewTo, to));\n else if (display.viewTo > to)\n display.view = display.view.slice(0, findViewIndex(cm, to));\n }\n display.viewTo = to;\n }\n\n // Count the number of lines in the view whose DOM representation is\n // out of date (or nonexistent).\n function countDirtyView(cm) {\n var view = cm.display.view, dirty = 0;\n for (var i = 0; i < view.length; i++) {\n var lineView = view[i];\n if (!lineView.hidden && (!lineView.node || lineView.changes)) ++dirty;\n }\n return dirty;\n }\n\n // EVENT HANDLERS\n\n // Attach the necessary event handlers when initializing the editor\n function registerEventHandlers(cm) {\n var d = cm.display;\n on(d.scroller, \"mousedown\", operation(cm, onMouseDown));\n // Older IE's will not fire a second mousedown for a double click\n if (ie && ie_version < 11)\n on(d.scroller, \"dblclick\", operation(cm, function(e) {\n if (signalDOMEvent(cm, e)) return;\n var pos = posFromMouse(cm, e);\n if (!pos || clickInGutter(cm, e) || eventInWidget(cm.display, e)) return;\n e_preventDefault(e);\n var word = cm.findWordAt(pos);\n extendSelection(cm.doc, word.anchor, word.head);\n }));\n else\n on(d.scroller, \"dblclick\", function(e) { signalDOMEvent(cm, e) || e_preventDefault(e); });\n // Some browsers fire contextmenu *after* opening the menu, at\n // which point we can't mess with it anymore. Context menu is\n // handled in onMouseDown for these browsers.\n if (!captureRightClick) on(d.scroller, \"contextmenu\", function(e) {onContextMenu(cm, e);});\n\n // Used to suppress mouse event handling when a touch happens\n var touchFinished, prevTouch = {end: 0};\n function finishTouch() {\n if (d.activeTouch) {\n touchFinished = setTimeout(function() {d.activeTouch = null;}, 1000);\n prevTouch = d.activeTouch;\n prevTouch.end = +new Date;\n }\n };\n function isMouseLikeTouchEvent(e) {\n if (e.touches.length != 1) return false;\n var touch = e.touches[0];\n return touch.radiusX <= 1 && touch.radiusY <= 1;\n }\n function farAway(touch, other) {\n if (other.left == null) return true;\n var dx = other.left - touch.left, dy = other.top - touch.top;\n return dx * dx + dy * dy > 20 * 20;\n }\n on(d.scroller, \"touchstart\", function(e) {\n if (!signalDOMEvent(cm, e) && !isMouseLikeTouchEvent(e)) {\n clearTimeout(touchFinished);\n var now = +new Date;\n d.activeTouch = {start: now, moved: false,\n prev: now - prevTouch.end <= 300 ? prevTouch : null};\n if (e.touches.length == 1) {\n d.activeTouch.left = e.touches[0].pageX;\n d.activeTouch.top = e.touches[0].pageY;\n }\n }\n });\n on(d.scroller, \"touchmove\", function() {\n if (d.activeTouch) d.activeTouch.moved = true;\n });\n on(d.scroller, \"touchend\", function(e) {\n var touch = d.activeTouch;\n if (touch && !eventInWidget(d, e) && touch.left != null &&\n !touch.moved && new Date - touch.start < 300) {\n var pos = cm.coordsChar(d.activeTouch, \"page\"), range;\n if (!touch.prev || farAway(touch, touch.prev)) // Single tap\n range = new Range(pos, pos);\n else if (!touch.prev.prev || farAway(touch, touch.prev.prev)) // Double tap\n range = cm.findWordAt(pos);\n else // Triple tap\n range = new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0)));\n cm.setSelection(range.anchor, range.head);\n cm.focus();\n e_preventDefault(e);\n }\n finishTouch();\n });\n on(d.scroller, \"touchcancel\", finishTouch);\n\n // Sync scrolling between fake scrollbars and real scrollable\n // area, ensure viewport is updated when scrolling.\n on(d.scroller, \"scroll\", function() {\n if (d.scroller.clientHeight) {\n setScrollTop(cm, d.scroller.scrollTop);\n setScrollLeft(cm, d.scroller.scrollLeft, true);\n signal(cm, \"scroll\", cm);\n }\n });\n\n // Listen to wheel events in order to try and update the viewport on time.\n on(d.scroller, \"mousewheel\", function(e){onScrollWheel(cm, e);});\n on(d.scroller, \"DOMMouseScroll\", function(e){onScrollWheel(cm, e);});\n\n // Prevent wrapper from ever scrolling\n on(d.wrapper, \"scroll\", function() { d.wrapper.scrollTop = d.wrapper.scrollLeft = 0; });\n\n d.dragFunctions = {\n enter: function(e) {if (!signalDOMEvent(cm, e)) e_stop(e);},\n over: function(e) {if (!signalDOMEvent(cm, e)) { onDragOver(cm, e); e_stop(e); }},\n start: function(e){onDragStart(cm, e);},\n drop: operation(cm, onDrop),\n leave: function(e) {if (!signalDOMEvent(cm, e)) { clearDragCursor(cm); }}\n };\n\n var inp = d.input.getField();\n on(inp, \"keyup\", function(e) { onKeyUp.call(cm, e); });\n on(inp, \"keydown\", operation(cm, onKeyDown));\n on(inp, \"keypress\", operation(cm, onKeyPress));\n on(inp, \"focus\", bind(onFocus, cm));\n on(inp, \"blur\", bind(onBlur, cm));\n }\n\n function dragDropChanged(cm, value, old) {\n var wasOn = old && old != CodeMirror.Init;\n if (!value != !wasOn) {\n var funcs = cm.display.dragFunctions;\n var toggle = value ? on : off;\n toggle(cm.display.scroller, \"dragstart\", funcs.start);\n toggle(cm.display.scroller, \"dragenter\", funcs.enter);\n toggle(cm.display.scroller, \"dragover\", funcs.over);\n toggle(cm.display.scroller, \"dragleave\", funcs.leave);\n toggle(cm.display.scroller, \"drop\", funcs.drop);\n }\n }\n\n // Called when the window resizes\n function onResize(cm) {\n var d = cm.display;\n if (d.lastWrapHeight == d.wrapper.clientHeight && d.lastWrapWidth == d.wrapper.clientWidth)\n return;\n // Might be a text scaling operation, clear size caches.\n d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;\n d.scrollbarsClipped = false;\n cm.setSize();\n }\n\n // MOUSE EVENTS\n\n // Return true when the given mouse event happened in a widget\n function eventInWidget(display, e) {\n for (var n = e_target(e); n != display.wrapper; n = n.parentNode) {\n if (!n || (n.nodeType == 1 && n.getAttribute(\"cm-ignore-events\") == \"true\") ||\n (n.parentNode == display.sizer && n != display.mover))\n return true;\n }\n }\n\n // Given a mouse event, find the corresponding position. If liberal\n // is false, it checks whether a gutter or scrollbar was clicked,\n // and returns null if it was. forRect is used by rectangular\n // selections, and tries to estimate a character position even for\n // coordinates beyond the right of the text.\n function posFromMouse(cm, e, liberal, forRect) {\n var display = cm.display;\n if (!liberal && e_target(e).getAttribute(\"cm-not-content\") == \"true\") return null;\n\n var x, y, space = display.lineSpace.getBoundingClientRect();\n // Fails unpredictably on IE[67] when mouse is dragged around quickly.\n try { x = e.clientX - space.left; y = e.clientY - space.top; }\n catch (e) { return null; }\n var coords = coordsChar(cm, x, y), line;\n if (forRect && coords.xRel == 1 && (line = getLine(cm.doc, coords.line).text).length == coords.ch) {\n var colDiff = countColumn(line, line.length, cm.options.tabSize) - line.length;\n coords = Pos(coords.line, Math.max(0, Math.round((x - paddingH(cm.display).left) / charWidth(cm.display)) - colDiff));\n }\n return coords;\n }\n\n // A mouse down can be a single click, double click, triple click,\n // start of selection drag, start of text drag, new cursor\n // (ctrl-click), rectangle drag (alt-drag), or xwin\n // middle-click-paste. Or it might be a click on something we should\n // not interfere with, such as a scrollbar or widget.\n function onMouseDown(e) {\n var cm = this, display = cm.display;\n if (signalDOMEvent(cm, e) || display.activeTouch && display.input.supportsTouch()) return;\n display.shift = e.shiftKey;\n\n if (eventInWidget(display, e)) {\n if (!webkit) {\n // Briefly turn off draggability, to allow widgets to do\n // normal dragging things.\n display.scroller.draggable = false;\n setTimeout(function(){display.scroller.draggable = true;}, 100);\n }\n return;\n }\n if (clickInGutter(cm, e)) return;\n var start = posFromMouse(cm, e);\n window.focus();\n\n switch (e_button(e)) {\n case 1:\n // #3261: make sure, that we're not starting a second selection\n if (cm.state.selectingText)\n cm.state.selectingText(e);\n else if (start)\n leftButtonDown(cm, e, start);\n else if (e_target(e) == display.scroller)\n e_preventDefault(e);\n break;\n case 2:\n if (webkit) cm.state.lastMiddleDown = +new Date;\n if (start) extendSelection(cm.doc, start);\n setTimeout(function() {display.input.focus();}, 20);\n e_preventDefault(e);\n break;\n case 3:\n if (captureRightClick) onContextMenu(cm, e);\n else delayBlurEvent(cm);\n break;\n }\n }\n\n var lastClick, lastDoubleClick;\n function leftButtonDown(cm, e, start) {\n if (ie) setTimeout(bind(ensureFocus, cm), 0);\n else cm.curOp.focus = activeElt();\n\n var now = +new Date, type;\n if (lastDoubleClick && lastDoubleClick.time > now - 400 && cmp(lastDoubleClick.pos, start) == 0) {\n type = \"triple\";\n } else if (lastClick && lastClick.time > now - 400 && cmp(lastClick.pos, start) == 0) {\n type = \"double\";\n lastDoubleClick = {time: now, pos: start};\n } else {\n type = \"single\";\n lastClick = {time: now, pos: start};\n }\n\n var sel = cm.doc.sel, modifier = mac ? e.metaKey : e.ctrlKey, contained;\n if (cm.options.dragDrop && dragAndDrop && !cm.isReadOnly() &&\n type == \"single\" && (contained = sel.contains(start)) > -1 &&\n (cmp((contained = sel.ranges[contained]).from(), start) < 0 || start.xRel > 0) &&\n (cmp(contained.to(), start) > 0 || start.xRel < 0))\n leftButtonStartDrag(cm, e, start, modifier);\n else\n leftButtonSelect(cm, e, start, type, modifier);\n }\n\n // Start a text drag. When it ends, see if any dragging actually\n // happen, and treat as a click if it didn't.\n function leftButtonStartDrag(cm, e, start, modifier) {\n var display = cm.display, startTime = +new Date;\n var dragEnd = operation(cm, function(e2) {\n if (webkit) display.scroller.draggable = false;\n cm.state.draggingText = false;\n off(document, \"mouseup\", dragEnd);\n off(display.scroller, \"drop\", dragEnd);\n if (Math.abs(e.clientX - e2.clientX) + Math.abs(e.clientY - e2.clientY) < 10) {\n e_preventDefault(e2);\n if (!modifier && +new Date - 200 < startTime)\n extendSelection(cm.doc, start);\n // Work around unexplainable focus problem in IE9 (#2127) and Chrome (#3081)\n if (webkit || ie && ie_version == 9)\n setTimeout(function() {document.body.focus(); display.input.focus();}, 20);\n else\n display.input.focus();\n }\n });\n // Let the drag handler handle this.\n if (webkit) display.scroller.draggable = true;\n cm.state.draggingText = dragEnd;\n dragEnd.copy = mac ? e.altKey : e.ctrlKey\n // IE's approach to draggable\n if (display.scroller.dragDrop) display.scroller.dragDrop();\n on(document, \"mouseup\", dragEnd);\n on(display.scroller, \"drop\", dragEnd);\n }\n\n // Normal selection, as opposed to text dragging.\n function leftButtonSelect(cm, e, start, type, addNew) {\n var display = cm.display, doc = cm.doc;\n e_preventDefault(e);\n\n var ourRange, ourIndex, startSel = doc.sel, ranges = startSel.ranges;\n if (addNew && !e.shiftKey) {\n ourIndex = doc.sel.contains(start);\n if (ourIndex > -1)\n ourRange = ranges[ourIndex];\n else\n ourRange = new Range(start, start);\n } else {\n ourRange = doc.sel.primary();\n ourIndex = doc.sel.primIndex;\n }\n\n if (chromeOS ? e.shiftKey && e.metaKey : e.altKey) {\n type = \"rect\";\n if (!addNew) ourRange = new Range(start, start);\n start = posFromMouse(cm, e, true, true);\n ourIndex = -1;\n } else if (type == \"double\") {\n var word = cm.findWordAt(start);\n if (cm.display.shift || doc.extend)\n ourRange = extendRange(doc, ourRange, word.anchor, word.head);\n else\n ourRange = word;\n } else if (type == \"triple\") {\n var line = new Range(Pos(start.line, 0), clipPos(doc, Pos(start.line + 1, 0)));\n if (cm.display.shift || doc.extend)\n ourRange = extendRange(doc, ourRange, line.anchor, line.head);\n else\n ourRange = line;\n } else {\n ourRange = extendRange(doc, ourRange, start);\n }\n\n if (!addNew) {\n ourIndex = 0;\n setSelection(doc, new Selection([ourRange], 0), sel_mouse);\n startSel = doc.sel;\n } else if (ourIndex == -1) {\n ourIndex = ranges.length;\n setSelection(doc, normalizeSelection(ranges.concat([ourRange]), ourIndex),\n {scroll: false, origin: \"*mouse\"});\n } else if (ranges.length > 1 && ranges[ourIndex].empty() && type == \"single\" && !e.shiftKey) {\n setSelection(doc, normalizeSelection(ranges.slice(0, ourIndex).concat(ranges.slice(ourIndex + 1)), 0),\n {scroll: false, origin: \"*mouse\"});\n startSel = doc.sel;\n } else {\n replaceOneSelection(doc, ourIndex, ourRange, sel_mouse);\n }\n\n var lastPos = start;\n function extendTo(pos) {\n if (cmp(lastPos, pos) == 0) return;\n lastPos = pos;\n\n if (type == \"rect\") {\n var ranges = [], tabSize = cm.options.tabSize;\n var startCol = countColumn(getLine(doc, start.line).text, start.ch, tabSize);\n var posCol = countColumn(getLine(doc, pos.line).text, pos.ch, tabSize);\n var left = Math.min(startCol, posCol), right = Math.max(startCol, posCol);\n for (var line = Math.min(start.line, pos.line), end = Math.min(cm.lastLine(), Math.max(start.line, pos.line));\n line <= end; line++) {\n var text = getLine(doc, line).text, leftPos = findColumn(text, left, tabSize);\n if (left == right)\n ranges.push(new Range(Pos(line, leftPos), Pos(line, leftPos)));\n else if (text.length > leftPos)\n ranges.push(new Range(Pos(line, leftPos), Pos(line, findColumn(text, right, tabSize))));\n }\n if (!ranges.length) ranges.push(new Range(start, start));\n setSelection(doc, normalizeSelection(startSel.ranges.slice(0, ourIndex).concat(ranges), ourIndex),\n {origin: \"*mouse\", scroll: false});\n cm.scrollIntoView(pos);\n } else {\n var oldRange = ourRange;\n var anchor = oldRange.anchor, head = pos;\n if (type != \"single\") {\n if (type == \"double\")\n var range = cm.findWordAt(pos);\n else\n var range = new Range(Pos(pos.line, 0), clipPos(doc, Pos(pos.line + 1, 0)));\n if (cmp(range.anchor, anchor) > 0) {\n head = range.head;\n anchor = minPos(oldRange.from(), range.anchor);\n } else {\n head = range.anchor;\n anchor = maxPos(oldRange.to(), range.head);\n }\n }\n var ranges = startSel.ranges.slice(0);\n ranges[ourIndex] = new Range(clipPos(doc, anchor), head);\n setSelection(doc, normalizeSelection(ranges, ourIndex), sel_mouse);\n }\n }\n\n var editorSize = display.wrapper.getBoundingClientRect();\n // Used to ensure timeout re-tries don't fire when another extend\n // happened in the meantime (clearTimeout isn't reliable -- at\n // least on Chrome, the timeouts still happen even when cleared,\n // if the clear happens after their scheduled firing time).\n var counter = 0;\n\n function extend(e) {\n var curCount = ++counter;\n var cur = posFromMouse(cm, e, true, type == \"rect\");\n if (!cur) return;\n if (cmp(cur, lastPos) != 0) {\n cm.curOp.focus = activeElt();\n extendTo(cur);\n var visible = visibleLines(display, doc);\n if (cur.line >= visible.to || cur.line < visible.from)\n setTimeout(operation(cm, function(){if (counter == curCount) extend(e);}), 150);\n } else {\n var outside = e.clientY < editorSize.top ? -20 : e.clientY > editorSize.bottom ? 20 : 0;\n if (outside) setTimeout(operation(cm, function() {\n if (counter != curCount) return;\n display.scroller.scrollTop += outside;\n extend(e);\n }), 50);\n }\n }\n\n function done(e) {\n cm.state.selectingText = false;\n counter = Infinity;\n e_preventDefault(e);\n display.input.focus();\n off(document, \"mousemove\", move);\n off(document, \"mouseup\", up);\n doc.history.lastSelOrigin = null;\n }\n\n var move = operation(cm, function(e) {\n if (!e_button(e)) done(e);\n else extend(e);\n });\n var up = operation(cm, done);\n cm.state.selectingText = up;\n on(document, \"mousemove\", move);\n on(document, \"mouseup\", up);\n }\n\n // Determines whether an event happened in the gutter, and fires the\n // handlers for the corresponding event.\n function gutterEvent(cm, e, type, prevent) {\n try { var mX = e.clientX, mY = e.clientY; }\n catch(e) { return false; }\n if (mX >= Math.floor(cm.display.gutters.getBoundingClientRect().right)) return false;\n if (prevent) e_preventDefault(e);\n\n var display = cm.display;\n var lineBox = display.lineDiv.getBoundingClientRect();\n\n if (mY > lineBox.bottom || !hasHandler(cm, type)) return e_defaultPrevented(e);\n mY -= lineBox.top - display.viewOffset;\n\n for (var i = 0; i < cm.options.gutters.length; ++i) {\n var g = display.gutters.childNodes[i];\n if (g && g.getBoundingClientRect().right >= mX) {\n var line = lineAtHeight(cm.doc, mY);\n var gutter = cm.options.gutters[i];\n signal(cm, type, cm, line, gutter, e);\n return e_defaultPrevented(e);\n }\n }\n }\n\n function clickInGutter(cm, e) {\n return gutterEvent(cm, e, \"gutterClick\", true);\n }\n\n // Kludge to work around strange IE behavior where it'll sometimes\n // re-fire a series of drag-related events right after the drop (#1551)\n var lastDrop = 0;\n\n function onDrop(e) {\n var cm = this;\n clearDragCursor(cm);\n if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e))\n return;\n e_preventDefault(e);\n if (ie) lastDrop = +new Date;\n var pos = posFromMouse(cm, e, true), files = e.dataTransfer.files;\n if (!pos || cm.isReadOnly()) return;\n // Might be a file drop, in which case we simply extract the text\n // and insert it.\n if (files && files.length && window.FileReader && window.File) {\n var n = files.length, text = Array(n), read = 0;\n var loadFile = function(file, i) {\n if (cm.options.allowDropFileTypes &&\n indexOf(cm.options.allowDropFileTypes, file.type) == -1)\n return;\n\n var reader = new FileReader;\n reader.onload = operation(cm, function() {\n var content = reader.result;\n if (/[\\x00-\\x08\\x0e-\\x1f]{2}/.test(content)) content = \"\";\n text[i] = content;\n if (++read == n) {\n pos = clipPos(cm.doc, pos);\n var change = {from: pos, to: pos,\n text: cm.doc.splitLines(text.join(cm.doc.lineSeparator())),\n origin: \"paste\"};\n makeChange(cm.doc, change);\n setSelectionReplaceHistory(cm.doc, simpleSelection(pos, changeEnd(change)));\n }\n });\n reader.readAsText(file);\n };\n for (var i = 0; i < n; ++i) loadFile(files[i], i);\n } else { // Normal drop\n // Don't do a replace if the drop happened inside of the selected text.\n if (cm.state.draggingText && cm.doc.sel.contains(pos) > -1) {\n cm.state.draggingText(e);\n // Ensure the editor is re-focused\n setTimeout(function() {cm.display.input.focus();}, 20);\n return;\n }\n try {\n var text = e.dataTransfer.getData(\"Text\");\n if (text) {\n if (cm.state.draggingText && !cm.state.draggingText.copy)\n var selected = cm.listSelections();\n setSelectionNoUndo(cm.doc, simpleSelection(pos, pos));\n if (selected) for (var i = 0; i < selected.length; ++i)\n replaceRange(cm.doc, \"\", selected[i].anchor, selected[i].head, \"drag\");\n cm.replaceSelection(text, \"around\", \"paste\");\n cm.display.input.focus();\n }\n }\n catch(e){}\n }\n }\n\n function onDragStart(cm, e) {\n if (ie && (!cm.state.draggingText || +new Date - lastDrop < 100)) { e_stop(e); return; }\n if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) return;\n\n e.dataTransfer.setData(\"Text\", cm.getSelection());\n e.dataTransfer.effectAllowed = \"copyMove\"\n\n // Use dummy image instead of default browsers image.\n // Recent Safari (~6.0.2) have a tendency to segfault when this happens, so we don't do it there.\n if (e.dataTransfer.setDragImage && !safari) {\n var img = elt(\"img\", null, null, \"position: fixed; left: 0; top: 0;\");\n img.src = \"data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\";\n if (presto) {\n img.width = img.height = 1;\n cm.display.wrapper.appendChild(img);\n // Force a relayout, or Opera won't use our image for some obscure reason\n img._top = img.offsetTop;\n }\n e.dataTransfer.setDragImage(img, 0, 0);\n if (presto) img.parentNode.removeChild(img);\n }\n }\n\n function onDragOver(cm, e) {\n var pos = posFromMouse(cm, e);\n if (!pos) return;\n var frag = document.createDocumentFragment();\n drawSelectionCursor(cm, pos, frag);\n if (!cm.display.dragCursor) {\n cm.display.dragCursor = elt(\"div\", null, \"CodeMirror-cursors CodeMirror-dragcursors\");\n cm.display.lineSpace.insertBefore(cm.display.dragCursor, cm.display.cursorDiv);\n }\n removeChildrenAndAdd(cm.display.dragCursor, frag);\n }\n\n function clearDragCursor(cm) {\n if (cm.display.dragCursor) {\n cm.display.lineSpace.removeChild(cm.display.dragCursor);\n cm.display.dragCursor = null;\n }\n }\n\n // SCROLL EVENTS\n\n // Sync the scrollable area and scrollbars, ensure the viewport\n // covers the visible area.\n function setScrollTop(cm, val) {\n if (Math.abs(cm.doc.scrollTop - val) < 2) return;\n cm.doc.scrollTop = val;\n if (!gecko) updateDisplaySimple(cm, {top: val});\n if (cm.display.scroller.scrollTop != val) cm.display.scroller.scrollTop = val;\n cm.display.scrollbars.setScrollTop(val);\n if (gecko) updateDisplaySimple(cm);\n startWorker(cm, 100);\n }\n // Sync scroller and scrollbar, ensure the gutter elements are\n // aligned.\n function setScrollLeft(cm, val, isScroller) {\n if (isScroller ? val == cm.doc.scrollLeft : Math.abs(cm.doc.scrollLeft - val) < 2) return;\n val = Math.min(val, cm.display.scroller.scrollWidth - cm.display.scroller.clientWidth);\n cm.doc.scrollLeft = val;\n alignHorizontally(cm);\n if (cm.display.scroller.scrollLeft != val) cm.display.scroller.scrollLeft = val;\n cm.display.scrollbars.setScrollLeft(val);\n }\n\n // Since the delta values reported on mouse wheel events are\n // unstandardized between browsers and even browser versions, and\n // generally horribly unpredictable, this code starts by measuring\n // the scroll effect that the first few mouse wheel events have,\n // and, from that, detects the way it can convert deltas to pixel\n // offsets afterwards.\n //\n // The reason we want to know the amount a wheel event will scroll\n // is that it gives us a chance to update the display before the\n // actual scrolling happens, reducing flickering.\n\n var wheelSamples = 0, wheelPixelsPerUnit = null;\n // Fill in a browser-detected starting value on browsers where we\n // know one. These don't have to be accurate -- the result of them\n // being wrong would just be a slight flicker on the first wheel\n // scroll (if it is large enough).\n if (ie) wheelPixelsPerUnit = -.53;\n else if (gecko) wheelPixelsPerUnit = 15;\n else if (chrome) wheelPixelsPerUnit = -.7;\n else if (safari) wheelPixelsPerUnit = -1/3;\n\n var wheelEventDelta = function(e) {\n var dx = e.wheelDeltaX, dy = e.wheelDeltaY;\n if (dx == null && e.detail && e.axis == e.HORIZONTAL_AXIS) dx = e.detail;\n if (dy == null && e.detail && e.axis == e.VERTICAL_AXIS) dy = e.detail;\n else if (dy == null) dy = e.wheelDelta;\n return {x: dx, y: dy};\n };\n CodeMirror.wheelEventPixels = function(e) {\n var delta = wheelEventDelta(e);\n delta.x *= wheelPixelsPerUnit;\n delta.y *= wheelPixelsPerUnit;\n return delta;\n };\n\n function onScrollWheel(cm, e) {\n var delta = wheelEventDelta(e), dx = delta.x, dy = delta.y;\n\n var display = cm.display, scroll = display.scroller;\n // Quit if there's nothing to scroll here\n var canScrollX = scroll.scrollWidth > scroll.clientWidth;\n var canScrollY = scroll.scrollHeight > scroll.clientHeight;\n if (!(dx && canScrollX || dy && canScrollY)) return;\n\n // Webkit browsers on OS X abort momentum scrolls when the target\n // of the scroll event is removed from the scrollable element.\n // This hack (see related code in patchDisplay) makes sure the\n // element is kept around.\n if (dy && mac && webkit) {\n outer: for (var cur = e.target, view = display.view; cur != scroll; cur = cur.parentNode) {\n for (var i = 0; i < view.length; i++) {\n if (view[i].node == cur) {\n cm.display.currentWheelTarget = cur;\n break outer;\n }\n }\n }\n }\n\n // On some browsers, horizontal scrolling will cause redraws to\n // happen before the gutter has been realigned, causing it to\n // wriggle around in a most unseemly way. When we have an\n // estimated pixels/delta value, we just handle horizontal\n // scrolling entirely here. It'll be slightly off from native, but\n // better than glitching out.\n if (dx && !gecko && !presto && wheelPixelsPerUnit != null) {\n if (dy && canScrollY)\n setScrollTop(cm, Math.max(0, Math.min(scroll.scrollTop + dy * wheelPixelsPerUnit, scroll.scrollHeight - scroll.clientHeight)));\n setScrollLeft(cm, Math.max(0, Math.min(scroll.scrollLeft + dx * wheelPixelsPerUnit, scroll.scrollWidth - scroll.clientWidth)));\n // Only prevent default scrolling if vertical scrolling is\n // actually possible. Otherwise, it causes vertical scroll\n // jitter on OSX trackpads when deltaX is small and deltaY\n // is large (issue #3579)\n if (!dy || (dy && canScrollY))\n e_preventDefault(e);\n display.wheelStartX = null; // Abort measurement, if in progress\n return;\n }\n\n // 'Project' the visible viewport to cover the area that is being\n // scrolled into view (if we know enough to estimate it).\n if (dy && wheelPixelsPerUnit != null) {\n var pixels = dy * wheelPixelsPerUnit;\n var top = cm.doc.scrollTop, bot = top + display.wrapper.clientHeight;\n if (pixels < 0) top = Math.max(0, top + pixels - 50);\n else bot = Math.min(cm.doc.height, bot + pixels + 50);\n updateDisplaySimple(cm, {top: top, bottom: bot});\n }\n\n if (wheelSamples < 20) {\n if (display.wheelStartX == null) {\n display.wheelStartX = scroll.scrollLeft; display.wheelStartY = scroll.scrollTop;\n display.wheelDX = dx; display.wheelDY = dy;\n setTimeout(function() {\n if (display.wheelStartX == null) return;\n var movedX = scroll.scrollLeft - display.wheelStartX;\n var movedY = scroll.scrollTop - display.wheelStartY;\n var sample = (movedY && display.wheelDY && movedY / display.wheelDY) ||\n (movedX && display.wheelDX && movedX / display.wheelDX);\n display.wheelStartX = display.wheelStartY = null;\n if (!sample) return;\n wheelPixelsPerUnit = (wheelPixelsPerUnit * wheelSamples + sample) / (wheelSamples + 1);\n ++wheelSamples;\n }, 200);\n } else {\n display.wheelDX += dx; display.wheelDY += dy;\n }\n }\n }\n\n // KEY EVENTS\n\n // Run a handler that was bound to a key.\n function doHandleBinding(cm, bound, dropShift) {\n if (typeof bound == \"string\") {\n bound = commands[bound];\n if (!bound) return false;\n }\n // Ensure previous input has been read, so that the handler sees a\n // consistent view of the document\n cm.display.input.ensurePolled();\n var prevShift = cm.display.shift, done = false;\n try {\n if (cm.isReadOnly()) cm.state.suppressEdits = true;\n if (dropShift) cm.display.shift = false;\n done = bound(cm) != Pass;\n } finally {\n cm.display.shift = prevShift;\n cm.state.suppressEdits = false;\n }\n return done;\n }\n\n function lookupKeyForEditor(cm, name, handle) {\n for (var i = 0; i < cm.state.keyMaps.length; i++) {\n var result = lookupKey(name, cm.state.keyMaps[i], handle, cm);\n if (result) return result;\n }\n return (cm.options.extraKeys && lookupKey(name, cm.options.extraKeys, handle, cm))\n || lookupKey(name, cm.options.keyMap, handle, cm);\n }\n\n var stopSeq = new Delayed;\n function dispatchKey(cm, name, e, handle) {\n var seq = cm.state.keySeq;\n if (seq) {\n if (isModifierKey(name)) return \"handled\";\n stopSeq.set(50, function() {\n if (cm.state.keySeq == seq) {\n cm.state.keySeq = null;\n cm.display.input.reset();\n }\n });\n name = seq + \" \" + name;\n }\n var result = lookupKeyForEditor(cm, name, handle);\n\n if (result == \"multi\")\n cm.state.keySeq = name;\n if (result == \"handled\")\n signalLater(cm, \"keyHandled\", cm, name, e);\n\n if (result == \"handled\" || result == \"multi\") {\n e_preventDefault(e);\n restartBlink(cm);\n }\n\n if (seq && !result && /\\'$/.test(name)) {\n e_preventDefault(e);\n return true;\n }\n return !!result;\n }\n\n // Handle a key from the keydown event.\n function handleKeyBinding(cm, e) {\n var name = keyName(e, true);\n if (!name) return false;\n\n if (e.shiftKey && !cm.state.keySeq) {\n // First try to resolve full name (including 'Shift-'). Failing\n // that, see if there is a cursor-motion command (starting with\n // 'go') bound to the keyname without 'Shift-'.\n return dispatchKey(cm, \"Shift-\" + name, e, function(b) {return doHandleBinding(cm, b, true);})\n || dispatchKey(cm, name, e, function(b) {\n if (typeof b == \"string\" ? /^go[A-Z]/.test(b) : b.motion)\n return doHandleBinding(cm, b);\n });\n } else {\n return dispatchKey(cm, name, e, function(b) { return doHandleBinding(cm, b); });\n }\n }\n\n // Handle a key from the keypress event\n function handleCharBinding(cm, e, ch) {\n return dispatchKey(cm, \"'\" + ch + \"'\", e,\n function(b) { return doHandleBinding(cm, b, true); });\n }\n\n var lastStoppedKey = null;\n function onKeyDown(e) {\n var cm = this;\n cm.curOp.focus = activeElt();\n if (signalDOMEvent(cm, e)) return;\n // IE does strange things with escape.\n if (ie && ie_version < 11 && e.keyCode == 27) e.returnValue = false;\n var code = e.keyCode;\n cm.display.shift = code == 16 || e.shiftKey;\n var handled = handleKeyBinding(cm, e);\n if (presto) {\n lastStoppedKey = handled ? code : null;\n // Opera has no cut event... we try to at least catch the key combo\n if (!handled && code == 88 && !hasCopyEvent && (mac ? e.metaKey : e.ctrlKey))\n cm.replaceSelection(\"\", null, \"cut\");\n }\n\n // Turn mouse into crosshair when Alt is held on Mac.\n if (code == 18 && !/\\bCodeMirror-crosshair\\b/.test(cm.display.lineDiv.className))\n showCrossHair(cm);\n }\n\n function showCrossHair(cm) {\n var lineDiv = cm.display.lineDiv;\n addClass(lineDiv, \"CodeMirror-crosshair\");\n\n function up(e) {\n if (e.keyCode == 18 || !e.altKey) {\n rmClass(lineDiv, \"CodeMirror-crosshair\");\n off(document, \"keyup\", up);\n off(document, \"mouseover\", up);\n }\n }\n on(document, \"keyup\", up);\n on(document, \"mouseover\", up);\n }\n\n function onKeyUp(e) {\n if (e.keyCode == 16) this.doc.sel.shift = false;\n signalDOMEvent(this, e);\n }\n\n function onKeyPress(e) {\n var cm = this;\n if (eventInWidget(cm.display, e) || signalDOMEvent(cm, e) || e.ctrlKey && !e.altKey || mac && e.metaKey) return;\n var keyCode = e.keyCode, charCode = e.charCode;\n if (presto && keyCode == lastStoppedKey) {lastStoppedKey = null; e_preventDefault(e); return;}\n if ((presto && (!e.which || e.which < 10)) && handleKeyBinding(cm, e)) return;\n var ch = String.fromCharCode(charCode == null ? keyCode : charCode);\n if (handleCharBinding(cm, e, ch)) return;\n cm.display.input.onKeyPress(e);\n }\n\n // FOCUS/BLUR EVENTS\n\n function delayBlurEvent(cm) {\n cm.state.delayingBlurEvent = true;\n setTimeout(function() {\n if (cm.state.delayingBlurEvent) {\n cm.state.delayingBlurEvent = false;\n onBlur(cm);\n }\n }, 100);\n }\n\n function onFocus(cm) {\n if (cm.state.delayingBlurEvent) cm.state.delayingBlurEvent = false;\n\n if (cm.options.readOnly == \"nocursor\") return;\n if (!cm.state.focused) {\n signal(cm, \"focus\", cm);\n cm.state.focused = true;\n addClass(cm.display.wrapper, \"CodeMirror-focused\");\n // This test prevents this from firing when a context\n // menu is closed (since the input reset would kill the\n // select-all detection hack)\n if (!cm.curOp && cm.display.selForContextMenu != cm.doc.sel) {\n cm.display.input.reset();\n if (webkit) setTimeout(function() { cm.display.input.reset(true); }, 20); // Issue #1730\n }\n cm.display.input.receivedFocus();\n }\n restartBlink(cm);\n }\n function onBlur(cm) {\n if (cm.state.delayingBlurEvent) return;\n\n if (cm.state.focused) {\n signal(cm, \"blur\", cm);\n cm.state.focused = false;\n rmClass(cm.display.wrapper, \"CodeMirror-focused\");\n }\n clearInterval(cm.display.blinker);\n setTimeout(function() {if (!cm.state.focused) cm.display.shift = false;}, 150);\n }\n\n // CONTEXT MENU HANDLING\n\n // To make the context menu work, we need to briefly unhide the\n // textarea (making it as unobtrusive as possible) to let the\n // right-click take effect on it.\n function onContextMenu(cm, e) {\n if (eventInWidget(cm.display, e) || contextMenuInGutter(cm, e)) return;\n if (signalDOMEvent(cm, e, \"contextmenu\")) return;\n cm.display.input.onContextMenu(e);\n }\n\n function contextMenuInGutter(cm, e) {\n if (!hasHandler(cm, \"gutterContextMenu\")) return false;\n return gutterEvent(cm, e, \"gutterContextMenu\", false);\n }\n\n // UPDATING\n\n // Compute the position of the end of a change (its 'to' property\n // refers to the pre-change end).\n var changeEnd = CodeMirror.changeEnd = function(change) {\n if (!change.text) return change.to;\n return Pos(change.from.line + change.text.length - 1,\n lst(change.text).length + (change.text.length == 1 ? change.from.ch : 0));\n };\n\n // Adjust a position to refer to the post-change position of the\n // same text, or the end of the change if the change covers it.\n function adjustForChange(pos, change) {\n if (cmp(pos, change.from) < 0) return pos;\n if (cmp(pos, change.to) <= 0) return changeEnd(change);\n\n var line = pos.line + change.text.length - (change.to.line - change.from.line) - 1, ch = pos.ch;\n if (pos.line == change.to.line) ch += changeEnd(change).ch - change.to.ch;\n return Pos(line, ch);\n }\n\n function computeSelAfterChange(doc, change) {\n var out = [];\n for (var i = 0; i < doc.sel.ranges.length; i++) {\n var range = doc.sel.ranges[i];\n out.push(new Range(adjustForChange(range.anchor, change),\n adjustForChange(range.head, change)));\n }\n return normalizeSelection(out, doc.sel.primIndex);\n }\n\n function offsetPos(pos, old, nw) {\n if (pos.line == old.line)\n return Pos(nw.line, pos.ch - old.ch + nw.ch);\n else\n return Pos(nw.line + (pos.line - old.line), pos.ch);\n }\n\n // Used by replaceSelections to allow moving the selection to the\n // start or around the replaced test. Hint may be \"start\" or \"around\".\n function computeReplacedSel(doc, changes, hint) {\n var out = [];\n var oldPrev = Pos(doc.first, 0), newPrev = oldPrev;\n for (var i = 0; i < changes.length; i++) {\n var change = changes[i];\n var from = offsetPos(change.from, oldPrev, newPrev);\n var to = offsetPos(changeEnd(change), oldPrev, newPrev);\n oldPrev = change.to;\n newPrev = to;\n if (hint == \"around\") {\n var range = doc.sel.ranges[i], inv = cmp(range.head, range.anchor) < 0;\n out[i] = new Range(inv ? to : from, inv ? from : to);\n } else {\n out[i] = new Range(from, from);\n }\n }\n return new Selection(out, doc.sel.primIndex);\n }\n\n // Allow \"beforeChange\" event handlers to influence a change\n function filterChange(doc, change, update) {\n var obj = {\n canceled: false,\n from: change.from,\n to: change.to,\n text: change.text,\n origin: change.origin,\n cancel: function() { this.canceled = true; }\n };\n if (update) obj.update = function(from, to, text, origin) {\n if (from) this.from = clipPos(doc, from);\n if (to) this.to = clipPos(doc, to);\n if (text) this.text = text;\n if (origin !== undefined) this.origin = origin;\n };\n signal(doc, \"beforeChange\", doc, obj);\n if (doc.cm) signal(doc.cm, \"beforeChange\", doc.cm, obj);\n\n if (obj.canceled) return null;\n return {from: obj.from, to: obj.to, text: obj.text, origin: obj.origin};\n }\n\n // Apply a change to a document, and add it to the document's\n // history, and propagating it to all linked documents.\n function makeChange(doc, change, ignoreReadOnly) {\n if (doc.cm) {\n if (!doc.cm.curOp) return operation(doc.cm, makeChange)(doc, change, ignoreReadOnly);\n if (doc.cm.state.suppressEdits) return;\n }\n\n if (hasHandler(doc, \"beforeChange\") || doc.cm && hasHandler(doc.cm, \"beforeChange\")) {\n change = filterChange(doc, change, true);\n if (!change) return;\n }\n\n // Possibly split or suppress the update based on the presence\n // of read-only spans in its range.\n var split = sawReadOnlySpans && !ignoreReadOnly && removeReadOnlyRanges(doc, change.from, change.to);\n if (split) {\n for (var i = split.length - 1; i >= 0; --i)\n makeChangeInner(doc, {from: split[i].from, to: split[i].to, text: i ? [\"\"] : change.text});\n } else {\n makeChangeInner(doc, change);\n }\n }\n\n function makeChangeInner(doc, change) {\n if (change.text.length == 1 && change.text[0] == \"\" && cmp(change.from, change.to) == 0) return;\n var selAfter = computeSelAfterChange(doc, change);\n addChangeToHistory(doc, change, selAfter, doc.cm ? doc.cm.curOp.id : NaN);\n\n makeChangeSingleDoc(doc, change, selAfter, stretchSpansOverChange(doc, change));\n var rebased = [];\n\n linkedDocs(doc, function(doc, sharedHist) {\n if (!sharedHist && indexOf(rebased, doc.history) == -1) {\n rebaseHist(doc.history, change);\n rebased.push(doc.history);\n }\n makeChangeSingleDoc(doc, change, null, stretchSpansOverChange(doc, change));\n });\n }\n\n // Revert a change stored in a document's history.\n function makeChangeFromHistory(doc, type, allowSelectionOnly) {\n if (doc.cm && doc.cm.state.suppressEdits && !allowSelectionOnly) return;\n\n var hist = doc.history, event, selAfter = doc.sel;\n var source = type == \"undo\" ? hist.done : hist.undone, dest = type == \"undo\" ? hist.undone : hist.done;\n\n // Verify that there is a useable event (so that ctrl-z won't\n // needlessly clear selection events)\n for (var i = 0; i < source.length; i++) {\n event = source[i];\n if (allowSelectionOnly ? event.ranges && !event.equals(doc.sel) : !event.ranges)\n break;\n }\n if (i == source.length) return;\n hist.lastOrigin = hist.lastSelOrigin = null;\n\n for (;;) {\n event = source.pop();\n if (event.ranges) {\n pushSelectionToHistory(event, dest);\n if (allowSelectionOnly && !event.equals(doc.sel)) {\n setSelection(doc, event, {clearRedo: false});\n return;\n }\n selAfter = event;\n }\n else break;\n }\n\n // Build up a reverse change object to add to the opposite history\n // stack (redo when undoing, and vice versa).\n var antiChanges = [];\n pushSelectionToHistory(selAfter, dest);\n dest.push({changes: antiChanges, generation: hist.generation});\n hist.generation = event.generation || ++hist.maxGeneration;\n\n var filter = hasHandler(doc, \"beforeChange\") || doc.cm && hasHandler(doc.cm, \"beforeChange\");\n\n for (var i = event.changes.length - 1; i >= 0; --i) {\n var change = event.changes[i];\n change.origin = type;\n if (filter && !filterChange(doc, change, false)) {\n source.length = 0;\n return;\n }\n\n antiChanges.push(historyChangeFromChange(doc, change));\n\n var after = i ? computeSelAfterChange(doc, change) : lst(source);\n makeChangeSingleDoc(doc, change, after, mergeOldSpans(doc, change));\n if (!i && doc.cm) doc.cm.scrollIntoView({from: change.from, to: changeEnd(change)});\n var rebased = [];\n\n // Propagate to the linked documents\n linkedDocs(doc, function(doc, sharedHist) {\n if (!sharedHist && indexOf(rebased, doc.history) == -1) {\n rebaseHist(doc.history, change);\n rebased.push(doc.history);\n }\n makeChangeSingleDoc(doc, change, null, mergeOldSpans(doc, change));\n });\n }\n }\n\n // Sub-views need their line numbers shifted when text is added\n // above or below them in the parent document.\n function shiftDoc(doc, distance) {\n if (distance == 0) return;\n doc.first += distance;\n doc.sel = new Selection(map(doc.sel.ranges, function(range) {\n return new Range(Pos(range.anchor.line + distance, range.anchor.ch),\n Pos(range.head.line + distance, range.head.ch));\n }), doc.sel.primIndex);\n if (doc.cm) {\n regChange(doc.cm, doc.first, doc.first - distance, distance);\n for (var d = doc.cm.display, l = d.viewFrom; l < d.viewTo; l++)\n regLineChange(doc.cm, l, \"gutter\");\n }\n }\n\n // More lower-level change function, handling only a single document\n // (not linked ones).\n function makeChangeSingleDoc(doc, change, selAfter, spans) {\n if (doc.cm && !doc.cm.curOp)\n return operation(doc.cm, makeChangeSingleDoc)(doc, change, selAfter, spans);\n\n if (change.to.line < doc.first) {\n shiftDoc(doc, change.text.length - 1 - (change.to.line - change.from.line));\n return;\n }\n if (change.from.line > doc.lastLine()) return;\n\n // Clip the change to the size of this doc\n if (change.from.line < doc.first) {\n var shift = change.text.length - 1 - (doc.first - change.from.line);\n shiftDoc(doc, shift);\n change = {from: Pos(doc.first, 0), to: Pos(change.to.line + shift, change.to.ch),\n text: [lst(change.text)], origin: change.origin};\n }\n var last = doc.lastLine();\n if (change.to.line > last) {\n change = {from: change.from, to: Pos(last, getLine(doc, last).text.length),\n text: [change.text[0]], origin: change.origin};\n }\n\n change.removed = getBetween(doc, change.from, change.to);\n\n if (!selAfter) selAfter = computeSelAfterChange(doc, change);\n if (doc.cm) makeChangeSingleDocInEditor(doc.cm, change, spans);\n else updateDoc(doc, change, spans);\n setSelectionNoUndo(doc, selAfter, sel_dontScroll);\n }\n\n // Handle the interaction of a change to a document with the editor\n // that this document is part of.\n function makeChangeSingleDocInEditor(cm, change, spans) {\n var doc = cm.doc, display = cm.display, from = change.from, to = change.to;\n\n var recomputeMaxLength = false, checkWidthStart = from.line;\n if (!cm.options.lineWrapping) {\n checkWidthStart = lineNo(visualLine(getLine(doc, from.line)));\n doc.iter(checkWidthStart, to.line + 1, function(line) {\n if (line == display.maxLine) {\n recomputeMaxLength = true;\n return true;\n }\n });\n }\n\n if (doc.sel.contains(change.from, change.to) > -1)\n signalCursorActivity(cm);\n\n updateDoc(doc, change, spans, estimateHeight(cm));\n\n if (!cm.options.lineWrapping) {\n doc.iter(checkWidthStart, from.line + change.text.length, function(line) {\n var len = lineLength(line);\n if (len > display.maxLineLength) {\n display.maxLine = line;\n display.maxLineLength = len;\n display.maxLineChanged = true;\n recomputeMaxLength = false;\n }\n });\n if (recomputeMaxLength) cm.curOp.updateMaxLine = true;\n }\n\n // Adjust frontier, schedule worker\n doc.frontier = Math.min(doc.frontier, from.line);\n startWorker(cm, 400);\n\n var lendiff = change.text.length - (to.line - from.line) - 1;\n // Remember that these lines changed, for updating the display\n if (change.full)\n regChange(cm);\n else if (from.line == to.line && change.text.length == 1 && !isWholeLineUpdate(cm.doc, change))\n regLineChange(cm, from.line, \"text\");\n else\n regChange(cm, from.line, to.line + 1, lendiff);\n\n var changesHandler = hasHandler(cm, \"changes\"), changeHandler = hasHandler(cm, \"change\");\n if (changeHandler || changesHandler) {\n var obj = {\n from: from, to: to,\n text: change.text,\n removed: change.removed,\n origin: change.origin\n };\n if (changeHandler) signalLater(cm, \"change\", cm, obj);\n if (changesHandler) (cm.curOp.changeObjs || (cm.curOp.changeObjs = [])).push(obj);\n }\n cm.display.selForContextMenu = null;\n }\n\n function replaceRange(doc, code, from, to, origin) {\n if (!to) to = from;\n if (cmp(to, from) < 0) { var tmp = to; to = from; from = tmp; }\n if (typeof code == \"string\") code = doc.splitLines(code);\n makeChange(doc, {from: from, to: to, text: code, origin: origin});\n }\n\n // SCROLLING THINGS INTO VIEW\n\n // If an editor sits on the top or bottom of the window, partially\n // scrolled out of view, this ensures that the cursor is visible.\n function maybeScrollWindow(cm, coords) {\n if (signalDOMEvent(cm, \"scrollCursorIntoView\")) return;\n\n var display = cm.display, box = display.sizer.getBoundingClientRect(), doScroll = null;\n if (coords.top + box.top < 0) doScroll = true;\n else if (coords.bottom + box.top > (window.innerHeight || document.documentElement.clientHeight)) doScroll = false;\n if (doScroll != null && !phantom) {\n var scrollNode = elt(\"div\", \"\\u200b\", null, \"position: absolute; top: \" +\n (coords.top - display.viewOffset - paddingTop(cm.display)) + \"px; height: \" +\n (coords.bottom - coords.top + scrollGap(cm) + display.barHeight) + \"px; left: \" +\n coords.left + \"px; width: 2px;\");\n cm.display.lineSpace.appendChild(scrollNode);\n scrollNode.scrollIntoView(doScroll);\n cm.display.lineSpace.removeChild(scrollNode);\n }\n }\n\n // Scroll a given position into view (immediately), verifying that\n // it actually became visible (as line heights are accurately\n // measured, the position of something may 'drift' during drawing).\n function scrollPosIntoView(cm, pos, end, margin) {\n if (margin == null) margin = 0;\n for (var limit = 0; limit < 5; limit++) {\n var changed = false, coords = cursorCoords(cm, pos);\n var endCoords = !end || end == pos ? coords : cursorCoords(cm, end);\n var scrollPos = calculateScrollPos(cm, Math.min(coords.left, endCoords.left),\n Math.min(coords.top, endCoords.top) - margin,\n Math.max(coords.left, endCoords.left),\n Math.max(coords.bottom, endCoords.bottom) + margin);\n var startTop = cm.doc.scrollTop, startLeft = cm.doc.scrollLeft;\n if (scrollPos.scrollTop != null) {\n setScrollTop(cm, scrollPos.scrollTop);\n if (Math.abs(cm.doc.scrollTop - startTop) > 1) changed = true;\n }\n if (scrollPos.scrollLeft != null) {\n setScrollLeft(cm, scrollPos.scrollLeft);\n if (Math.abs(cm.doc.scrollLeft - startLeft) > 1) changed = true;\n }\n if (!changed) break;\n }\n return coords;\n }\n\n // Scroll a given set of coordinates into view (immediately).\n function scrollIntoView(cm, x1, y1, x2, y2) {\n var scrollPos = calculateScrollPos(cm, x1, y1, x2, y2);\n if (scrollPos.scrollTop != null) setScrollTop(cm, scrollPos.scrollTop);\n if (scrollPos.scrollLeft != null) setScrollLeft(cm, scrollPos.scrollLeft);\n }\n\n // Calculate a new scroll position needed to scroll the given\n // rectangle into view. Returns an object with scrollTop and\n // scrollLeft properties. When these are undefined, the\n // vertical/horizontal position does not need to be adjusted.\n function calculateScrollPos(cm, x1, y1, x2, y2) {\n var display = cm.display, snapMargin = textHeight(cm.display);\n if (y1 < 0) y1 = 0;\n var screentop = cm.curOp && cm.curOp.scrollTop != null ? cm.curOp.scrollTop : display.scroller.scrollTop;\n var screen = displayHeight(cm), result = {};\n if (y2 - y1 > screen) y2 = y1 + screen;\n var docBottom = cm.doc.height + paddingVert(display);\n var atTop = y1 < snapMargin, atBottom = y2 > docBottom - snapMargin;\n if (y1 < screentop) {\n result.scrollTop = atTop ? 0 : y1;\n } else if (y2 > screentop + screen) {\n var newTop = Math.min(y1, (atBottom ? docBottom : y2) - screen);\n if (newTop != screentop) result.scrollTop = newTop;\n }\n\n var screenleft = cm.curOp && cm.curOp.scrollLeft != null ? cm.curOp.scrollLeft : display.scroller.scrollLeft;\n var screenw = displayWidth(cm) - (cm.options.fixedGutter ? display.gutters.offsetWidth : 0);\n var tooWide = x2 - x1 > screenw;\n if (tooWide) x2 = x1 + screenw;\n if (x1 < 10)\n result.scrollLeft = 0;\n else if (x1 < screenleft)\n result.scrollLeft = Math.max(0, x1 - (tooWide ? 0 : 10));\n else if (x2 > screenw + screenleft - 3)\n result.scrollLeft = x2 + (tooWide ? 0 : 10) - screenw;\n return result;\n }\n\n // Store a relative adjustment to the scroll position in the current\n // operation (to be applied when the operation finishes).\n function addToScrollPos(cm, left, top) {\n if (left != null || top != null) resolveScrollToPos(cm);\n if (left != null)\n cm.curOp.scrollLeft = (cm.curOp.scrollLeft == null ? cm.doc.scrollLeft : cm.curOp.scrollLeft) + left;\n if (top != null)\n cm.curOp.scrollTop = (cm.curOp.scrollTop == null ? cm.doc.scrollTop : cm.curOp.scrollTop) + top;\n }\n\n // Make sure that at the end of the operation the current cursor is\n // shown.\n function ensureCursorVisible(cm) {\n resolveScrollToPos(cm);\n var cur = cm.getCursor(), from = cur, to = cur;\n if (!cm.options.lineWrapping) {\n from = cur.ch ? Pos(cur.line, cur.ch - 1) : cur;\n to = Pos(cur.line, cur.ch + 1);\n }\n cm.curOp.scrollToPos = {from: from, to: to, margin: cm.options.cursorScrollMargin, isCursor: true};\n }\n\n // When an operation has its scrollToPos property set, and another\n // scroll action is applied before the end of the operation, this\n // 'simulates' scrolling that position into view in a cheap way, so\n // that the effect of intermediate scroll commands is not ignored.\n function resolveScrollToPos(cm) {\n var range = cm.curOp.scrollToPos;\n if (range) {\n cm.curOp.scrollToPos = null;\n var from = estimateCoords(cm, range.from), to = estimateCoords(cm, range.to);\n var sPos = calculateScrollPos(cm, Math.min(from.left, to.left),\n Math.min(from.top, to.top) - range.margin,\n Math.max(from.right, to.right),\n Math.max(from.bottom, to.bottom) + range.margin);\n cm.scrollTo(sPos.scrollLeft, sPos.scrollTop);\n }\n }\n\n // API UTILITIES\n\n // Indent the given line. The how parameter can be \"smart\",\n // \"add\"/null, \"subtract\", or \"prev\". When aggressive is false\n // (typically set to true for forced single-line indents), empty\n // lines are not indented, and places where the mode returns Pass\n // are left alone.\n function indentLine(cm, n, how, aggressive) {\n var doc = cm.doc, state;\n if (how == null) how = \"add\";\n if (how == \"smart\") {\n // Fall back to \"prev\" when the mode doesn't have an indentation\n // method.\n if (!doc.mode.indent) how = \"prev\";\n else state = getStateBefore(cm, n);\n }\n\n var tabSize = cm.options.tabSize;\n var line = getLine(doc, n), curSpace = countColumn(line.text, null, tabSize);\n if (line.stateAfter) line.stateAfter = null;\n var curSpaceString = line.text.match(/^\\s*/)[0], indentation;\n if (!aggressive && !/\\S/.test(line.text)) {\n indentation = 0;\n how = \"not\";\n } else if (how == \"smart\") {\n indentation = doc.mode.indent(state, line.text.slice(curSpaceString.length), line.text);\n if (indentation == Pass || indentation > 150) {\n if (!aggressive) return;\n how = \"prev\";\n }\n }\n if (how == \"prev\") {\n if (n > doc.first) indentation = countColumn(getLine(doc, n-1).text, null, tabSize);\n else indentation = 0;\n } else if (how == \"add\") {\n indentation = curSpace + cm.options.indentUnit;\n } else if (how == \"subtract\") {\n indentation = curSpace - cm.options.indentUnit;\n } else if (typeof how == \"number\") {\n indentation = curSpace + how;\n }\n indentation = Math.max(0, indentation);\n\n var indentString = \"\", pos = 0;\n if (cm.options.indentWithTabs)\n for (var i = Math.floor(indentation / tabSize); i; --i) {pos += tabSize; indentString += \"\\t\";}\n if (pos < indentation) indentString += spaceStr(indentation - pos);\n\n if (indentString != curSpaceString) {\n replaceRange(doc, indentString, Pos(n, 0), Pos(n, curSpaceString.length), \"+input\");\n line.stateAfter = null;\n return true;\n } else {\n // Ensure that, if the cursor was in the whitespace at the start\n // of the line, it is moved to the end of that space.\n for (var i = 0; i < doc.sel.ranges.length; i++) {\n var range = doc.sel.ranges[i];\n if (range.head.line == n && range.head.ch < curSpaceString.length) {\n var pos = Pos(n, curSpaceString.length);\n replaceOneSelection(doc, i, new Range(pos, pos));\n break;\n }\n }\n }\n }\n\n // Utility for applying a change to a line by handle or number,\n // returning the number and optionally registering the line as\n // changed.\n function changeLine(doc, handle, changeType, op) {\n var no = handle, line = handle;\n if (typeof handle == \"number\") line = getLine(doc, clipLine(doc, handle));\n else no = lineNo(handle);\n if (no == null) return null;\n if (op(line, no) && doc.cm) regLineChange(doc.cm, no, changeType);\n return line;\n }\n\n // Helper for deleting text near the selection(s), used to implement\n // backspace, delete, and similar functionality.\n function deleteNearSelection(cm, compute) {\n var ranges = cm.doc.sel.ranges, kill = [];\n // Build up a set of ranges to kill first, merging overlapping\n // ranges.\n for (var i = 0; i < ranges.length; i++) {\n var toKill = compute(ranges[i]);\n while (kill.length && cmp(toKill.from, lst(kill).to) <= 0) {\n var replaced = kill.pop();\n if (cmp(replaced.from, toKill.from) < 0) {\n toKill.from = replaced.from;\n break;\n }\n }\n kill.push(toKill);\n }\n // Next, remove those actual ranges.\n runInOp(cm, function() {\n for (var i = kill.length - 1; i >= 0; i--)\n replaceRange(cm.doc, \"\", kill[i].from, kill[i].to, \"+delete\");\n ensureCursorVisible(cm);\n });\n }\n\n // Used for horizontal relative motion. Dir is -1 or 1 (left or\n // right), unit can be \"char\", \"column\" (like char, but doesn't\n // cross line boundaries), \"word\" (across next word), or \"group\" (to\n // the start of next group of word or non-word-non-whitespace\n // chars). The visually param controls whether, in right-to-left\n // text, direction 1 means to move towards the next index in the\n // string, or towards the character to the right of the current\n // position. The resulting position will have a hitSide=true\n // property if it reached the end of the document.\n function findPosH(doc, pos, dir, unit, visually) {\n var line = pos.line, ch = pos.ch, origDir = dir;\n var lineObj = getLine(doc, line);\n function findNextLine() {\n var l = line + dir;\n if (l < doc.first || l >= doc.first + doc.size) return false\n line = l;\n return lineObj = getLine(doc, l);\n }\n function moveOnce(boundToLine) {\n var next = (visually ? moveVisually : moveLogically)(lineObj, ch, dir, true);\n if (next == null) {\n if (!boundToLine && findNextLine()) {\n if (visually) ch = (dir < 0 ? lineRight : lineLeft)(lineObj);\n else ch = dir < 0 ? lineObj.text.length : 0;\n } else return false\n } else ch = next;\n return true;\n }\n\n if (unit == \"char\") {\n moveOnce()\n } else if (unit == \"column\") {\n moveOnce(true)\n } else if (unit == \"word\" || unit == \"group\") {\n var sawType = null, group = unit == \"group\";\n var helper = doc.cm && doc.cm.getHelper(pos, \"wordChars\");\n for (var first = true;; first = false) {\n if (dir < 0 && !moveOnce(!first)) break;\n var cur = lineObj.text.charAt(ch) || \"\\n\";\n var type = isWordChar(cur, helper) ? \"w\"\n : group && cur == \"\\n\" ? \"n\"\n : !group || /\\s/.test(cur) ? null\n : \"p\";\n if (group && !first && !type) type = \"s\";\n if (sawType && sawType != type) {\n if (dir < 0) {dir = 1; moveOnce();}\n break;\n }\n\n if (type) sawType = type;\n if (dir > 0 && !moveOnce(!first)) break;\n }\n }\n var result = skipAtomic(doc, Pos(line, ch), pos, origDir, true);\n if (!cmp(pos, result)) result.hitSide = true;\n return result;\n }\n\n // For relative vertical movement. Dir may be -1 or 1. Unit can be\n // \"page\" or \"line\". The resulting position will have a hitSide=true\n // property if it reached the end of the document.\n function findPosV(cm, pos, dir, unit) {\n var doc = cm.doc, x = pos.left, y;\n if (unit == \"page\") {\n var pageSize = Math.min(cm.display.wrapper.clientHeight, window.innerHeight || document.documentElement.clientHeight);\n y = pos.top + dir * (pageSize - (dir < 0 ? 1.5 : .5) * textHeight(cm.display));\n } else if (unit == \"line\") {\n y = dir > 0 ? pos.bottom + 3 : pos.top - 3;\n }\n for (;;) {\n var target = coordsChar(cm, x, y);\n if (!target.outside) break;\n if (dir < 0 ? y <= 0 : y >= doc.height) { target.hitSide = true; break; }\n y += dir * 5;\n }\n return target;\n }\n\n // EDITOR METHODS\n\n // The publicly visible API. Note that methodOp(f) means\n // 'wrap f in an operation, performed on its `this` parameter'.\n\n // This is not the complete set of editor methods. Most of the\n // methods defined on the Doc type are also injected into\n // CodeMirror.prototype, for backwards compatibility and\n // convenience.\n\n CodeMirror.prototype = {\n constructor: CodeMirror,\n focus: function(){window.focus(); this.display.input.focus();},\n\n setOption: function(option, value) {\n var options = this.options, old = options[option];\n if (options[option] == value && option != \"mode\") return;\n options[option] = value;\n if (optionHandlers.hasOwnProperty(option))\n operation(this, optionHandlers[option])(this, value, old);\n },\n\n getOption: function(option) {return this.options[option];},\n getDoc: function() {return this.doc;},\n\n addKeyMap: function(map, bottom) {\n this.state.keyMaps[bottom ? \"push\" : \"unshift\"](getKeyMap(map));\n },\n removeKeyMap: function(map) {\n var maps = this.state.keyMaps;\n for (var i = 0; i < maps.length; ++i)\n if (maps[i] == map || maps[i].name == map) {\n maps.splice(i, 1);\n return true;\n }\n },\n\n addOverlay: methodOp(function(spec, options) {\n var mode = spec.token ? spec : CodeMirror.getMode(this.options, spec);\n if (mode.startState) throw new Error(\"Overlays may not be stateful.\");\n this.state.overlays.push({mode: mode, modeSpec: spec, opaque: options && options.opaque});\n this.state.modeGen++;\n regChange(this);\n }),\n removeOverlay: methodOp(function(spec) {\n var overlays = this.state.overlays;\n for (var i = 0; i < overlays.length; ++i) {\n var cur = overlays[i].modeSpec;\n if (cur == spec || typeof spec == \"string\" && cur.name == spec) {\n overlays.splice(i, 1);\n this.state.modeGen++;\n regChange(this);\n return;\n }\n }\n }),\n\n indentLine: methodOp(function(n, dir, aggressive) {\n if (typeof dir != \"string\" && typeof dir != \"number\") {\n if (dir == null) dir = this.options.smartIndent ? \"smart\" : \"prev\";\n else dir = dir ? \"add\" : \"subtract\";\n }\n if (isLine(this.doc, n)) indentLine(this, n, dir, aggressive);\n }),\n indentSelection: methodOp(function(how) {\n var ranges = this.doc.sel.ranges, end = -1;\n for (var i = 0; i < ranges.length; i++) {\n var range = ranges[i];\n if (!range.empty()) {\n var from = range.from(), to = range.to();\n var start = Math.max(end, from.line);\n end = Math.min(this.lastLine(), to.line - (to.ch ? 0 : 1)) + 1;\n for (var j = start; j < end; ++j)\n indentLine(this, j, how);\n var newRanges = this.doc.sel.ranges;\n if (from.ch == 0 && ranges.length == newRanges.length && newRanges[i].from().ch > 0)\n replaceOneSelection(this.doc, i, new Range(from, newRanges[i].to()), sel_dontScroll);\n } else if (range.head.line > end) {\n indentLine(this, range.head.line, how, true);\n end = range.head.line;\n if (i == this.doc.sel.primIndex) ensureCursorVisible(this);\n }\n }\n }),\n\n // Fetch the parser token for a given character. Useful for hacks\n // that want to inspect the mode state (say, for completion).\n getTokenAt: function(pos, precise) {\n return takeToken(this, pos, precise);\n },\n\n getLineTokens: function(line, precise) {\n return takeToken(this, Pos(line), precise, true);\n },\n\n getTokenTypeAt: function(pos) {\n pos = clipPos(this.doc, pos);\n var styles = getLineStyles(this, getLine(this.doc, pos.line));\n var before = 0, after = (styles.length - 1) / 2, ch = pos.ch;\n var type;\n if (ch == 0) type = styles[2];\n else for (;;) {\n var mid = (before + after) >> 1;\n if ((mid ? styles[mid * 2 - 1] : 0) >= ch) after = mid;\n else if (styles[mid * 2 + 1] < ch) before = mid + 1;\n else { type = styles[mid * 2 + 2]; break; }\n }\n var cut = type ? type.indexOf(\"cm-overlay \") : -1;\n return cut < 0 ? type : cut == 0 ? null : type.slice(0, cut - 1);\n },\n\n getModeAt: function(pos) {\n var mode = this.doc.mode;\n if (!mode.innerMode) return mode;\n return CodeMirror.innerMode(mode, this.getTokenAt(pos).state).mode;\n },\n\n getHelper: function(pos, type) {\n return this.getHelpers(pos, type)[0];\n },\n\n getHelpers: function(pos, type) {\n var found = [];\n if (!helpers.hasOwnProperty(type)) return found;\n var help = helpers[type], mode = this.getModeAt(pos);\n if (typeof mode[type] == \"string\") {\n if (help[mode[type]]) found.push(help[mode[type]]);\n } else if (mode[type]) {\n for (var i = 0; i < mode[type].length; i++) {\n var val = help[mode[type][i]];\n if (val) found.push(val);\n }\n } else if (mode.helperType && help[mode.helperType]) {\n found.push(help[mode.helperType]);\n } else if (help[mode.name]) {\n found.push(help[mode.name]);\n }\n for (var i = 0; i < help._global.length; i++) {\n var cur = help._global[i];\n if (cur.pred(mode, this) && indexOf(found, cur.val) == -1)\n found.push(cur.val);\n }\n return found;\n },\n\n getStateAfter: function(line, precise) {\n var doc = this.doc;\n line = clipLine(doc, line == null ? doc.first + doc.size - 1: line);\n return getStateBefore(this, line + 1, precise);\n },\n\n cursorCoords: function(start, mode) {\n var pos, range = this.doc.sel.primary();\n if (start == null) pos = range.head;\n else if (typeof start == \"object\") pos = clipPos(this.doc, start);\n else pos = start ? range.from() : range.to();\n return cursorCoords(this, pos, mode || \"page\");\n },\n\n charCoords: function(pos, mode) {\n return charCoords(this, clipPos(this.doc, pos), mode || \"page\");\n },\n\n coordsChar: function(coords, mode) {\n coords = fromCoordSystem(this, coords, mode || \"page\");\n return coordsChar(this, coords.left, coords.top);\n },\n\n lineAtHeight: function(height, mode) {\n height = fromCoordSystem(this, {top: height, left: 0}, mode || \"page\").top;\n return lineAtHeight(this.doc, height + this.display.viewOffset);\n },\n heightAtLine: function(line, mode) {\n var end = false, lineObj;\n if (typeof line == \"number\") {\n var last = this.doc.first + this.doc.size - 1;\n if (line < this.doc.first) line = this.doc.first;\n else if (line > last) { line = last; end = true; }\n lineObj = getLine(this.doc, line);\n } else {\n lineObj = line;\n }\n return intoCoordSystem(this, lineObj, {top: 0, left: 0}, mode || \"page\").top +\n (end ? this.doc.height - heightAtLine(lineObj) : 0);\n },\n\n defaultTextHeight: function() { return textHeight(this.display); },\n defaultCharWidth: function() { return charWidth(this.display); },\n\n setGutterMarker: methodOp(function(line, gutterID, value) {\n return changeLine(this.doc, line, \"gutter\", function(line) {\n var markers = line.gutterMarkers || (line.gutterMarkers = {});\n markers[gutterID] = value;\n if (!value && isEmpty(markers)) line.gutterMarkers = null;\n return true;\n });\n }),\n\n clearGutter: methodOp(function(gutterID) {\n var cm = this, doc = cm.doc, i = doc.first;\n doc.iter(function(line) {\n if (line.gutterMarkers && line.gutterMarkers[gutterID]) {\n line.gutterMarkers[gutterID] = null;\n regLineChange(cm, i, \"gutter\");\n if (isEmpty(line.gutterMarkers)) line.gutterMarkers = null;\n }\n ++i;\n });\n }),\n\n lineInfo: function(line) {\n if (typeof line == \"number\") {\n if (!isLine(this.doc, line)) return null;\n var n = line;\n line = getLine(this.doc, line);\n if (!line) return null;\n } else {\n var n = lineNo(line);\n if (n == null) return null;\n }\n return {line: n, handle: line, text: line.text, gutterMarkers: line.gutterMarkers,\n textClass: line.textClass, bgClass: line.bgClass, wrapClass: line.wrapClass,\n widgets: line.widgets};\n },\n\n getViewport: function() { return {from: this.display.viewFrom, to: this.display.viewTo};},\n\n addWidget: function(pos, node, scroll, vert, horiz) {\n var display = this.display;\n pos = cursorCoords(this, clipPos(this.doc, pos));\n var top = pos.bottom, left = pos.left;\n node.style.position = \"absolute\";\n node.setAttribute(\"cm-ignore-events\", \"true\");\n this.display.input.setUneditable(node);\n display.sizer.appendChild(node);\n if (vert == \"over\") {\n top = pos.top;\n } else if (vert == \"above\" || vert == \"near\") {\n var vspace = Math.max(display.wrapper.clientHeight, this.doc.height),\n hspace = Math.max(display.sizer.clientWidth, display.lineSpace.clientWidth);\n // Default to positioning above (if specified and possible); otherwise default to positioning below\n if ((vert == 'above' || pos.bottom + node.offsetHeight > vspace) && pos.top > node.offsetHeight)\n top = pos.top - node.offsetHeight;\n else if (pos.bottom + node.offsetHeight <= vspace)\n top = pos.bottom;\n if (left + node.offsetWidth > hspace)\n left = hspace - node.offsetWidth;\n }\n node.style.top = top + \"px\";\n node.style.left = node.style.right = \"\";\n if (horiz == \"right\") {\n left = display.sizer.clientWidth - node.offsetWidth;\n node.style.right = \"0px\";\n } else {\n if (horiz == \"left\") left = 0;\n else if (horiz == \"middle\") left = (display.sizer.clientWidth - node.offsetWidth) / 2;\n node.style.left = left + \"px\";\n }\n if (scroll)\n scrollIntoView(this, left, top, left + node.offsetWidth, top + node.offsetHeight);\n },\n\n triggerOnKeyDown: methodOp(onKeyDown),\n triggerOnKeyPress: methodOp(onKeyPress),\n triggerOnKeyUp: onKeyUp,\n\n execCommand: function(cmd) {\n if (commands.hasOwnProperty(cmd))\n return commands[cmd].call(null, this);\n },\n\n triggerElectric: methodOp(function(text) { triggerElectric(this, text); }),\n\n findPosH: function(from, amount, unit, visually) {\n var dir = 1;\n if (amount < 0) { dir = -1; amount = -amount; }\n for (var i = 0, cur = clipPos(this.doc, from); i < amount; ++i) {\n cur = findPosH(this.doc, cur, dir, unit, visually);\n if (cur.hitSide) break;\n }\n return cur;\n },\n\n moveH: methodOp(function(dir, unit) {\n var cm = this;\n cm.extendSelectionsBy(function(range) {\n if (cm.display.shift || cm.doc.extend || range.empty())\n return findPosH(cm.doc, range.head, dir, unit, cm.options.rtlMoveVisually);\n else\n return dir < 0 ? range.from() : range.to();\n }, sel_move);\n }),\n\n deleteH: methodOp(function(dir, unit) {\n var sel = this.doc.sel, doc = this.doc;\n if (sel.somethingSelected())\n doc.replaceSelection(\"\", null, \"+delete\");\n else\n deleteNearSelection(this, function(range) {\n var other = findPosH(doc, range.head, dir, unit, false);\n return dir < 0 ? {from: other, to: range.head} : {from: range.head, to: other};\n });\n }),\n\n findPosV: function(from, amount, unit, goalColumn) {\n var dir = 1, x = goalColumn;\n if (amount < 0) { dir = -1; amount = -amount; }\n for (var i = 0, cur = clipPos(this.doc, from); i < amount; ++i) {\n var coords = cursorCoords(this, cur, \"div\");\n if (x == null) x = coords.left;\n else coords.left = x;\n cur = findPosV(this, coords, dir, unit);\n if (cur.hitSide) break;\n }\n return cur;\n },\n\n moveV: methodOp(function(dir, unit) {\n var cm = this, doc = this.doc, goals = [];\n var collapse = !cm.display.shift && !doc.extend && doc.sel.somethingSelected();\n doc.extendSelectionsBy(function(range) {\n if (collapse)\n return dir < 0 ? range.from() : range.to();\n var headPos = cursorCoords(cm, range.head, \"div\");\n if (range.goalColumn != null) headPos.left = range.goalColumn;\n goals.push(headPos.left);\n var pos = findPosV(cm, headPos, dir, unit);\n if (unit == \"page\" && range == doc.sel.primary())\n addToScrollPos(cm, null, charCoords(cm, pos, \"div\").top - headPos.top);\n return pos;\n }, sel_move);\n if (goals.length) for (var i = 0; i < doc.sel.ranges.length; i++)\n doc.sel.ranges[i].goalColumn = goals[i];\n }),\n\n // Find the word at the given position (as returned by coordsChar).\n findWordAt: function(pos) {\n var doc = this.doc, line = getLine(doc, pos.line).text;\n var start = pos.ch, end = pos.ch;\n if (line) {\n var helper = this.getHelper(pos, \"wordChars\");\n if ((pos.xRel < 0 || end == line.length) && start) --start; else ++end;\n var startChar = line.charAt(start);\n var check = isWordChar(startChar, helper)\n ? function(ch) { return isWordChar(ch, helper); }\n : /\\s/.test(startChar) ? function(ch) {return /\\s/.test(ch);}\n : function(ch) {return !/\\s/.test(ch) && !isWordChar(ch);};\n while (start > 0 && check(line.charAt(start - 1))) --start;\n while (end < line.length && check(line.charAt(end))) ++end;\n }\n return new Range(Pos(pos.line, start), Pos(pos.line, end));\n },\n\n toggleOverwrite: function(value) {\n if (value != null && value == this.state.overwrite) return;\n if (this.state.overwrite = !this.state.overwrite)\n addClass(this.display.cursorDiv, \"CodeMirror-overwrite\");\n else\n rmClass(this.display.cursorDiv, \"CodeMirror-overwrite\");\n\n signal(this, \"overwriteToggle\", this, this.state.overwrite);\n },\n hasFocus: function() { return this.display.input.getField() == activeElt(); },\n isReadOnly: function() { return !!(this.options.readOnly || this.doc.cantEdit); },\n\n scrollTo: methodOp(function(x, y) {\n if (x != null || y != null) resolveScrollToPos(this);\n if (x != null) this.curOp.scrollLeft = x;\n if (y != null) this.curOp.scrollTop = y;\n }),\n getScrollInfo: function() {\n var scroller = this.display.scroller;\n return {left: scroller.scrollLeft, top: scroller.scrollTop,\n height: scroller.scrollHeight - scrollGap(this) - this.display.barHeight,\n width: scroller.scrollWidth - scrollGap(this) - this.display.barWidth,\n clientHeight: displayHeight(this), clientWidth: displayWidth(this)};\n },\n\n scrollIntoView: methodOp(function(range, margin) {\n if (range == null) {\n range = {from: this.doc.sel.primary().head, to: null};\n if (margin == null) margin = this.options.cursorScrollMargin;\n } else if (typeof range == \"number\") {\n range = {from: Pos(range, 0), to: null};\n } else if (range.from == null) {\n range = {from: range, to: null};\n }\n if (!range.to) range.to = range.from;\n range.margin = margin || 0;\n\n if (range.from.line != null) {\n resolveScrollToPos(this);\n this.curOp.scrollToPos = range;\n } else {\n var sPos = calculateScrollPos(this, Math.min(range.from.left, range.to.left),\n Math.min(range.from.top, range.to.top) - range.margin,\n Math.max(range.from.right, range.to.right),\n Math.max(range.from.bottom, range.to.bottom) + range.margin);\n this.scrollTo(sPos.scrollLeft, sPos.scrollTop);\n }\n }),\n\n setSize: methodOp(function(width, height) {\n var cm = this;\n function interpret(val) {\n return typeof val == \"number\" || /^\\d+$/.test(String(val)) ? val + \"px\" : val;\n }\n if (width != null) cm.display.wrapper.style.width = interpret(width);\n if (height != null) cm.display.wrapper.style.height = interpret(height);\n if (cm.options.lineWrapping) clearLineMeasurementCache(this);\n var lineNo = cm.display.viewFrom;\n cm.doc.iter(lineNo, cm.display.viewTo, function(line) {\n if (line.widgets) for (var i = 0; i < line.widgets.length; i++)\n if (line.widgets[i].noHScroll) { regLineChange(cm, lineNo, \"widget\"); break; }\n ++lineNo;\n });\n cm.curOp.forceUpdate = true;\n signal(cm, \"refresh\", this);\n }),\n\n operation: function(f){return runInOp(this, f);},\n\n refresh: methodOp(function() {\n var oldHeight = this.display.cachedTextHeight;\n regChange(this);\n this.curOp.forceUpdate = true;\n clearCaches(this);\n this.scrollTo(this.doc.scrollLeft, this.doc.scrollTop);\n updateGutterSpace(this);\n if (oldHeight == null || Math.abs(oldHeight - textHeight(this.display)) > .5)\n estimateLineHeights(this);\n signal(this, \"refresh\", this);\n }),\n\n swapDoc: methodOp(function(doc) {\n var old = this.doc;\n old.cm = null;\n attachDoc(this, doc);\n clearCaches(this);\n this.display.input.reset();\n this.scrollTo(doc.scrollLeft, doc.scrollTop);\n this.curOp.forceScroll = true;\n signalLater(this, \"swapDoc\", this, old);\n return old;\n }),\n\n getInputField: function(){return this.display.input.getField();},\n getWrapperElement: function(){return this.display.wrapper;},\n getScrollerElement: function(){return this.display.scroller;},\n getGutterElement: function(){return this.display.gutters;}\n };\n eventMixin(CodeMirror);\n\n // OPTION DEFAULTS\n\n // The default configuration options.\n var defaults = CodeMirror.defaults = {};\n // Functions to run when options are changed.\n var optionHandlers = CodeMirror.optionHandlers = {};\n\n function option(name, deflt, handle, notOnInit) {\n CodeMirror.defaults[name] = deflt;\n if (handle) optionHandlers[name] =\n notOnInit ? function(cm, val, old) {if (old != Init) handle(cm, val, old);} : handle;\n }\n\n // Passed to option handlers when there is no old value.\n var Init = CodeMirror.Init = {toString: function(){return \"CodeMirror.Init\";}};\n\n // These two are, on init, called from the constructor because they\n // have to be initialized before the editor can start at all.\n option(\"value\", \"\", function(cm, val) {\n cm.setValue(val);\n }, true);\n option(\"mode\", null, function(cm, val) {\n cm.doc.modeOption = val;\n loadMode(cm);\n }, true);\n\n option(\"indentUnit\", 2, loadMode, true);\n option(\"indentWithTabs\", false);\n option(\"smartIndent\", true);\n option(\"tabSize\", 4, function(cm) {\n resetModeState(cm);\n clearCaches(cm);\n regChange(cm);\n }, true);\n option(\"lineSeparator\", null, function(cm, val) {\n cm.doc.lineSep = val;\n if (!val) return;\n var newBreaks = [], lineNo = cm.doc.first;\n cm.doc.iter(function(line) {\n for (var pos = 0;;) {\n var found = line.text.indexOf(val, pos);\n if (found == -1) break;\n pos = found + val.length;\n newBreaks.push(Pos(lineNo, found));\n }\n lineNo++;\n });\n for (var i = newBreaks.length - 1; i >= 0; i--)\n replaceRange(cm.doc, val, newBreaks[i], Pos(newBreaks[i].line, newBreaks[i].ch + val.length))\n });\n option(\"specialChars\", /[\\u0000-\\u001f\\u007f\\u00ad\\u200b-\\u200f\\u2028\\u2029\\ufeff]/g, function(cm, val, old) {\n cm.state.specialChars = new RegExp(val.source + (val.test(\"\\t\") ? \"\" : \"|\\t\"), \"g\");\n if (old != CodeMirror.Init) cm.refresh();\n });\n option(\"specialCharPlaceholder\", defaultSpecialCharPlaceholder, function(cm) {cm.refresh();}, true);\n option(\"electricChars\", true);\n option(\"inputStyle\", mobile ? \"contenteditable\" : \"textarea\", function() {\n throw new Error(\"inputStyle can not (yet) be changed in a running editor\"); // FIXME\n }, true);\n option(\"rtlMoveVisually\", !windows);\n option(\"wholeLineUpdateBefore\", true);\n\n option(\"theme\", \"default\", function(cm) {\n themeChanged(cm);\n guttersChanged(cm);\n }, true);\n option(\"keyMap\", \"default\", function(cm, val, old) {\n var next = getKeyMap(val);\n var prev = old != CodeMirror.Init && getKeyMap(old);\n if (prev && prev.detach) prev.detach(cm, next);\n if (next.attach) next.attach(cm, prev || null);\n });\n option(\"extraKeys\", null);\n\n option(\"lineWrapping\", false, wrappingChanged, true);\n option(\"gutters\", [], function(cm) {\n setGuttersForLineNumbers(cm.options);\n guttersChanged(cm);\n }, true);\n option(\"fixedGutter\", true, function(cm, val) {\n cm.display.gutters.style.left = val ? compensateForHScroll(cm.display) + \"px\" : \"0\";\n cm.refresh();\n }, true);\n option(\"coverGutterNextToScrollbar\", false, function(cm) {updateScrollbars(cm);}, true);\n option(\"scrollbarStyle\", \"native\", function(cm) {\n initScrollbars(cm);\n updateScrollbars(cm);\n cm.display.scrollbars.setScrollTop(cm.doc.scrollTop);\n cm.display.scrollbars.setScrollLeft(cm.doc.scrollLeft);\n }, true);\n option(\"lineNumbers\", false, function(cm) {\n setGuttersForLineNumbers(cm.options);\n guttersChanged(cm);\n }, true);\n option(\"firstLineNumber\", 1, guttersChanged, true);\n option(\"lineNumberFormatter\", function(integer) {return integer;}, guttersChanged, true);\n option(\"showCursorWhenSelecting\", false, updateSelection, true);\n\n option(\"resetSelectionOnContextMenu\", true);\n option(\"lineWiseCopyCut\", true);\n\n option(\"readOnly\", false, function(cm, val) {\n if (val == \"nocursor\") {\n onBlur(cm);\n cm.display.input.blur();\n cm.display.disabled = true;\n } else {\n cm.display.disabled = false;\n }\n cm.display.input.readOnlyChanged(val)\n });\n option(\"disableInput\", false, function(cm, val) {if (!val) cm.display.input.reset();}, true);\n option(\"dragDrop\", true, dragDropChanged);\n option(\"allowDropFileTypes\", null);\n\n option(\"cursorBlinkRate\", 530);\n option(\"cursorScrollMargin\", 0);\n option(\"cursorHeight\", 1, updateSelection, true);\n option(\"singleCursorHeightPerLine\", true, updateSelection, true);\n option(\"workTime\", 100);\n option(\"workDelay\", 100);\n option(\"flattenSpans\", true, resetModeState, true);\n option(\"addModeClass\", false, resetModeState, true);\n option(\"pollInterval\", 100);\n option(\"undoDepth\", 200, function(cm, val){cm.doc.history.undoDepth = val;});\n option(\"historyEventDelay\", 1250);\n option(\"viewportMargin\", 10, function(cm){cm.refresh();}, true);\n option(\"maxHighlightLength\", 10000, resetModeState, true);\n option(\"moveInputWithCursor\", true, function(cm, val) {\n if (!val) cm.display.input.resetPosition();\n });\n\n option(\"tabindex\", null, function(cm, val) {\n cm.display.input.getField().tabIndex = val || \"\";\n });\n option(\"autofocus\", null);\n\n // MODE DEFINITION AND QUERYING\n\n // Known modes, by name and by MIME\n var modes = CodeMirror.modes = {}, mimeModes = CodeMirror.mimeModes = {};\n\n // Extra arguments are stored as the mode's dependencies, which is\n // used by (legacy) mechanisms like loadmode.js to automatically\n // load a mode. (Preferred mechanism is the require/define calls.)\n CodeMirror.defineMode = function(name, mode) {\n if (!CodeMirror.defaults.mode && name != \"null\") CodeMirror.defaults.mode = name;\n if (arguments.length > 2)\n mode.dependencies = Array.prototype.slice.call(arguments, 2);\n modes[name] = mode;\n };\n\n CodeMirror.defineMIME = function(mime, spec) {\n mimeModes[mime] = spec;\n };\n\n // Given a MIME type, a {name, ...options} config object, or a name\n // string, return a mode config object.\n CodeMirror.resolveMode = function(spec) {\n if (typeof spec == \"string\" && mimeModes.hasOwnProperty(spec)) {\n spec = mimeModes[spec];\n } else if (spec && typeof spec.name == \"string\" && mimeModes.hasOwnProperty(spec.name)) {\n var found = mimeModes[spec.name];\n if (typeof found == \"string\") found = {name: found};\n spec = createObj(found, spec);\n spec.name = found.name;\n } else if (typeof spec == \"string\" && /^[\\w\\-]+\\/[\\w\\-]+\\+xml$/.test(spec)) {\n return CodeMirror.resolveMode(\"application/xml\");\n }\n if (typeof spec == \"string\") return {name: spec};\n else return spec || {name: \"null\"};\n };\n\n // Given a mode spec (anything that resolveMode accepts), find and\n // initialize an actual mode object.\n CodeMirror.getMode = function(options, spec) {\n var spec = CodeMirror.resolveMode(spec);\n var mfactory = modes[spec.name];\n if (!mfactory) return CodeMirror.getMode(options, \"text/plain\");\n var modeObj = mfactory(options, spec);\n if (modeExtensions.hasOwnProperty(spec.name)) {\n var exts = modeExtensions[spec.name];\n for (var prop in exts) {\n if (!exts.hasOwnProperty(prop)) continue;\n if (modeObj.hasOwnProperty(prop)) modeObj[\"_\" + prop] = modeObj[prop];\n modeObj[prop] = exts[prop];\n }\n }\n modeObj.name = spec.name;\n if (spec.helperType) modeObj.helperType = spec.helperType;\n if (spec.modeProps) for (var prop in spec.modeProps)\n modeObj[prop] = spec.modeProps[prop];\n\n return modeObj;\n };\n\n // Minimal default mode.\n CodeMirror.defineMode(\"null\", function() {\n return {token: function(stream) {stream.skipToEnd();}};\n });\n CodeMirror.defineMIME(\"text/plain\", \"null\");\n\n // This can be used to attach properties to mode objects from\n // outside the actual mode definition.\n var modeExtensions = CodeMirror.modeExtensions = {};\n CodeMirror.extendMode = function(mode, properties) {\n var exts = modeExtensions.hasOwnProperty(mode) ? modeExtensions[mode] : (modeExtensions[mode] = {});\n copyObj(properties, exts);\n };\n\n // EXTENSIONS\n\n CodeMirror.defineExtension = function(name, func) {\n CodeMirror.prototype[name] = func;\n };\n CodeMirror.defineDocExtension = function(name, func) {\n Doc.prototype[name] = func;\n };\n CodeMirror.defineOption = option;\n\n var initHooks = [];\n CodeMirror.defineInitHook = function(f) {initHooks.push(f);};\n\n var helpers = CodeMirror.helpers = {};\n CodeMirror.registerHelper = function(type, name, value) {\n if (!helpers.hasOwnProperty(type)) helpers[type] = CodeMirror[type] = {_global: []};\n helpers[type][name] = value;\n };\n CodeMirror.registerGlobalHelper = function(type, name, predicate, value) {\n CodeMirror.registerHelper(type, name, value);\n helpers[type]._global.push({pred: predicate, val: value});\n };\n\n // MODE STATE HANDLING\n\n // Utility functions for working with state. Exported because nested\n // modes need to do this for their inner modes.\n\n var copyState = CodeMirror.copyState = function(mode, state) {\n if (state === true) return state;\n if (mode.copyState) return mode.copyState(state);\n var nstate = {};\n for (var n in state) {\n var val = state[n];\n if (val instanceof Array) val = val.concat([]);\n nstate[n] = val;\n }\n return nstate;\n };\n\n var startState = CodeMirror.startState = function(mode, a1, a2) {\n return mode.startState ? mode.startState(a1, a2) : true;\n };\n\n // Given a mode and a state (for that mode), find the inner mode and\n // state at the position that the state refers to.\n CodeMirror.innerMode = function(mode, state) {\n while (mode.innerMode) {\n var info = mode.innerMode(state);\n if (!info || info.mode == mode) break;\n state = info.state;\n mode = info.mode;\n }\n return info || {mode: mode, state: state};\n };\n\n // STANDARD COMMANDS\n\n // Commands are parameter-less actions that can be performed on an\n // editor, mostly used for keybindings.\n var commands = CodeMirror.commands = {\n selectAll: function(cm) {cm.setSelection(Pos(cm.firstLine(), 0), Pos(cm.lastLine()), sel_dontScroll);},\n singleSelection: function(cm) {\n cm.setSelection(cm.getCursor(\"anchor\"), cm.getCursor(\"head\"), sel_dontScroll);\n },\n killLine: function(cm) {\n deleteNearSelection(cm, function(range) {\n if (range.empty()) {\n var len = getLine(cm.doc, range.head.line).text.length;\n if (range.head.ch == len && range.head.line < cm.lastLine())\n return {from: range.head, to: Pos(range.head.line + 1, 0)};\n else\n return {from: range.head, to: Pos(range.head.line, len)};\n } else {\n return {from: range.from(), to: range.to()};\n }\n });\n },\n deleteLine: function(cm) {\n deleteNearSelection(cm, function(range) {\n return {from: Pos(range.from().line, 0),\n to: clipPos(cm.doc, Pos(range.to().line + 1, 0))};\n });\n },\n delLineLeft: function(cm) {\n deleteNearSelection(cm, function(range) {\n return {from: Pos(range.from().line, 0), to: range.from()};\n });\n },\n delWrappedLineLeft: function(cm) {\n deleteNearSelection(cm, function(range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n var leftPos = cm.coordsChar({left: 0, top: top}, \"div\");\n return {from: leftPos, to: range.from()};\n });\n },\n delWrappedLineRight: function(cm) {\n deleteNearSelection(cm, function(range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n var rightPos = cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, \"div\");\n return {from: range.from(), to: rightPos };\n });\n },\n undo: function(cm) {cm.undo();},\n redo: function(cm) {cm.redo();},\n undoSelection: function(cm) {cm.undoSelection();},\n redoSelection: function(cm) {cm.redoSelection();},\n goDocStart: function(cm) {cm.extendSelection(Pos(cm.firstLine(), 0));},\n goDocEnd: function(cm) {cm.extendSelection(Pos(cm.lastLine()));},\n goLineStart: function(cm) {\n cm.extendSelectionsBy(function(range) { return lineStart(cm, range.head.line); },\n {origin: \"+move\", bias: 1});\n },\n goLineStartSmart: function(cm) {\n cm.extendSelectionsBy(function(range) {\n return lineStartSmart(cm, range.head);\n }, {origin: \"+move\", bias: 1});\n },\n goLineEnd: function(cm) {\n cm.extendSelectionsBy(function(range) { return lineEnd(cm, range.head.line); },\n {origin: \"+move\", bias: -1});\n },\n goLineRight: function(cm) {\n cm.extendSelectionsBy(function(range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n return cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, \"div\");\n }, sel_move);\n },\n goLineLeft: function(cm) {\n cm.extendSelectionsBy(function(range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n return cm.coordsChar({left: 0, top: top}, \"div\");\n }, sel_move);\n },\n goLineLeftSmart: function(cm) {\n cm.extendSelectionsBy(function(range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n var pos = cm.coordsChar({left: 0, top: top}, \"div\");\n if (pos.ch < cm.getLine(pos.line).search(/\\S/)) return lineStartSmart(cm, range.head);\n return pos;\n }, sel_move);\n },\n goLineUp: function(cm) {cm.moveV(-1, \"line\");},\n goLineDown: function(cm) {cm.moveV(1, \"line\");},\n goPageUp: function(cm) {cm.moveV(-1, \"page\");},\n goPageDown: function(cm) {cm.moveV(1, \"page\");},\n goCharLeft: function(cm) {cm.moveH(-1, \"char\");},\n goCharRight: function(cm) {cm.moveH(1, \"char\");},\n goColumnLeft: function(cm) {cm.moveH(-1, \"column\");},\n goColumnRight: function(cm) {cm.moveH(1, \"column\");},\n goWordLeft: function(cm) {cm.moveH(-1, \"word\");},\n goGroupRight: function(cm) {cm.moveH(1, \"group\");},\n goGroupLeft: function(cm) {cm.moveH(-1, \"group\");},\n goWordRight: function(cm) {cm.moveH(1, \"word\");},\n delCharBefore: function(cm) {cm.deleteH(-1, \"char\");},\n delCharAfter: function(cm) {cm.deleteH(1, \"char\");},\n delWordBefore: function(cm) {cm.deleteH(-1, \"word\");},\n delWordAfter: function(cm) {cm.deleteH(1, \"word\");},\n delGroupBefore: function(cm) {cm.deleteH(-1, \"group\");},\n delGroupAfter: function(cm) {cm.deleteH(1, \"group\");},\n indentAuto: function(cm) {cm.indentSelection(\"smart\");},\n indentMore: function(cm) {cm.indentSelection(\"add\");},\n indentLess: function(cm) {cm.indentSelection(\"subtract\");},\n insertTab: function(cm) {cm.replaceSelection(\"\\t\");},\n insertSoftTab: function(cm) {\n var spaces = [], ranges = cm.listSelections(), tabSize = cm.options.tabSize;\n for (var i = 0; i < ranges.length; i++) {\n var pos = ranges[i].from();\n var col = countColumn(cm.getLine(pos.line), pos.ch, tabSize);\n spaces.push(spaceStr(tabSize - col % tabSize));\n }\n cm.replaceSelections(spaces);\n },\n defaultTab: function(cm) {\n if (cm.somethingSelected()) cm.indentSelection(\"add\");\n else cm.execCommand(\"insertTab\");\n },\n transposeChars: function(cm) {\n runInOp(cm, function() {\n var ranges = cm.listSelections(), newSel = [];\n for (var i = 0; i < ranges.length; i++) {\n var cur = ranges[i].head, line = getLine(cm.doc, cur.line).text;\n if (line) {\n if (cur.ch == line.length) cur = new Pos(cur.line, cur.ch - 1);\n if (cur.ch > 0) {\n cur = new Pos(cur.line, cur.ch + 1);\n cm.replaceRange(line.charAt(cur.ch - 1) + line.charAt(cur.ch - 2),\n Pos(cur.line, cur.ch - 2), cur, \"+transpose\");\n } else if (cur.line > cm.doc.first) {\n var prev = getLine(cm.doc, cur.line - 1).text;\n if (prev)\n cm.replaceRange(line.charAt(0) + cm.doc.lineSeparator() +\n prev.charAt(prev.length - 1),\n Pos(cur.line - 1, prev.length - 1), Pos(cur.line, 1), \"+transpose\");\n }\n }\n newSel.push(new Range(cur, cur));\n }\n cm.setSelections(newSel);\n });\n },\n newlineAndIndent: function(cm) {\n runInOp(cm, function() {\n var len = cm.listSelections().length;\n for (var i = 0; i < len; i++) {\n var range = cm.listSelections()[i];\n cm.replaceRange(cm.doc.lineSeparator(), range.anchor, range.head, \"+input\");\n cm.indentLine(range.from().line + 1, null, true);\n }\n ensureCursorVisible(cm);\n });\n },\n openLine: function(cm) {cm.replaceSelection(\"\\n\", \"start\")},\n toggleOverwrite: function(cm) {cm.toggleOverwrite();}\n };\n\n\n // STANDARD KEYMAPS\n\n var keyMap = CodeMirror.keyMap = {};\n\n keyMap.basic = {\n \"Left\": \"goCharLeft\", \"Right\": \"goCharRight\", \"Up\": \"goLineUp\", \"Down\": \"goLineDown\",\n \"End\": \"goLineEnd\", \"Home\": \"goLineStartSmart\", \"PageUp\": \"goPageUp\", \"PageDown\": \"goPageDown\",\n \"Delete\": \"delCharAfter\", \"Backspace\": \"delCharBefore\", \"Shift-Backspace\": \"delCharBefore\",\n \"Tab\": \"defaultTab\", \"Shift-Tab\": \"indentAuto\",\n \"Enter\": \"newlineAndIndent\", \"Insert\": \"toggleOverwrite\",\n \"Esc\": \"singleSelection\"\n };\n // Note that the save and find-related commands aren't defined by\n // default. User code or addons can define them. Unknown commands\n // are simply ignored.\n keyMap.pcDefault = {\n \"Ctrl-A\": \"selectAll\", \"Ctrl-D\": \"deleteLine\", \"Ctrl-Z\": \"undo\", \"Shift-Ctrl-Z\": \"redo\", \"Ctrl-Y\": \"redo\",\n \"Ctrl-Home\": \"goDocStart\", \"Ctrl-End\": \"goDocEnd\", \"Ctrl-Up\": \"goLineUp\", \"Ctrl-Down\": \"goLineDown\",\n \"Ctrl-Left\": \"goGroupLeft\", \"Ctrl-Right\": \"goGroupRight\", \"Alt-Left\": \"goLineStart\", \"Alt-Right\": \"goLineEnd\",\n \"Ctrl-Backspace\": \"delGroupBefore\", \"Ctrl-Delete\": \"delGroupAfter\", \"Ctrl-S\": \"save\", \"Ctrl-F\": \"find\",\n \"Ctrl-G\": \"findNext\", \"Shift-Ctrl-G\": \"findPrev\", \"Shift-Ctrl-F\": \"replace\", \"Shift-Ctrl-R\": \"replaceAll\",\n \"Ctrl-[\": \"indentLess\", \"Ctrl-]\": \"indentMore\",\n \"Ctrl-U\": \"undoSelection\", \"Shift-Ctrl-U\": \"redoSelection\", \"Alt-U\": \"redoSelection\",\n fallthrough: \"basic\"\n };\n // Very basic readline/emacs-style bindings, which are standard on Mac.\n keyMap.emacsy = {\n \"Ctrl-F\": \"goCharRight\", \"Ctrl-B\": \"goCharLeft\", \"Ctrl-P\": \"goLineUp\", \"Ctrl-N\": \"goLineDown\",\n \"Alt-F\": \"goWordRight\", \"Alt-B\": \"goWordLeft\", \"Ctrl-A\": \"goLineStart\", \"Ctrl-E\": \"goLineEnd\",\n \"Ctrl-V\": \"goPageDown\", \"Shift-Ctrl-V\": \"goPageUp\", \"Ctrl-D\": \"delCharAfter\", \"Ctrl-H\": \"delCharBefore\",\n \"Alt-D\": \"delWordAfter\", \"Alt-Backspace\": \"delWordBefore\", \"Ctrl-K\": \"killLine\", \"Ctrl-T\": \"transposeChars\",\n \"Ctrl-O\": \"openLine\"\n };\n keyMap.macDefault = {\n \"Cmd-A\": \"selectAll\", \"Cmd-D\": \"deleteLine\", \"Cmd-Z\": \"undo\", \"Shift-Cmd-Z\": \"redo\", \"Cmd-Y\": \"redo\",\n \"Cmd-Home\": \"goDocStart\", \"Cmd-Up\": \"goDocStart\", \"Cmd-End\": \"goDocEnd\", \"Cmd-Down\": \"goDocEnd\", \"Alt-Left\": \"goGroupLeft\",\n \"Alt-Right\": \"goGroupRight\", \"Cmd-Left\": \"goLineLeft\", \"Cmd-Right\": \"goLineRight\", \"Alt-Backspace\": \"delGroupBefore\",\n \"Ctrl-Alt-Backspace\": \"delGroupAfter\", \"Alt-Delete\": \"delGroupAfter\", \"Cmd-S\": \"save\", \"Cmd-F\": \"find\",\n \"Cmd-G\": \"findNext\", \"Shift-Cmd-G\": \"findPrev\", \"Cmd-Alt-F\": \"replace\", \"Shift-Cmd-Alt-F\": \"replaceAll\",\n \"Cmd-[\": \"indentLess\", \"Cmd-]\": \"indentMore\", \"Cmd-Backspace\": \"delWrappedLineLeft\", \"Cmd-Delete\": \"delWrappedLineRight\",\n \"Cmd-U\": \"undoSelection\", \"Shift-Cmd-U\": \"redoSelection\", \"Ctrl-Up\": \"goDocStart\", \"Ctrl-Down\": \"goDocEnd\",\n fallthrough: [\"basic\", \"emacsy\"]\n };\n keyMap[\"default\"] = mac ? keyMap.macDefault : keyMap.pcDefault;\n\n // KEYMAP DISPATCH\n\n function normalizeKeyName(name) {\n var parts = name.split(/-(?!$)/), name = parts[parts.length - 1];\n var alt, ctrl, shift, cmd;\n for (var i = 0; i < parts.length - 1; i++) {\n var mod = parts[i];\n if (/^(cmd|meta|m)$/i.test(mod)) cmd = true;\n else if (/^a(lt)?$/i.test(mod)) alt = true;\n else if (/^(c|ctrl|control)$/i.test(mod)) ctrl = true;\n else if (/^s(hift)$/i.test(mod)) shift = true;\n else throw new Error(\"Unrecognized modifier name: \" + mod);\n }\n if (alt) name = \"Alt-\" + name;\n if (ctrl) name = \"Ctrl-\" + name;\n if (cmd) name = \"Cmd-\" + name;\n if (shift) name = \"Shift-\" + name;\n return name;\n }\n\n // This is a kludge to keep keymaps mostly working as raw objects\n // (backwards compatibility) while at the same time support features\n // like normalization and multi-stroke key bindings. It compiles a\n // new normalized keymap, and then updates the old object to reflect\n // this.\n CodeMirror.normalizeKeyMap = function(keymap) {\n var copy = {};\n for (var keyname in keymap) if (keymap.hasOwnProperty(keyname)) {\n var value = keymap[keyname];\n if (/^(name|fallthrough|(de|at)tach)$/.test(keyname)) continue;\n if (value == \"...\") { delete keymap[keyname]; continue; }\n\n var keys = map(keyname.split(\" \"), normalizeKeyName);\n for (var i = 0; i < keys.length; i++) {\n var val, name;\n if (i == keys.length - 1) {\n name = keys.join(\" \");\n val = value;\n } else {\n name = keys.slice(0, i + 1).join(\" \");\n val = \"...\";\n }\n var prev = copy[name];\n if (!prev) copy[name] = val;\n else if (prev != val) throw new Error(\"Inconsistent bindings for \" + name);\n }\n delete keymap[keyname];\n }\n for (var prop in copy) keymap[prop] = copy[prop];\n return keymap;\n };\n\n var lookupKey = CodeMirror.lookupKey = function(key, map, handle, context) {\n map = getKeyMap(map);\n var found = map.call ? map.call(key, context) : map[key];\n if (found === false) return \"nothing\";\n if (found === \"...\") return \"multi\";\n if (found != null && handle(found)) return \"handled\";\n\n if (map.fallthrough) {\n if (Object.prototype.toString.call(map.fallthrough) != \"[object Array]\")\n return lookupKey(key, map.fallthrough, handle, context);\n for (var i = 0; i < map.fallthrough.length; i++) {\n var result = lookupKey(key, map.fallthrough[i], handle, context);\n if (result) return result;\n }\n }\n };\n\n // Modifier key presses don't count as 'real' key presses for the\n // purpose of keymap fallthrough.\n var isModifierKey = CodeMirror.isModifierKey = function(value) {\n var name = typeof value == \"string\" ? value : keyNames[value.keyCode];\n return name == \"Ctrl\" || name == \"Alt\" || name == \"Shift\" || name == \"Mod\";\n };\n\n // Look up the name of a key as indicated by an event object.\n var keyName = CodeMirror.keyName = function(event, noShift) {\n if (presto && event.keyCode == 34 && event[\"char\"]) return false;\n var base = keyNames[event.keyCode], name = base;\n if (name == null || event.altGraphKey) return false;\n if (event.altKey && base != \"Alt\") name = \"Alt-\" + name;\n if ((flipCtrlCmd ? event.metaKey : event.ctrlKey) && base != \"Ctrl\") name = \"Ctrl-\" + name;\n if ((flipCtrlCmd ? event.ctrlKey : event.metaKey) && base != \"Cmd\") name = \"Cmd-\" + name;\n if (!noShift && event.shiftKey && base != \"Shift\") name = \"Shift-\" + name;\n return name;\n };\n\n function getKeyMap(val) {\n return typeof val == \"string\" ? keyMap[val] : val;\n }\n\n // FROMTEXTAREA\n\n CodeMirror.fromTextArea = function(textarea, options) {\n options = options ? copyObj(options) : {};\n options.value = textarea.value;\n if (!options.tabindex && textarea.tabIndex)\n options.tabindex = textarea.tabIndex;\n if (!options.placeholder && textarea.placeholder)\n options.placeholder = textarea.placeholder;\n // Set autofocus to true if this textarea is focused, or if it has\n // autofocus and no other element is focused.\n if (options.autofocus == null) {\n var hasFocus = activeElt();\n options.autofocus = hasFocus == textarea ||\n textarea.getAttribute(\"autofocus\") != null && hasFocus == document.body;\n }\n\n function save() {textarea.value = cm.getValue();}\n if (textarea.form) {\n on(textarea.form, \"submit\", save);\n // Deplorable hack to make the submit method do the right thing.\n if (!options.leaveSubmitMethodAlone) {\n var form = textarea.form, realSubmit = form.submit;\n try {\n var wrappedSubmit = form.submit = function() {\n save();\n form.submit = realSubmit;\n form.submit();\n form.submit = wrappedSubmit;\n };\n } catch(e) {}\n }\n }\n\n options.finishInit = function(cm) {\n cm.save = save;\n cm.getTextArea = function() { return textarea; };\n cm.toTextArea = function() {\n cm.toTextArea = isNaN; // Prevent this from being ran twice\n save();\n textarea.parentNode.removeChild(cm.getWrapperElement());\n textarea.style.display = \"\";\n if (textarea.form) {\n off(textarea.form, \"submit\", save);\n if (typeof textarea.form.submit == \"function\")\n textarea.form.submit = realSubmit;\n }\n };\n };\n\n textarea.style.display = \"none\";\n var cm = CodeMirror(function(node) {\n textarea.parentNode.insertBefore(node, textarea.nextSibling);\n }, options);\n return cm;\n };\n\n // STRING STREAM\n\n // Fed to the mode parsers, provides helper functions to make\n // parsers more succinct.\n\n var StringStream = CodeMirror.StringStream = function(string, tabSize) {\n this.pos = this.start = 0;\n this.string = string;\n this.tabSize = tabSize || 8;\n this.lastColumnPos = this.lastColumnValue = 0;\n this.lineStart = 0;\n };\n\n StringStream.prototype = {\n eol: function() {return this.pos >= this.string.length;},\n sol: function() {return this.pos == this.lineStart;},\n peek: function() {return this.string.charAt(this.pos) || undefined;},\n next: function() {\n if (this.pos < this.string.length)\n return this.string.charAt(this.pos++);\n },\n eat: function(match) {\n var ch = this.string.charAt(this.pos);\n if (typeof match == \"string\") var ok = ch == match;\n else var ok = ch && (match.test ? match.test(ch) : match(ch));\n if (ok) {++this.pos; return ch;}\n },\n eatWhile: function(match) {\n var start = this.pos;\n while (this.eat(match)){}\n return this.pos > start;\n },\n eatSpace: function() {\n var start = this.pos;\n while (/[\\s\\u00a0]/.test(this.string.charAt(this.pos))) ++this.pos;\n return this.pos > start;\n },\n skipToEnd: function() {this.pos = this.string.length;},\n skipTo: function(ch) {\n var found = this.string.indexOf(ch, this.pos);\n if (found > -1) {this.pos = found; return true;}\n },\n backUp: function(n) {this.pos -= n;},\n column: function() {\n if (this.lastColumnPos < this.start) {\n this.lastColumnValue = countColumn(this.string, this.start, this.tabSize, this.lastColumnPos, this.lastColumnValue);\n this.lastColumnPos = this.start;\n }\n return this.lastColumnValue - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0);\n },\n indentation: function() {\n return countColumn(this.string, null, this.tabSize) -\n (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0);\n },\n match: function(pattern, consume, caseInsensitive) {\n if (typeof pattern == \"string\") {\n var cased = function(str) {return caseInsensitive ? str.toLowerCase() : str;};\n var substr = this.string.substr(this.pos, pattern.length);\n if (cased(substr) == cased(pattern)) {\n if (consume !== false) this.pos += pattern.length;\n return true;\n }\n } else {\n var match = this.string.slice(this.pos).match(pattern);\n if (match && match.index > 0) return null;\n if (match && consume !== false) this.pos += match[0].length;\n return match;\n }\n },\n current: function(){return this.string.slice(this.start, this.pos);},\n hideFirstChars: function(n, inner) {\n this.lineStart += n;\n try { return inner(); }\n finally { this.lineStart -= n; }\n }\n };\n\n // TEXTMARKERS\n\n // Created with markText and setBookmark methods. A TextMarker is a\n // handle that can be used to clear or find a marked position in the\n // document. Line objects hold arrays (markedSpans) containing\n // {from, to, marker} object pointing to such marker objects, and\n // indicating that such a marker is present on that line. Multiple\n // lines may point to the same marker when it spans across lines.\n // The spans will have null for their from/to properties when the\n // marker continues beyond the start/end of the line. Markers have\n // links back to the lines they currently touch.\n\n var nextMarkerId = 0;\n\n var TextMarker = CodeMirror.TextMarker = function(doc, type) {\n this.lines = [];\n this.type = type;\n this.doc = doc;\n this.id = ++nextMarkerId;\n };\n eventMixin(TextMarker);\n\n // Clear the marker.\n TextMarker.prototype.clear = function() {\n if (this.explicitlyCleared) return;\n var cm = this.doc.cm, withOp = cm && !cm.curOp;\n if (withOp) startOperation(cm);\n if (hasHandler(this, \"clear\")) {\n var found = this.find();\n if (found) signalLater(this, \"clear\", found.from, found.to);\n }\n var min = null, max = null;\n for (var i = 0; i < this.lines.length; ++i) {\n var line = this.lines[i];\n var span = getMarkedSpanFor(line.markedSpans, this);\n if (cm && !this.collapsed) regLineChange(cm, lineNo(line), \"text\");\n else if (cm) {\n if (span.to != null) max = lineNo(line);\n if (span.from != null) min = lineNo(line);\n }\n line.markedSpans = removeMarkedSpan(line.markedSpans, span);\n if (span.from == null && this.collapsed && !lineIsHidden(this.doc, line) && cm)\n updateLineHeight(line, textHeight(cm.display));\n }\n if (cm && this.collapsed && !cm.options.lineWrapping) for (var i = 0; i < this.lines.length; ++i) {\n var visual = visualLine(this.lines[i]), len = lineLength(visual);\n if (len > cm.display.maxLineLength) {\n cm.display.maxLine = visual;\n cm.display.maxLineLength = len;\n cm.display.maxLineChanged = true;\n }\n }\n\n if (min != null && cm && this.collapsed) regChange(cm, min, max + 1);\n this.lines.length = 0;\n this.explicitlyCleared = true;\n if (this.atomic && this.doc.cantEdit) {\n this.doc.cantEdit = false;\n if (cm) reCheckSelection(cm.doc);\n }\n if (cm) signalLater(cm, \"markerCleared\", cm, this);\n if (withOp) endOperation(cm);\n if (this.parent) this.parent.clear();\n };\n\n // Find the position of the marker in the document. Returns a {from,\n // to} object by default. Side can be passed to get a specific side\n // -- 0 (both), -1 (left), or 1 (right). When lineObj is true, the\n // Pos objects returned contain a line object, rather than a line\n // number (used to prevent looking up the same line twice).\n TextMarker.prototype.find = function(side, lineObj) {\n if (side == null && this.type == \"bookmark\") side = 1;\n var from, to;\n for (var i = 0; i < this.lines.length; ++i) {\n var line = this.lines[i];\n var span = getMarkedSpanFor(line.markedSpans, this);\n if (span.from != null) {\n from = Pos(lineObj ? line : lineNo(line), span.from);\n if (side == -1) return from;\n }\n if (span.to != null) {\n to = Pos(lineObj ? line : lineNo(line), span.to);\n if (side == 1) return to;\n }\n }\n return from && {from: from, to: to};\n };\n\n // Signals that the marker's widget changed, and surrounding layout\n // should be recomputed.\n TextMarker.prototype.changed = function() {\n var pos = this.find(-1, true), widget = this, cm = this.doc.cm;\n if (!pos || !cm) return;\n runInOp(cm, function() {\n var line = pos.line, lineN = lineNo(pos.line);\n var view = findViewForLine(cm, lineN);\n if (view) {\n clearLineMeasurementCacheFor(view);\n cm.curOp.selectionChanged = cm.curOp.forceUpdate = true;\n }\n cm.curOp.updateMaxLine = true;\n if (!lineIsHidden(widget.doc, line) && widget.height != null) {\n var oldHeight = widget.height;\n widget.height = null;\n var dHeight = widgetHeight(widget) - oldHeight;\n if (dHeight)\n updateLineHeight(line, line.height + dHeight);\n }\n });\n };\n\n TextMarker.prototype.attachLine = function(line) {\n if (!this.lines.length && this.doc.cm) {\n var op = this.doc.cm.curOp;\n if (!op.maybeHiddenMarkers || indexOf(op.maybeHiddenMarkers, this) == -1)\n (op.maybeUnhiddenMarkers || (op.maybeUnhiddenMarkers = [])).push(this);\n }\n this.lines.push(line);\n };\n TextMarker.prototype.detachLine = function(line) {\n this.lines.splice(indexOf(this.lines, line), 1);\n if (!this.lines.length && this.doc.cm) {\n var op = this.doc.cm.curOp;\n (op.maybeHiddenMarkers || (op.maybeHiddenMarkers = [])).push(this);\n }\n };\n\n // Collapsed markers have unique ids, in order to be able to order\n // them, which is needed for uniquely determining an outer marker\n // when they overlap (they may nest, but not partially overlap).\n var nextMarkerId = 0;\n\n // Create a marker, wire it up to the right lines, and\n function markText(doc, from, to, options, type) {\n // Shared markers (across linked documents) are handled separately\n // (markTextShared will call out to this again, once per\n // document).\n if (options && options.shared) return markTextShared(doc, from, to, options, type);\n // Ensure we are in an operation.\n if (doc.cm && !doc.cm.curOp) return operation(doc.cm, markText)(doc, from, to, options, type);\n\n var marker = new TextMarker(doc, type), diff = cmp(from, to);\n if (options) copyObj(options, marker, false);\n // Don't connect empty markers unless clearWhenEmpty is false\n if (diff > 0 || diff == 0 && marker.clearWhenEmpty !== false)\n return marker;\n if (marker.replacedWith) {\n // Showing up as a widget implies collapsed (widget replaces text)\n marker.collapsed = true;\n marker.widgetNode = elt(\"span\", [marker.replacedWith], \"CodeMirror-widget\");\n if (!options.handleMouseEvents) marker.widgetNode.setAttribute(\"cm-ignore-events\", \"true\");\n if (options.insertLeft) marker.widgetNode.insertLeft = true;\n }\n if (marker.collapsed) {\n if (conflictingCollapsedRange(doc, from.line, from, to, marker) ||\n from.line != to.line && conflictingCollapsedRange(doc, to.line, from, to, marker))\n throw new Error(\"Inserting collapsed marker partially overlapping an existing one\");\n sawCollapsedSpans = true;\n }\n\n if (marker.addToHistory)\n addChangeToHistory(doc, {from: from, to: to, origin: \"markText\"}, doc.sel, NaN);\n\n var curLine = from.line, cm = doc.cm, updateMaxLine;\n doc.iter(curLine, to.line + 1, function(line) {\n if (cm && marker.collapsed && !cm.options.lineWrapping && visualLine(line) == cm.display.maxLine)\n updateMaxLine = true;\n if (marker.collapsed && curLine != from.line) updateLineHeight(line, 0);\n addMarkedSpan(line, new MarkedSpan(marker,\n curLine == from.line ? from.ch : null,\n curLine == to.line ? to.ch : null));\n ++curLine;\n });\n // lineIsHidden depends on the presence of the spans, so needs a second pass\n if (marker.collapsed) doc.iter(from.line, to.line + 1, function(line) {\n if (lineIsHidden(doc, line)) updateLineHeight(line, 0);\n });\n\n if (marker.clearOnEnter) on(marker, \"beforeCursorEnter\", function() { marker.clear(); });\n\n if (marker.readOnly) {\n sawReadOnlySpans = true;\n if (doc.history.done.length || doc.history.undone.length)\n doc.clearHistory();\n }\n if (marker.collapsed) {\n marker.id = ++nextMarkerId;\n marker.atomic = true;\n }\n if (cm) {\n // Sync editor state\n if (updateMaxLine) cm.curOp.updateMaxLine = true;\n if (marker.collapsed)\n regChange(cm, from.line, to.line + 1);\n else if (marker.className || marker.title || marker.startStyle || marker.endStyle || marker.css)\n for (var i = from.line; i <= to.line; i++) regLineChange(cm, i, \"text\");\n if (marker.atomic) reCheckSelection(cm.doc);\n signalLater(cm, \"markerAdded\", cm, marker);\n }\n return marker;\n }\n\n // SHARED TEXTMARKERS\n\n // A shared marker spans multiple linked documents. It is\n // implemented as a meta-marker-object controlling multiple normal\n // markers.\n var SharedTextMarker = CodeMirror.SharedTextMarker = function(markers, primary) {\n this.markers = markers;\n this.primary = primary;\n for (var i = 0; i < markers.length; ++i)\n markers[i].parent = this;\n };\n eventMixin(SharedTextMarker);\n\n SharedTextMarker.prototype.clear = function() {\n if (this.explicitlyCleared) return;\n this.explicitlyCleared = true;\n for (var i = 0; i < this.markers.length; ++i)\n this.markers[i].clear();\n signalLater(this, \"clear\");\n };\n SharedTextMarker.prototype.find = function(side, lineObj) {\n return this.primary.find(side, lineObj);\n };\n\n function markTextShared(doc, from, to, options, type) {\n options = copyObj(options);\n options.shared = false;\n var markers = [markText(doc, from, to, options, type)], primary = markers[0];\n var widget = options.widgetNode;\n linkedDocs(doc, function(doc) {\n if (widget) options.widgetNode = widget.cloneNode(true);\n markers.push(markText(doc, clipPos(doc, from), clipPos(doc, to), options, type));\n for (var i = 0; i < doc.linked.length; ++i)\n if (doc.linked[i].isParent) return;\n primary = lst(markers);\n });\n return new SharedTextMarker(markers, primary);\n }\n\n function findSharedMarkers(doc) {\n return doc.findMarks(Pos(doc.first, 0), doc.clipPos(Pos(doc.lastLine())),\n function(m) { return m.parent; });\n }\n\n function copySharedMarkers(doc, markers) {\n for (var i = 0; i < markers.length; i++) {\n var marker = markers[i], pos = marker.find();\n var mFrom = doc.clipPos(pos.from), mTo = doc.clipPos(pos.to);\n if (cmp(mFrom, mTo)) {\n var subMark = markText(doc, mFrom, mTo, marker.primary, marker.primary.type);\n marker.markers.push(subMark);\n subMark.parent = marker;\n }\n }\n }\n\n function detachSharedMarkers(markers) {\n for (var i = 0; i < markers.length; i++) {\n var marker = markers[i], linked = [marker.primary.doc];;\n linkedDocs(marker.primary.doc, function(d) { linked.push(d); });\n for (var j = 0; j < marker.markers.length; j++) {\n var subMarker = marker.markers[j];\n if (indexOf(linked, subMarker.doc) == -1) {\n subMarker.parent = null;\n marker.markers.splice(j--, 1);\n }\n }\n }\n }\n\n // TEXTMARKER SPANS\n\n function MarkedSpan(marker, from, to) {\n this.marker = marker;\n this.from = from; this.to = to;\n }\n\n // Search an array of spans for a span matching the given marker.\n function getMarkedSpanFor(spans, marker) {\n if (spans) for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if (span.marker == marker) return span;\n }\n }\n // Remove a span from an array, returning undefined if no spans are\n // left (we don't store arrays for lines without spans).\n function removeMarkedSpan(spans, span) {\n for (var r, i = 0; i < spans.length; ++i)\n if (spans[i] != span) (r || (r = [])).push(spans[i]);\n return r;\n }\n // Add a span to a line.\n function addMarkedSpan(line, span) {\n line.markedSpans = line.markedSpans ? line.markedSpans.concat([span]) : [span];\n span.marker.attachLine(line);\n }\n\n // Used for the algorithm that adjusts markers for a change in the\n // document. These functions cut an array of spans at a given\n // character position, returning an array of remaining chunks (or\n // undefined if nothing remains).\n function markedSpansBefore(old, startCh, isInsert) {\n if (old) for (var i = 0, nw; i < old.length; ++i) {\n var span = old[i], marker = span.marker;\n var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= startCh : span.from < startCh);\n if (startsBefore || span.from == startCh && marker.type == \"bookmark\" && (!isInsert || !span.marker.insertLeft)) {\n var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= startCh : span.to > startCh);\n (nw || (nw = [])).push(new MarkedSpan(marker, span.from, endsAfter ? null : span.to));\n }\n }\n return nw;\n }\n function markedSpansAfter(old, endCh, isInsert) {\n if (old) for (var i = 0, nw; i < old.length; ++i) {\n var span = old[i], marker = span.marker;\n var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= endCh : span.to > endCh);\n if (endsAfter || span.from == endCh && marker.type == \"bookmark\" && (!isInsert || span.marker.insertLeft)) {\n var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= endCh : span.from < endCh);\n (nw || (nw = [])).push(new MarkedSpan(marker, startsBefore ? null : span.from - endCh,\n span.to == null ? null : span.to - endCh));\n }\n }\n return nw;\n }\n\n // Given a change object, compute the new set of marker spans that\n // cover the line in which the change took place. Removes spans\n // entirely within the change, reconnects spans belonging to the\n // same marker that appear on both sides of the change, and cuts off\n // spans partially within the change. Returns an array of span\n // arrays with one element for each line in (after) the change.\n function stretchSpansOverChange(doc, change) {\n if (change.full) return null;\n var oldFirst = isLine(doc, change.from.line) && getLine(doc, change.from.line).markedSpans;\n var oldLast = isLine(doc, change.to.line) && getLine(doc, change.to.line).markedSpans;\n if (!oldFirst && !oldLast) return null;\n\n var startCh = change.from.ch, endCh = change.to.ch, isInsert = cmp(change.from, change.to) == 0;\n // Get the spans that 'stick out' on both sides\n var first = markedSpansBefore(oldFirst, startCh, isInsert);\n var last = markedSpansAfter(oldLast, endCh, isInsert);\n\n // Next, merge those two ends\n var sameLine = change.text.length == 1, offset = lst(change.text).length + (sameLine ? startCh : 0);\n if (first) {\n // Fix up .to properties of first\n for (var i = 0; i < first.length; ++i) {\n var span = first[i];\n if (span.to == null) {\n var found = getMarkedSpanFor(last, span.marker);\n if (!found) span.to = startCh;\n else if (sameLine) span.to = found.to == null ? null : found.to + offset;\n }\n }\n }\n if (last) {\n // Fix up .from in last (or move them into first in case of sameLine)\n for (var i = 0; i < last.length; ++i) {\n var span = last[i];\n if (span.to != null) span.to += offset;\n if (span.from == null) {\n var found = getMarkedSpanFor(first, span.marker);\n if (!found) {\n span.from = offset;\n if (sameLine) (first || (first = [])).push(span);\n }\n } else {\n span.from += offset;\n if (sameLine) (first || (first = [])).push(span);\n }\n }\n }\n // Make sure we didn't create any zero-length spans\n if (first) first = clearEmptySpans(first);\n if (last && last != first) last = clearEmptySpans(last);\n\n var newMarkers = [first];\n if (!sameLine) {\n // Fill gap with whole-line-spans\n var gap = change.text.length - 2, gapMarkers;\n if (gap > 0 && first)\n for (var i = 0; i < first.length; ++i)\n if (first[i].to == null)\n (gapMarkers || (gapMarkers = [])).push(new MarkedSpan(first[i].marker, null, null));\n for (var i = 0; i < gap; ++i)\n newMarkers.push(gapMarkers);\n newMarkers.push(last);\n }\n return newMarkers;\n }\n\n // Remove spans that are empty and don't have a clearWhenEmpty\n // option of false.\n function clearEmptySpans(spans) {\n for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if (span.from != null && span.from == span.to && span.marker.clearWhenEmpty !== false)\n spans.splice(i--, 1);\n }\n if (!spans.length) return null;\n return spans;\n }\n\n // Used for un/re-doing changes from the history. Combines the\n // result of computing the existing spans with the set of spans that\n // existed in the history (so that deleting around a span and then\n // undoing brings back the span).\n function mergeOldSpans(doc, change) {\n var old = getOldSpans(doc, change);\n var stretched = stretchSpansOverChange(doc, change);\n if (!old) return stretched;\n if (!stretched) return old;\n\n for (var i = 0; i < old.length; ++i) {\n var oldCur = old[i], stretchCur = stretched[i];\n if (oldCur && stretchCur) {\n spans: for (var j = 0; j < stretchCur.length; ++j) {\n var span = stretchCur[j];\n for (var k = 0; k < oldCur.length; ++k)\n if (oldCur[k].marker == span.marker) continue spans;\n oldCur.push(span);\n }\n } else if (stretchCur) {\n old[i] = stretchCur;\n }\n }\n return old;\n }\n\n // Used to 'clip' out readOnly ranges when making a change.\n function removeReadOnlyRanges(doc, from, to) {\n var markers = null;\n doc.iter(from.line, to.line + 1, function(line) {\n if (line.markedSpans) for (var i = 0; i < line.markedSpans.length; ++i) {\n var mark = line.markedSpans[i].marker;\n if (mark.readOnly && (!markers || indexOf(markers, mark) == -1))\n (markers || (markers = [])).push(mark);\n }\n });\n if (!markers) return null;\n var parts = [{from: from, to: to}];\n for (var i = 0; i < markers.length; ++i) {\n var mk = markers[i], m = mk.find(0);\n for (var j = 0; j < parts.length; ++j) {\n var p = parts[j];\n if (cmp(p.to, m.from) < 0 || cmp(p.from, m.to) > 0) continue;\n var newParts = [j, 1], dfrom = cmp(p.from, m.from), dto = cmp(p.to, m.to);\n if (dfrom < 0 || !mk.inclusiveLeft && !dfrom)\n newParts.push({from: p.from, to: m.from});\n if (dto > 0 || !mk.inclusiveRight && !dto)\n newParts.push({from: m.to, to: p.to});\n parts.splice.apply(parts, newParts);\n j += newParts.length - 1;\n }\n }\n return parts;\n }\n\n // Connect or disconnect spans from a line.\n function detachMarkedSpans(line) {\n var spans = line.markedSpans;\n if (!spans) return;\n for (var i = 0; i < spans.length; ++i)\n spans[i].marker.detachLine(line);\n line.markedSpans = null;\n }\n function attachMarkedSpans(line, spans) {\n if (!spans) return;\n for (var i = 0; i < spans.length; ++i)\n spans[i].marker.attachLine(line);\n line.markedSpans = spans;\n }\n\n // Helpers used when computing which overlapping collapsed span\n // counts as the larger one.\n function extraLeft(marker) { return marker.inclusiveLeft ? -1 : 0; }\n function extraRight(marker) { return marker.inclusiveRight ? 1 : 0; }\n\n // Returns a number indicating which of two overlapping collapsed\n // spans is larger (and thus includes the other). Falls back to\n // comparing ids when the spans cover exactly the same range.\n function compareCollapsedMarkers(a, b) {\n var lenDiff = a.lines.length - b.lines.length;\n if (lenDiff != 0) return lenDiff;\n var aPos = a.find(), bPos = b.find();\n var fromCmp = cmp(aPos.from, bPos.from) || extraLeft(a) - extraLeft(b);\n if (fromCmp) return -fromCmp;\n var toCmp = cmp(aPos.to, bPos.to) || extraRight(a) - extraRight(b);\n if (toCmp) return toCmp;\n return b.id - a.id;\n }\n\n // Find out whether a line ends or starts in a collapsed span. If\n // so, return the marker for that span.\n function collapsedSpanAtSide(line, start) {\n var sps = sawCollapsedSpans && line.markedSpans, found;\n if (sps) for (var sp, i = 0; i < sps.length; ++i) {\n sp = sps[i];\n if (sp.marker.collapsed && (start ? sp.from : sp.to) == null &&\n (!found || compareCollapsedMarkers(found, sp.marker) < 0))\n found = sp.marker;\n }\n return found;\n }\n function collapsedSpanAtStart(line) { return collapsedSpanAtSide(line, true); }\n function collapsedSpanAtEnd(line) { return collapsedSpanAtSide(line, false); }\n\n // Test whether there exists a collapsed span that partially\n // overlaps (covers the start or end, but not both) of a new span.\n // Such overlap is not allowed.\n function conflictingCollapsedRange(doc, lineNo, from, to, marker) {\n var line = getLine(doc, lineNo);\n var sps = sawCollapsedSpans && line.markedSpans;\n if (sps) for (var i = 0; i < sps.length; ++i) {\n var sp = sps[i];\n if (!sp.marker.collapsed) continue;\n var found = sp.marker.find(0);\n var fromCmp = cmp(found.from, from) || extraLeft(sp.marker) - extraLeft(marker);\n var toCmp = cmp(found.to, to) || extraRight(sp.marker) - extraRight(marker);\n if (fromCmp >= 0 && toCmp <= 0 || fromCmp <= 0 && toCmp >= 0) continue;\n if (fromCmp <= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.to, from) >= 0 : cmp(found.to, from) > 0) ||\n fromCmp >= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.from, to) <= 0 : cmp(found.from, to) < 0))\n return true;\n }\n }\n\n // A visual line is a line as drawn on the screen. Folding, for\n // example, can cause multiple logical lines to appear on the same\n // visual line. This finds the start of the visual line that the\n // given line is part of (usually that is the line itself).\n function visualLine(line) {\n var merged;\n while (merged = collapsedSpanAtStart(line))\n line = merged.find(-1, true).line;\n return line;\n }\n\n // Returns an array of logical lines that continue the visual line\n // started by the argument, or undefined if there are no such lines.\n function visualLineContinued(line) {\n var merged, lines;\n while (merged = collapsedSpanAtEnd(line)) {\n line = merged.find(1, true).line;\n (lines || (lines = [])).push(line);\n }\n return lines;\n }\n\n // Get the line number of the start of the visual line that the\n // given line number is part of.\n function visualLineNo(doc, lineN) {\n var line = getLine(doc, lineN), vis = visualLine(line);\n if (line == vis) return lineN;\n return lineNo(vis);\n }\n // Get the line number of the start of the next visual line after\n // the given line.\n function visualLineEndNo(doc, lineN) {\n if (lineN > doc.lastLine()) return lineN;\n var line = getLine(doc, lineN), merged;\n if (!lineIsHidden(doc, line)) return lineN;\n while (merged = collapsedSpanAtEnd(line))\n line = merged.find(1, true).line;\n return lineNo(line) + 1;\n }\n\n // Compute whether a line is hidden. Lines count as hidden when they\n // are part of a visual line that starts with another line, or when\n // they are entirely covered by collapsed, non-widget span.\n function lineIsHidden(doc, line) {\n var sps = sawCollapsedSpans && line.markedSpans;\n if (sps) for (var sp, i = 0; i < sps.length; ++i) {\n sp = sps[i];\n if (!sp.marker.collapsed) continue;\n if (sp.from == null) return true;\n if (sp.marker.widgetNode) continue;\n if (sp.from == 0 && sp.marker.inclusiveLeft && lineIsHiddenInner(doc, line, sp))\n return true;\n }\n }\n function lineIsHiddenInner(doc, line, span) {\n if (span.to == null) {\n var end = span.marker.find(1, true);\n return lineIsHiddenInner(doc, end.line, getMarkedSpanFor(end.line.markedSpans, span.marker));\n }\n if (span.marker.inclusiveRight && span.to == line.text.length)\n return true;\n for (var sp, i = 0; i < line.markedSpans.length; ++i) {\n sp = line.markedSpans[i];\n if (sp.marker.collapsed && !sp.marker.widgetNode && sp.from == span.to &&\n (sp.to == null || sp.to != span.from) &&\n (sp.marker.inclusiveLeft || span.marker.inclusiveRight) &&\n lineIsHiddenInner(doc, line, sp)) return true;\n }\n }\n\n // LINE WIDGETS\n\n // Line widgets are block elements displayed above or below a line.\n\n var LineWidget = CodeMirror.LineWidget = function(doc, node, options) {\n if (options) for (var opt in options) if (options.hasOwnProperty(opt))\n this[opt] = options[opt];\n this.doc = doc;\n this.node = node;\n };\n eventMixin(LineWidget);\n\n function adjustScrollWhenAboveVisible(cm, line, diff) {\n if (heightAtLine(line) < ((cm.curOp && cm.curOp.scrollTop) || cm.doc.scrollTop))\n addToScrollPos(cm, null, diff);\n }\n\n LineWidget.prototype.clear = function() {\n var cm = this.doc.cm, ws = this.line.widgets, line = this.line, no = lineNo(line);\n if (no == null || !ws) return;\n for (var i = 0; i < ws.length; ++i) if (ws[i] == this) ws.splice(i--, 1);\n if (!ws.length) line.widgets = null;\n var height = widgetHeight(this);\n updateLineHeight(line, Math.max(0, line.height - height));\n if (cm) runInOp(cm, function() {\n adjustScrollWhenAboveVisible(cm, line, -height);\n regLineChange(cm, no, \"widget\");\n });\n };\n LineWidget.prototype.changed = function() {\n var oldH = this.height, cm = this.doc.cm, line = this.line;\n this.height = null;\n var diff = widgetHeight(this) - oldH;\n if (!diff) return;\n updateLineHeight(line, line.height + diff);\n if (cm) runInOp(cm, function() {\n cm.curOp.forceUpdate = true;\n adjustScrollWhenAboveVisible(cm, line, diff);\n });\n };\n\n function widgetHeight(widget) {\n if (widget.height != null) return widget.height;\n var cm = widget.doc.cm;\n if (!cm) return 0;\n if (!contains(document.body, widget.node)) {\n var parentStyle = \"position: relative;\";\n if (widget.coverGutter)\n parentStyle += \"margin-left: -\" + cm.display.gutters.offsetWidth + \"px;\";\n if (widget.noHScroll)\n parentStyle += \"width: \" + cm.display.wrapper.clientWidth + \"px;\";\n removeChildrenAndAdd(cm.display.measure, elt(\"div\", [widget.node], null, parentStyle));\n }\n return widget.height = widget.node.parentNode.offsetHeight;\n }\n\n function addLineWidget(doc, handle, node, options) {\n var widget = new LineWidget(doc, node, options);\n var cm = doc.cm;\n if (cm && widget.noHScroll) cm.display.alignWidgets = true;\n changeLine(doc, handle, \"widget\", function(line) {\n var widgets = line.widgets || (line.widgets = []);\n if (widget.insertAt == null) widgets.push(widget);\n else widgets.splice(Math.min(widgets.length - 1, Math.max(0, widget.insertAt)), 0, widget);\n widget.line = line;\n if (cm && !lineIsHidden(doc, line)) {\n var aboveVisible = heightAtLine(line) < doc.scrollTop;\n updateLineHeight(line, line.height + widgetHeight(widget));\n if (aboveVisible) addToScrollPos(cm, null, widget.height);\n cm.curOp.forceUpdate = true;\n }\n return true;\n });\n return widget;\n }\n\n // LINE DATA STRUCTURE\n\n // Line objects. These hold state related to a line, including\n // highlighting info (the styles array).\n var Line = CodeMirror.Line = function(text, markedSpans, estimateHeight) {\n this.text = text;\n attachMarkedSpans(this, markedSpans);\n this.height = estimateHeight ? estimateHeight(this) : 1;\n };\n eventMixin(Line);\n Line.prototype.lineNo = function() { return lineNo(this); };\n\n // Change the content (text, markers) of a line. Automatically\n // invalidates cached information and tries to re-estimate the\n // line's height.\n function updateLine(line, text, markedSpans, estimateHeight) {\n line.text = text;\n if (line.stateAfter) line.stateAfter = null;\n if (line.styles) line.styles = null;\n if (line.order != null) line.order = null;\n detachMarkedSpans(line);\n attachMarkedSpans(line, markedSpans);\n var estHeight = estimateHeight ? estimateHeight(line) : 1;\n if (estHeight != line.height) updateLineHeight(line, estHeight);\n }\n\n // Detach a line from the document tree and its markers.\n function cleanUpLine(line) {\n line.parent = null;\n detachMarkedSpans(line);\n }\n\n function extractLineClasses(type, output) {\n if (type) for (;;) {\n var lineClass = type.match(/(?:^|\\s+)line-(background-)?(\\S+)/);\n if (!lineClass) break;\n type = type.slice(0, lineClass.index) + type.slice(lineClass.index + lineClass[0].length);\n var prop = lineClass[1] ? \"bgClass\" : \"textClass\";\n if (output[prop] == null)\n output[prop] = lineClass[2];\n else if (!(new RegExp(\"(?:^|\\s)\" + lineClass[2] + \"(?:$|\\s)\")).test(output[prop]))\n output[prop] += \" \" + lineClass[2];\n }\n return type;\n }\n\n function callBlankLine(mode, state) {\n if (mode.blankLine) return mode.blankLine(state);\n if (!mode.innerMode) return;\n var inner = CodeMirror.innerMode(mode, state);\n if (inner.mode.blankLine) return inner.mode.blankLine(inner.state);\n }\n\n function readToken(mode, stream, state, inner) {\n for (var i = 0; i < 10; i++) {\n if (inner) inner[0] = CodeMirror.innerMode(mode, state).mode;\n var style = mode.token(stream, state);\n if (stream.pos > stream.start) return style;\n }\n throw new Error(\"Mode \" + mode.name + \" failed to advance stream.\");\n }\n\n // Utility for getTokenAt and getLineTokens\n function takeToken(cm, pos, precise, asArray) {\n function getObj(copy) {\n return {start: stream.start, end: stream.pos,\n string: stream.current(),\n type: style || null,\n state: copy ? copyState(doc.mode, state) : state};\n }\n\n var doc = cm.doc, mode = doc.mode, style;\n pos = clipPos(doc, pos);\n var line = getLine(doc, pos.line), state = getStateBefore(cm, pos.line, precise);\n var stream = new StringStream(line.text, cm.options.tabSize), tokens;\n if (asArray) tokens = [];\n while ((asArray || stream.pos < pos.ch) && !stream.eol()) {\n stream.start = stream.pos;\n style = readToken(mode, stream, state);\n if (asArray) tokens.push(getObj(true));\n }\n return asArray ? tokens : getObj();\n }\n\n // Run the given mode's parser over a line, calling f for each token.\n function runMode(cm, text, mode, state, f, lineClasses, forceToEnd) {\n var flattenSpans = mode.flattenSpans;\n if (flattenSpans == null) flattenSpans = cm.options.flattenSpans;\n var curStart = 0, curStyle = null;\n var stream = new StringStream(text, cm.options.tabSize), style;\n var inner = cm.options.addModeClass && [null];\n if (text == \"\") extractLineClasses(callBlankLine(mode, state), lineClasses);\n while (!stream.eol()) {\n if (stream.pos > cm.options.maxHighlightLength) {\n flattenSpans = false;\n if (forceToEnd) processLine(cm, text, state, stream.pos);\n stream.pos = text.length;\n style = null;\n } else {\n style = extractLineClasses(readToken(mode, stream, state, inner), lineClasses);\n }\n if (inner) {\n var mName = inner[0].name;\n if (mName) style = \"m-\" + (style ? mName + \" \" + style : mName);\n }\n if (!flattenSpans || curStyle != style) {\n while (curStart < stream.start) {\n curStart = Math.min(stream.start, curStart + 50000);\n f(curStart, curStyle);\n }\n curStyle = style;\n }\n stream.start = stream.pos;\n }\n while (curStart < stream.pos) {\n // Webkit seems to refuse to render text nodes longer than 57444 characters\n var pos = Math.min(stream.pos, curStart + 50000);\n f(pos, curStyle);\n curStart = pos;\n }\n }\n\n // Compute a style array (an array starting with a mode generation\n // -- for invalidation -- followed by pairs of end positions and\n // style strings), which is used to highlight the tokens on the\n // line.\n function highlightLine(cm, line, state, forceToEnd) {\n // A styles array always starts with a number identifying the\n // mode/overlays that it is based on (for easy invalidation).\n var st = [cm.state.modeGen], lineClasses = {};\n // Compute the base array of styles\n runMode(cm, line.text, cm.doc.mode, state, function(end, style) {\n st.push(end, style);\n }, lineClasses, forceToEnd);\n\n // Run overlays, adjust style array.\n for (var o = 0; o < cm.state.overlays.length; ++o) {\n var overlay = cm.state.overlays[o], i = 1, at = 0;\n runMode(cm, line.text, overlay.mode, true, function(end, style) {\n var start = i;\n // Ensure there's a token end at the current position, and that i points at it\n while (at < end) {\n var i_end = st[i];\n if (i_end > end)\n st.splice(i, 1, end, st[i+1], i_end);\n i += 2;\n at = Math.min(end, i_end);\n }\n if (!style) return;\n if (overlay.opaque) {\n st.splice(start, i - start, end, \"cm-overlay \" + style);\n i = start + 2;\n } else {\n for (; start < i; start += 2) {\n var cur = st[start+1];\n st[start+1] = (cur ? cur + \" \" : \"\") + \"cm-overlay \" + style;\n }\n }\n }, lineClasses);\n }\n\n return {styles: st, classes: lineClasses.bgClass || lineClasses.textClass ? lineClasses : null};\n }\n\n function getLineStyles(cm, line, updateFrontier) {\n if (!line.styles || line.styles[0] != cm.state.modeGen) {\n var state = getStateBefore(cm, lineNo(line));\n var result = highlightLine(cm, line, line.text.length > cm.options.maxHighlightLength ? copyState(cm.doc.mode, state) : state);\n line.stateAfter = state;\n line.styles = result.styles;\n if (result.classes) line.styleClasses = result.classes;\n else if (line.styleClasses) line.styleClasses = null;\n if (updateFrontier === cm.doc.frontier) cm.doc.frontier++;\n }\n return line.styles;\n }\n\n // Lightweight form of highlight -- proceed over this line and\n // update state, but don't save a style array. Used for lines that\n // aren't currently visible.\n function processLine(cm, text, state, startAt) {\n var mode = cm.doc.mode;\n var stream = new StringStream(text, cm.options.tabSize);\n stream.start = stream.pos = startAt || 0;\n if (text == \"\") callBlankLine(mode, state);\n while (!stream.eol()) {\n readToken(mode, stream, state);\n stream.start = stream.pos;\n }\n }\n\n // Convert a style as returned by a mode (either null, or a string\n // containing one or more styles) to a CSS style. This is cached,\n // and also looks for line-wide styles.\n var styleToClassCache = {}, styleToClassCacheWithMode = {};\n function interpretTokenStyle(style, options) {\n if (!style || /^\\s*$/.test(style)) return null;\n var cache = options.addModeClass ? styleToClassCacheWithMode : styleToClassCache;\n return cache[style] ||\n (cache[style] = style.replace(/\\S+/g, \"cm-$&\"));\n }\n\n // Render the DOM representation of the text of a line. Also builds\n // up a 'line map', which points at the DOM nodes that represent\n // specific stretches of text, and is used by the measuring code.\n // The returned object contains the DOM node, this map, and\n // information about line-wide styles that were set by the mode.\n function buildLineContent(cm, lineView) {\n // The padding-right forces the element to have a 'border', which\n // is needed on Webkit to be able to get line-level bounding\n // rectangles for it (in measureChar).\n var content = elt(\"span\", null, null, webkit ? \"padding-right: .1px\" : null);\n var builder = {pre: elt(\"pre\", [content], \"CodeMirror-line\"), content: content,\n col: 0, pos: 0, cm: cm,\n trailingSpace: false,\n splitSpaces: (ie || webkit) && cm.getOption(\"lineWrapping\")};\n lineView.measure = {};\n\n // Iterate over the logical lines that make up this visual line.\n for (var i = 0; i <= (lineView.rest ? lineView.rest.length : 0); i++) {\n var line = i ? lineView.rest[i - 1] : lineView.line, order;\n builder.pos = 0;\n builder.addToken = buildToken;\n // Optionally wire in some hacks into the token-rendering\n // algorithm, to deal with browser quirks.\n if (hasBadBidiRects(cm.display.measure) && (order = getOrder(line)))\n builder.addToken = buildTokenBadBidi(builder.addToken, order);\n builder.map = [];\n var allowFrontierUpdate = lineView != cm.display.externalMeasured && lineNo(line);\n insertLineContent(line, builder, getLineStyles(cm, line, allowFrontierUpdate));\n if (line.styleClasses) {\n if (line.styleClasses.bgClass)\n builder.bgClass = joinClasses(line.styleClasses.bgClass, builder.bgClass || \"\");\n if (line.styleClasses.textClass)\n builder.textClass = joinClasses(line.styleClasses.textClass, builder.textClass || \"\");\n }\n\n // Ensure at least a single node is present, for measuring.\n if (builder.map.length == 0)\n builder.map.push(0, 0, builder.content.appendChild(zeroWidthElement(cm.display.measure)));\n\n // Store the map and a cache object for the current logical line\n if (i == 0) {\n lineView.measure.map = builder.map;\n lineView.measure.cache = {};\n } else {\n (lineView.measure.maps || (lineView.measure.maps = [])).push(builder.map);\n (lineView.measure.caches || (lineView.measure.caches = [])).push({});\n }\n }\n\n // See issue #2901\n if (webkit) {\n var last = builder.content.lastChild\n if (/\\bcm-tab\\b/.test(last.className) || (last.querySelector && last.querySelector(\".cm-tab\")))\n builder.content.className = \"cm-tab-wrap-hack\";\n }\n\n signal(cm, \"renderLine\", cm, lineView.line, builder.pre);\n if (builder.pre.className)\n builder.textClass = joinClasses(builder.pre.className, builder.textClass || \"\");\n\n return builder;\n }\n\n function defaultSpecialCharPlaceholder(ch) {\n var token = elt(\"span\", \"\\u2022\", \"cm-invalidchar\");\n token.title = \"\\\\u\" + ch.charCodeAt(0).toString(16);\n token.setAttribute(\"aria-label\", token.title);\n return token;\n }\n\n // Build up the DOM representation for a single token, and add it to\n // the line map. Takes care to render special characters separately.\n function buildToken(builder, text, style, startStyle, endStyle, title, css) {\n if (!text) return;\n var displayText = builder.splitSpaces ? splitSpaces(text, builder.trailingSpace) : text\n var special = builder.cm.state.specialChars, mustWrap = false;\n if (!special.test(text)) {\n builder.col += text.length;\n var content = document.createTextNode(displayText);\n builder.map.push(builder.pos, builder.pos + text.length, content);\n if (ie && ie_version < 9) mustWrap = true;\n builder.pos += text.length;\n } else {\n var content = document.createDocumentFragment(), pos = 0;\n while (true) {\n special.lastIndex = pos;\n var m = special.exec(text);\n var skipped = m ? m.index - pos : text.length - pos;\n if (skipped) {\n var txt = document.createTextNode(displayText.slice(pos, pos + skipped));\n if (ie && ie_version < 9) content.appendChild(elt(\"span\", [txt]));\n else content.appendChild(txt);\n builder.map.push(builder.pos, builder.pos + skipped, txt);\n builder.col += skipped;\n builder.pos += skipped;\n }\n if (!m) break;\n pos += skipped + 1;\n if (m[0] == \"\\t\") {\n var tabSize = builder.cm.options.tabSize, tabWidth = tabSize - builder.col % tabSize;\n var txt = content.appendChild(elt(\"span\", spaceStr(tabWidth), \"cm-tab\"));\n txt.setAttribute(\"role\", \"presentation\");\n txt.setAttribute(\"cm-text\", \"\\t\");\n builder.col += tabWidth;\n } else if (m[0] == \"\\r\" || m[0] == \"\\n\") {\n var txt = content.appendChild(elt(\"span\", m[0] == \"\\r\" ? \"\\u240d\" : \"\\u2424\", \"cm-invalidchar\"));\n txt.setAttribute(\"cm-text\", m[0]);\n builder.col += 1;\n } else {\n var txt = builder.cm.options.specialCharPlaceholder(m[0]);\n txt.setAttribute(\"cm-text\", m[0]);\n if (ie && ie_version < 9) content.appendChild(elt(\"span\", [txt]));\n else content.appendChild(txt);\n builder.col += 1;\n }\n builder.map.push(builder.pos, builder.pos + 1, txt);\n builder.pos++;\n }\n }\n builder.trailingSpace = displayText.charCodeAt(text.length - 1) == 32\n if (style || startStyle || endStyle || mustWrap || css) {\n var fullStyle = style || \"\";\n if (startStyle) fullStyle += startStyle;\n if (endStyle) fullStyle += endStyle;\n var token = elt(\"span\", [content], fullStyle, css);\n if (title) token.title = title;\n return builder.content.appendChild(token);\n }\n builder.content.appendChild(content);\n }\n\n function splitSpaces(text, trailingBefore) {\n if (text.length > 1 && !/ /.test(text)) return text\n var spaceBefore = trailingBefore, result = \"\"\n for (var i = 0; i < text.length; i++) {\n var ch = text.charAt(i)\n if (ch == \" \" && spaceBefore && (i == text.length - 1 || text.charCodeAt(i + 1) == 32))\n ch = \"\\u00a0\"\n result += ch\n spaceBefore = ch == \" \"\n }\n return result\n }\n\n // Work around nonsense dimensions being reported for stretches of\n // right-to-left text.\n function buildTokenBadBidi(inner, order) {\n return function(builder, text, style, startStyle, endStyle, title, css) {\n style = style ? style + \" cm-force-border\" : \"cm-force-border\";\n var start = builder.pos, end = start + text.length;\n for (;;) {\n // Find the part that overlaps with the start of this text\n for (var i = 0; i < order.length; i++) {\n var part = order[i];\n if (part.to > start && part.from <= start) break;\n }\n if (part.to >= end) return inner(builder, text, style, startStyle, endStyle, title, css);\n inner(builder, text.slice(0, part.to - start), style, startStyle, null, title, css);\n startStyle = null;\n text = text.slice(part.to - start);\n start = part.to;\n }\n };\n }\n\n function buildCollapsedSpan(builder, size, marker, ignoreWidget) {\n var widget = !ignoreWidget && marker.widgetNode;\n if (widget) builder.map.push(builder.pos, builder.pos + size, widget);\n if (!ignoreWidget && builder.cm.display.input.needsContentAttribute) {\n if (!widget)\n widget = builder.content.appendChild(document.createElement(\"span\"));\n widget.setAttribute(\"cm-marker\", marker.id);\n }\n if (widget) {\n builder.cm.display.input.setUneditable(widget);\n builder.content.appendChild(widget);\n }\n builder.pos += size;\n builder.trailingSpace = false\n }\n\n // Outputs a number of spans to make up a line, taking highlighting\n // and marked text into account.\n function insertLineContent(line, builder, styles) {\n var spans = line.markedSpans, allText = line.text, at = 0;\n if (!spans) {\n for (var i = 1; i < styles.length; i+=2)\n builder.addToken(builder, allText.slice(at, at = styles[i]), interpretTokenStyle(styles[i+1], builder.cm.options));\n return;\n }\n\n var len = allText.length, pos = 0, i = 1, text = \"\", style, css;\n var nextChange = 0, spanStyle, spanEndStyle, spanStartStyle, title, collapsed;\n for (;;) {\n if (nextChange == pos) { // Update current marker set\n spanStyle = spanEndStyle = spanStartStyle = title = css = \"\";\n collapsed = null; nextChange = Infinity;\n var foundBookmarks = [], endStyles\n for (var j = 0; j < spans.length; ++j) {\n var sp = spans[j], m = sp.marker;\n if (m.type == \"bookmark\" && sp.from == pos && m.widgetNode) {\n foundBookmarks.push(m);\n } else if (sp.from <= pos && (sp.to == null || sp.to > pos || m.collapsed && sp.to == pos && sp.from == pos)) {\n if (sp.to != null && sp.to != pos && nextChange > sp.to) {\n nextChange = sp.to;\n spanEndStyle = \"\";\n }\n if (m.className) spanStyle += \" \" + m.className;\n if (m.css) css = (css ? css + \";\" : \"\") + m.css;\n if (m.startStyle && sp.from == pos) spanStartStyle += \" \" + m.startStyle;\n if (m.endStyle && sp.to == nextChange) (endStyles || (endStyles = [])).push(m.endStyle, sp.to)\n if (m.title && !title) title = m.title;\n if (m.collapsed && (!collapsed || compareCollapsedMarkers(collapsed.marker, m) < 0))\n collapsed = sp;\n } else if (sp.from > pos && nextChange > sp.from) {\n nextChange = sp.from;\n }\n }\n if (endStyles) for (var j = 0; j < endStyles.length; j += 2)\n if (endStyles[j + 1] == nextChange) spanEndStyle += \" \" + endStyles[j]\n\n if (!collapsed || collapsed.from == pos) for (var j = 0; j < foundBookmarks.length; ++j)\n buildCollapsedSpan(builder, 0, foundBookmarks[j]);\n if (collapsed && (collapsed.from || 0) == pos) {\n buildCollapsedSpan(builder, (collapsed.to == null ? len + 1 : collapsed.to) - pos,\n collapsed.marker, collapsed.from == null);\n if (collapsed.to == null) return;\n if (collapsed.to == pos) collapsed = false;\n }\n }\n if (pos >= len) break;\n\n var upto = Math.min(len, nextChange);\n while (true) {\n if (text) {\n var end = pos + text.length;\n if (!collapsed) {\n var tokenText = end > upto ? text.slice(0, upto - pos) : text;\n builder.addToken(builder, tokenText, style ? style + spanStyle : spanStyle,\n spanStartStyle, pos + tokenText.length == nextChange ? spanEndStyle : \"\", title, css);\n }\n if (end >= upto) {text = text.slice(upto - pos); pos = upto; break;}\n pos = end;\n spanStartStyle = \"\";\n }\n text = allText.slice(at, at = styles[i++]);\n style = interpretTokenStyle(styles[i++], builder.cm.options);\n }\n }\n }\n\n // DOCUMENT DATA STRUCTURE\n\n // By default, updates that start and end at the beginning of a line\n // are treated specially, in order to make the association of line\n // widgets and marker elements with the text behave more intuitive.\n function isWholeLineUpdate(doc, change) {\n return change.from.ch == 0 && change.to.ch == 0 && lst(change.text) == \"\" &&\n (!doc.cm || doc.cm.options.wholeLineUpdateBefore);\n }\n\n // Perform a change on the document data structure.\n function updateDoc(doc, change, markedSpans, estimateHeight) {\n function spansFor(n) {return markedSpans ? markedSpans[n] : null;}\n function update(line, text, spans) {\n updateLine(line, text, spans, estimateHeight);\n signalLater(line, \"change\", line, change);\n }\n function linesFor(start, end) {\n for (var i = start, result = []; i < end; ++i)\n result.push(new Line(text[i], spansFor(i), estimateHeight));\n return result;\n }\n\n var from = change.from, to = change.to, text = change.text;\n var firstLine = getLine(doc, from.line), lastLine = getLine(doc, to.line);\n var lastText = lst(text), lastSpans = spansFor(text.length - 1), nlines = to.line - from.line;\n\n // Adjust the line structure\n if (change.full) {\n doc.insert(0, linesFor(0, text.length));\n doc.remove(text.length, doc.size - text.length);\n } else if (isWholeLineUpdate(doc, change)) {\n // This is a whole-line replace. Treated specially to make\n // sure line objects move the way they are supposed to.\n var added = linesFor(0, text.length - 1);\n update(lastLine, lastLine.text, lastSpans);\n if (nlines) doc.remove(from.line, nlines);\n if (added.length) doc.insert(from.line, added);\n } else if (firstLine == lastLine) {\n if (text.length == 1) {\n update(firstLine, firstLine.text.slice(0, from.ch) + lastText + firstLine.text.slice(to.ch), lastSpans);\n } else {\n var added = linesFor(1, text.length - 1);\n added.push(new Line(lastText + firstLine.text.slice(to.ch), lastSpans, estimateHeight));\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));\n doc.insert(from.line + 1, added);\n }\n } else if (text.length == 1) {\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0] + lastLine.text.slice(to.ch), spansFor(0));\n doc.remove(from.line + 1, nlines);\n } else {\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));\n update(lastLine, lastText + lastLine.text.slice(to.ch), lastSpans);\n var added = linesFor(1, text.length - 1);\n if (nlines > 1) doc.remove(from.line + 1, nlines - 1);\n doc.insert(from.line + 1, added);\n }\n\n signalLater(doc, \"change\", doc, change);\n }\n\n // The document is represented as a BTree consisting of leaves, with\n // chunk of lines in them, and branches, with up to ten leaves or\n // other branch nodes below them. The top node is always a branch\n // node, and is the document object itself (meaning it has\n // additional methods and properties).\n //\n // All nodes have parent links. The tree is used both to go from\n // line numbers to line objects, and to go from objects to numbers.\n // It also indexes by height, and is used to convert between height\n // and line object, and to find the total height of the document.\n //\n // See also http://marijnhaverbeke.nl/blog/codemirror-line-tree.html\n\n function LeafChunk(lines) {\n this.lines = lines;\n this.parent = null;\n for (var i = 0, height = 0; i < lines.length; ++i) {\n lines[i].parent = this;\n height += lines[i].height;\n }\n this.height = height;\n }\n\n LeafChunk.prototype = {\n chunkSize: function() { return this.lines.length; },\n // Remove the n lines at offset 'at'.\n removeInner: function(at, n) {\n for (var i = at, e = at + n; i < e; ++i) {\n var line = this.lines[i];\n this.height -= line.height;\n cleanUpLine(line);\n signalLater(line, \"delete\");\n }\n this.lines.splice(at, n);\n },\n // Helper used to collapse a small branch into a single leaf.\n collapse: function(lines) {\n lines.push.apply(lines, this.lines);\n },\n // Insert the given array of lines at offset 'at', count them as\n // having the given height.\n insertInner: function(at, lines, height) {\n this.height += height;\n this.lines = this.lines.slice(0, at).concat(lines).concat(this.lines.slice(at));\n for (var i = 0; i < lines.length; ++i) lines[i].parent = this;\n },\n // Used to iterate over a part of the tree.\n iterN: function(at, n, op) {\n for (var e = at + n; at < e; ++at)\n if (op(this.lines[at])) return true;\n }\n };\n\n function BranchChunk(children) {\n this.children = children;\n var size = 0, height = 0;\n for (var i = 0; i < children.length; ++i) {\n var ch = children[i];\n size += ch.chunkSize(); height += ch.height;\n ch.parent = this;\n }\n this.size = size;\n this.height = height;\n this.parent = null;\n }\n\n BranchChunk.prototype = {\n chunkSize: function() { return this.size; },\n removeInner: function(at, n) {\n this.size -= n;\n for (var i = 0; i < this.children.length; ++i) {\n var child = this.children[i], sz = child.chunkSize();\n if (at < sz) {\n var rm = Math.min(n, sz - at), oldHeight = child.height;\n child.removeInner(at, rm);\n this.height -= oldHeight - child.height;\n if (sz == rm) { this.children.splice(i--, 1); child.parent = null; }\n if ((n -= rm) == 0) break;\n at = 0;\n } else at -= sz;\n }\n // If the result is smaller than 25 lines, ensure that it is a\n // single leaf node.\n if (this.size - n < 25 &&\n (this.children.length > 1 || !(this.children[0] instanceof LeafChunk))) {\n var lines = [];\n this.collapse(lines);\n this.children = [new LeafChunk(lines)];\n this.children[0].parent = this;\n }\n },\n collapse: function(lines) {\n for (var i = 0; i < this.children.length; ++i) this.children[i].collapse(lines);\n },\n insertInner: function(at, lines, height) {\n this.size += lines.length;\n this.height += height;\n for (var i = 0; i < this.children.length; ++i) {\n var child = this.children[i], sz = child.chunkSize();\n if (at <= sz) {\n child.insertInner(at, lines, height);\n if (child.lines && child.lines.length > 50) {\n // To avoid memory thrashing when child.lines is huge (e.g. first view of a large file), it's never spliced.\n // Instead, small slices are taken. They're taken in order because sequential memory accesses are fastest.\n var remaining = child.lines.length % 25 + 25\n for (var pos = remaining; pos < child.lines.length;) {\n var leaf = new LeafChunk(child.lines.slice(pos, pos += 25));\n child.height -= leaf.height;\n this.children.splice(++i, 0, leaf);\n leaf.parent = this;\n }\n child.lines = child.lines.slice(0, remaining);\n this.maybeSpill();\n }\n break;\n }\n at -= sz;\n }\n },\n // When a node has grown, check whether it should be split.\n maybeSpill: function() {\n if (this.children.length <= 10) return;\n var me = this;\n do {\n var spilled = me.children.splice(me.children.length - 5, 5);\n var sibling = new BranchChunk(spilled);\n if (!me.parent) { // Become the parent node\n var copy = new BranchChunk(me.children);\n copy.parent = me;\n me.children = [copy, sibling];\n me = copy;\n } else {\n me.size -= sibling.size;\n me.height -= sibling.height;\n var myIndex = indexOf(me.parent.children, me);\n me.parent.children.splice(myIndex + 1, 0, sibling);\n }\n sibling.parent = me.parent;\n } while (me.children.length > 10);\n me.parent.maybeSpill();\n },\n iterN: function(at, n, op) {\n for (var i = 0; i < this.children.length; ++i) {\n var child = this.children[i], sz = child.chunkSize();\n if (at < sz) {\n var used = Math.min(n, sz - at);\n if (child.iterN(at, used, op)) return true;\n if ((n -= used) == 0) break;\n at = 0;\n } else at -= sz;\n }\n }\n };\n\n var nextDocId = 0;\n var Doc = CodeMirror.Doc = function(text, mode, firstLine, lineSep) {\n if (!(this instanceof Doc)) return new Doc(text, mode, firstLine, lineSep);\n if (firstLine == null) firstLine = 0;\n\n BranchChunk.call(this, [new LeafChunk([new Line(\"\", null)])]);\n this.first = firstLine;\n this.scrollTop = this.scrollLeft = 0;\n this.cantEdit = false;\n this.cleanGeneration = 1;\n this.frontier = firstLine;\n var start = Pos(firstLine, 0);\n this.sel = simpleSelection(start);\n this.history = new History(null);\n this.id = ++nextDocId;\n this.modeOption = mode;\n this.lineSep = lineSep;\n this.extend = false;\n\n if (typeof text == \"string\") text = this.splitLines(text);\n updateDoc(this, {from: start, to: start, text: text});\n setSelection(this, simpleSelection(start), sel_dontScroll);\n };\n\n Doc.prototype = createObj(BranchChunk.prototype, {\n constructor: Doc,\n // Iterate over the document. Supports two forms -- with only one\n // argument, it calls that for each line in the document. With\n // three, it iterates over the range given by the first two (with\n // the second being non-inclusive).\n iter: function(from, to, op) {\n if (op) this.iterN(from - this.first, to - from, op);\n else this.iterN(this.first, this.first + this.size, from);\n },\n\n // Non-public interface for adding and removing lines.\n insert: function(at, lines) {\n var height = 0;\n for (var i = 0; i < lines.length; ++i) height += lines[i].height;\n this.insertInner(at - this.first, lines, height);\n },\n remove: function(at, n) { this.removeInner(at - this.first, n); },\n\n // From here, the methods are part of the public interface. Most\n // are also available from CodeMirror (editor) instances.\n\n getValue: function(lineSep) {\n var lines = getLines(this, this.first, this.first + this.size);\n if (lineSep === false) return lines;\n return lines.join(lineSep || this.lineSeparator());\n },\n setValue: docMethodOp(function(code) {\n var top = Pos(this.first, 0), last = this.first + this.size - 1;\n makeChange(this, {from: top, to: Pos(last, getLine(this, last).text.length),\n text: this.splitLines(code), origin: \"setValue\", full: true}, true);\n setSelection(this, simpleSelection(top));\n }),\n replaceRange: function(code, from, to, origin) {\n from = clipPos(this, from);\n to = to ? clipPos(this, to) : from;\n replaceRange(this, code, from, to, origin);\n },\n getRange: function(from, to, lineSep) {\n var lines = getBetween(this, clipPos(this, from), clipPos(this, to));\n if (lineSep === false) return lines;\n return lines.join(lineSep || this.lineSeparator());\n },\n\n getLine: function(line) {var l = this.getLineHandle(line); return l && l.text;},\n\n getLineHandle: function(line) {if (isLine(this, line)) return getLine(this, line);},\n getLineNumber: function(line) {return lineNo(line);},\n\n getLineHandleVisualStart: function(line) {\n if (typeof line == \"number\") line = getLine(this, line);\n return visualLine(line);\n },\n\n lineCount: function() {return this.size;},\n firstLine: function() {return this.first;},\n lastLine: function() {return this.first + this.size - 1;},\n\n clipPos: function(pos) {return clipPos(this, pos);},\n\n getCursor: function(start) {\n var range = this.sel.primary(), pos;\n if (start == null || start == \"head\") pos = range.head;\n else if (start == \"anchor\") pos = range.anchor;\n else if (start == \"end\" || start == \"to\" || start === false) pos = range.to();\n else pos = range.from();\n return pos;\n },\n listSelections: function() { return this.sel.ranges; },\n somethingSelected: function() {return this.sel.somethingSelected();},\n\n setCursor: docMethodOp(function(line, ch, options) {\n setSimpleSelection(this, clipPos(this, typeof line == \"number\" ? Pos(line, ch || 0) : line), null, options);\n }),\n setSelection: docMethodOp(function(anchor, head, options) {\n setSimpleSelection(this, clipPos(this, anchor), clipPos(this, head || anchor), options);\n }),\n extendSelection: docMethodOp(function(head, other, options) {\n extendSelection(this, clipPos(this, head), other && clipPos(this, other), options);\n }),\n extendSelections: docMethodOp(function(heads, options) {\n extendSelections(this, clipPosArray(this, heads), options);\n }),\n extendSelectionsBy: docMethodOp(function(f, options) {\n var heads = map(this.sel.ranges, f);\n extendSelections(this, clipPosArray(this, heads), options);\n }),\n setSelections: docMethodOp(function(ranges, primary, options) {\n if (!ranges.length) return;\n for (var i = 0, out = []; i < ranges.length; i++)\n out[i] = new Range(clipPos(this, ranges[i].anchor),\n clipPos(this, ranges[i].head));\n if (primary == null) primary = Math.min(ranges.length - 1, this.sel.primIndex);\n setSelection(this, normalizeSelection(out, primary), options);\n }),\n addSelection: docMethodOp(function(anchor, head, options) {\n var ranges = this.sel.ranges.slice(0);\n ranges.push(new Range(clipPos(this, anchor), clipPos(this, head || anchor)));\n setSelection(this, normalizeSelection(ranges, ranges.length - 1), options);\n }),\n\n getSelection: function(lineSep) {\n var ranges = this.sel.ranges, lines;\n for (var i = 0; i < ranges.length; i++) {\n var sel = getBetween(this, ranges[i].from(), ranges[i].to());\n lines = lines ? lines.concat(sel) : sel;\n }\n if (lineSep === false) return lines;\n else return lines.join(lineSep || this.lineSeparator());\n },\n getSelections: function(lineSep) {\n var parts = [], ranges = this.sel.ranges;\n for (var i = 0; i < ranges.length; i++) {\n var sel = getBetween(this, ranges[i].from(), ranges[i].to());\n if (lineSep !== false) sel = sel.join(lineSep || this.lineSeparator());\n parts[i] = sel;\n }\n return parts;\n },\n replaceSelection: function(code, collapse, origin) {\n var dup = [];\n for (var i = 0; i < this.sel.ranges.length; i++)\n dup[i] = code;\n this.replaceSelections(dup, collapse, origin || \"+input\");\n },\n replaceSelections: docMethodOp(function(code, collapse, origin) {\n var changes = [], sel = this.sel;\n for (var i = 0; i < sel.ranges.length; i++) {\n var range = sel.ranges[i];\n changes[i] = {from: range.from(), to: range.to(), text: this.splitLines(code[i]), origin: origin};\n }\n var newSel = collapse && collapse != \"end\" && computeReplacedSel(this, changes, collapse);\n for (var i = changes.length - 1; i >= 0; i--)\n makeChange(this, changes[i]);\n if (newSel) setSelectionReplaceHistory(this, newSel);\n else if (this.cm) ensureCursorVisible(this.cm);\n }),\n undo: docMethodOp(function() {makeChangeFromHistory(this, \"undo\");}),\n redo: docMethodOp(function() {makeChangeFromHistory(this, \"redo\");}),\n undoSelection: docMethodOp(function() {makeChangeFromHistory(this, \"undo\", true);}),\n redoSelection: docMethodOp(function() {makeChangeFromHistory(this, \"redo\", true);}),\n\n setExtending: function(val) {this.extend = val;},\n getExtending: function() {return this.extend;},\n\n historySize: function() {\n var hist = this.history, done = 0, undone = 0;\n for (var i = 0; i < hist.done.length; i++) if (!hist.done[i].ranges) ++done;\n for (var i = 0; i < hist.undone.length; i++) if (!hist.undone[i].ranges) ++undone;\n return {undo: done, redo: undone};\n },\n clearHistory: function() {this.history = new History(this.history.maxGeneration);},\n\n markClean: function() {\n this.cleanGeneration = this.changeGeneration(true);\n },\n changeGeneration: function(forceSplit) {\n if (forceSplit)\n this.history.lastOp = this.history.lastSelOp = this.history.lastOrigin = null;\n return this.history.generation;\n },\n isClean: function (gen) {\n return this.history.generation == (gen || this.cleanGeneration);\n },\n\n getHistory: function() {\n return {done: copyHistoryArray(this.history.done),\n undone: copyHistoryArray(this.history.undone)};\n },\n setHistory: function(histData) {\n var hist = this.history = new History(this.history.maxGeneration);\n hist.done = copyHistoryArray(histData.done.slice(0), null, true);\n hist.undone = copyHistoryArray(histData.undone.slice(0), null, true);\n },\n\n addLineClass: docMethodOp(function(handle, where, cls) {\n return changeLine(this, handle, where == \"gutter\" ? \"gutter\" : \"class\", function(line) {\n var prop = where == \"text\" ? \"textClass\"\n : where == \"background\" ? \"bgClass\"\n : where == \"gutter\" ? \"gutterClass\" : \"wrapClass\";\n if (!line[prop]) line[prop] = cls;\n else if (classTest(cls).test(line[prop])) return false;\n else line[prop] += \" \" + cls;\n return true;\n });\n }),\n removeLineClass: docMethodOp(function(handle, where, cls) {\n return changeLine(this, handle, where == \"gutter\" ? \"gutter\" : \"class\", function(line) {\n var prop = where == \"text\" ? \"textClass\"\n : where == \"background\" ? \"bgClass\"\n : where == \"gutter\" ? \"gutterClass\" : \"wrapClass\";\n var cur = line[prop];\n if (!cur) return false;\n else if (cls == null) line[prop] = null;\n else {\n var found = cur.match(classTest(cls));\n if (!found) return false;\n var end = found.index + found[0].length;\n line[prop] = cur.slice(0, found.index) + (!found.index || end == cur.length ? \"\" : \" \") + cur.slice(end) || null;\n }\n return true;\n });\n }),\n\n addLineWidget: docMethodOp(function(handle, node, options) {\n return addLineWidget(this, handle, node, options);\n }),\n removeLineWidget: function(widget) { widget.clear(); },\n\n markText: function(from, to, options) {\n return markText(this, clipPos(this, from), clipPos(this, to), options, options && options.type || \"range\");\n },\n setBookmark: function(pos, options) {\n var realOpts = {replacedWith: options && (options.nodeType == null ? options.widget : options),\n insertLeft: options && options.insertLeft,\n clearWhenEmpty: false, shared: options && options.shared,\n handleMouseEvents: options && options.handleMouseEvents};\n pos = clipPos(this, pos);\n return markText(this, pos, pos, realOpts, \"bookmark\");\n },\n findMarksAt: function(pos) {\n pos = clipPos(this, pos);\n var markers = [], spans = getLine(this, pos.line).markedSpans;\n if (spans) for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if ((span.from == null || span.from <= pos.ch) &&\n (span.to == null || span.to >= pos.ch))\n markers.push(span.marker.parent || span.marker);\n }\n return markers;\n },\n findMarks: function(from, to, filter) {\n from = clipPos(this, from); to = clipPos(this, to);\n var found = [], lineNo = from.line;\n this.iter(from.line, to.line + 1, function(line) {\n var spans = line.markedSpans;\n if (spans) for (var i = 0; i < spans.length; i++) {\n var span = spans[i];\n if (!(span.to != null && lineNo == from.line && from.ch >= span.to ||\n span.from == null && lineNo != from.line ||\n span.from != null && lineNo == to.line && span.from >= to.ch) &&\n (!filter || filter(span.marker)))\n found.push(span.marker.parent || span.marker);\n }\n ++lineNo;\n });\n return found;\n },\n getAllMarks: function() {\n var markers = [];\n this.iter(function(line) {\n var sps = line.markedSpans;\n if (sps) for (var i = 0; i < sps.length; ++i)\n if (sps[i].from != null) markers.push(sps[i].marker);\n });\n return markers;\n },\n\n posFromIndex: function(off) {\n var ch, lineNo = this.first, sepSize = this.lineSeparator().length;\n this.iter(function(line) {\n var sz = line.text.length + sepSize;\n if (sz > off) { ch = off; return true; }\n off -= sz;\n ++lineNo;\n });\n return clipPos(this, Pos(lineNo, ch));\n },\n indexFromPos: function (coords) {\n coords = clipPos(this, coords);\n var index = coords.ch;\n if (coords.line < this.first || coords.ch < 0) return 0;\n var sepSize = this.lineSeparator().length;\n this.iter(this.first, coords.line, function (line) {\n index += line.text.length + sepSize;\n });\n return index;\n },\n\n copy: function(copyHistory) {\n var doc = new Doc(getLines(this, this.first, this.first + this.size),\n this.modeOption, this.first, this.lineSep);\n doc.scrollTop = this.scrollTop; doc.scrollLeft = this.scrollLeft;\n doc.sel = this.sel;\n doc.extend = false;\n if (copyHistory) {\n doc.history.undoDepth = this.history.undoDepth;\n doc.setHistory(this.getHistory());\n }\n return doc;\n },\n\n linkedDoc: function(options) {\n if (!options) options = {};\n var from = this.first, to = this.first + this.size;\n if (options.from != null && options.from > from) from = options.from;\n if (options.to != null && options.to < to) to = options.to;\n var copy = new Doc(getLines(this, from, to), options.mode || this.modeOption, from, this.lineSep);\n if (options.sharedHist) copy.history = this.history;\n (this.linked || (this.linked = [])).push({doc: copy, sharedHist: options.sharedHist});\n copy.linked = [{doc: this, isParent: true, sharedHist: options.sharedHist}];\n copySharedMarkers(copy, findSharedMarkers(this));\n return copy;\n },\n unlinkDoc: function(other) {\n if (other instanceof CodeMirror) other = other.doc;\n if (this.linked) for (var i = 0; i < this.linked.length; ++i) {\n var link = this.linked[i];\n if (link.doc != other) continue;\n this.linked.splice(i, 1);\n other.unlinkDoc(this);\n detachSharedMarkers(findSharedMarkers(this));\n break;\n }\n // If the histories were shared, split them again\n if (other.history == this.history) {\n var splitIds = [other.id];\n linkedDocs(other, function(doc) {splitIds.push(doc.id);}, true);\n other.history = new History(null);\n other.history.done = copyHistoryArray(this.history.done, splitIds);\n other.history.undone = copyHistoryArray(this.history.undone, splitIds);\n }\n },\n iterLinkedDocs: function(f) {linkedDocs(this, f);},\n\n getMode: function() {return this.mode;},\n getEditor: function() {return this.cm;},\n\n splitLines: function(str) {\n if (this.lineSep) return str.split(this.lineSep);\n return splitLinesAuto(str);\n },\n lineSeparator: function() { return this.lineSep || \"\\n\"; }\n });\n\n // Public alias.\n Doc.prototype.eachLine = Doc.prototype.iter;\n\n // Set up methods on CodeMirror's prototype to redirect to the editor's document.\n var dontDelegate = \"iter insert remove copy getEditor constructor\".split(\" \");\n for (var prop in Doc.prototype) if (Doc.prototype.hasOwnProperty(prop) && indexOf(dontDelegate, prop) < 0)\n CodeMirror.prototype[prop] = (function(method) {\n return function() {return method.apply(this.doc, arguments);};\n })(Doc.prototype[prop]);\n\n eventMixin(Doc);\n\n // Call f for all linked documents.\n function linkedDocs(doc, f, sharedHistOnly) {\n function propagate(doc, skip, sharedHist) {\n if (doc.linked) for (var i = 0; i < doc.linked.length; ++i) {\n var rel = doc.linked[i];\n if (rel.doc == skip) continue;\n var shared = sharedHist && rel.sharedHist;\n if (sharedHistOnly && !shared) continue;\n f(rel.doc, shared);\n propagate(rel.doc, doc, shared);\n }\n }\n propagate(doc, null, true);\n }\n\n // Attach a document to an editor.\n function attachDoc(cm, doc) {\n if (doc.cm) throw new Error(\"This document is already in use.\");\n cm.doc = doc;\n doc.cm = cm;\n estimateLineHeights(cm);\n loadMode(cm);\n if (!cm.options.lineWrapping) findMaxLine(cm);\n cm.options.mode = doc.modeOption;\n regChange(cm);\n }\n\n // LINE UTILITIES\n\n // Find the line object corresponding to the given line number.\n function getLine(doc, n) {\n n -= doc.first;\n if (n < 0 || n >= doc.size) throw new Error(\"There is no line \" + (n + doc.first) + \" in the document.\");\n for (var chunk = doc; !chunk.lines;) {\n for (var i = 0;; ++i) {\n var child = chunk.children[i], sz = child.chunkSize();\n if (n < sz) { chunk = child; break; }\n n -= sz;\n }\n }\n return chunk.lines[n];\n }\n\n // Get the part of a document between two positions, as an array of\n // strings.\n function getBetween(doc, start, end) {\n var out = [], n = start.line;\n doc.iter(start.line, end.line + 1, function(line) {\n var text = line.text;\n if (n == end.line) text = text.slice(0, end.ch);\n if (n == start.line) text = text.slice(start.ch);\n out.push(text);\n ++n;\n });\n return out;\n }\n // Get the lines between from and to, as array of strings.\n function getLines(doc, from, to) {\n var out = [];\n doc.iter(from, to, function(line) { out.push(line.text); });\n return out;\n }\n\n // Update the height of a line, propagating the height change\n // upwards to parent nodes.\n function updateLineHeight(line, height) {\n var diff = height - line.height;\n if (diff) for (var n = line; n; n = n.parent) n.height += diff;\n }\n\n // Given a line object, find its line number by walking up through\n // its parent links.\n function lineNo(line) {\n if (line.parent == null) return null;\n var cur = line.parent, no = indexOf(cur.lines, line);\n for (var chunk = cur.parent; chunk; cur = chunk, chunk = chunk.parent) {\n for (var i = 0;; ++i) {\n if (chunk.children[i] == cur) break;\n no += chunk.children[i].chunkSize();\n }\n }\n return no + cur.first;\n }\n\n // Find the line at the given vertical position, using the height\n // information in the document tree.\n function lineAtHeight(chunk, h) {\n var n = chunk.first;\n outer: do {\n for (var i = 0; i < chunk.children.length; ++i) {\n var child = chunk.children[i], ch = child.height;\n if (h < ch) { chunk = child; continue outer; }\n h -= ch;\n n += child.chunkSize();\n }\n return n;\n } while (!chunk.lines);\n for (var i = 0; i < chunk.lines.length; ++i) {\n var line = chunk.lines[i], lh = line.height;\n if (h < lh) break;\n h -= lh;\n }\n return n + i;\n }\n\n\n // Find the height above the given line.\n function heightAtLine(lineObj) {\n lineObj = visualLine(lineObj);\n\n var h = 0, chunk = lineObj.parent;\n for (var i = 0; i < chunk.lines.length; ++i) {\n var line = chunk.lines[i];\n if (line == lineObj) break;\n else h += line.height;\n }\n for (var p = chunk.parent; p; chunk = p, p = chunk.parent) {\n for (var i = 0; i < p.children.length; ++i) {\n var cur = p.children[i];\n if (cur == chunk) break;\n else h += cur.height;\n }\n }\n return h;\n }\n\n // Get the bidi ordering for the given line (and cache it). Returns\n // false for lines that are fully left-to-right, and an array of\n // BidiSpan objects otherwise.\n function getOrder(line) {\n var order = line.order;\n if (order == null) order = line.order = bidiOrdering(line.text);\n return order;\n }\n\n // HISTORY\n\n function History(startGen) {\n // Arrays of change events and selections. Doing something adds an\n // event to done and clears undo. Undoing moves events from done\n // to undone, redoing moves them in the other direction.\n this.done = []; this.undone = [];\n this.undoDepth = Infinity;\n // Used to track when changes can be merged into a single undo\n // event\n this.lastModTime = this.lastSelTime = 0;\n this.lastOp = this.lastSelOp = null;\n this.lastOrigin = this.lastSelOrigin = null;\n // Used by the isClean() method\n this.generation = this.maxGeneration = startGen || 1;\n }\n\n // Create a history change event from an updateDoc-style change\n // object.\n function historyChangeFromChange(doc, change) {\n var histChange = {from: copyPos(change.from), to: changeEnd(change), text: getBetween(doc, change.from, change.to)};\n attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1);\n linkedDocs(doc, function(doc) {attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1);}, true);\n return histChange;\n }\n\n // Pop all selection events off the end of a history array. Stop at\n // a change event.\n function clearSelectionEvents(array) {\n while (array.length) {\n var last = lst(array);\n if (last.ranges) array.pop();\n else break;\n }\n }\n\n // Find the top change event in the history. Pop off selection\n // events that are in the way.\n function lastChangeEvent(hist, force) {\n if (force) {\n clearSelectionEvents(hist.done);\n return lst(hist.done);\n } else if (hist.done.length && !lst(hist.done).ranges) {\n return lst(hist.done);\n } else if (hist.done.length > 1 && !hist.done[hist.done.length - 2].ranges) {\n hist.done.pop();\n return lst(hist.done);\n }\n }\n\n // Register a change in the history. Merges changes that are within\n // a single operation, ore are close together with an origin that\n // allows merging (starting with \"+\") into a single event.\n function addChangeToHistory(doc, change, selAfter, opId) {\n var hist = doc.history;\n hist.undone.length = 0;\n var time = +new Date, cur;\n\n if ((hist.lastOp == opId ||\n hist.lastOrigin == change.origin && change.origin &&\n ((change.origin.charAt(0) == \"+\" && doc.cm && hist.lastModTime > time - doc.cm.options.historyEventDelay) ||\n change.origin.charAt(0) == \"*\")) &&\n (cur = lastChangeEvent(hist, hist.lastOp == opId))) {\n // Merge this change into the last event\n var last = lst(cur.changes);\n if (cmp(change.from, change.to) == 0 && cmp(change.from, last.to) == 0) {\n // Optimized case for simple insertion -- don't want to add\n // new changesets for every character typed\n last.to = changeEnd(change);\n } else {\n // Add new sub-event\n cur.changes.push(historyChangeFromChange(doc, change));\n }\n } else {\n // Can not be merged, start a new event.\n var before = lst(hist.done);\n if (!before || !before.ranges)\n pushSelectionToHistory(doc.sel, hist.done);\n cur = {changes: [historyChangeFromChange(doc, change)],\n generation: hist.generation};\n hist.done.push(cur);\n while (hist.done.length > hist.undoDepth) {\n hist.done.shift();\n if (!hist.done[0].ranges) hist.done.shift();\n }\n }\n hist.done.push(selAfter);\n hist.generation = ++hist.maxGeneration;\n hist.lastModTime = hist.lastSelTime = time;\n hist.lastOp = hist.lastSelOp = opId;\n hist.lastOrigin = hist.lastSelOrigin = change.origin;\n\n if (!last) signal(doc, \"historyAdded\");\n }\n\n function selectionEventCanBeMerged(doc, origin, prev, sel) {\n var ch = origin.charAt(0);\n return ch == \"*\" ||\n ch == \"+\" &&\n prev.ranges.length == sel.ranges.length &&\n prev.somethingSelected() == sel.somethingSelected() &&\n new Date - doc.history.lastSelTime <= (doc.cm ? doc.cm.options.historyEventDelay : 500);\n }\n\n // Called whenever the selection changes, sets the new selection as\n // the pending selection in the history, and pushes the old pending\n // selection into the 'done' array when it was significantly\n // different (in number of selected ranges, emptiness, or time).\n function addSelectionToHistory(doc, sel, opId, options) {\n var hist = doc.history, origin = options && options.origin;\n\n // A new event is started when the previous origin does not match\n // the current, or the origins don't allow matching. Origins\n // starting with * are always merged, those starting with + are\n // merged when similar and close together in time.\n if (opId == hist.lastSelOp ||\n (origin && hist.lastSelOrigin == origin &&\n (hist.lastModTime == hist.lastSelTime && hist.lastOrigin == origin ||\n selectionEventCanBeMerged(doc, origin, lst(hist.done), sel))))\n hist.done[hist.done.length - 1] = sel;\n else\n pushSelectionToHistory(sel, hist.done);\n\n hist.lastSelTime = +new Date;\n hist.lastSelOrigin = origin;\n hist.lastSelOp = opId;\n if (options && options.clearRedo !== false)\n clearSelectionEvents(hist.undone);\n }\n\n function pushSelectionToHistory(sel, dest) {\n var top = lst(dest);\n if (!(top && top.ranges && top.equals(sel)))\n dest.push(sel);\n }\n\n // Used to store marked span information in the history.\n function attachLocalSpans(doc, change, from, to) {\n var existing = change[\"spans_\" + doc.id], n = 0;\n doc.iter(Math.max(doc.first, from), Math.min(doc.first + doc.size, to), function(line) {\n if (line.markedSpans)\n (existing || (existing = change[\"spans_\" + doc.id] = {}))[n] = line.markedSpans;\n ++n;\n });\n }\n\n // When un/re-doing restores text containing marked spans, those\n // that have been explicitly cleared should not be restored.\n function removeClearedSpans(spans) {\n if (!spans) return null;\n for (var i = 0, out; i < spans.length; ++i) {\n if (spans[i].marker.explicitlyCleared) { if (!out) out = spans.slice(0, i); }\n else if (out) out.push(spans[i]);\n }\n return !out ? spans : out.length ? out : null;\n }\n\n // Retrieve and filter the old marked spans stored in a change event.\n function getOldSpans(doc, change) {\n var found = change[\"spans_\" + doc.id];\n if (!found) return null;\n for (var i = 0, nw = []; i < change.text.length; ++i)\n nw.push(removeClearedSpans(found[i]));\n return nw;\n }\n\n // Used both to provide a JSON-safe object in .getHistory, and, when\n // detaching a document, to split the history in two\n function copyHistoryArray(events, newGroup, instantiateSel) {\n for (var i = 0, copy = []; i < events.length; ++i) {\n var event = events[i];\n if (event.ranges) {\n copy.push(instantiateSel ? Selection.prototype.deepCopy.call(event) : event);\n continue;\n }\n var changes = event.changes, newChanges = [];\n copy.push({changes: newChanges});\n for (var j = 0; j < changes.length; ++j) {\n var change = changes[j], m;\n newChanges.push({from: change.from, to: change.to, text: change.text});\n if (newGroup) for (var prop in change) if (m = prop.match(/^spans_(\\d+)$/)) {\n if (indexOf(newGroup, Number(m[1])) > -1) {\n lst(newChanges)[prop] = change[prop];\n delete change[prop];\n }\n }\n }\n }\n return copy;\n }\n\n // Rebasing/resetting history to deal with externally-sourced changes\n\n function rebaseHistSelSingle(pos, from, to, diff) {\n if (to < pos.line) {\n pos.line += diff;\n } else if (from < pos.line) {\n pos.line = from;\n pos.ch = 0;\n }\n }\n\n // Tries to rebase an array of history events given a change in the\n // document. If the change touches the same lines as the event, the\n // event, and everything 'behind' it, is discarded. If the change is\n // before the event, the event's positions are updated. Uses a\n // copy-on-write scheme for the positions, to avoid having to\n // reallocate them all on every rebase, but also avoid problems with\n // shared position objects being unsafely updated.\n function rebaseHistArray(array, from, to, diff) {\n for (var i = 0; i < array.length; ++i) {\n var sub = array[i], ok = true;\n if (sub.ranges) {\n if (!sub.copied) { sub = array[i] = sub.deepCopy(); sub.copied = true; }\n for (var j = 0; j < sub.ranges.length; j++) {\n rebaseHistSelSingle(sub.ranges[j].anchor, from, to, diff);\n rebaseHistSelSingle(sub.ranges[j].head, from, to, diff);\n }\n continue;\n }\n for (var j = 0; j < sub.changes.length; ++j) {\n var cur = sub.changes[j];\n if (to < cur.from.line) {\n cur.from = Pos(cur.from.line + diff, cur.from.ch);\n cur.to = Pos(cur.to.line + diff, cur.to.ch);\n } else if (from <= cur.to.line) {\n ok = false;\n break;\n }\n }\n if (!ok) {\n array.splice(0, i + 1);\n i = 0;\n }\n }\n }\n\n function rebaseHist(hist, change) {\n var from = change.from.line, to = change.to.line, diff = change.text.length - (to - from) - 1;\n rebaseHistArray(hist.done, from, to, diff);\n rebaseHistArray(hist.undone, from, to, diff);\n }\n\n // EVENT UTILITIES\n\n // Due to the fact that we still support jurassic IE versions, some\n // compatibility wrappers are needed.\n\n var e_preventDefault = CodeMirror.e_preventDefault = function(e) {\n if (e.preventDefault) e.preventDefault();\n else e.returnValue = false;\n };\n var e_stopPropagation = CodeMirror.e_stopPropagation = function(e) {\n if (e.stopPropagation) e.stopPropagation();\n else e.cancelBubble = true;\n };\n function e_defaultPrevented(e) {\n return e.defaultPrevented != null ? e.defaultPrevented : e.returnValue == false;\n }\n var e_stop = CodeMirror.e_stop = function(e) {e_preventDefault(e); e_stopPropagation(e);};\n\n function e_target(e) {return e.target || e.srcElement;}\n function e_button(e) {\n var b = e.which;\n if (b == null) {\n if (e.button & 1) b = 1;\n else if (e.button & 2) b = 3;\n else if (e.button & 4) b = 2;\n }\n if (mac && e.ctrlKey && b == 1) b = 3;\n return b;\n }\n\n // EVENT HANDLING\n\n // Lightweight event framework. on/off also work on DOM nodes,\n // registering native DOM handlers.\n\n var on = CodeMirror.on = function(emitter, type, f) {\n if (emitter.addEventListener)\n emitter.addEventListener(type, f, false);\n else if (emitter.attachEvent)\n emitter.attachEvent(\"on\" + type, f);\n else {\n var map = emitter._handlers || (emitter._handlers = {});\n var arr = map[type] || (map[type] = []);\n arr.push(f);\n }\n };\n\n var noHandlers = []\n function getHandlers(emitter, type, copy) {\n var arr = emitter._handlers && emitter._handlers[type]\n if (copy) return arr && arr.length > 0 ? arr.slice() : noHandlers\n else return arr || noHandlers\n }\n\n var off = CodeMirror.off = function(emitter, type, f) {\n if (emitter.removeEventListener)\n emitter.removeEventListener(type, f, false);\n else if (emitter.detachEvent)\n emitter.detachEvent(\"on\" + type, f);\n else {\n var handlers = getHandlers(emitter, type, false)\n for (var i = 0; i < handlers.length; ++i)\n if (handlers[i] == f) { handlers.splice(i, 1); break; }\n }\n };\n\n var signal = CodeMirror.signal = function(emitter, type /*, values...*/) {\n var handlers = getHandlers(emitter, type, true)\n if (!handlers.length) return;\n var args = Array.prototype.slice.call(arguments, 2);\n for (var i = 0; i < handlers.length; ++i) handlers[i].apply(null, args);\n };\n\n var orphanDelayedCallbacks = null;\n\n // Often, we want to signal events at a point where we are in the\n // middle of some work, but don't want the handler to start calling\n // other methods on the editor, which might be in an inconsistent\n // state or simply not expect any other events to happen.\n // signalLater looks whether there are any handlers, and schedules\n // them to be executed when the last operation ends, or, if no\n // operation is active, when a timeout fires.\n function signalLater(emitter, type /*, values...*/) {\n var arr = getHandlers(emitter, type, false)\n if (!arr.length) return;\n var args = Array.prototype.slice.call(arguments, 2), list;\n if (operationGroup) {\n list = operationGroup.delayedCallbacks;\n } else if (orphanDelayedCallbacks) {\n list = orphanDelayedCallbacks;\n } else {\n list = orphanDelayedCallbacks = [];\n setTimeout(fireOrphanDelayed, 0);\n }\n function bnd(f) {return function(){f.apply(null, args);};};\n for (var i = 0; i < arr.length; ++i)\n list.push(bnd(arr[i]));\n }\n\n function fireOrphanDelayed() {\n var delayed = orphanDelayedCallbacks;\n orphanDelayedCallbacks = null;\n for (var i = 0; i < delayed.length; ++i) delayed[i]();\n }\n\n // The DOM events that CodeMirror handles can be overridden by\n // registering a (non-DOM) handler on the editor for the event name,\n // and preventDefault-ing the event in that handler.\n function signalDOMEvent(cm, e, override) {\n if (typeof e == \"string\")\n e = {type: e, preventDefault: function() { this.defaultPrevented = true; }};\n signal(cm, override || e.type, cm, e);\n return e_defaultPrevented(e) || e.codemirrorIgnore;\n }\n\n function signalCursorActivity(cm) {\n var arr = cm._handlers && cm._handlers.cursorActivity;\n if (!arr) return;\n var set = cm.curOp.cursorActivityHandlers || (cm.curOp.cursorActivityHandlers = []);\n for (var i = 0; i < arr.length; ++i) if (indexOf(set, arr[i]) == -1)\n set.push(arr[i]);\n }\n\n function hasHandler(emitter, type) {\n return getHandlers(emitter, type).length > 0\n }\n\n // Add on and off methods to a constructor's prototype, to make\n // registering events on such objects more convenient.\n function eventMixin(ctor) {\n ctor.prototype.on = function(type, f) {on(this, type, f);};\n ctor.prototype.off = function(type, f) {off(this, type, f);};\n }\n\n // MISC UTILITIES\n\n // Number of pixels added to scroller and sizer to hide scrollbar\n var scrollerGap = 30;\n\n // Returned or thrown by various protocols to signal 'I'm not\n // handling this'.\n var Pass = CodeMirror.Pass = {toString: function(){return \"CodeMirror.Pass\";}};\n\n // Reused option objects for setSelection & friends\n var sel_dontScroll = {scroll: false}, sel_mouse = {origin: \"*mouse\"}, sel_move = {origin: \"+move\"};\n\n function Delayed() {this.id = null;}\n Delayed.prototype.set = function(ms, f) {\n clearTimeout(this.id);\n this.id = setTimeout(f, ms);\n };\n\n // Counts the column offset in a string, taking tabs into account.\n // Used mostly to find indentation.\n var countColumn = CodeMirror.countColumn = function(string, end, tabSize, startIndex, startValue) {\n if (end == null) {\n end = string.search(/[^\\s\\u00a0]/);\n if (end == -1) end = string.length;\n }\n for (var i = startIndex || 0, n = startValue || 0;;) {\n var nextTab = string.indexOf(\"\\t\", i);\n if (nextTab < 0 || nextTab >= end)\n return n + (end - i);\n n += nextTab - i;\n n += tabSize - (n % tabSize);\n i = nextTab + 1;\n }\n };\n\n // The inverse of countColumn -- find the offset that corresponds to\n // a particular column.\n var findColumn = CodeMirror.findColumn = function(string, goal, tabSize) {\n for (var pos = 0, col = 0;;) {\n var nextTab = string.indexOf(\"\\t\", pos);\n if (nextTab == -1) nextTab = string.length;\n var skipped = nextTab - pos;\n if (nextTab == string.length || col + skipped >= goal)\n return pos + Math.min(skipped, goal - col);\n col += nextTab - pos;\n col += tabSize - (col % tabSize);\n pos = nextTab + 1;\n if (col >= goal) return pos;\n }\n }\n\n var spaceStrs = [\"\"];\n function spaceStr(n) {\n while (spaceStrs.length <= n)\n spaceStrs.push(lst(spaceStrs) + \" \");\n return spaceStrs[n];\n }\n\n function lst(arr) { return arr[arr.length-1]; }\n\n var selectInput = function(node) { node.select(); };\n if (ios) // Mobile Safari apparently has a bug where select() is broken.\n selectInput = function(node) { node.selectionStart = 0; node.selectionEnd = node.value.length; };\n else if (ie) // Suppress mysterious IE10 errors\n selectInput = function(node) { try { node.select(); } catch(_e) {} };\n\n function indexOf(array, elt) {\n for (var i = 0; i < array.length; ++i)\n if (array[i] == elt) return i;\n return -1;\n }\n function map(array, f) {\n var out = [];\n for (var i = 0; i < array.length; i++) out[i] = f(array[i], i);\n return out;\n }\n\n function nothing() {}\n\n function createObj(base, props) {\n var inst;\n if (Object.create) {\n inst = Object.create(base);\n } else {\n nothing.prototype = base;\n inst = new nothing();\n }\n if (props) copyObj(props, inst);\n return inst;\n };\n\n function copyObj(obj, target, overwrite) {\n if (!target) target = {};\n for (var prop in obj)\n if (obj.hasOwnProperty(prop) && (overwrite !== false || !target.hasOwnProperty(prop)))\n target[prop] = obj[prop];\n return target;\n }\n\n function bind(f) {\n var args = Array.prototype.slice.call(arguments, 1);\n return function(){return f.apply(null, args);};\n }\n\n var nonASCIISingleCaseWordChar = /[\\u00df\\u0587\\u0590-\\u05f4\\u0600-\\u06ff\\u3040-\\u309f\\u30a0-\\u30ff\\u3400-\\u4db5\\u4e00-\\u9fcc\\uac00-\\ud7af]/;\n var isWordCharBasic = CodeMirror.isWordChar = function(ch) {\n return /\\w/.test(ch) || ch > \"\\x80\" &&\n (ch.toUpperCase() != ch.toLowerCase() || nonASCIISingleCaseWordChar.test(ch));\n };\n function isWordChar(ch, helper) {\n if (!helper) return isWordCharBasic(ch);\n if (helper.source.indexOf(\"\\\\w\") > -1 && isWordCharBasic(ch)) return true;\n return helper.test(ch);\n }\n\n function isEmpty(obj) {\n for (var n in obj) if (obj.hasOwnProperty(n) && obj[n]) return false;\n return true;\n }\n\n // Extending unicode characters. A series of a non-extending char +\n // any number of extending chars is treated as a single unit as far\n // as editing and measuring is concerned. This is not fully correct,\n // since some scripts/fonts/browsers also treat other configurations\n // of code points as a group.\n var extendingChars = /[\\u0300-\\u036f\\u0483-\\u0489\\u0591-\\u05bd\\u05bf\\u05c1\\u05c2\\u05c4\\u05c5\\u05c7\\u0610-\\u061a\\u064b-\\u065e\\u0670\\u06d6-\\u06dc\\u06de-\\u06e4\\u06e7\\u06e8\\u06ea-\\u06ed\\u0711\\u0730-\\u074a\\u07a6-\\u07b0\\u07eb-\\u07f3\\u0816-\\u0819\\u081b-\\u0823\\u0825-\\u0827\\u0829-\\u082d\\u0900-\\u0902\\u093c\\u0941-\\u0948\\u094d\\u0951-\\u0955\\u0962\\u0963\\u0981\\u09bc\\u09be\\u09c1-\\u09c4\\u09cd\\u09d7\\u09e2\\u09e3\\u0a01\\u0a02\\u0a3c\\u0a41\\u0a42\\u0a47\\u0a48\\u0a4b-\\u0a4d\\u0a51\\u0a70\\u0a71\\u0a75\\u0a81\\u0a82\\u0abc\\u0ac1-\\u0ac5\\u0ac7\\u0ac8\\u0acd\\u0ae2\\u0ae3\\u0b01\\u0b3c\\u0b3e\\u0b3f\\u0b41-\\u0b44\\u0b4d\\u0b56\\u0b57\\u0b62\\u0b63\\u0b82\\u0bbe\\u0bc0\\u0bcd\\u0bd7\\u0c3e-\\u0c40\\u0c46-\\u0c48\\u0c4a-\\u0c4d\\u0c55\\u0c56\\u0c62\\u0c63\\u0cbc\\u0cbf\\u0cc2\\u0cc6\\u0ccc\\u0ccd\\u0cd5\\u0cd6\\u0ce2\\u0ce3\\u0d3e\\u0d41-\\u0d44\\u0d4d\\u0d57\\u0d62\\u0d63\\u0dca\\u0dcf\\u0dd2-\\u0dd4\\u0dd6\\u0ddf\\u0e31\\u0e34-\\u0e3a\\u0e47-\\u0e4e\\u0eb1\\u0eb4-\\u0eb9\\u0ebb\\u0ebc\\u0ec8-\\u0ecd\\u0f18\\u0f19\\u0f35\\u0f37\\u0f39\\u0f71-\\u0f7e\\u0f80-\\u0f84\\u0f86\\u0f87\\u0f90-\\u0f97\\u0f99-\\u0fbc\\u0fc6\\u102d-\\u1030\\u1032-\\u1037\\u1039\\u103a\\u103d\\u103e\\u1058\\u1059\\u105e-\\u1060\\u1071-\\u1074\\u1082\\u1085\\u1086\\u108d\\u109d\\u135f\\u1712-\\u1714\\u1732-\\u1734\\u1752\\u1753\\u1772\\u1773\\u17b7-\\u17bd\\u17c6\\u17c9-\\u17d3\\u17dd\\u180b-\\u180d\\u18a9\\u1920-\\u1922\\u1927\\u1928\\u1932\\u1939-\\u193b\\u1a17\\u1a18\\u1a56\\u1a58-\\u1a5e\\u1a60\\u1a62\\u1a65-\\u1a6c\\u1a73-\\u1a7c\\u1a7f\\u1b00-\\u1b03\\u1b34\\u1b36-\\u1b3a\\u1b3c\\u1b42\\u1b6b-\\u1b73\\u1b80\\u1b81\\u1ba2-\\u1ba5\\u1ba8\\u1ba9\\u1c2c-\\u1c33\\u1c36\\u1c37\\u1cd0-\\u1cd2\\u1cd4-\\u1ce0\\u1ce2-\\u1ce8\\u1ced\\u1dc0-\\u1de6\\u1dfd-\\u1dff\\u200c\\u200d\\u20d0-\\u20f0\\u2cef-\\u2cf1\\u2de0-\\u2dff\\u302a-\\u302f\\u3099\\u309a\\ua66f-\\ua672\\ua67c\\ua67d\\ua6f0\\ua6f1\\ua802\\ua806\\ua80b\\ua825\\ua826\\ua8c4\\ua8e0-\\ua8f1\\ua926-\\ua92d\\ua947-\\ua951\\ua980-\\ua982\\ua9b3\\ua9b6-\\ua9b9\\ua9bc\\uaa29-\\uaa2e\\uaa31\\uaa32\\uaa35\\uaa36\\uaa43\\uaa4c\\uaab0\\uaab2-\\uaab4\\uaab7\\uaab8\\uaabe\\uaabf\\uaac1\\uabe5\\uabe8\\uabed\\udc00-\\udfff\\ufb1e\\ufe00-\\ufe0f\\ufe20-\\ufe26\\uff9e\\uff9f]/;\n function isExtendingChar(ch) { return ch.charCodeAt(0) >= 768 && extendingChars.test(ch); }\n\n // DOM UTILITIES\n\n function elt(tag, content, className, style) {\n var e = document.createElement(tag);\n if (className) e.className = className;\n if (style) e.style.cssText = style;\n if (typeof content == \"string\") e.appendChild(document.createTextNode(content));\n else if (content) for (var i = 0; i < content.length; ++i) e.appendChild(content[i]);\n return e;\n }\n\n var range;\n if (document.createRange) range = function(node, start, end, endNode) {\n var r = document.createRange();\n r.setEnd(endNode || node, end);\n r.setStart(node, start);\n return r;\n };\n else range = function(node, start, end) {\n var r = document.body.createTextRange();\n try { r.moveToElementText(node.parentNode); }\n catch(e) { return r; }\n r.collapse(true);\n r.moveEnd(\"character\", end);\n r.moveStart(\"character\", start);\n return r;\n };\n\n function removeChildren(e) {\n for (var count = e.childNodes.length; count > 0; --count)\n e.removeChild(e.firstChild);\n return e;\n }\n\n function removeChildrenAndAdd(parent, e) {\n return removeChildren(parent).appendChild(e);\n }\n\n var contains = CodeMirror.contains = function(parent, child) {\n if (child.nodeType == 3) // Android browser always returns false when child is a textnode\n child = child.parentNode;\n if (parent.contains)\n return parent.contains(child);\n do {\n if (child.nodeType == 11) child = child.host;\n if (child == parent) return true;\n } while (child = child.parentNode);\n };\n\n function activeElt() {\n var activeElement = document.activeElement;\n while (activeElement && activeElement.root && activeElement.root.activeElement)\n activeElement = activeElement.root.activeElement;\n return activeElement;\n }\n // Older versions of IE throws unspecified error when touching\n // document.activeElement in some cases (during loading, in iframe)\n if (ie && ie_version < 11) activeElt = function() {\n try { return document.activeElement; }\n catch(e) { return document.body; }\n };\n\n function classTest(cls) { return new RegExp(\"(^|\\\\s)\" + cls + \"(?:$|\\\\s)\\\\s*\"); }\n var rmClass = CodeMirror.rmClass = function(node, cls) {\n var current = node.className;\n var match = classTest(cls).exec(current);\n if (match) {\n var after = current.slice(match.index + match[0].length);\n node.className = current.slice(0, match.index) + (after ? match[1] + after : \"\");\n }\n };\n var addClass = CodeMirror.addClass = function(node, cls) {\n var current = node.className;\n if (!classTest(cls).test(current)) node.className += (current ? \" \" : \"\") + cls;\n };\n function joinClasses(a, b) {\n var as = a.split(\" \");\n for (var i = 0; i < as.length; i++)\n if (as[i] && !classTest(as[i]).test(b)) b += \" \" + as[i];\n return b;\n }\n\n // WINDOW-WIDE EVENTS\n\n // These must be handled carefully, because naively registering a\n // handler for each editor will cause the editors to never be\n // garbage collected.\n\n function forEachCodeMirror(f) {\n if (!document.body.getElementsByClassName) return;\n var byClass = document.body.getElementsByClassName(\"CodeMirror\");\n for (var i = 0; i < byClass.length; i++) {\n var cm = byClass[i].CodeMirror;\n if (cm) f(cm);\n }\n }\n\n var globalsRegistered = false;\n function ensureGlobalHandlers() {\n if (globalsRegistered) return;\n registerGlobalHandlers();\n globalsRegistered = true;\n }\n function registerGlobalHandlers() {\n // When the window resizes, we need to refresh active editors.\n var resizeTimer;\n on(window, \"resize\", function() {\n if (resizeTimer == null) resizeTimer = setTimeout(function() {\n resizeTimer = null;\n forEachCodeMirror(onResize);\n }, 100);\n });\n // When the window loses focus, we want to show the editor as blurred\n on(window, \"blur\", function() {\n forEachCodeMirror(onBlur);\n });\n }\n\n // FEATURE DETECTION\n\n // Detect drag-and-drop\n var dragAndDrop = function() {\n // There is *some* kind of drag-and-drop support in IE6-8, but I\n // couldn't get it to work yet.\n if (ie && ie_version < 9) return false;\n var div = elt('div');\n return \"draggable\" in div || \"dragDrop\" in div;\n }();\n\n var zwspSupported;\n function zeroWidthElement(measure) {\n if (zwspSupported == null) {\n var test = elt(\"span\", \"\\u200b\");\n removeChildrenAndAdd(measure, elt(\"span\", [test, document.createTextNode(\"x\")]));\n if (measure.firstChild.offsetHeight != 0)\n zwspSupported = test.offsetWidth <= 1 && test.offsetHeight > 2 && !(ie && ie_version < 8);\n }\n var node = zwspSupported ? elt(\"span\", \"\\u200b\") :\n elt(\"span\", \"\\u00a0\", null, \"display: inline-block; width: 1px; margin-right: -1px\");\n node.setAttribute(\"cm-text\", \"\");\n return node;\n }\n\n // Feature-detect IE's crummy client rect reporting for bidi text\n var badBidiRects;\n function hasBadBidiRects(measure) {\n if (badBidiRects != null) return badBidiRects;\n var txt = removeChildrenAndAdd(measure, document.createTextNode(\"A\\u062eA\"));\n var r0 = range(txt, 0, 1).getBoundingClientRect();\n var r1 = range(txt, 1, 2).getBoundingClientRect();\n removeChildren(measure);\n if (!r0 || r0.left == r0.right) return false; // Safari returns null in some cases (#2780)\n return badBidiRects = (r1.right - r0.right < 3);\n }\n\n // See if \"\".split is the broken IE version, if so, provide an\n // alternative way to split lines.\n var splitLinesAuto = CodeMirror.splitLines = \"\\n\\nb\".split(/\\n/).length != 3 ? function(string) {\n var pos = 0, result = [], l = string.length;\n while (pos <= l) {\n var nl = string.indexOf(\"\\n\", pos);\n if (nl == -1) nl = string.length;\n var line = string.slice(pos, string.charAt(nl - 1) == \"\\r\" ? nl - 1 : nl);\n var rt = line.indexOf(\"\\r\");\n if (rt != -1) {\n result.push(line.slice(0, rt));\n pos += rt + 1;\n } else {\n result.push(line);\n pos = nl + 1;\n }\n }\n return result;\n } : function(string){return string.split(/\\r\\n?|\\n/);};\n\n var hasSelection = window.getSelection ? function(te) {\n try { return te.selectionStart != te.selectionEnd; }\n catch(e) { return false; }\n } : function(te) {\n try {var range = te.ownerDocument.selection.createRange();}\n catch(e) {}\n if (!range || range.parentElement() != te) return false;\n return range.compareEndPoints(\"StartToEnd\", range) != 0;\n };\n\n var hasCopyEvent = (function() {\n var e = elt(\"div\");\n if (\"oncopy\" in e) return true;\n e.setAttribute(\"oncopy\", \"return;\");\n return typeof e.oncopy == \"function\";\n })();\n\n var badZoomedRects = null;\n function hasBadZoomedRects(measure) {\n if (badZoomedRects != null) return badZoomedRects;\n var node = removeChildrenAndAdd(measure, elt(\"span\", \"x\"));\n var normal = node.getBoundingClientRect();\n var fromRange = range(node, 0, 1).getBoundingClientRect();\n return badZoomedRects = Math.abs(normal.left - fromRange.left) > 1;\n }\n\n // KEY NAMES\n\n var keyNames = CodeMirror.keyNames = {\n 3: \"Enter\", 8: \"Backspace\", 9: \"Tab\", 13: \"Enter\", 16: \"Shift\", 17: \"Ctrl\", 18: \"Alt\",\n 19: \"Pause\", 20: \"CapsLock\", 27: \"Esc\", 32: \"Space\", 33: \"PageUp\", 34: \"PageDown\", 35: \"End\",\n 36: \"Home\", 37: \"Left\", 38: \"Up\", 39: \"Right\", 40: \"Down\", 44: \"PrintScrn\", 45: \"Insert\",\n 46: \"Delete\", 59: \";\", 61: \"=\", 91: \"Mod\", 92: \"Mod\", 93: \"Mod\",\n 106: \"*\", 107: \"=\", 109: \"-\", 110: \".\", 111: \"/\", 127: \"Delete\",\n 173: \"-\", 186: \";\", 187: \"=\", 188: \",\", 189: \"-\", 190: \".\", 191: \"/\", 192: \"`\", 219: \"[\", 220: \"\\\\\",\n 221: \"]\", 222: \"'\", 63232: \"Up\", 63233: \"Down\", 63234: \"Left\", 63235: \"Right\", 63272: \"Delete\",\n 63273: \"Home\", 63275: \"End\", 63276: \"PageUp\", 63277: \"PageDown\", 63302: \"Insert\"\n };\n (function() {\n // Number keys\n for (var i = 0; i < 10; i++) keyNames[i + 48] = keyNames[i + 96] = String(i);\n // Alphabetic keys\n for (var i = 65; i <= 90; i++) keyNames[i] = String.fromCharCode(i);\n // Function keys\n for (var i = 1; i <= 12; i++) keyNames[i + 111] = keyNames[i + 63235] = \"F\" + i;\n })();\n\n // BIDI HELPERS\n\n function iterateBidiSections(order, from, to, f) {\n if (!order) return f(from, to, \"ltr\");\n var found = false;\n for (var i = 0; i < order.length; ++i) {\n var part = order[i];\n if (part.from < to && part.to > from || from == to && part.to == from) {\n f(Math.max(part.from, from), Math.min(part.to, to), part.level == 1 ? \"rtl\" : \"ltr\");\n found = true;\n }\n }\n if (!found) f(from, to, \"ltr\");\n }\n\n function bidiLeft(part) { return part.level % 2 ? part.to : part.from; }\n function bidiRight(part) { return part.level % 2 ? part.from : part.to; }\n\n function lineLeft(line) { var order = getOrder(line); return order ? bidiLeft(order[0]) : 0; }\n function lineRight(line) {\n var order = getOrder(line);\n if (!order) return line.text.length;\n return bidiRight(lst(order));\n }\n\n function lineStart(cm, lineN) {\n var line = getLine(cm.doc, lineN);\n var visual = visualLine(line);\n if (visual != line) lineN = lineNo(visual);\n var order = getOrder(visual);\n var ch = !order ? 0 : order[0].level % 2 ? lineRight(visual) : lineLeft(visual);\n return Pos(lineN, ch);\n }\n function lineEnd(cm, lineN) {\n var merged, line = getLine(cm.doc, lineN);\n while (merged = collapsedSpanAtEnd(line)) {\n line = merged.find(1, true).line;\n lineN = null;\n }\n var order = getOrder(line);\n var ch = !order ? line.text.length : order[0].level % 2 ? lineLeft(line) : lineRight(line);\n return Pos(lineN == null ? lineNo(line) : lineN, ch);\n }\n function lineStartSmart(cm, pos) {\n var start = lineStart(cm, pos.line);\n var line = getLine(cm.doc, start.line);\n var order = getOrder(line);\n if (!order || order[0].level == 0) {\n var firstNonWS = Math.max(0, line.text.search(/\\S/));\n var inWS = pos.line == start.line && pos.ch <= firstNonWS && pos.ch;\n return Pos(start.line, inWS ? 0 : firstNonWS);\n }\n return start;\n }\n\n function compareBidiLevel(order, a, b) {\n var linedir = order[0].level;\n if (a == linedir) return true;\n if (b == linedir) return false;\n return a < b;\n }\n var bidiOther;\n function getBidiPartAt(order, pos) {\n bidiOther = null;\n for (var i = 0, found; i < order.length; ++i) {\n var cur = order[i];\n if (cur.from < pos && cur.to > pos) return i;\n if ((cur.from == pos || cur.to == pos)) {\n if (found == null) {\n found = i;\n } else if (compareBidiLevel(order, cur.level, order[found].level)) {\n if (cur.from != cur.to) bidiOther = found;\n return i;\n } else {\n if (cur.from != cur.to) bidiOther = i;\n return found;\n }\n }\n }\n return found;\n }\n\n function moveInLine(line, pos, dir, byUnit) {\n if (!byUnit) return pos + dir;\n do pos += dir;\n while (pos > 0 && isExtendingChar(line.text.charAt(pos)));\n return pos;\n }\n\n // This is needed in order to move 'visually' through bi-directional\n // text -- i.e., pressing left should make the cursor go left, even\n // when in RTL text. The tricky part is the 'jumps', where RTL and\n // LTR text touch each other. This often requires the cursor offset\n // to move more than one unit, in order to visually move one unit.\n function moveVisually(line, start, dir, byUnit) {\n var bidi = getOrder(line);\n if (!bidi) return moveLogically(line, start, dir, byUnit);\n var pos = getBidiPartAt(bidi, start), part = bidi[pos];\n var target = moveInLine(line, start, part.level % 2 ? -dir : dir, byUnit);\n\n for (;;) {\n if (target > part.from && target < part.to) return target;\n if (target == part.from || target == part.to) {\n if (getBidiPartAt(bidi, target) == pos) return target;\n part = bidi[pos += dir];\n return (dir > 0) == part.level % 2 ? part.to : part.from;\n } else {\n part = bidi[pos += dir];\n if (!part) return null;\n if ((dir > 0) == part.level % 2)\n target = moveInLine(line, part.to, -1, byUnit);\n else\n target = moveInLine(line, part.from, 1, byUnit);\n }\n }\n }\n\n function moveLogically(line, start, dir, byUnit) {\n var target = start + dir;\n if (byUnit) while (target > 0 && isExtendingChar(line.text.charAt(target))) target += dir;\n return target < 0 || target > line.text.length ? null : target;\n }\n\n // Bidirectional ordering algorithm\n // See http://unicode.org/reports/tr9/tr9-13.html for the algorithm\n // that this (partially) implements.\n\n // One-char codes used for character types:\n // L (L): Left-to-Right\n // R (R): Right-to-Left\n // r (AL): Right-to-Left Arabic\n // 1 (EN): European Number\n // + (ES): European Number Separator\n // % (ET): European Number Terminator\n // n (AN): Arabic Number\n // , (CS): Common Number Separator\n // m (NSM): Non-Spacing Mark\n // b (BN): Boundary Neutral\n // s (B): Paragraph Separator\n // t (S): Segment Separator\n // w (WS): Whitespace\n // N (ON): Other Neutrals\n\n // Returns null if characters are ordered as they appear\n // (left-to-right), or an array of sections ({from, to, level}\n // objects) in the order in which they occur visually.\n var bidiOrdering = (function() {\n // Character types for codepoints 0 to 0xff\n var lowTypes = \"bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN\";\n // Character types for codepoints 0x600 to 0x6ff\n var arabicTypes = \"rrrrrrrrrrrr,rNNmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmrrrrrrrnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmNmmmm\";\n function charType(code) {\n if (code <= 0xf7) return lowTypes.charAt(code);\n else if (0x590 <= code && code <= 0x5f4) return \"R\";\n else if (0x600 <= code && code <= 0x6ed) return arabicTypes.charAt(code - 0x600);\n else if (0x6ee <= code && code <= 0x8ac) return \"r\";\n else if (0x2000 <= code && code <= 0x200b) return \"w\";\n else if (code == 0x200c) return \"b\";\n else return \"L\";\n }\n\n var bidiRE = /[\\u0590-\\u05f4\\u0600-\\u06ff\\u0700-\\u08ac]/;\n var isNeutral = /[stwN]/, isStrong = /[LRr]/, countsAsLeft = /[Lb1n]/, countsAsNum = /[1n]/;\n // Browsers seem to always treat the boundaries of block elements as being L.\n var outerType = \"L\";\n\n function BidiSpan(level, from, to) {\n this.level = level;\n this.from = from; this.to = to;\n }\n\n return function(str) {\n if (!bidiRE.test(str)) return false;\n var len = str.length, types = [];\n for (var i = 0, type; i < len; ++i)\n types.push(type = charType(str.charCodeAt(i)));\n\n // W1. Examine each non-spacing mark (NSM) in the level run, and\n // change the type of the NSM to the type of the previous\n // character. If the NSM is at the start of the level run, it will\n // get the type of sor.\n for (var i = 0, prev = outerType; i < len; ++i) {\n var type = types[i];\n if (type == \"m\") types[i] = prev;\n else prev = type;\n }\n\n // W2. Search backwards from each instance of a European number\n // until the first strong type (R, L, AL, or sor) is found. If an\n // AL is found, change the type of the European number to Arabic\n // number.\n // W3. Change all ALs to R.\n for (var i = 0, cur = outerType; i < len; ++i) {\n var type = types[i];\n if (type == \"1\" && cur == \"r\") types[i] = \"n\";\n else if (isStrong.test(type)) { cur = type; if (type == \"r\") types[i] = \"R\"; }\n }\n\n // W4. A single European separator between two European numbers\n // changes to a European number. A single common separator between\n // two numbers of the same type changes to that type.\n for (var i = 1, prev = types[0]; i < len - 1; ++i) {\n var type = types[i];\n if (type == \"+\" && prev == \"1\" && types[i+1] == \"1\") types[i] = \"1\";\n else if (type == \",\" && prev == types[i+1] &&\n (prev == \"1\" || prev == \"n\")) types[i] = prev;\n prev = type;\n }\n\n // W5. A sequence of European terminators adjacent to European\n // numbers changes to all European numbers.\n // W6. Otherwise, separators and terminators change to Other\n // Neutral.\n for (var i = 0; i < len; ++i) {\n var type = types[i];\n if (type == \",\") types[i] = \"N\";\n else if (type == \"%\") {\n for (var end = i + 1; end < len && types[end] == \"%\"; ++end) {}\n var replace = (i && types[i-1] == \"!\") || (end < len && types[end] == \"1\") ? \"1\" : \"N\";\n for (var j = i; j < end; ++j) types[j] = replace;\n i = end - 1;\n }\n }\n\n // W7. Search backwards from each instance of a European number\n // until the first strong type (R, L, or sor) is found. If an L is\n // found, then change the type of the European number to L.\n for (var i = 0, cur = outerType; i < len; ++i) {\n var type = types[i];\n if (cur == \"L\" && type == \"1\") types[i] = \"L\";\n else if (isStrong.test(type)) cur = type;\n }\n\n // N1. A sequence of neutrals takes the direction of the\n // surrounding strong text if the text on both sides has the same\n // direction. European and Arabic numbers act as if they were R in\n // terms of their influence on neutrals. Start-of-level-run (sor)\n // and end-of-level-run (eor) are used at level run boundaries.\n // N2. Any remaining neutrals take the embedding direction.\n for (var i = 0; i < len; ++i) {\n if (isNeutral.test(types[i])) {\n for (var end = i + 1; end < len && isNeutral.test(types[end]); ++end) {}\n var before = (i ? types[i-1] : outerType) == \"L\";\n var after = (end < len ? types[end] : outerType) == \"L\";\n var replace = before || after ? \"L\" : \"R\";\n for (var j = i; j < end; ++j) types[j] = replace;\n i = end - 1;\n }\n }\n\n // Here we depart from the documented algorithm, in order to avoid\n // building up an actual levels array. Since there are only three\n // levels (0, 1, 2) in an implementation that doesn't take\n // explicit embedding into account, we can build up the order on\n // the fly, without following the level-based algorithm.\n var order = [], m;\n for (var i = 0; i < len;) {\n if (countsAsLeft.test(types[i])) {\n var start = i;\n for (++i; i < len && countsAsLeft.test(types[i]); ++i) {}\n order.push(new BidiSpan(0, start, i));\n } else {\n var pos = i, at = order.length;\n for (++i; i < len && types[i] != \"L\"; ++i) {}\n for (var j = pos; j < i;) {\n if (countsAsNum.test(types[j])) {\n if (pos < j) order.splice(at, 0, new BidiSpan(1, pos, j));\n var nstart = j;\n for (++j; j < i && countsAsNum.test(types[j]); ++j) {}\n order.splice(at, 0, new BidiSpan(2, nstart, j));\n pos = j;\n } else ++j;\n }\n if (pos < i) order.splice(at, 0, new BidiSpan(1, pos, i));\n }\n }\n if (order[0].level == 1 && (m = str.match(/^\\s+/))) {\n order[0].from = m[0].length;\n order.unshift(new BidiSpan(0, 0, m[0].length));\n }\n if (lst(order).level == 1 && (m = str.match(/\\s+$/))) {\n lst(order).to -= m[0].length;\n order.push(new BidiSpan(0, len - m[0].length, len));\n }\n if (order[0].level == 2)\n order.unshift(new BidiSpan(1, order[0].to, order[0].to));\n if (order[0].level != lst(order).level)\n order.push(new BidiSpan(order[0].level, len, len));\n\n return order;\n };\n })();\n\n // THE END\n\n CodeMirror.version = \"5.17.0\";\n\n return CodeMirror;\n});\n\n},{}],9:[function(require,module,exports){\n// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n// TODO actually recognize syntax of TypeScript constructs\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n\"use strict\";\n\nfunction expressionAllowed(stream, state, backUp) {\n return /^(?:operator|sof|keyword c|case|new|[\\[{}\\(,;:]|=>)$/.test(state.lastType) ||\n (state.lastType == \"quasi\" && /\\{\\s*$/.test(stream.string.slice(0, stream.pos - (backUp || 0))))\n}\n\nCodeMirror.defineMode(\"javascript\", function(config, parserConfig) {\n var indentUnit = config.indentUnit;\n var statementIndent = parserConfig.statementIndent;\n var jsonldMode = parserConfig.jsonld;\n var jsonMode = parserConfig.json || jsonldMode;\n var isTS = parserConfig.typescript;\n var wordRE = parserConfig.wordCharacters || /[\\w$\\xa1-\\uffff]/;\n\n // Tokenizer\n\n var keywords = function(){\n function kw(type) {return {type: type, style: \"keyword\"};}\n var A = kw(\"keyword a\"), B = kw(\"keyword b\"), C = kw(\"keyword c\");\n var operator = kw(\"operator\"), atom = {type: \"atom\", style: \"atom\"};\n\n var jsKeywords = {\n \"if\": kw(\"if\"), \"while\": A, \"with\": A, \"else\": B, \"do\": B, \"try\": B, \"finally\": B,\n \"return\": C, \"break\": C, \"continue\": C, \"new\": kw(\"new\"), \"delete\": C, \"throw\": C, \"debugger\": C,\n \"var\": kw(\"var\"), \"const\": kw(\"var\"), \"let\": kw(\"var\"),\n \"function\": kw(\"function\"), \"catch\": kw(\"catch\"),\n \"for\": kw(\"for\"), \"switch\": kw(\"switch\"), \"case\": kw(\"case\"), \"default\": kw(\"default\"),\n \"in\": operator, \"typeof\": operator, \"instanceof\": operator,\n \"true\": atom, \"false\": atom, \"null\": atom, \"undefined\": atom, \"NaN\": atom, \"Infinity\": atom,\n \"this\": kw(\"this\"), \"class\": kw(\"class\"), \"super\": kw(\"atom\"),\n \"yield\": C, \"export\": kw(\"export\"), \"import\": kw(\"import\"), \"extends\": C,\n \"await\": C, \"async\": kw(\"async\")\n };\n\n // Extend the 'normal' keywords with the TypeScript language extensions\n if (isTS) {\n var type = {type: \"variable\", style: \"variable-3\"};\n var tsKeywords = {\n // object-like things\n \"interface\": kw(\"class\"),\n \"implements\": C,\n \"namespace\": C,\n \"module\": kw(\"module\"),\n \"enum\": kw(\"module\"),\n\n // scope modifiers\n \"public\": kw(\"modifier\"),\n \"private\": kw(\"modifier\"),\n \"protected\": kw(\"modifier\"),\n \"abstract\": kw(\"modifier\"),\n\n // operators\n \"as\": operator,\n\n // types\n \"string\": type, \"number\": type, \"boolean\": type, \"any\": type\n };\n\n for (var attr in tsKeywords) {\n jsKeywords[attr] = tsKeywords[attr];\n }\n }\n\n return jsKeywords;\n }();\n\n var isOperatorChar = /[+\\-*&%=<>!?|~^]/;\n var isJsonldKeyword = /^@(context|id|value|language|type|container|list|set|reverse|index|base|vocab|graph)\"/;\n\n function readRegexp(stream) {\n var escaped = false, next, inSet = false;\n while ((next = stream.next()) != null) {\n if (!escaped) {\n if (next == \"/\" && !inSet) return;\n if (next == \"[\") inSet = true;\n else if (inSet && next == \"]\") inSet = false;\n }\n escaped = !escaped && next == \"\\\\\";\n }\n }\n\n // Used as scratch variables to communicate multiple values without\n // consing up tons of objects.\n var type, content;\n function ret(tp, style, cont) {\n type = tp; content = cont;\n return style;\n }\n function tokenBase(stream, state) {\n var ch = stream.next();\n if (ch == '\"' || ch == \"'\") {\n state.tokenize = tokenString(ch);\n return state.tokenize(stream, state);\n } else if (ch == \".\" && stream.match(/^\\d+(?:[eE][+\\-]?\\d+)?/)) {\n return ret(\"number\", \"number\");\n } else if (ch == \".\" && stream.match(\"..\")) {\n return ret(\"spread\", \"meta\");\n } else if (/[\\[\\]{}\\(\\),;\\:\\.]/.test(ch)) {\n return ret(ch);\n } else if (ch == \"=\" && stream.eat(\">\")) {\n return ret(\"=>\", \"operator\");\n } else if (ch == \"0\" && stream.eat(/x/i)) {\n stream.eatWhile(/[\\da-f]/i);\n return ret(\"number\", \"number\");\n } else if (ch == \"0\" && stream.eat(/o/i)) {\n stream.eatWhile(/[0-7]/i);\n return ret(\"number\", \"number\");\n } else if (ch == \"0\" && stream.eat(/b/i)) {\n stream.eatWhile(/[01]/i);\n return ret(\"number\", \"number\");\n } else if (/\\d/.test(ch)) {\n stream.match(/^\\d*(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?/);\n return ret(\"number\", \"number\");\n } else if (ch == \"/\") {\n if (stream.eat(\"*\")) {\n state.tokenize = tokenComment;\n return tokenComment(stream, state);\n } else if (stream.eat(\"/\")) {\n stream.skipToEnd();\n return ret(\"comment\", \"comment\");\n } else if (expressionAllowed(stream, state, 1)) {\n readRegexp(stream);\n stream.match(/^\\b(([gimyu])(?![gimyu]*\\2))+\\b/);\n return ret(\"regexp\", \"string-2\");\n } else {\n stream.eatWhile(isOperatorChar);\n return ret(\"operator\", \"operator\", stream.current());\n }\n } else if (ch == \"`\") {\n state.tokenize = tokenQuasi;\n return tokenQuasi(stream, state);\n } else if (ch == \"#\") {\n stream.skipToEnd();\n return ret(\"error\", \"error\");\n } else if (isOperatorChar.test(ch)) {\n stream.eatWhile(isOperatorChar);\n return ret(\"operator\", \"operator\", stream.current());\n } else if (wordRE.test(ch)) {\n stream.eatWhile(wordRE);\n var word = stream.current(), known = keywords.propertyIsEnumerable(word) && keywords[word];\n return (known && state.lastType != \".\") ? ret(known.type, known.style, word) :\n ret(\"variable\", \"variable\", word);\n }\n }\n\n function tokenString(quote) {\n return function(stream, state) {\n var escaped = false, next;\n if (jsonldMode && stream.peek() == \"@\" && stream.match(isJsonldKeyword)){\n state.tokenize = tokenBase;\n return ret(\"jsonld-keyword\", \"meta\");\n }\n while ((next = stream.next()) != null) {\n if (next == quote && !escaped) break;\n escaped = !escaped && next == \"\\\\\";\n }\n if (!escaped) state.tokenize = tokenBase;\n return ret(\"string\", \"string\");\n };\n }\n\n function tokenComment(stream, state) {\n var maybeEnd = false, ch;\n while (ch = stream.next()) {\n if (ch == \"/\" && maybeEnd) {\n state.tokenize = tokenBase;\n break;\n }\n maybeEnd = (ch == \"*\");\n }\n return ret(\"comment\", \"comment\");\n }\n\n function tokenQuasi(stream, state) {\n var escaped = false, next;\n while ((next = stream.next()) != null) {\n if (!escaped && (next == \"`\" || next == \"$\" && stream.eat(\"{\"))) {\n state.tokenize = tokenBase;\n break;\n }\n escaped = !escaped && next == \"\\\\\";\n }\n return ret(\"quasi\", \"string-2\", stream.current());\n }\n\n var brackets = \"([{}])\";\n // This is a crude lookahead trick to try and notice that we're\n // parsing the argument patterns for a fat-arrow function before we\n // actually hit the arrow token. It only works if the arrow is on\n // the same line as the arguments and there's no strange noise\n // (comments) in between. Fallback is to only notice when we hit the\n // arrow, and not declare the arguments as locals for the arrow\n // body.\n function findFatArrow(stream, state) {\n if (state.fatArrowAt) state.fatArrowAt = null;\n var arrow = stream.string.indexOf(\"=>\", stream.start);\n if (arrow < 0) return;\n\n var depth = 0, sawSomething = false;\n for (var pos = arrow - 1; pos >= 0; --pos) {\n var ch = stream.string.charAt(pos);\n var bracket = brackets.indexOf(ch);\n if (bracket >= 0 && bracket < 3) {\n if (!depth) { ++pos; break; }\n if (--depth == 0) break;\n } else if (bracket >= 3 && bracket < 6) {\n ++depth;\n } else if (wordRE.test(ch)) {\n sawSomething = true;\n } else if (/[\"'\\/]/.test(ch)) {\n return;\n } else if (sawSomething && !depth) {\n ++pos;\n break;\n }\n }\n if (sawSomething && !depth) state.fatArrowAt = pos;\n }\n\n // Parser\n\n var atomicTypes = {\"atom\": true, \"number\": true, \"variable\": true, \"string\": true, \"regexp\": true, \"this\": true, \"jsonld-keyword\": true};\n\n function JSLexical(indented, column, type, align, prev, info) {\n this.indented = indented;\n this.column = column;\n this.type = type;\n this.prev = prev;\n this.info = info;\n if (align != null) this.align = align;\n }\n\n function inScope(state, varname) {\n for (var v = state.localVars; v; v = v.next)\n if (v.name == varname) return true;\n for (var cx = state.context; cx; cx = cx.prev) {\n for (var v = cx.vars; v; v = v.next)\n if (v.name == varname) return true;\n }\n }\n\n function parseJS(state, style, type, content, stream) {\n var cc = state.cc;\n // Communicate our context to the combinators.\n // (Less wasteful than consing up a hundred closures on every call.)\n cx.state = state; cx.stream = stream; cx.marked = null, cx.cc = cc; cx.style = style;\n\n if (!state.lexical.hasOwnProperty(\"align\"))\n state.lexical.align = true;\n\n while(true) {\n var combinator = cc.length ? cc.pop() : jsonMode ? expression : statement;\n if (combinator(type, content)) {\n while(cc.length && cc[cc.length - 1].lex)\n cc.pop()();\n if (cx.marked) return cx.marked;\n if (type == \"variable\" && inScope(state, content)) return \"variable-2\";\n return style;\n }\n }\n }\n\n // Combinator utils\n\n var cx = {state: null, column: null, marked: null, cc: null};\n function pass() {\n for (var i = arguments.length - 1; i >= 0; i--) cx.cc.push(arguments[i]);\n }\n function cont() {\n pass.apply(null, arguments);\n return true;\n }\n function register(varname) {\n function inList(list) {\n for (var v = list; v; v = v.next)\n if (v.name == varname) return true;\n return false;\n }\n var state = cx.state;\n cx.marked = \"def\";\n if (state.context) {\n if (inList(state.localVars)) return;\n state.localVars = {name: varname, next: state.localVars};\n } else {\n if (inList(state.globalVars)) return;\n if (parserConfig.globalVars)\n state.globalVars = {name: varname, next: state.globalVars};\n }\n }\n\n // Combinators\n\n var defaultVars = {name: \"this\", next: {name: \"arguments\"}};\n function pushcontext() {\n cx.state.context = {prev: cx.state.context, vars: cx.state.localVars};\n cx.state.localVars = defaultVars;\n }\n function popcontext() {\n cx.state.localVars = cx.state.context.vars;\n cx.state.context = cx.state.context.prev;\n }\n function pushlex(type, info) {\n var result = function() {\n var state = cx.state, indent = state.indented;\n if (state.lexical.type == \"stat\") indent = state.lexical.indented;\n else for (var outer = state.lexical; outer && outer.type == \")\" && outer.align; outer = outer.prev)\n indent = outer.indented;\n state.lexical = new JSLexical(indent, cx.stream.column(), type, null, state.lexical, info);\n };\n result.lex = true;\n return result;\n }\n function poplex() {\n var state = cx.state;\n if (state.lexical.prev) {\n if (state.lexical.type == \")\")\n state.indented = state.lexical.indented;\n state.lexical = state.lexical.prev;\n }\n }\n poplex.lex = true;\n\n function expect(wanted) {\n function exp(type) {\n if (type == wanted) return cont();\n else if (wanted == \";\") return pass();\n else return cont(exp);\n };\n return exp;\n }\n\n function statement(type, value) {\n if (type == \"var\") return cont(pushlex(\"vardef\", value.length), vardef, expect(\";\"), poplex);\n if (type == \"keyword a\") return cont(pushlex(\"form\"), expression, statement, poplex);\n if (type == \"keyword b\") return cont(pushlex(\"form\"), statement, poplex);\n if (type == \"{\") return cont(pushlex(\"}\"), block, poplex);\n if (type == \";\") return cont();\n if (type == \"if\") {\n if (cx.state.lexical.info == \"else\" && cx.state.cc[cx.state.cc.length - 1] == poplex)\n cx.state.cc.pop()();\n return cont(pushlex(\"form\"), expression, statement, poplex, maybeelse);\n }\n if (type == \"function\") return cont(functiondef);\n if (type == \"for\") return cont(pushlex(\"form\"), forspec, statement, poplex);\n if (type == \"variable\") return cont(pushlex(\"stat\"), maybelabel);\n if (type == \"switch\") return cont(pushlex(\"form\"), expression, pushlex(\"}\", \"switch\"), expect(\"{\"),\n block, poplex, poplex);\n if (type == \"case\") return cont(expression, expect(\":\"));\n if (type == \"default\") return cont(expect(\":\"));\n if (type == \"catch\") return cont(pushlex(\"form\"), pushcontext, expect(\"(\"), funarg, expect(\")\"),\n statement, poplex, popcontext);\n if (type == \"class\") return cont(pushlex(\"form\"), className, poplex);\n if (type == \"export\") return cont(pushlex(\"stat\"), afterExport, poplex);\n if (type == \"import\") return cont(pushlex(\"stat\"), afterImport, poplex);\n if (type == \"module\") return cont(pushlex(\"form\"), pattern, pushlex(\"}\"), expect(\"{\"), block, poplex, poplex)\n if (type == \"async\") return cont(statement)\n return pass(pushlex(\"stat\"), expression, expect(\";\"), poplex);\n }\n function expression(type) {\n return expressionInner(type, false);\n }\n function expressionNoComma(type) {\n return expressionInner(type, true);\n }\n function expressionInner(type, noComma) {\n if (cx.state.fatArrowAt == cx.stream.start) {\n var body = noComma ? arrowBodyNoComma : arrowBody;\n if (type == \"(\") return cont(pushcontext, pushlex(\")\"), commasep(pattern, \")\"), poplex, expect(\"=>\"), body, popcontext);\n else if (type == \"variable\") return pass(pushcontext, pattern, expect(\"=>\"), body, popcontext);\n }\n\n var maybeop = noComma ? maybeoperatorNoComma : maybeoperatorComma;\n if (atomicTypes.hasOwnProperty(type)) return cont(maybeop);\n if (type == \"function\") return cont(functiondef, maybeop);\n if (type == \"keyword c\" || type == \"async\") return cont(noComma ? maybeexpressionNoComma : maybeexpression);\n if (type == \"(\") return cont(pushlex(\")\"), maybeexpression, expect(\")\"), poplex, maybeop);\n if (type == \"operator\" || type == \"spread\") return cont(noComma ? expressionNoComma : expression);\n if (type == \"[\") return cont(pushlex(\"]\"), arrayLiteral, poplex, maybeop);\n if (type == \"{\") return contCommasep(objprop, \"}\", null, maybeop);\n if (type == \"quasi\") return pass(quasi, maybeop);\n if (type == \"new\") return cont(maybeTarget(noComma));\n return cont();\n }\n function maybeexpression(type) {\n if (type.match(/[;\\}\\)\\],]/)) return pass();\n return pass(expression);\n }\n function maybeexpressionNoComma(type) {\n if (type.match(/[;\\}\\)\\],]/)) return pass();\n return pass(expressionNoComma);\n }\n\n function maybeoperatorComma(type, value) {\n if (type == \",\") return cont(expression);\n return maybeoperatorNoComma(type, value, false);\n }\n function maybeoperatorNoComma(type, value, noComma) {\n var me = noComma == false ? maybeoperatorComma : maybeoperatorNoComma;\n var expr = noComma == false ? expression : expressionNoComma;\n if (type == \"=>\") return cont(pushcontext, noComma ? arrowBodyNoComma : arrowBody, popcontext);\n if (type == \"operator\") {\n if (/\\+\\+|--/.test(value)) return cont(me);\n if (value == \"?\") return cont(expression, expect(\":\"), expr);\n return cont(expr);\n }\n if (type == \"quasi\") { return pass(quasi, me); }\n if (type == \";\") return;\n if (type == \"(\") return contCommasep(expressionNoComma, \")\", \"call\", me);\n if (type == \".\") return cont(property, me);\n if (type == \"[\") return cont(pushlex(\"]\"), maybeexpression, expect(\"]\"), poplex, me);\n }\n function quasi(type, value) {\n if (type != \"quasi\") return pass();\n if (value.slice(value.length - 2) != \"${\") return cont(quasi);\n return cont(expression, continueQuasi);\n }\n function continueQuasi(type) {\n if (type == \"}\") {\n cx.marked = \"string-2\";\n cx.state.tokenize = tokenQuasi;\n return cont(quasi);\n }\n }\n function arrowBody(type) {\n findFatArrow(cx.stream, cx.state);\n return pass(type == \"{\" ? statement : expression);\n }\n function arrowBodyNoComma(type) {\n findFatArrow(cx.stream, cx.state);\n return pass(type == \"{\" ? statement : expressionNoComma);\n }\n function maybeTarget(noComma) {\n return function(type) {\n if (type == \".\") return cont(noComma ? targetNoComma : target);\n else return pass(noComma ? expressionNoComma : expression);\n };\n }\n function target(_, value) {\n if (value == \"target\") { cx.marked = \"keyword\"; return cont(maybeoperatorComma); }\n }\n function targetNoComma(_, value) {\n if (value == \"target\") { cx.marked = \"keyword\"; return cont(maybeoperatorNoComma); }\n }\n function maybelabel(type) {\n if (type == \":\") return cont(poplex, statement);\n return pass(maybeoperatorComma, expect(\";\"), poplex);\n }\n function property(type) {\n if (type == \"variable\") {cx.marked = \"property\"; return cont();}\n }\n function objprop(type, value) {\n if (type == \"async\") return cont(objprop);\n if (type == \"variable\" || cx.style == \"keyword\") {\n cx.marked = \"property\";\n if (value == \"get\" || value == \"set\") return cont(getterSetter);\n return cont(afterprop);\n } else if (type == \"number\" || type == \"string\") {\n cx.marked = jsonldMode ? \"property\" : (cx.style + \" property\");\n return cont(afterprop);\n } else if (type == \"jsonld-keyword\") {\n return cont(afterprop);\n } else if (type == \"modifier\") {\n return cont(objprop)\n } else if (type == \"[\") {\n return cont(expression, expect(\"]\"), afterprop);\n } else if (type == \"spread\") {\n return cont(expression);\n }\n }\n function getterSetter(type) {\n if (type != \"variable\") return pass(afterprop);\n cx.marked = \"property\";\n return cont(functiondef);\n }\n function afterprop(type) {\n if (type == \":\") return cont(expressionNoComma);\n if (type == \"(\") return pass(functiondef);\n }\n function commasep(what, end) {\n function proceed(type, value) {\n if (type == \",\") {\n var lex = cx.state.lexical;\n if (lex.info == \"call\") lex.pos = (lex.pos || 0) + 1;\n return cont(function(type, value) {\n if (type == end || value == end) return pass()\n return pass(what)\n }, proceed);\n }\n if (type == end || value == end) return cont();\n return cont(expect(end));\n }\n return function(type, value) {\n if (type == end || value == end) return cont();\n return pass(what, proceed);\n };\n }\n function contCommasep(what, end, info) {\n for (var i = 3; i < arguments.length; i++)\n cx.cc.push(arguments[i]);\n return cont(pushlex(end, info), commasep(what, end), poplex);\n }\n function block(type) {\n if (type == \"}\") return cont();\n return pass(statement, block);\n }\n function maybetype(type) {\n if (isTS && type == \":\") return cont(typeexpr);\n }\n function maybedefault(_, value) {\n if (value == \"=\") return cont(expressionNoComma);\n }\n function typeexpr(type) {\n if (type == \"variable\") {cx.marked = \"variable-3\"; return cont(afterType);}\n }\n function afterType(type, value) {\n if (value == \"<\") return cont(commasep(typeexpr, \">\"), afterType)\n if (type == \"[\") return cont(expect(\"]\"), afterType)\n }\n function vardef() {\n return pass(pattern, maybetype, maybeAssign, vardefCont);\n }\n function pattern(type, value) {\n if (type == \"modifier\") return cont(pattern)\n if (type == \"variable\") { register(value); return cont(); }\n if (type == \"spread\") return cont(pattern);\n if (type == \"[\") return contCommasep(pattern, \"]\");\n if (type == \"{\") return contCommasep(proppattern, \"}\");\n }\n function proppattern(type, value) {\n if (type == \"variable\" && !cx.stream.match(/^\\s*:/, false)) {\n register(value);\n return cont(maybeAssign);\n }\n if (type == \"variable\") cx.marked = \"property\";\n if (type == \"spread\") return cont(pattern);\n if (type == \"}\") return pass();\n return cont(expect(\":\"), pattern, maybeAssign);\n }\n function maybeAssign(_type, value) {\n if (value == \"=\") return cont(expressionNoComma);\n }\n function vardefCont(type) {\n if (type == \",\") return cont(vardef);\n }\n function maybeelse(type, value) {\n if (type == \"keyword b\" && value == \"else\") return cont(pushlex(\"form\", \"else\"), statement, poplex);\n }\n function forspec(type) {\n if (type == \"(\") return cont(pushlex(\")\"), forspec1, expect(\")\"), poplex);\n }\n function forspec1(type) {\n if (type == \"var\") return cont(vardef, expect(\";\"), forspec2);\n if (type == \";\") return cont(forspec2);\n if (type == \"variable\") return cont(formaybeinof);\n return pass(expression, expect(\";\"), forspec2);\n }\n function formaybeinof(_type, value) {\n if (value == \"in\" || value == \"of\") { cx.marked = \"keyword\"; return cont(expression); }\n return cont(maybeoperatorComma, forspec2);\n }\n function forspec2(type, value) {\n if (type == \";\") return cont(forspec3);\n if (value == \"in\" || value == \"of\") { cx.marked = \"keyword\"; return cont(expression); }\n return pass(expression, expect(\";\"), forspec3);\n }\n function forspec3(type) {\n if (type != \")\") cont(expression);\n }\n function functiondef(type, value) {\n if (value == \"*\") {cx.marked = \"keyword\"; return cont(functiondef);}\n if (type == \"variable\") {register(value); return cont(functiondef);}\n if (type == \"(\") return cont(pushcontext, pushlex(\")\"), commasep(funarg, \")\"), poplex, maybetype, statement, popcontext);\n }\n function funarg(type) {\n if (type == \"spread\") return cont(funarg);\n return pass(pattern, maybetype, maybedefault);\n }\n function className(type, value) {\n if (type == \"variable\") {register(value); return cont(classNameAfter);}\n }\n function classNameAfter(type, value) {\n if (value == \"extends\") return cont(expression, classNameAfter);\n if (type == \"{\") return cont(pushlex(\"}\"), classBody, poplex);\n }\n function classBody(type, value) {\n if (type == \"variable\" || cx.style == \"keyword\") {\n if (value == \"static\") {\n cx.marked = \"keyword\";\n return cont(classBody);\n }\n cx.marked = \"property\";\n if (value == \"get\" || value == \"set\") return cont(classGetterSetter, functiondef, classBody);\n return cont(functiondef, classBody);\n }\n if (value == \"*\") {\n cx.marked = \"keyword\";\n return cont(classBody);\n }\n if (type == \";\") return cont(classBody);\n if (type == \"}\") return cont();\n }\n function classGetterSetter(type) {\n if (type != \"variable\") return pass();\n cx.marked = \"property\";\n return cont();\n }\n function afterExport(_type, value) {\n if (value == \"*\") { cx.marked = \"keyword\"; return cont(maybeFrom, expect(\";\")); }\n if (value == \"default\") { cx.marked = \"keyword\"; return cont(expression, expect(\";\")); }\n return pass(statement);\n }\n function afterImport(type) {\n if (type == \"string\") return cont();\n return pass(importSpec, maybeFrom);\n }\n function importSpec(type, value) {\n if (type == \"{\") return contCommasep(importSpec, \"}\");\n if (type == \"variable\") register(value);\n if (value == \"*\") cx.marked = \"keyword\";\n return cont(maybeAs);\n }\n function maybeAs(_type, value) {\n if (value == \"as\") { cx.marked = \"keyword\"; return cont(importSpec); }\n }\n function maybeFrom(_type, value) {\n if (value == \"from\") { cx.marked = \"keyword\"; return cont(expression); }\n }\n function arrayLiteral(type) {\n if (type == \"]\") return cont();\n return pass(expressionNoComma, commasep(expressionNoComma, \"]\"));\n }\n\n function isContinuedStatement(state, textAfter) {\n return state.lastType == \"operator\" || state.lastType == \",\" ||\n isOperatorChar.test(textAfter.charAt(0)) ||\n /[,.]/.test(textAfter.charAt(0));\n }\n\n // Interface\n\n return {\n startState: function(basecolumn) {\n var state = {\n tokenize: tokenBase,\n lastType: \"sof\",\n cc: [],\n lexical: new JSLexical((basecolumn || 0) - indentUnit, 0, \"block\", false),\n localVars: parserConfig.localVars,\n context: parserConfig.localVars && {vars: parserConfig.localVars},\n indented: basecolumn || 0\n };\n if (parserConfig.globalVars && typeof parserConfig.globalVars == \"object\")\n state.globalVars = parserConfig.globalVars;\n return state;\n },\n\n token: function(stream, state) {\n if (stream.sol()) {\n if (!state.lexical.hasOwnProperty(\"align\"))\n state.lexical.align = false;\n state.indented = stream.indentation();\n findFatArrow(stream, state);\n }\n if (state.tokenize != tokenComment && stream.eatSpace()) return null;\n var style = state.tokenize(stream, state);\n if (type == \"comment\") return style;\n state.lastType = type == \"operator\" && (content == \"++\" || content == \"--\") ? \"incdec\" : type;\n return parseJS(state, style, type, content, stream);\n },\n\n indent: function(state, textAfter) {\n if (state.tokenize == tokenComment) return CodeMirror.Pass;\n if (state.tokenize != tokenBase) return 0;\n var firstChar = textAfter && textAfter.charAt(0), lexical = state.lexical;\n // Kludge to prevent 'maybelse' from blocking lexical scope pops\n if (!/^\\s*else\\b/.test(textAfter)) for (var i = state.cc.length - 1; i >= 0; --i) {\n var c = state.cc[i];\n if (c == poplex) lexical = lexical.prev;\n else if (c != maybeelse) break;\n }\n if (lexical.type == \"stat\" && firstChar == \"}\") lexical = lexical.prev;\n if (statementIndent && lexical.type == \")\" && lexical.prev.type == \"stat\")\n lexical = lexical.prev;\n var type = lexical.type, closing = firstChar == type;\n\n if (type == \"vardef\") return lexical.indented + (state.lastType == \"operator\" || state.lastType == \",\" ? lexical.info + 1 : 0);\n else if (type == \"form\" && firstChar == \"{\") return lexical.indented;\n else if (type == \"form\") return lexical.indented + indentUnit;\n else if (type == \"stat\")\n return lexical.indented + (isContinuedStatement(state, textAfter) ? statementIndent || indentUnit : 0);\n else if (lexical.info == \"switch\" && !closing && parserConfig.doubleIndentSwitch != false)\n return lexical.indented + (/^(?:case|default)\\b/.test(textAfter) ? indentUnit : 2 * indentUnit);\n else if (lexical.align) return lexical.column + (closing ? 0 : 1);\n else return lexical.indented + (closing ? 0 : indentUnit);\n },\n\n electricInput: /^\\s*(?:case .*?:|default:|\\{|\\})$/,\n blockCommentStart: jsonMode ? null : \"/*\",\n blockCommentEnd: jsonMode ? null : \"*/\",\n lineComment: jsonMode ? null : \"//\",\n fold: \"brace\",\n closeBrackets: \"()[]{}''\\\"\\\"``\",\n\n helperType: jsonMode ? \"json\" : \"javascript\",\n jsonldMode: jsonldMode,\n jsonMode: jsonMode,\n\n expressionAllowed: expressionAllowed,\n skipExpression: function(state) {\n var top = state.cc[state.cc.length - 1]\n if (top == expression || top == expressionNoComma) state.cc.pop()\n }\n };\n});\n\nCodeMirror.registerHelper(\"wordChars\", \"javascript\", /[\\w$]/);\n\nCodeMirror.defineMIME(\"text/javascript\", \"javascript\");\nCodeMirror.defineMIME(\"text/ecmascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/javascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/x-javascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/ecmascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/json\", {name: \"javascript\", json: true});\nCodeMirror.defineMIME(\"application/x-json\", {name: \"javascript\", json: true});\nCodeMirror.defineMIME(\"application/ld+json\", {name: \"javascript\", jsonld: true});\nCodeMirror.defineMIME(\"text/typescript\", { name: \"javascript\", typescript: true });\nCodeMirror.defineMIME(\"application/typescript\", { name: \"javascript\", typescript: true });\n\n});\n\n},{\"../../lib/codemirror\":8}],10:[function(require,module,exports){\n// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n\"use strict\";\n\nvar htmlConfig = {\n autoSelfClosers: {'area': true, 'base': true, 'br': true, 'col': true, 'command': true,\n 'embed': true, 'frame': true, 'hr': true, 'img': true, 'input': true,\n 'keygen': true, 'link': true, 'meta': true, 'param': true, 'source': true,\n 'track': true, 'wbr': true, 'menuitem': true},\n implicitlyClosed: {'dd': true, 'li': true, 'optgroup': true, 'option': true, 'p': true,\n 'rp': true, 'rt': true, 'tbody': true, 'td': true, 'tfoot': true,\n 'th': true, 'tr': true},\n contextGrabbers: {\n 'dd': {'dd': true, 'dt': true},\n 'dt': {'dd': true, 'dt': true},\n 'li': {'li': true},\n 'option': {'option': true, 'optgroup': true},\n 'optgroup': {'optgroup': true},\n 'p': {'address': true, 'article': true, 'aside': true, 'blockquote': true, 'dir': true,\n 'div': true, 'dl': true, 'fieldset': true, 'footer': true, 'form': true,\n 'h1': true, 'h2': true, 'h3': true, 'h4': true, 'h5': true, 'h6': true,\n 'header': true, 'hgroup': true, 'hr': true, 'menu': true, 'nav': true, 'ol': true,\n 'p': true, 'pre': true, 'section': true, 'table': true, 'ul': true},\n 'rp': {'rp': true, 'rt': true},\n 'rt': {'rp': true, 'rt': true},\n 'tbody': {'tbody': true, 'tfoot': true},\n 'td': {'td': true, 'th': true},\n 'tfoot': {'tbody': true},\n 'th': {'td': true, 'th': true},\n 'thead': {'tbody': true, 'tfoot': true},\n 'tr': {'tr': true}\n },\n doNotIndent: {\"pre\": true},\n allowUnquoted: true,\n allowMissing: true,\n caseFold: true\n}\n\nvar xmlConfig = {\n autoSelfClosers: {},\n implicitlyClosed: {},\n contextGrabbers: {},\n doNotIndent: {},\n allowUnquoted: false,\n allowMissing: false,\n caseFold: false\n}\n\nCodeMirror.defineMode(\"xml\", function(editorConf, config_) {\n var indentUnit = editorConf.indentUnit\n var config = {}\n var defaults = config_.htmlMode ? htmlConfig : xmlConfig\n for (var prop in defaults) config[prop] = defaults[prop]\n for (var prop in config_) config[prop] = config_[prop]\n\n // Return variables for tokenizers\n var type, setStyle;\n\n function inText(stream, state) {\n function chain(parser) {\n state.tokenize = parser;\n return parser(stream, state);\n }\n\n var ch = stream.next();\n if (ch == \"<\") {\n if (stream.eat(\"!\")) {\n if (stream.eat(\"[\")) {\n if (stream.match(\"CDATA[\")) return chain(inBlock(\"atom\", \"]]>\"));\n else return null;\n } else if (stream.match(\"--\")) {\n return chain(inBlock(\"comment\", \"-->\"));\n } else if (stream.match(\"DOCTYPE\", true, true)) {\n stream.eatWhile(/[\\w\\._\\-]/);\n return chain(doctype(1));\n } else {\n return null;\n }\n } else if (stream.eat(\"?\")) {\n stream.eatWhile(/[\\w\\._\\-]/);\n state.tokenize = inBlock(\"meta\", \"?>\");\n return \"meta\";\n } else {\n type = stream.eat(\"/\") ? \"closeTag\" : \"openTag\";\n state.tokenize = inTag;\n return \"tag bracket\";\n }\n } else if (ch == \"&\") {\n var ok;\n if (stream.eat(\"#\")) {\n if (stream.eat(\"x\")) {\n ok = stream.eatWhile(/[a-fA-F\\d]/) && stream.eat(\";\");\n } else {\n ok = stream.eatWhile(/[\\d]/) && stream.eat(\";\");\n }\n } else {\n ok = stream.eatWhile(/[\\w\\.\\-:]/) && stream.eat(\";\");\n }\n return ok ? \"atom\" : \"error\";\n } else {\n stream.eatWhile(/[^&<]/);\n return null;\n }\n }\n inText.isInText = true;\n\n function inTag(stream, state) {\n var ch = stream.next();\n if (ch == \">\" || (ch == \"/\" && stream.eat(\">\"))) {\n state.tokenize = inText;\n type = ch == \">\" ? \"endTag\" : \"selfcloseTag\";\n return \"tag bracket\";\n } else if (ch == \"=\") {\n type = \"equals\";\n return null;\n } else if (ch == \"<\") {\n state.tokenize = inText;\n state.state = baseState;\n state.tagName = state.tagStart = null;\n var next = state.tokenize(stream, state);\n return next ? next + \" tag error\" : \"tag error\";\n } else if (/[\\'\\\"]/.test(ch)) {\n state.tokenize = inAttribute(ch);\n state.stringStartCol = stream.column();\n return state.tokenize(stream, state);\n } else {\n stream.match(/^[^\\s\\u00a0=<>\\\"\\']*[^\\s\\u00a0=<>\\\"\\'\\/]/);\n return \"word\";\n }\n }\n\n function inAttribute(quote) {\n var closure = function(stream, state) {\n while (!stream.eol()) {\n if (stream.next() == quote) {\n state.tokenize = inTag;\n break;\n }\n }\n return \"string\";\n };\n closure.isInAttribute = true;\n return closure;\n }\n\n function inBlock(style, terminator) {\n return function(stream, state) {\n while (!stream.eol()) {\n if (stream.match(terminator)) {\n state.tokenize = inText;\n break;\n }\n stream.next();\n }\n return style;\n };\n }\n function doctype(depth) {\n return function(stream, state) {\n var ch;\n while ((ch = stream.next()) != null) {\n if (ch == \"<\") {\n state.tokenize = doctype(depth + 1);\n return state.tokenize(stream, state);\n } else if (ch == \">\") {\n if (depth == 1) {\n state.tokenize = inText;\n break;\n } else {\n state.tokenize = doctype(depth - 1);\n return state.tokenize(stream, state);\n }\n }\n }\n return \"meta\";\n };\n }\n\n function Context(state, tagName, startOfLine) {\n this.prev = state.context;\n this.tagName = tagName;\n this.indent = state.indented;\n this.startOfLine = startOfLine;\n if (config.doNotIndent.hasOwnProperty(tagName) || (state.context && state.context.noIndent))\n this.noIndent = true;\n }\n function popContext(state) {\n if (state.context) state.context = state.context.prev;\n }\n function maybePopContext(state, nextTagName) {\n var parentTagName;\n while (true) {\n if (!state.context) {\n return;\n }\n parentTagName = state.context.tagName;\n if (!config.contextGrabbers.hasOwnProperty(parentTagName) ||\n !config.contextGrabbers[parentTagName].hasOwnProperty(nextTagName)) {\n return;\n }\n popContext(state);\n }\n }\n\n function baseState(type, stream, state) {\n if (type == \"openTag\") {\n state.tagStart = stream.column();\n return tagNameState;\n } else if (type == \"closeTag\") {\n return closeTagNameState;\n } else {\n return baseState;\n }\n }\n function tagNameState(type, stream, state) {\n if (type == \"word\") {\n state.tagName = stream.current();\n setStyle = \"tag\";\n return attrState;\n } else {\n setStyle = \"error\";\n return tagNameState;\n }\n }\n function closeTagNameState(type, stream, state) {\n if (type == \"word\") {\n var tagName = stream.current();\n if (state.context && state.context.tagName != tagName &&\n config.implicitlyClosed.hasOwnProperty(state.context.tagName))\n popContext(state);\n if ((state.context && state.context.tagName == tagName) || config.matchClosing === false) {\n setStyle = \"tag\";\n return closeState;\n } else {\n setStyle = \"tag error\";\n return closeStateErr;\n }\n } else {\n setStyle = \"error\";\n return closeStateErr;\n }\n }\n\n function closeState(type, _stream, state) {\n if (type != \"endTag\") {\n setStyle = \"error\";\n return closeState;\n }\n popContext(state);\n return baseState;\n }\n function closeStateErr(type, stream, state) {\n setStyle = \"error\";\n return closeState(type, stream, state);\n }\n\n function attrState(type, _stream, state) {\n if (type == \"word\") {\n setStyle = \"attribute\";\n return attrEqState;\n } else if (type == \"endTag\" || type == \"selfcloseTag\") {\n var tagName = state.tagName, tagStart = state.tagStart;\n state.tagName = state.tagStart = null;\n if (type == \"selfcloseTag\" ||\n config.autoSelfClosers.hasOwnProperty(tagName)) {\n maybePopContext(state, tagName);\n } else {\n maybePopContext(state, tagName);\n state.context = new Context(state, tagName, tagStart == state.indented);\n }\n return baseState;\n }\n setStyle = \"error\";\n return attrState;\n }\n function attrEqState(type, stream, state) {\n if (type == \"equals\") return attrValueState;\n if (!config.allowMissing) setStyle = \"error\";\n return attrState(type, stream, state);\n }\n function attrValueState(type, stream, state) {\n if (type == \"string\") return attrContinuedState;\n if (type == \"word\" && config.allowUnquoted) {setStyle = \"string\"; return attrState;}\n setStyle = \"error\";\n return attrState(type, stream, state);\n }\n function attrContinuedState(type, stream, state) {\n if (type == \"string\") return attrContinuedState;\n return attrState(type, stream, state);\n }\n\n return {\n startState: function(baseIndent) {\n var state = {tokenize: inText,\n state: baseState,\n indented: baseIndent || 0,\n tagName: null, tagStart: null,\n context: null}\n if (baseIndent != null) state.baseIndent = baseIndent\n return state\n },\n\n token: function(stream, state) {\n if (!state.tagName && stream.sol())\n state.indented = stream.indentation();\n\n if (stream.eatSpace()) return null;\n type = null;\n var style = state.tokenize(stream, state);\n if ((style || type) && style != \"comment\") {\n setStyle = null;\n state.state = state.state(type || style, stream, state);\n if (setStyle)\n style = setStyle == \"error\" ? style + \" error\" : setStyle;\n }\n return style;\n },\n\n indent: function(state, textAfter, fullLine) {\n var context = state.context;\n // Indent multi-line strings (e.g. css).\n if (state.tokenize.isInAttribute) {\n if (state.tagStart == state.indented)\n return state.stringStartCol + 1;\n else\n return state.indented + indentUnit;\n }\n if (context && context.noIndent) return CodeMirror.Pass;\n if (state.tokenize != inTag && state.tokenize != inText)\n return fullLine ? fullLine.match(/^(\\s*)/)[0].length : 0;\n // Indent the starts of attribute names.\n if (state.tagName) {\n if (config.multilineTagIndentPastTag !== false)\n return state.tagStart + state.tagName.length + 2;\n else\n return state.tagStart + indentUnit * (config.multilineTagIndentFactor || 1);\n }\n if (config.alignCDATA && /<!\\[CDATA\\[/.test(textAfter)) return 0;\n var tagAfter = textAfter && /^<(\\/)?([\\w_:\\.-]*)/.exec(textAfter);\n if (tagAfter && tagAfter[1]) { // Closing tag spotted\n while (context) {\n if (context.tagName == tagAfter[2]) {\n context = context.prev;\n break;\n } else if (config.implicitlyClosed.hasOwnProperty(context.tagName)) {\n context = context.prev;\n } else {\n break;\n }\n }\n } else if (tagAfter) { // Opening tag spotted\n while (context) {\n var grabbers = config.contextGrabbers[context.tagName];\n if (grabbers && grabbers.hasOwnProperty(tagAfter[2]))\n context = context.prev;\n else\n break;\n }\n }\n while (context && context.prev && !context.startOfLine)\n context = context.prev;\n if (context) return context.indent + indentUnit;\n else return state.baseIndent || 0;\n },\n\n electricInput: /<\\/[\\s\\w:]+>$/,\n blockCommentStart: \"<!--\",\n blockCommentEnd: \"-->\",\n\n configuration: config.htmlMode ? \"html\" : \"xml\",\n helperType: config.htmlMode ? \"html\" : \"xml\",\n\n skipAttribute: function(state) {\n if (state.state == attrValueState)\n state.state = attrState\n }\n };\n});\n\nCodeMirror.defineMIME(\"text/xml\", \"xml\");\nCodeMirror.defineMIME(\"application/xml\", \"xml\");\nif (!CodeMirror.mimeModes.hasOwnProperty(\"text/html\"))\n CodeMirror.defineMIME(\"text/html\", {name: \"xml\", htmlMode: true});\n\n});\n\n},{\"../../lib/codemirror\":8}],11:[function(require,module,exports){\n// https://d3js.org Version 4.1.1. Copyright 2016 Mike Bostock.\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :\n typeof define === 'function' && define.amd ? define(['exports'], factory) :\n (factory((global.d3 = global.d3 || {})));\n}(this, function (exports) { 'use strict';\n\n var version = \"4.1.1\";\n\n function ascending(a, b) {\n return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n }\n\n function bisector(compare) {\n if (compare.length === 1) compare = ascendingComparator(compare);\n return {\n left: function(a, x, lo, hi) {\n if (lo == null) lo = 0;\n if (hi == null) hi = a.length;\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (compare(a[mid], x) < 0) lo = mid + 1;\n else hi = mid;\n }\n return lo;\n },\n right: function(a, x, lo, hi) {\n if (lo == null) lo = 0;\n if (hi == null) hi = a.length;\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (compare(a[mid], x) > 0) hi = mid;\n else lo = mid + 1;\n }\n return lo;\n }\n };\n }\n\n function ascendingComparator(f) {\n return function(d, x) {\n return ascending(f(d), x);\n };\n }\n\n var ascendingBisect = bisector(ascending);\n var bisectRight = ascendingBisect.right;\n var bisectLeft = ascendingBisect.left;\n\n function descending(a, b) {\n return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;\n }\n\n function number(x) {\n return x === null ? NaN : +x;\n }\n\n function variance(array, f) {\n var n = array.length,\n m = 0,\n a,\n d,\n s = 0,\n i = -1,\n j = 0;\n\n if (f == null) {\n while (++i < n) {\n if (!isNaN(a = number(array[i]))) {\n d = a - m;\n m += d / ++j;\n s += d * (a - m);\n }\n }\n }\n\n else {\n while (++i < n) {\n if (!isNaN(a = number(f(array[i], i, array)))) {\n d = a - m;\n m += d / ++j;\n s += d * (a - m);\n }\n }\n }\n\n if (j > 1) return s / (j - 1);\n }\n\n function deviation(array, f) {\n var v = variance(array, f);\n return v ? Math.sqrt(v) : v;\n }\n\n function extent(array, f) {\n var i = -1,\n n = array.length,\n a,\n b,\n c;\n\n if (f == null) {\n while (++i < n) if ((b = array[i]) != null && b >= b) { a = c = b; break; }\n while (++i < n) if ((b = array[i]) != null) {\n if (a > b) a = b;\n if (c < b) c = b;\n }\n }\n\n else {\n while (++i < n) if ((b = f(array[i], i, array)) != null && b >= b) { a = c = b; break; }\n while (++i < n) if ((b = f(array[i], i, array)) != null) {\n if (a > b) a = b;\n if (c < b) c = b;\n }\n }\n\n return [a, c];\n }\n\n var array = Array.prototype;\n\n var slice = array.slice;\n var map = array.map;\n\n function constant(x) {\n return function() {\n return x;\n };\n }\n\n function identity(x) {\n return x;\n }\n\n function range(start, stop, step) {\n start = +start, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start, start = 0, 1) : n < 3 ? 1 : +step;\n\n var i = -1,\n n = Math.max(0, Math.ceil((stop - start) / step)) | 0,\n range = new Array(n);\n\n while (++i < n) {\n range[i] = start + i * step;\n }\n\n return range;\n }\n\n var e10 = Math.sqrt(50);\n var e5 = Math.sqrt(10);\n var e2 = Math.sqrt(2);\n function ticks(start, stop, count) {\n var step = tickStep(start, stop, count);\n return range(\n Math.ceil(start / step) * step,\n Math.floor(stop / step) * step + step / 2, // inclusive\n step\n );\n }\n\n function tickStep(start, stop, count) {\n var step0 = Math.abs(stop - start) / Math.max(0, count),\n step1 = Math.pow(10, Math.floor(Math.log(step0) / Math.LN10)),\n error = step0 / step1;\n if (error >= e10) step1 *= 10;\n else if (error >= e5) step1 *= 5;\n else if (error >= e2) step1 *= 2;\n return stop < start ? -step1 : step1;\n }\n\n function sturges(values) {\n return Math.ceil(Math.log(values.length) / Math.LN2) + 1;\n }\n\n function histogram() {\n var value = identity,\n domain = extent,\n threshold = sturges;\n\n function histogram(data) {\n var i,\n n = data.length,\n x,\n values = new Array(n);\n\n for (i = 0; i < n; ++i) {\n values[i] = value(data[i], i, data);\n }\n\n var xz = domain(values),\n x0 = xz[0],\n x1 = xz[1],\n tz = threshold(values, x0, x1);\n\n // Convert number of thresholds into uniform thresholds.\n if (!Array.isArray(tz)) tz = ticks(x0, x1, tz);\n\n // Remove any thresholds outside the domain.\n var m = tz.length;\n while (tz[0] <= x0) tz.shift(), --m;\n while (tz[m - 1] >= x1) tz.pop(), --m;\n\n var bins = new Array(m + 1),\n bin;\n\n // Initialize bins.\n for (i = 0; i <= m; ++i) {\n bin = bins[i] = [];\n bin.x0 = i > 0 ? tz[i - 1] : x0;\n bin.x1 = i < m ? tz[i] : x1;\n }\n\n // Assign data to bins by value, ignoring any outside the domain.\n for (i = 0; i < n; ++i) {\n x = values[i];\n if (x0 <= x && x <= x1) {\n bins[bisectRight(tz, x, 0, m)].push(data[i]);\n }\n }\n\n return bins;\n }\n\n histogram.value = function(_) {\n return arguments.length ? (value = typeof _ === \"function\" ? _ : constant(_), histogram) : value;\n };\n\n histogram.domain = function(_) {\n return arguments.length ? (domain = typeof _ === \"function\" ? _ : constant([_[0], _[1]]), histogram) : domain;\n };\n\n histogram.thresholds = function(_) {\n return arguments.length ? (threshold = typeof _ === \"function\" ? _ : Array.isArray(_) ? constant(slice.call(_)) : constant(_), histogram) : threshold;\n };\n\n return histogram;\n }\n\n function threshold(array, p, f) {\n if (f == null) f = number;\n if (!(n = array.length)) return;\n if ((p = +p) <= 0 || n < 2) return +f(array[0], 0, array);\n if (p >= 1) return +f(array[n - 1], n - 1, array);\n var n,\n h = (n - 1) * p,\n i = Math.floor(h),\n a = +f(array[i], i, array),\n b = +f(array[i + 1], i + 1, array);\n return a + (b - a) * (h - i);\n }\n\n function freedmanDiaconis(values, min, max) {\n values = map.call(values, number).sort(ascending);\n return Math.ceil((max - min) / (2 * (threshold(values, 0.75) - threshold(values, 0.25)) * Math.pow(values.length, -1 / 3)));\n }\n\n function scott(values, min, max) {\n return Math.ceil((max - min) / (3.5 * deviation(values) * Math.pow(values.length, -1 / 3)));\n }\n\n function max(array, f) {\n var i = -1,\n n = array.length,\n a,\n b;\n\n if (f == null) {\n while (++i < n) if ((b = array[i]) != null && b >= b) { a = b; break; }\n while (++i < n) if ((b = array[i]) != null && b > a) a = b;\n }\n\n else {\n while (++i < n) if ((b = f(array[i], i, array)) != null && b >= b) { a = b; break; }\n while (++i < n) if ((b = f(array[i], i, array)) != null && b > a) a = b;\n }\n\n return a;\n }\n\n function mean(array, f) {\n var s = 0,\n n = array.length,\n a,\n i = -1,\n j = n;\n\n if (f == null) {\n while (++i < n) if (!isNaN(a = number(array[i]))) s += a; else --j;\n }\n\n else {\n while (++i < n) if (!isNaN(a = number(f(array[i], i, array)))) s += a; else --j;\n }\n\n if (j) return s / j;\n }\n\n function median(array, f) {\n var numbers = [],\n n = array.length,\n a,\n i = -1;\n\n if (f == null) {\n while (++i < n) if (!isNaN(a = number(array[i]))) numbers.push(a);\n }\n\n else {\n while (++i < n) if (!isNaN(a = number(f(array[i], i, array)))) numbers.push(a);\n }\n\n return threshold(numbers.sort(ascending), 0.5);\n }\n\n function merge(arrays) {\n var n = arrays.length,\n m,\n i = -1,\n j = 0,\n merged,\n array;\n\n while (++i < n) j += arrays[i].length;\n merged = new Array(j);\n\n while (--n >= 0) {\n array = arrays[n];\n m = array.length;\n while (--m >= 0) {\n merged[--j] = array[m];\n }\n }\n\n return merged;\n }\n\n function min(array, f) {\n var i = -1,\n n = array.length,\n a,\n b;\n\n if (f == null) {\n while (++i < n) if ((b = array[i]) != null && b >= b) { a = b; break; }\n while (++i < n) if ((b = array[i]) != null && a > b) a = b;\n }\n\n else {\n while (++i < n) if ((b = f(array[i], i, array)) != null && b >= b) { a = b; break; }\n while (++i < n) if ((b = f(array[i], i, array)) != null && a > b) a = b;\n }\n\n return a;\n }\n\n function pairs(array) {\n var i = 0, n = array.length - 1, p = array[0], pairs = new Array(n < 0 ? 0 : n);\n while (i < n) pairs[i] = [p, p = array[++i]];\n return pairs;\n }\n\n function permute(array, indexes) {\n var i = indexes.length, permutes = new Array(i);\n while (i--) permutes[i] = array[indexes[i]];\n return permutes;\n }\n\n function scan(array, compare) {\n if (!(n = array.length)) return;\n var i = 0,\n n,\n j = 0,\n xi,\n xj = array[j];\n\n if (!compare) compare = ascending;\n\n while (++i < n) if (compare(xi = array[i], xj) < 0 || compare(xj, xj) !== 0) xj = xi, j = i;\n\n if (compare(xj, xj) === 0) return j;\n }\n\n function shuffle(array, i0, i1) {\n var m = (i1 == null ? array.length : i1) - (i0 = i0 == null ? 0 : +i0),\n t,\n i;\n\n while (m) {\n i = Math.random() * m-- | 0;\n t = array[m + i0];\n array[m + i0] = array[i + i0];\n array[i + i0] = t;\n }\n\n return array;\n }\n\n function sum(array, f) {\n var s = 0,\n n = array.length,\n a,\n i = -1;\n\n if (f == null) {\n while (++i < n) if (a = +array[i]) s += a; // Note: zero and null are equivalent.\n }\n\n else {\n while (++i < n) if (a = +f(array[i], i, array)) s += a;\n }\n\n return s;\n }\n\n function transpose(matrix) {\n if (!(n = matrix.length)) return [];\n for (var i = -1, m = min(matrix, length), transpose = new Array(m); ++i < m;) {\n for (var j = -1, n, row = transpose[i] = new Array(n); ++j < n;) {\n row[j] = matrix[j][i];\n }\n }\n return transpose;\n }\n\n function length(d) {\n return d.length;\n }\n\n function zip() {\n return transpose(arguments);\n }\n\n var prefix = \"$\";\n\n function Map() {}\n\n Map.prototype = map$1.prototype = {\n constructor: Map,\n has: function(key) {\n return (prefix + key) in this;\n },\n get: function(key) {\n return this[prefix + key];\n },\n set: function(key, value) {\n this[prefix + key] = value;\n return this;\n },\n remove: function(key) {\n var property = prefix + key;\n return property in this && delete this[property];\n },\n clear: function() {\n for (var property in this) if (property[0] === prefix) delete this[property];\n },\n keys: function() {\n var keys = [];\n for (var property in this) if (property[0] === prefix) keys.push(property.slice(1));\n return keys;\n },\n values: function() {\n var values = [];\n for (var property in this) if (property[0] === prefix) values.push(this[property]);\n return values;\n },\n entries: function() {\n var entries = [];\n for (var property in this) if (property[0] === prefix) entries.push({key: property.slice(1), value: this[property]});\n return entries;\n },\n size: function() {\n var size = 0;\n for (var property in this) if (property[0] === prefix) ++size;\n return size;\n },\n empty: function() {\n for (var property in this) if (property[0] === prefix) return false;\n return true;\n },\n each: function(f) {\n for (var property in this) if (property[0] === prefix) f(this[property], property.slice(1), this);\n }\n };\n\n function map$1(object, f) {\n var map = new Map;\n\n // Copy constructor.\n if (object instanceof Map) object.each(function(value, key) { map.set(key, value); });\n\n // Index array by numeric index or specified key function.\n else if (Array.isArray(object)) {\n var i = -1,\n n = object.length,\n o;\n\n if (f == null) while (++i < n) map.set(i, object[i]);\n else while (++i < n) map.set(f(o = object[i], i, object), o);\n }\n\n // Convert object to map.\n else if (object) for (var key in object) map.set(key, object[key]);\n\n return map;\n }\n\n function nest() {\n var keys = [],\n sortKeys = [],\n sortValues,\n rollup,\n nest;\n\n function apply(array, depth, createResult, setResult) {\n if (depth >= keys.length) return rollup != null\n ? rollup(array) : (sortValues != null\n ? array.sort(sortValues)\n : array);\n\n var i = -1,\n n = array.length,\n key = keys[depth++],\n keyValue,\n value,\n valuesByKey = map$1(),\n values,\n result = createResult();\n\n while (++i < n) {\n if (values = valuesByKey.get(keyValue = key(value = array[i]) + \"\")) {\n values.push(value);\n } else {\n valuesByKey.set(keyValue, [value]);\n }\n }\n\n valuesByKey.each(function(values, key) {\n setResult(result, key, apply(values, depth, createResult, setResult));\n });\n\n return result;\n }\n\n function entries(map, depth) {\n if (++depth > keys.length) return map;\n var array, sortKey = sortKeys[depth - 1];\n if (rollup != null && depth >= keys.length) array = map.entries();\n else array = [], map.each(function(v, k) { array.push({key: k, values: entries(v, depth)}); });\n return sortKey != null ? array.sort(function(a, b) { return sortKey(a.key, b.key); }) : array;\n }\n\n return nest = {\n object: function(array) { return apply(array, 0, createObject, setObject); },\n map: function(array) { return apply(array, 0, createMap, setMap); },\n entries: function(array) { return entries(apply(array, 0, createMap, setMap), 0); },\n key: function(d) { keys.push(d); return nest; },\n sortKeys: function(order) { sortKeys[keys.length - 1] = order; return nest; },\n sortValues: function(order) { sortValues = order; return nest; },\n rollup: function(f) { rollup = f; return nest; }\n };\n }\n\n function createObject() {\n return {};\n }\n\n function setObject(object, key, value) {\n object[key] = value;\n }\n\n function createMap() {\n return map$1();\n }\n\n function setMap(map, key, value) {\n map.set(key, value);\n }\n\n function Set() {}\n\n var proto = map$1.prototype;\n\n Set.prototype = set.prototype = {\n constructor: Set,\n has: proto.has,\n add: function(value) {\n value += \"\";\n this[prefix + value] = value;\n return this;\n },\n remove: proto.remove,\n clear: proto.clear,\n values: proto.keys,\n size: proto.size,\n empty: proto.empty,\n each: proto.each\n };\n\n function set(object, f) {\n var set = new Set;\n\n // Copy constructor.\n if (object instanceof Set) object.each(function(value) { set.add(value); });\n\n // Otherwise, assume it’s an array.\n else if (object) {\n var i = -1, n = object.length;\n if (f == null) while (++i < n) set.add(object[i]);\n else while (++i < n) set.add(f(object[i], i, object));\n }\n\n return set;\n }\n\n function keys(map) {\n var keys = [];\n for (var key in map) keys.push(key);\n return keys;\n }\n\n function values(map) {\n var values = [];\n for (var key in map) values.push(map[key]);\n return values;\n }\n\n function entries(map) {\n var entries = [];\n for (var key in map) entries.push({key: key, value: map[key]});\n return entries;\n }\n\n function uniform(min, max) {\n min = min == null ? 0 : +min;\n max = max == null ? 1 : +max;\n if (arguments.length === 1) max = min, min = 0;\n else max -= min;\n return function() {\n return Math.random() * max + min;\n };\n }\n\n function normal(mu, sigma) {\n var x, r;\n mu = mu == null ? 0 : +mu;\n sigma = sigma == null ? 1 : +sigma;\n return function() {\n var y;\n\n // If available, use the second previously-generated uniform random.\n if (x != null) y = x, x = null;\n\n // Otherwise, generate a new x and y.\n else do {\n x = Math.random() * 2 - 1;\n y = Math.random() * 2 - 1;\n r = x * x + y * y;\n } while (!r || r > 1);\n\n return mu + sigma * y * Math.sqrt(-2 * Math.log(r) / r);\n };\n }\n\n function logNormal() {\n var randomNormal = normal.apply(this, arguments);\n return function() {\n return Math.exp(randomNormal());\n };\n }\n\n function irwinHall(n) {\n return function() {\n for (var sum = 0, i = 0; i < n; ++i) sum += Math.random();\n return sum;\n };\n }\n\n function bates(n) {\n var randomIrwinHall = irwinHall(n);\n return function() {\n return randomIrwinHall() / n;\n };\n }\n\n function exponential(lambda) {\n return function() {\n return -Math.log(1 - Math.random()) / lambda;\n };\n }\n\n function linear(t) {\n return +t;\n }\n\n function quadIn(t) {\n return t * t;\n }\n\n function quadOut(t) {\n return t * (2 - t);\n }\n\n function quadInOut(t) {\n return ((t *= 2) <= 1 ? t * t : --t * (2 - t) + 1) / 2;\n }\n\n function cubicIn(t) {\n return t * t * t;\n }\n\n function cubicOut(t) {\n return --t * t * t + 1;\n }\n\n function easeCubicInOut(t) {\n return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;\n }\n\n var exponent = 3;\n\n var polyIn = (function custom(e) {\n e = +e;\n\n function polyIn(t) {\n return Math.pow(t, e);\n }\n\n polyIn.exponent = custom;\n\n return polyIn;\n })(exponent);\n\n var polyOut = (function custom(e) {\n e = +e;\n\n function polyOut(t) {\n return 1 - Math.pow(1 - t, e);\n }\n\n polyOut.exponent = custom;\n\n return polyOut;\n })(exponent);\n\n var polyInOut = (function custom(e) {\n e = +e;\n\n function polyInOut(t) {\n return ((t *= 2) <= 1 ? Math.pow(t, e) : 2 - Math.pow(2 - t, e)) / 2;\n }\n\n polyInOut.exponent = custom;\n\n return polyInOut;\n })(exponent);\n\n var pi = Math.PI;\n var halfPi = pi / 2;\n function sinIn(t) {\n return 1 - Math.cos(t * halfPi);\n }\n\n function sinOut(t) {\n return Math.sin(t * halfPi);\n }\n\n function sinInOut(t) {\n return (1 - Math.cos(pi * t)) / 2;\n }\n\n function expIn(t) {\n return Math.pow(2, 10 * t - 10);\n }\n\n function expOut(t) {\n return 1 - Math.pow(2, -10 * t);\n }\n\n function expInOut(t) {\n return ((t *= 2) <= 1 ? Math.pow(2, 10 * t - 10) : 2 - Math.pow(2, 10 - 10 * t)) / 2;\n }\n\n function circleIn(t) {\n return 1 - Math.sqrt(1 - t * t);\n }\n\n function circleOut(t) {\n return Math.sqrt(1 - --t * t);\n }\n\n function circleInOut(t) {\n return ((t *= 2) <= 1 ? 1 - Math.sqrt(1 - t * t) : Math.sqrt(1 - (t -= 2) * t) + 1) / 2;\n }\n\n var b1 = 4 / 11;\n var b2 = 6 / 11;\n var b3 = 8 / 11;\n var b4 = 3 / 4;\n var b5 = 9 / 11;\n var b6 = 10 / 11;\n var b7 = 15 / 16;\n var b8 = 21 / 22;\n var b9 = 63 / 64;\n var b0 = 1 / b1 / b1;\n function bounceIn(t) {\n return 1 - bounceOut(1 - t);\n }\n\n function bounceOut(t) {\n return (t = +t) < b1 ? b0 * t * t : t < b3 ? b0 * (t -= b2) * t + b4 : t < b6 ? b0 * (t -= b5) * t + b7 : b0 * (t -= b8) * t + b9;\n }\n\n function bounceInOut(t) {\n return ((t *= 2) <= 1 ? 1 - bounceOut(1 - t) : bounceOut(t - 1) + 1) / 2;\n }\n\n var overshoot = 1.70158;\n\n var backIn = (function custom(s) {\n s = +s;\n\n function backIn(t) {\n return t * t * ((s + 1) * t - s);\n }\n\n backIn.overshoot = custom;\n\n return backIn;\n })(overshoot);\n\n var backOut = (function custom(s) {\n s = +s;\n\n function backOut(t) {\n return --t * t * ((s + 1) * t + s) + 1;\n }\n\n backOut.overshoot = custom;\n\n return backOut;\n })(overshoot);\n\n var backInOut = (function custom(s) {\n s = +s;\n\n function backInOut(t) {\n return ((t *= 2) < 1 ? t * t * ((s + 1) * t - s) : (t -= 2) * t * ((s + 1) * t + s) + 2) / 2;\n }\n\n backInOut.overshoot = custom;\n\n return backInOut;\n })(overshoot);\n\n var tau = 2 * Math.PI;\n var amplitude = 1;\n var period = 0.3;\n var elasticIn = (function custom(a, p) {\n var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n function elasticIn(t) {\n return a * Math.pow(2, 10 * --t) * Math.sin((s - t) / p);\n }\n\n elasticIn.amplitude = function(a) { return custom(a, p * tau); };\n elasticIn.period = function(p) { return custom(a, p); };\n\n return elasticIn;\n })(amplitude, period);\n\n var elasticOut = (function custom(a, p) {\n var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n function elasticOut(t) {\n return 1 - a * Math.pow(2, -10 * (t = +t)) * Math.sin((t + s) / p);\n }\n\n elasticOut.amplitude = function(a) { return custom(a, p * tau); };\n elasticOut.period = function(p) { return custom(a, p); };\n\n return elasticOut;\n })(amplitude, period);\n\n var elasticInOut = (function custom(a, p) {\n var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n function elasticInOut(t) {\n return ((t = t * 2 - 1) < 0\n ? a * Math.pow(2, 10 * t) * Math.sin((s - t) / p)\n : 2 - a * Math.pow(2, -10 * t) * Math.sin((s + t) / p)) / 2;\n }\n\n elasticInOut.amplitude = function(a) { return custom(a, p * tau); };\n elasticInOut.period = function(p) { return custom(a, p); };\n\n return elasticInOut;\n })(amplitude, period);\n\n function area(polygon) {\n var i = -1,\n n = polygon.length,\n a,\n b = polygon[n - 1],\n area = 0;\n\n while (++i < n) {\n a = b;\n b = polygon[i];\n area += a[1] * b[0] - a[0] * b[1];\n }\n\n return area / 2;\n }\n\n function centroid(polygon) {\n var i = -1,\n n = polygon.length,\n x = 0,\n y = 0,\n a,\n b = polygon[n - 1],\n c,\n k = 0;\n\n while (++i < n) {\n a = b;\n b = polygon[i];\n k += c = a[0] * b[1] - b[0] * a[1];\n x += (a[0] + b[0]) * c;\n y += (a[1] + b[1]) * c;\n }\n\n return k *= 3, [x / k, y / k];\n }\n\n // Returns the 2D cross product of AB and AC vectors, i.e., the z-component of\n // the 3D cross product in a quadrant I Cartesian coordinate system (+x is\n // right, +y is up). Returns a positive value if ABC is counter-clockwise,\n // negative if clockwise, and zero if the points are collinear.\n function cross(a, b, c) {\n return (b[0] - a[0]) * (c[1] - a[1]) - (b[1] - a[1]) * (c[0] - a[0]);\n }\n\n function lexicographicOrder(a, b) {\n return a[0] - b[0] || a[1] - b[1];\n }\n\n // Computes the upper convex hull per the monotone chain algorithm.\n // Assumes points.length >= 3, is sorted by x, unique in y.\n // Returns an array of indices into points in left-to-right order.\n function computeUpperHullIndexes(points) {\n var n = points.length,\n indexes = [0, 1],\n size = 2;\n\n for (var i = 2; i < n; ++i) {\n while (size > 1 && cross(points[indexes[size - 2]], points[indexes[size - 1]], points[i]) <= 0) --size;\n indexes[size++] = i;\n }\n\n return indexes.slice(0, size); // remove popped points\n }\n\n function hull(points) {\n if ((n = points.length) < 3) return null;\n\n var i,\n n,\n sortedPoints = new Array(n),\n flippedPoints = new Array(n);\n\n for (i = 0; i < n; ++i) sortedPoints[i] = [+points[i][0], +points[i][1], i];\n sortedPoints.sort(lexicographicOrder);\n for (i = 0; i < n; ++i) flippedPoints[i] = [sortedPoints[i][0], -sortedPoints[i][1]];\n\n var upperIndexes = computeUpperHullIndexes(sortedPoints),\n lowerIndexes = computeUpperHullIndexes(flippedPoints);\n\n // Construct the hull polygon, removing possible duplicate endpoints.\n var skipLeft = lowerIndexes[0] === upperIndexes[0],\n skipRight = lowerIndexes[lowerIndexes.length - 1] === upperIndexes[upperIndexes.length - 1],\n hull = [];\n\n // Add upper hull in right-to-l order.\n // Then add lower hull in left-to-right order.\n for (i = upperIndexes.length - 1; i >= 0; --i) hull.push(points[sortedPoints[upperIndexes[i]][2]]);\n for (i = +skipLeft; i < lowerIndexes.length - skipRight; ++i) hull.push(points[sortedPoints[lowerIndexes[i]][2]]);\n\n return hull;\n }\n\n function contains(polygon, point) {\n var n = polygon.length,\n p = polygon[n - 1],\n x = point[0], y = point[1],\n x0 = p[0], y0 = p[1],\n x1, y1,\n inside = false;\n\n for (var i = 0; i < n; ++i) {\n p = polygon[i], x1 = p[0], y1 = p[1];\n if (((y1 > y) !== (y0 > y)) && (x < (x0 - x1) * (y - y1) / (y0 - y1) + x1)) inside = !inside;\n x0 = x1, y0 = y1;\n }\n\n return inside;\n }\n\n function length$1(polygon) {\n var i = -1,\n n = polygon.length,\n b = polygon[n - 1],\n xa,\n ya,\n xb = b[0],\n yb = b[1],\n perimeter = 0;\n\n while (++i < n) {\n xa = xb;\n ya = yb;\n b = polygon[i];\n xb = b[0];\n yb = b[1];\n xa -= xb;\n ya -= yb;\n perimeter += Math.sqrt(xa * xa + ya * ya);\n }\n\n return perimeter;\n }\n\nvar pi$1 = Math.PI;\nvar tau$1 = 2 * pi$1;\n var epsilon = 1e-6;\n var tauEpsilon = tau$1 - epsilon;\n function Path() {\n this._x0 = this._y0 = // start of current subpath\n this._x1 = this._y1 = null; // end of current subpath\n this._ = [];\n }\n\n function path() {\n return new Path;\n }\n\n Path.prototype = path.prototype = {\n constructor: Path,\n moveTo: function(x, y) {\n this._.push(\"M\", this._x0 = this._x1 = +x, \",\", this._y0 = this._y1 = +y);\n },\n closePath: function() {\n if (this._x1 !== null) {\n this._x1 = this._x0, this._y1 = this._y0;\n this._.push(\"Z\");\n }\n },\n lineTo: function(x, y) {\n this._.push(\"L\", this._x1 = +x, \",\", this._y1 = +y);\n },\n quadraticCurveTo: function(x1, y1, x, y) {\n this._.push(\"Q\", +x1, \",\", +y1, \",\", this._x1 = +x, \",\", this._y1 = +y);\n },\n bezierCurveTo: function(x1, y1, x2, y2, x, y) {\n this._.push(\"C\", +x1, \",\", +y1, \",\", +x2, \",\", +y2, \",\", this._x1 = +x, \",\", this._y1 = +y);\n },\n arcTo: function(x1, y1, x2, y2, r) {\n x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r;\n var x0 = this._x1,\n y0 = this._y1,\n x21 = x2 - x1,\n y21 = y2 - y1,\n x01 = x0 - x1,\n y01 = y0 - y1,\n l01_2 = x01 * x01 + y01 * y01;\n\n // Is the radius negative? Error.\n if (r < 0) throw new Error(\"negative radius: \" + r);\n\n // Is this path empty? Move to (x1,y1).\n if (this._x1 === null) {\n this._.push(\n \"M\", this._x1 = x1, \",\", this._y1 = y1\n );\n }\n\n // Or, is (x1,y1) coincident with (x0,y0)? Do nothing.\n else if (!(l01_2 > epsilon));\n\n // Or, are (x0,y0), (x1,y1) and (x2,y2) collinear?\n // Equivalently, is (x1,y1) coincident with (x2,y2)?\n // Or, is the radius zero? Line to (x1,y1).\n else if (!(Math.abs(y01 * x21 - y21 * x01) > epsilon) || !r) {\n this._.push(\n \"L\", this._x1 = x1, \",\", this._y1 = y1\n );\n }\n\n // Otherwise, draw an arc!\n else {\n var x20 = x2 - x0,\n y20 = y2 - y0,\n l21_2 = x21 * x21 + y21 * y21,\n l20_2 = x20 * x20 + y20 * y20,\n l21 = Math.sqrt(l21_2),\n l01 = Math.sqrt(l01_2),\n l = r * Math.tan((pi$1 - Math.acos((l21_2 + l01_2 - l20_2) / (2 * l21 * l01))) / 2),\n t01 = l / l01,\n t21 = l / l21;\n\n // If the start tangent is not coincident with (x0,y0), line to.\n if (Math.abs(t01 - 1) > epsilon) {\n this._.push(\n \"L\", x1 + t01 * x01, \",\", y1 + t01 * y01\n );\n }\n\n this._.push(\n \"A\", r, \",\", r, \",0,0,\", +(y01 * x20 > x01 * y20), \",\", this._x1 = x1 + t21 * x21, \",\", this._y1 = y1 + t21 * y21\n );\n }\n },\n arc: function(x, y, r, a0, a1, ccw) {\n x = +x, y = +y, r = +r;\n var dx = r * Math.cos(a0),\n dy = r * Math.sin(a0),\n x0 = x + dx,\n y0 = y + dy,\n cw = 1 ^ ccw,\n da = ccw ? a0 - a1 : a1 - a0;\n\n // Is the radius negative? Error.\n if (r < 0) throw new Error(\"negative radius: \" + r);\n\n // Is this path empty? Move to (x0,y0).\n if (this._x1 === null) {\n this._.push(\n \"M\", x0, \",\", y0\n );\n }\n\n // Or, is (x0,y0) not coincident with the previous point? Line to (x0,y0).\n else if (Math.abs(this._x1 - x0) > epsilon || Math.abs(this._y1 - y0) > epsilon) {\n this._.push(\n \"L\", x0, \",\", y0\n );\n }\n\n // Is this arc empty? We’re done.\n if (!r) return;\n\n // Is this a complete circle? Draw two arcs to complete the circle.\n if (da > tauEpsilon) {\n this._.push(\n \"A\", r, \",\", r, \",0,1,\", cw, \",\", x - dx, \",\", y - dy,\n \"A\", r, \",\", r, \",0,1,\", cw, \",\", this._x1 = x0, \",\", this._y1 = y0\n );\n }\n\n // Otherwise, draw an arc!\n else {\n if (da < 0) da = da % tau$1 + tau$1;\n this._.push(\n \"A\", r, \",\", r, \",0,\", +(da >= pi$1), \",\", cw, \",\", this._x1 = x + r * Math.cos(a1), \",\", this._y1 = y + r * Math.sin(a1)\n );\n }\n },\n rect: function(x, y, w, h) {\n this._.push(\"M\", this._x0 = this._x1 = +x, \",\", this._y0 = this._y1 = +y, \"h\", +w, \"v\", +h, \"h\", -w, \"Z\");\n },\n toString: function() {\n return this._.join(\"\");\n }\n };\n\n function tree_add(d) {\n var x = +this._x.call(null, d),\n y = +this._y.call(null, d);\n return add(this.cover(x, y), x, y, d);\n }\n\n function add(tree, x, y, d) {\n if (isNaN(x) || isNaN(y)) return tree; // ignore invalid points\n\n var parent,\n node = tree._root,\n leaf = {data: d},\n x0 = tree._x0,\n y0 = tree._y0,\n x1 = tree._x1,\n y1 = tree._y1,\n xm,\n ym,\n xp,\n yp,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return tree._root = leaf, tree;\n\n // Find the existing leaf for the new point, or add it.\n while (node.length) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (parent = node, !(node = node[i = bottom << 1 | right])) return parent[i] = leaf, tree;\n }\n\n // Is the new point is exactly coincident with the existing point?\n xp = +tree._x.call(null, node.data);\n yp = +tree._y.call(null, node.data);\n if (x === xp && y === yp) return leaf.next = node, parent ? parent[i] = leaf : tree._root = leaf, tree;\n\n // Otherwise, split the leaf node until the old and new point are separated.\n do {\n parent = parent ? parent[i] = new Array(4) : tree._root = new Array(4);\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n } while ((i = bottom << 1 | right) === (j = (yp >= ym) << 1 | (xp >= xm)));\n return parent[j] = node, parent[i] = leaf, tree;\n }\n\n function addAll(data) {\n var d, i, n = data.length,\n x,\n y,\n xz = new Array(n),\n yz = new Array(n),\n x0 = Infinity,\n y0 = Infinity,\n x1 = -Infinity,\n y1 = -Infinity;\n\n // Compute the points and their extent.\n for (i = 0; i < n; ++i) {\n if (isNaN(x = +this._x.call(null, d = data[i])) || isNaN(y = +this._y.call(null, d))) continue;\n xz[i] = x;\n yz[i] = y;\n if (x < x0) x0 = x;\n if (x > x1) x1 = x;\n if (y < y0) y0 = y;\n if (y > y1) y1 = y;\n }\n\n // If there were no (valid) points, inherit the existing extent.\n if (x1 < x0) x0 = this._x0, x1 = this._x1;\n if (y1 < y0) y0 = this._y0, y1 = this._y1;\n\n // Expand the tree to cover the new points.\n this.cover(x0, y0).cover(x1, y1);\n\n // Add the new points.\n for (i = 0; i < n; ++i) {\n add(this, xz[i], yz[i], data[i]);\n }\n\n return this;\n }\n\n function tree_cover(x, y) {\n if (isNaN(x = +x) || isNaN(y = +y)) return this; // ignore invalid points\n\n var x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1;\n\n // If the quadtree has no extent, initialize them.\n // Integer extent are necessary so that if we later double the extent,\n // the existing quadrant boundaries don’t change due to floating point error!\n if (isNaN(x0)) {\n x1 = (x0 = Math.floor(x)) + 1;\n y1 = (y0 = Math.floor(y)) + 1;\n }\n\n // Otherwise, double repeatedly to cover.\n else if (x0 > x || x > x1 || y0 > y || y > y1) {\n var z = x1 - x0,\n node = this._root,\n parent,\n i;\n\n switch (i = (y < (y0 + y1) / 2) << 1 | (x < (x0 + x1) / 2)) {\n case 0: {\n do parent = new Array(4), parent[i] = node, node = parent;\n while (z *= 2, x1 = x0 + z, y1 = y0 + z, x > x1 || y > y1);\n break;\n }\n case 1: {\n do parent = new Array(4), parent[i] = node, node = parent;\n while (z *= 2, x0 = x1 - z, y1 = y0 + z, x0 > x || y > y1);\n break;\n }\n case 2: {\n do parent = new Array(4), parent[i] = node, node = parent;\n while (z *= 2, x1 = x0 + z, y0 = y1 - z, x > x1 || y0 > y);\n break;\n }\n case 3: {\n do parent = new Array(4), parent[i] = node, node = parent;\n while (z *= 2, x0 = x1 - z, y0 = y1 - z, x0 > x || y0 > y);\n break;\n }\n }\n\n if (this._root && this._root.length) this._root = node;\n }\n\n // If the quadtree covers the point already, just return.\n else return this;\n\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n return this;\n }\n\n function tree_data() {\n var data = [];\n this.visit(function(node) {\n if (!node.length) do data.push(node.data); while (node = node.next)\n });\n return data;\n }\n\n function tree_extent(_) {\n return arguments.length\n ? this.cover(+_[0][0], +_[0][1]).cover(+_[1][0], +_[1][1])\n : isNaN(this._x0) ? undefined : [[this._x0, this._y0], [this._x1, this._y1]];\n }\n\n function Quad(node, x0, y0, x1, y1) {\n this.node = node;\n this.x0 = x0;\n this.y0 = y0;\n this.x1 = x1;\n this.y1 = y1;\n }\n\n function tree_find(x, y, radius) {\n var data,\n x0 = this._x0,\n y0 = this._y0,\n x1,\n y1,\n x2,\n y2,\n x3 = this._x1,\n y3 = this._y1,\n quads = [],\n node = this._root,\n q,\n i;\n\n if (node) quads.push(new Quad(node, x0, y0, x3, y3));\n if (radius == null) radius = Infinity;\n else {\n x0 = x - radius, y0 = y - radius;\n x3 = x + radius, y3 = y + radius;\n radius *= radius;\n }\n\n while (q = quads.pop()) {\n\n // Stop searching if this quadrant can’t contain a closer node.\n if (!(node = q.node)\n || (x1 = q.x0) > x3\n || (y1 = q.y0) > y3\n || (x2 = q.x1) < x0\n || (y2 = q.y1) < y0) continue;\n\n // Bisect the current quadrant.\n if (node.length) {\n var xm = (x1 + x2) / 2,\n ym = (y1 + y2) / 2;\n\n quads.push(\n new Quad(node[3], xm, ym, x2, y2),\n new Quad(node[2], x1, ym, xm, y2),\n new Quad(node[1], xm, y1, x2, ym),\n new Quad(node[0], x1, y1, xm, ym)\n );\n\n // Visit the closest quadrant first.\n if (i = (y >= ym) << 1 | (x >= xm)) {\n q = quads[quads.length - 1];\n quads[quads.length - 1] = quads[quads.length - 1 - i];\n quads[quads.length - 1 - i] = q;\n }\n }\n\n // Visit this point. (Visiting coincident points isn’t necessary!)\n else {\n var dx = x - +this._x.call(null, node.data),\n dy = y - +this._y.call(null, node.data),\n d2 = dx * dx + dy * dy;\n if (d2 < radius) {\n var d = Math.sqrt(radius = d2);\n x0 = x - d, y0 = y - d;\n x3 = x + d, y3 = y + d;\n data = node.data;\n }\n }\n }\n\n return data;\n }\n\n function tree_remove(d) {\n if (isNaN(x = +this._x.call(null, d)) || isNaN(y = +this._y.call(null, d))) return this; // ignore invalid points\n\n var parent,\n node = this._root,\n retainer,\n previous,\n next,\n x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1,\n x,\n y,\n xm,\n ym,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return this;\n\n // Find the leaf node for the point.\n // While descending, also retain the deepest parent with a non-removed sibling.\n if (node.length) while (true) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (!(parent = node, node = node[i = bottom << 1 | right])) return this;\n if (!node.length) break;\n if (parent[(i + 1) & 3] || parent[(i + 2) & 3] || parent[(i + 3) & 3]) retainer = parent, j = i;\n }\n\n // Find the point to remove.\n while (node.data !== d) if (!(previous = node, node = node.next)) return this;\n if (next = node.next) delete node.next;\n\n // If there are multiple coincident points, remove just the point.\n if (previous) return (next ? previous.next = next : delete previous.next), this;\n\n // If this is the root point, remove it.\n if (!parent) return this._root = next, this;\n\n // Remove this leaf.\n next ? parent[i] = next : delete parent[i];\n\n // If the parent now contains exactly one leaf, collapse superfluous parents.\n if ((node = parent[0] || parent[1] || parent[2] || parent[3])\n && node === (parent[3] || parent[2] || parent[1] || parent[0])\n && !node.length) {\n if (retainer) retainer[j] = node;\n else this._root = node;\n }\n\n return this;\n }\n\n function removeAll(data) {\n for (var i = 0, n = data.length; i < n; ++i) this.remove(data[i]);\n return this;\n }\n\n function tree_root() {\n return this._root;\n }\n\n function tree_size() {\n var size = 0;\n this.visit(function(node) {\n if (!node.length) do ++size; while (node = node.next)\n });\n return size;\n }\n\n function tree_visit(callback) {\n var quads = [], q, node = this._root, child, x0, y0, x1, y1;\n if (node) quads.push(new Quad(node, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n if (!callback(node = q.node, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1) && node.length) {\n var xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n }\n }\n return this;\n }\n\n function tree_visitAfter(callback) {\n var quads = [], next = [], q;\n if (this._root) quads.push(new Quad(this._root, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n var node = q.node;\n if (node.length) {\n var child, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1, xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n }\n next.push(q);\n }\n while (q = next.pop()) {\n callback(q.node, q.x0, q.y0, q.x1, q.y1);\n }\n return this;\n }\n\n function defaultX(d) {\n return d[0];\n }\n\n function tree_x(_) {\n return arguments.length ? (this._x = _, this) : this._x;\n }\n\n function defaultY(d) {\n return d[1];\n }\n\n function tree_y(_) {\n return arguments.length ? (this._y = _, this) : this._y;\n }\n\n function quadtree(nodes, x, y) {\n var tree = new Quadtree(x == null ? defaultX : x, y == null ? defaultY : y, NaN, NaN, NaN, NaN);\n return nodes == null ? tree : tree.addAll(nodes);\n }\n\n function Quadtree(x, y, x0, y0, x1, y1) {\n this._x = x;\n this._y = y;\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n this._root = undefined;\n }\n\n function leaf_copy(leaf) {\n var copy = {data: leaf.data}, next = copy;\n while (leaf = leaf.next) next = next.next = {data: leaf.data};\n return copy;\n }\n\n var treeProto = quadtree.prototype = Quadtree.prototype;\n\n treeProto.copy = function() {\n var copy = new Quadtree(this._x, this._y, this._x0, this._y0, this._x1, this._y1),\n node = this._root,\n nodes,\n child;\n\n if (!node) return copy;\n\n if (!node.length) return copy._root = leaf_copy(node), copy;\n\n nodes = [{source: node, target: copy._root = new Array(4)}];\n while (node = nodes.pop()) {\n for (var i = 0; i < 4; ++i) {\n if (child = node.source[i]) {\n if (child.length) nodes.push({source: child, target: node.target[i] = new Array(4)});\n else node.target[i] = leaf_copy(child);\n }\n }\n }\n\n return copy;\n };\n\n treeProto.add = tree_add;\n treeProto.addAll = addAll;\n treeProto.cover = tree_cover;\n treeProto.data = tree_data;\n treeProto.extent = tree_extent;\n treeProto.find = tree_find;\n treeProto.remove = tree_remove;\n treeProto.removeAll = removeAll;\n treeProto.root = tree_root;\n treeProto.size = tree_size;\n treeProto.visit = tree_visit;\n treeProto.visitAfter = tree_visitAfter;\n treeProto.x = tree_x;\n treeProto.y = tree_y;\n\n var slice$1 = [].slice;\n\n var noabort = {};\n\n function Queue(size) {\n if (!(size >= 1)) throw new Error;\n this._size = size;\n this._call =\n this._error = null;\n this._tasks = [];\n this._data = [];\n this._waiting =\n this._active =\n this._ended =\n this._start = 0; // inside a synchronous task callback?\n }\n\n Queue.prototype = queue.prototype = {\n constructor: Queue,\n defer: function(callback) {\n if (typeof callback !== \"function\" || this._call) throw new Error;\n if (this._error != null) return this;\n var t = slice$1.call(arguments, 1);\n t.push(callback);\n ++this._waiting, this._tasks.push(t);\n poke(this);\n return this;\n },\n abort: function() {\n if (this._error == null) abort(this, new Error(\"abort\"));\n return this;\n },\n await: function(callback) {\n if (typeof callback !== \"function\" || this._call) throw new Error;\n this._call = function(error, results) { callback.apply(null, [error].concat(results)); };\n maybeNotify(this);\n return this;\n },\n awaitAll: function(callback) {\n if (typeof callback !== \"function\" || this._call) throw new Error;\n this._call = callback;\n maybeNotify(this);\n return this;\n }\n };\n\n function poke(q) {\n if (!q._start) try { start(q); } // let the current task complete\n catch (e) { if (q._tasks[q._ended + q._active - 1]) abort(q, e); } // task errored synchronously\n }\n\n function start(q) {\n while (q._start = q._waiting && q._active < q._size) {\n var i = q._ended + q._active,\n t = q._tasks[i],\n j = t.length - 1,\n c = t[j];\n t[j] = end(q, i);\n --q._waiting, ++q._active;\n t = c.apply(null, t);\n if (!q._tasks[i]) continue; // task finished synchronously\n q._tasks[i] = t || noabort;\n }\n }\n\n function end(q, i) {\n return function(e, r) {\n if (!q._tasks[i]) return; // ignore multiple callbacks\n --q._active, ++q._ended;\n q._tasks[i] = null;\n if (q._error != null) return; // ignore secondary errors\n if (e != null) {\n abort(q, e);\n } else {\n q._data[i] = r;\n if (q._waiting) poke(q);\n else maybeNotify(q);\n }\n };\n }\n\n function abort(q, e) {\n var i = q._tasks.length, t;\n q._error = e; // ignore active callbacks\n q._data = undefined; // allow gc\n q._waiting = NaN; // prevent starting\n\n while (--i >= 0) {\n if (t = q._tasks[i]) {\n q._tasks[i] = null;\n if (t.abort) try { t.abort(); }\n catch (e) { /* ignore */ }\n }\n }\n\n q._active = NaN; // allow notification\n maybeNotify(q);\n }\n\n function maybeNotify(q) {\n if (!q._active && q._call) q._call(q._error, q._data);\n }\n\n function queue(concurrency) {\n return new Queue(arguments.length ? +concurrency : Infinity);\n }\n\n function constant$1(x) {\n return function constant() {\n return x;\n };\n }\n\n var epsilon$1 = 1e-12;\n var pi$2 = Math.PI;\n var halfPi$1 = pi$2 / 2;\n var tau$2 = 2 * pi$2;\n\n function arcInnerRadius(d) {\n return d.innerRadius;\n }\n\n function arcOuterRadius(d) {\n return d.outerRadius;\n }\n\n function arcStartAngle(d) {\n return d.startAngle;\n }\n\n function arcEndAngle(d) {\n return d.endAngle;\n }\n\n function arcPadAngle(d) {\n return d && d.padAngle; // Note: optional!\n }\n\n function asin(x) {\n return x >= 1 ? halfPi$1 : x <= -1 ? -halfPi$1 : Math.asin(x);\n }\n\n function intersect(x0, y0, x1, y1, x2, y2, x3, y3) {\n var x10 = x1 - x0, y10 = y1 - y0,\n x32 = x3 - x2, y32 = y3 - y2,\n t = (x32 * (y0 - y2) - y32 * (x0 - x2)) / (y32 * x10 - x32 * y10);\n return [x0 + t * x10, y0 + t * y10];\n }\n\n // Compute perpendicular offset line of length rc.\n // http://mathworld.wolfram.com/Circle-LineIntersection.html\n function cornerTangents(x0, y0, x1, y1, r1, rc, cw) {\n var x01 = x0 - x1,\n y01 = y0 - y1,\n lo = (cw ? rc : -rc) / Math.sqrt(x01 * x01 + y01 * y01),\n ox = lo * y01,\n oy = -lo * x01,\n x11 = x0 + ox,\n y11 = y0 + oy,\n x10 = x1 + ox,\n y10 = y1 + oy,\n x00 = (x11 + x10) / 2,\n y00 = (y11 + y10) / 2,\n dx = x10 - x11,\n dy = y10 - y11,\n d2 = dx * dx + dy * dy,\n r = r1 - rc,\n D = x11 * y10 - x10 * y11,\n d = (dy < 0 ? -1 : 1) * Math.sqrt(Math.max(0, r * r * d2 - D * D)),\n cx0 = (D * dy - dx * d) / d2,\n cy0 = (-D * dx - dy * d) / d2,\n cx1 = (D * dy + dx * d) / d2,\n cy1 = (-D * dx + dy * d) / d2,\n dx0 = cx0 - x00,\n dy0 = cy0 - y00,\n dx1 = cx1 - x00,\n dy1 = cy1 - y00;\n\n // Pick the closer of the two intersection points.\n // TODO Is there a faster way to determine which intersection to use?\n if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1) cx0 = cx1, cy0 = cy1;\n\n return {\n cx: cx0,\n cy: cy0,\n x01: -ox,\n y01: -oy,\n x11: cx0 * (r1 / r - 1),\n y11: cy0 * (r1 / r - 1)\n };\n }\n\n function arc() {\n var innerRadius = arcInnerRadius,\n outerRadius = arcOuterRadius,\n cornerRadius = constant$1(0),\n padRadius = null,\n startAngle = arcStartAngle,\n endAngle = arcEndAngle,\n padAngle = arcPadAngle,\n context = null;\n\n function arc() {\n var buffer,\n r,\n r0 = +innerRadius.apply(this, arguments),\n r1 = +outerRadius.apply(this, arguments),\n a0 = startAngle.apply(this, arguments) - halfPi$1,\n a1 = endAngle.apply(this, arguments) - halfPi$1,\n da = Math.abs(a1 - a0),\n cw = a1 > a0;\n\n if (!context) context = buffer = path();\n\n // Ensure that the outer radius is always larger than the inner radius.\n if (r1 < r0) r = r1, r1 = r0, r0 = r;\n\n // Is it a point?\n if (!(r1 > epsilon$1)) context.moveTo(0, 0);\n\n // Or is it a circle or annulus?\n else if (da > tau$2 - epsilon$1) {\n context.moveTo(r1 * Math.cos(a0), r1 * Math.sin(a0));\n context.arc(0, 0, r1, a0, a1, !cw);\n if (r0 > epsilon$1) {\n context.moveTo(r0 * Math.cos(a1), r0 * Math.sin(a1));\n context.arc(0, 0, r0, a1, a0, cw);\n }\n }\n\n // Or is it a circular or annular sector?\n else {\n var a01 = a0,\n a11 = a1,\n a00 = a0,\n a10 = a1,\n da0 = da,\n da1 = da,\n ap = padAngle.apply(this, arguments) / 2,\n rp = (ap > epsilon$1) && (padRadius ? +padRadius.apply(this, arguments) : Math.sqrt(r0 * r0 + r1 * r1)),\n rc = Math.min(Math.abs(r1 - r0) / 2, +cornerRadius.apply(this, arguments)),\n rc0 = rc,\n rc1 = rc,\n t0,\n t1;\n\n // Apply padding? Note that since r1 ≥ r0, da1 ≥ da0.\n if (rp > epsilon$1) {\n var p0 = asin(rp / r0 * Math.sin(ap)),\n p1 = asin(rp / r1 * Math.sin(ap));\n if ((da0 -= p0 * 2) > epsilon$1) p0 *= (cw ? 1 : -1), a00 += p0, a10 -= p0;\n else da0 = 0, a00 = a10 = (a0 + a1) / 2;\n if ((da1 -= p1 * 2) > epsilon$1) p1 *= (cw ? 1 : -1), a01 += p1, a11 -= p1;\n else da1 = 0, a01 = a11 = (a0 + a1) / 2;\n }\n\n var x01 = r1 * Math.cos(a01),\n y01 = r1 * Math.sin(a01),\n x10 = r0 * Math.cos(a10),\n y10 = r0 * Math.sin(a10);\n\n // Apply rounded corners?\n if (rc > epsilon$1) {\n var x11 = r1 * Math.cos(a11),\n y11 = r1 * Math.sin(a11),\n x00 = r0 * Math.cos(a00),\n y00 = r0 * Math.sin(a00);\n\n // Restrict the corner radius according to the sector angle.\n if (da < pi$2) {\n var oc = da0 > epsilon$1 ? intersect(x01, y01, x00, y00, x11, y11, x10, y10) : [x10, y10],\n ax = x01 - oc[0],\n ay = y01 - oc[1],\n bx = x11 - oc[0],\n by = y11 - oc[1],\n kc = 1 / Math.sin(Math.acos((ax * bx + ay * by) / (Math.sqrt(ax * ax + ay * ay) * Math.sqrt(bx * bx + by * by))) / 2),\n lc = Math.sqrt(oc[0] * oc[0] + oc[1] * oc[1]);\n rc0 = Math.min(rc, (r0 - lc) / (kc - 1));\n rc1 = Math.min(rc, (r1 - lc) / (kc + 1));\n }\n }\n\n // Is the sector collapsed to a line?\n if (!(da1 > epsilon$1)) context.moveTo(x01, y01);\n\n // Does the sector’s outer ring have rounded corners?\n else if (rc1 > epsilon$1) {\n t0 = cornerTangents(x00, y00, x01, y01, r1, rc1, cw);\n t1 = cornerTangents(x11, y11, x10, y10, r1, rc1, cw);\n\n context.moveTo(t0.cx + t0.x01, t0.cy + t0.y01);\n\n // Have the corners merged?\n if (rc1 < rc) context.arc(t0.cx, t0.cy, rc1, Math.atan2(t0.y01, t0.x01), Math.atan2(t1.y01, t1.x01), !cw);\n\n // Otherwise, draw the two corners and the ring.\n else {\n context.arc(t0.cx, t0.cy, rc1, Math.atan2(t0.y01, t0.x01), Math.atan2(t0.y11, t0.x11), !cw);\n context.arc(0, 0, r1, Math.atan2(t0.cy + t0.y11, t0.cx + t0.x11), Math.atan2(t1.cy + t1.y11, t1.cx + t1.x11), !cw);\n context.arc(t1.cx, t1.cy, rc1, Math.atan2(t1.y11, t1.x11), Math.atan2(t1.y01, t1.x01), !cw);\n }\n }\n\n // Or is the outer ring just a circular arc?\n else context.moveTo(x01, y01), context.arc(0, 0, r1, a01, a11, !cw);\n\n // Is there no inner ring, and it’s a circular sector?\n // Or perhaps it’s an annular sector collapsed due to padding?\n if (!(r0 > epsilon$1) || !(da0 > epsilon$1)) context.lineTo(x10, y10);\n\n // Does the sector’s inner ring (or point) have rounded corners?\n else if (rc0 > epsilon$1) {\n t0 = cornerTangents(x10, y10, x11, y11, r0, -rc0, cw);\n t1 = cornerTangents(x01, y01, x00, y00, r0, -rc0, cw);\n\n context.lineTo(t0.cx + t0.x01, t0.cy + t0.y01);\n\n // Have the corners merged?\n if (rc0 < rc) context.arc(t0.cx, t0.cy, rc0, Math.atan2(t0.y01, t0.x01), Math.atan2(t1.y01, t1.x01), !cw);\n\n // Otherwise, draw the two corners and the ring.\n else {\n context.arc(t0.cx, t0.cy, rc0, Math.atan2(t0.y01, t0.x01), Math.atan2(t0.y11, t0.x11), !cw);\n context.arc(0, 0, r0, Math.atan2(t0.cy + t0.y11, t0.cx + t0.x11), Math.atan2(t1.cy + t1.y11, t1.cx + t1.x11), cw);\n context.arc(t1.cx, t1.cy, rc0, Math.atan2(t1.y11, t1.x11), Math.atan2(t1.y01, t1.x01), !cw);\n }\n }\n\n // Or is the inner ring just a circular arc?\n else context.arc(0, 0, r0, a10, a00, cw);\n }\n\n context.closePath();\n\n if (buffer) return context = null, buffer + \"\" || null;\n }\n\n arc.centroid = function() {\n var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2,\n a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - pi$2 / 2;\n return [Math.cos(a) * r, Math.sin(a) * r];\n };\n\n arc.innerRadius = function(_) {\n return arguments.length ? (innerRadius = typeof _ === \"function\" ? _ : constant$1(+_), arc) : innerRadius;\n };\n\n arc.outerRadius = function(_) {\n return arguments.length ? (outerRadius = typeof _ === \"function\" ? _ : constant$1(+_), arc) : outerRadius;\n };\n\n arc.cornerRadius = function(_) {\n return arguments.length ? (cornerRadius = typeof _ === \"function\" ? _ : constant$1(+_), arc) : cornerRadius;\n };\n\n arc.padRadius = function(_) {\n return arguments.length ? (padRadius = _ == null ? null : typeof _ === \"function\" ? _ : constant$1(+_), arc) : padRadius;\n };\n\n arc.startAngle = function(_) {\n return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant$1(+_), arc) : startAngle;\n };\n\n arc.endAngle = function(_) {\n return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant$1(+_), arc) : endAngle;\n };\n\n arc.padAngle = function(_) {\n return arguments.length ? (padAngle = typeof _ === \"function\" ? _ : constant$1(+_), arc) : padAngle;\n };\n\n arc.context = function(_) {\n return arguments.length ? ((context = _ == null ? null : _), arc) : context;\n };\n\n return arc;\n }\n\n function Linear(context) {\n this._context = context;\n }\n\n Linear.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; // proceed\n default: this._context.lineTo(x, y); break;\n }\n }\n };\n\n function curveLinear(context) {\n return new Linear(context);\n }\n\n function x(p) {\n return p[0];\n }\n\n function y(p) {\n return p[1];\n }\n\n function line() {\n var x$$ = x,\n y$$ = y,\n defined = constant$1(true),\n context = null,\n curve = curveLinear,\n output = null;\n\n function line(data) {\n var i,\n n = data.length,\n d,\n defined0 = false,\n buffer;\n\n if (context == null) output = curve(buffer = path());\n\n for (i = 0; i <= n; ++i) {\n if (!(i < n && defined(d = data[i], i, data)) === defined0) {\n if (defined0 = !defined0) output.lineStart();\n else output.lineEnd();\n }\n if (defined0) output.point(+x$$(d, i, data), +y$$(d, i, data));\n }\n\n if (buffer) return output = null, buffer + \"\" || null;\n }\n\n line.x = function(_) {\n return arguments.length ? (x$$ = typeof _ === \"function\" ? _ : constant$1(+_), line) : x$$;\n };\n\n line.y = function(_) {\n return arguments.length ? (y$$ = typeof _ === \"function\" ? _ : constant$1(+_), line) : y$$;\n };\n\n line.defined = function(_) {\n return arguments.length ? (defined = typeof _ === \"function\" ? _ : constant$1(!!_), line) : defined;\n };\n\n line.curve = function(_) {\n return arguments.length ? (curve = _, context != null && (output = curve(context)), line) : curve;\n };\n\n line.context = function(_) {\n return arguments.length ? (_ == null ? context = output = null : output = curve(context = _), line) : context;\n };\n\n return line;\n }\n\n function area$1() {\n var x0 = x,\n x1 = null,\n y0 = constant$1(0),\n y1 = y,\n defined = constant$1(true),\n context = null,\n curve = curveLinear,\n output = null;\n\n function area(data) {\n var i,\n j,\n k,\n n = data.length,\n d,\n defined0 = false,\n buffer,\n x0z = new Array(n),\n y0z = new Array(n);\n\n if (context == null) output = curve(buffer = path());\n\n for (i = 0; i <= n; ++i) {\n if (!(i < n && defined(d = data[i], i, data)) === defined0) {\n if (defined0 = !defined0) {\n j = i;\n output.areaStart();\n output.lineStart();\n } else {\n output.lineEnd();\n output.lineStart();\n for (k = i - 1; k >= j; --k) {\n output.point(x0z[k], y0z[k]);\n }\n output.lineEnd();\n output.areaEnd();\n }\n }\n if (defined0) {\n x0z[i] = +x0(d, i, data), y0z[i] = +y0(d, i, data);\n output.point(x1 ? +x1(d, i, data) : x0z[i], y1 ? +y1(d, i, data) : y0z[i]);\n }\n }\n\n if (buffer) return output = null, buffer + \"\" || null;\n }\n\n function arealine() {\n return line().defined(defined).curve(curve).context(context);\n }\n\n area.x = function(_) {\n return arguments.length ? (x0 = typeof _ === \"function\" ? _ : constant$1(+_), x1 = null, area) : x0;\n };\n\n area.x0 = function(_) {\n return arguments.length ? (x0 = typeof _ === \"function\" ? _ : constant$1(+_), area) : x0;\n };\n\n area.x1 = function(_) {\n return arguments.length ? (x1 = _ == null ? null : typeof _ === \"function\" ? _ : constant$1(+_), area) : x1;\n };\n\n area.y = function(_) {\n return arguments.length ? (y0 = typeof _ === \"function\" ? _ : constant$1(+_), y1 = null, area) : y0;\n };\n\n area.y0 = function(_) {\n return arguments.length ? (y0 = typeof _ === \"function\" ? _ : constant$1(+_), area) : y0;\n };\n\n area.y1 = function(_) {\n return arguments.length ? (y1 = _ == null ? null : typeof _ === \"function\" ? _ : constant$1(+_), area) : y1;\n };\n\n area.lineX0 =\n area.lineY0 = function() {\n return arealine().x(x0).y(y0);\n };\n\n area.lineY1 = function() {\n return arealine().x(x0).y(y1);\n };\n\n area.lineX1 = function() {\n return arealine().x(x1).y(y0);\n };\n\n area.defined = function(_) {\n return arguments.length ? (defined = typeof _ === \"function\" ? _ : constant$1(!!_), area) : defined;\n };\n\n area.curve = function(_) {\n return arguments.length ? (curve = _, context != null && (output = curve(context)), area) : curve;\n };\n\n area.context = function(_) {\n return arguments.length ? (_ == null ? context = output = null : output = curve(context = _), area) : context;\n };\n\n return area;\n }\n\n function descending$1(a, b) {\n return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;\n }\n\n function identity$1(d) {\n return d;\n }\n\n function pie() {\n var value = identity$1,\n sortValues = descending$1,\n sort = null,\n startAngle = constant$1(0),\n endAngle = constant$1(tau$2),\n padAngle = constant$1(0);\n\n function pie(data) {\n var i,\n n = data.length,\n j,\n k,\n sum = 0,\n index = new Array(n),\n arcs = new Array(n),\n a0 = +startAngle.apply(this, arguments),\n da = Math.min(tau$2, Math.max(-tau$2, endAngle.apply(this, arguments) - a0)),\n a1,\n p = Math.min(Math.abs(da) / n, padAngle.apply(this, arguments)),\n pa = p * (da < 0 ? -1 : 1),\n v;\n\n for (i = 0; i < n; ++i) {\n if ((v = arcs[index[i] = i] = +value(data[i], i, data)) > 0) {\n sum += v;\n }\n }\n\n // Optionally sort the arcs by previously-computed values or by data.\n if (sortValues != null) index.sort(function(i, j) { return sortValues(arcs[i], arcs[j]); });\n else if (sort != null) index.sort(function(i, j) { return sort(data[i], data[j]); });\n\n // Compute the arcs! They are stored in the original data's order.\n for (i = 0, k = sum ? (da - n * pa) / sum : 0; i < n; ++i, a0 = a1) {\n j = index[i], v = arcs[j], a1 = a0 + (v > 0 ? v * k : 0) + pa, arcs[j] = {\n data: data[j],\n index: i,\n value: v,\n startAngle: a0,\n endAngle: a1,\n padAngle: p\n };\n }\n\n return arcs;\n }\n\n pie.value = function(_) {\n return arguments.length ? (value = typeof _ === \"function\" ? _ : constant$1(+_), pie) : value;\n };\n\n pie.sortValues = function(_) {\n return arguments.length ? (sortValues = _, sort = null, pie) : sortValues;\n };\n\n pie.sort = function(_) {\n return arguments.length ? (sort = _, sortValues = null, pie) : sort;\n };\n\n pie.startAngle = function(_) {\n return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant$1(+_), pie) : startAngle;\n };\n\n pie.endAngle = function(_) {\n return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant$1(+_), pie) : endAngle;\n };\n\n pie.padAngle = function(_) {\n return arguments.length ? (padAngle = typeof _ === \"function\" ? _ : constant$1(+_), pie) : padAngle;\n };\n\n return pie;\n }\n\n var curveRadialLinear = curveRadial(curveLinear);\n\n function Radial(curve) {\n this._curve = curve;\n }\n\n Radial.prototype = {\n areaStart: function() {\n this._curve.areaStart();\n },\n areaEnd: function() {\n this._curve.areaEnd();\n },\n lineStart: function() {\n this._curve.lineStart();\n },\n lineEnd: function() {\n this._curve.lineEnd();\n },\n point: function(a, r) {\n this._curve.point(r * Math.sin(a), r * -Math.cos(a));\n }\n };\n\n function curveRadial(curve) {\n\n function radial(context) {\n return new Radial(curve(context));\n }\n\n radial._curve = curve;\n\n return radial;\n }\n\n function radialLine(l) {\n var c = l.curve;\n\n l.angle = l.x, delete l.x;\n l.radius = l.y, delete l.y;\n\n l.curve = function(_) {\n return arguments.length ? c(curveRadial(_)) : c()._curve;\n };\n\n return l;\n }\n\n function radialLine$1() {\n return radialLine(line().curve(curveRadialLinear));\n }\n\n function radialArea() {\n var a = area$1().curve(curveRadialLinear),\n c = a.curve,\n x0 = a.lineX0,\n x1 = a.lineX1,\n y0 = a.lineY0,\n y1 = a.lineY1;\n\n a.angle = a.x, delete a.x;\n a.startAngle = a.x0, delete a.x0;\n a.endAngle = a.x1, delete a.x1;\n a.radius = a.y, delete a.y;\n a.innerRadius = a.y0, delete a.y0;\n a.outerRadius = a.y1, delete a.y1;\n a.lineStartAngle = function() { return radialLine(x0()); }, delete a.lineX0;\n a.lineEndAngle = function() { return radialLine(x1()); }, delete a.lineX1;\n a.lineInnerRadius = function() { return radialLine(y0()); }, delete a.lineY0;\n a.lineOuterRadius = function() { return radialLine(y1()); }, delete a.lineY1;\n\n a.curve = function(_) {\n return arguments.length ? c(curveRadial(_)) : c()._curve;\n };\n\n return a;\n }\n\n var circle = {\n draw: function(context, size) {\n var r = Math.sqrt(size / pi$2);\n context.moveTo(r, 0);\n context.arc(0, 0, r, 0, tau$2);\n }\n };\n\n var cross$1 = {\n draw: function(context, size) {\n var r = Math.sqrt(size / 5) / 2;\n context.moveTo(-3 * r, -r);\n context.lineTo(-r, -r);\n context.lineTo(-r, -3 * r);\n context.lineTo(r, -3 * r);\n context.lineTo(r, -r);\n context.lineTo(3 * r, -r);\n context.lineTo(3 * r, r);\n context.lineTo(r, r);\n context.lineTo(r, 3 * r);\n context.lineTo(-r, 3 * r);\n context.lineTo(-r, r);\n context.lineTo(-3 * r, r);\n context.closePath();\n }\n };\n\n var tan30 = Math.sqrt(1 / 3);\n var tan30_2 = tan30 * 2;\n var diamond = {\n draw: function(context, size) {\n var y = Math.sqrt(size / tan30_2),\n x = y * tan30;\n context.moveTo(0, -y);\n context.lineTo(x, 0);\n context.lineTo(0, y);\n context.lineTo(-x, 0);\n context.closePath();\n }\n };\n\n var ka = 0.89081309152928522810;\n var kr = Math.sin(pi$2 / 10) / Math.sin(7 * pi$2 / 10);\n var kx = Math.sin(tau$2 / 10) * kr;\n var ky = -Math.cos(tau$2 / 10) * kr;\n var star = {\n draw: function(context, size) {\n var r = Math.sqrt(size * ka),\n x = kx * r,\n y = ky * r;\n context.moveTo(0, -r);\n context.lineTo(x, y);\n for (var i = 1; i < 5; ++i) {\n var a = tau$2 * i / 5,\n c = Math.cos(a),\n s = Math.sin(a);\n context.lineTo(s * r, -c * r);\n context.lineTo(c * x - s * y, s * x + c * y);\n }\n context.closePath();\n }\n };\n\n var square = {\n draw: function(context, size) {\n var w = Math.sqrt(size),\n x = -w / 2;\n context.rect(x, x, w, w);\n }\n };\n\n var sqrt3 = Math.sqrt(3);\n\n var triangle = {\n draw: function(context, size) {\n var y = -Math.sqrt(size / (sqrt3 * 3));\n context.moveTo(0, y * 2);\n context.lineTo(-sqrt3 * y, -y);\n context.lineTo(sqrt3 * y, -y);\n context.closePath();\n }\n };\n\n var c = -0.5;\n var s = Math.sqrt(3) / 2;\n var k = 1 / Math.sqrt(12);\n var a = (k / 2 + 1) * 3;\n var wye = {\n draw: function(context, size) {\n var r = Math.sqrt(size / a),\n x0 = r / 2,\n y0 = r * k,\n x1 = x0,\n y1 = r * k + r,\n x2 = -x1,\n y2 = y1;\n context.moveTo(x0, y0);\n context.lineTo(x1, y1);\n context.lineTo(x2, y2);\n context.lineTo(c * x0 - s * y0, s * x0 + c * y0);\n context.lineTo(c * x1 - s * y1, s * x1 + c * y1);\n context.lineTo(c * x2 - s * y2, s * x2 + c * y2);\n context.lineTo(c * x0 + s * y0, c * y0 - s * x0);\n context.lineTo(c * x1 + s * y1, c * y1 - s * x1);\n context.lineTo(c * x2 + s * y2, c * y2 - s * x2);\n context.closePath();\n }\n };\n\n var symbols = [\n circle,\n cross$1,\n diamond,\n square,\n star,\n triangle,\n wye\n ];\n\n function symbol() {\n var type = constant$1(circle),\n size = constant$1(64),\n context = null;\n\n function symbol() {\n var buffer;\n if (!context) context = buffer = path();\n type.apply(this, arguments).draw(context, +size.apply(this, arguments));\n if (buffer) return context = null, buffer + \"\" || null;\n }\n\n symbol.type = function(_) {\n return arguments.length ? (type = typeof _ === \"function\" ? _ : constant$1(_), symbol) : type;\n };\n\n symbol.size = function(_) {\n return arguments.length ? (size = typeof _ === \"function\" ? _ : constant$1(+_), symbol) : size;\n };\n\n symbol.context = function(_) {\n return arguments.length ? (context = _ == null ? null : _, symbol) : context;\n };\n\n return symbol;\n }\n\n function noop() {}\n\n function point(that, x, y) {\n that._context.bezierCurveTo(\n (2 * that._x0 + that._x1) / 3,\n (2 * that._y0 + that._y1) / 3,\n (that._x0 + 2 * that._x1) / 3,\n (that._y0 + 2 * that._y1) / 3,\n (that._x0 + 4 * that._x1 + x) / 6,\n (that._y0 + 4 * that._y1 + y) / 6\n );\n }\n\n function Basis(context) {\n this._context = context;\n }\n\n Basis.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 3: point(this, this._x1, this._y1); // proceed\n case 2: this._context.lineTo(this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._context.lineTo((5 * this._x0 + this._x1) / 6, (5 * this._y0 + this._y1) / 6); // proceed\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n };\n\n function basis(context) {\n return new Basis(context);\n }\n\n function BasisClosed(context) {\n this._context = context;\n }\n\n BasisClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x2, this._y2);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.moveTo((this._x2 + 2 * this._x3) / 3, (this._y2 + 2 * this._y3) / 3);\n this._context.lineTo((this._x3 + 2 * this._x2) / 3, (this._y3 + 2 * this._y2) / 3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x2, this._y2);\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x2 = x, this._y2 = y; break;\n case 1: this._point = 2; this._x3 = x, this._y3 = y; break;\n case 2: this._point = 3; this._x4 = x, this._y4 = y; this._context.moveTo((this._x0 + 4 * this._x1 + x) / 6, (this._y0 + 4 * this._y1 + y) / 6); break;\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n };\n\n function basisClosed(context) {\n return new BasisClosed(context);\n }\n\n function BasisOpen(context) {\n this._context = context;\n }\n\n BasisOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; var x0 = (this._x0 + 4 * this._x1 + x) / 6, y0 = (this._y0 + 4 * this._y1 + y) / 6; this._line ? this._context.lineTo(x0, y0) : this._context.moveTo(x0, y0); break;\n case 3: this._point = 4; // proceed\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n };\n\n function basisOpen(context) {\n return new BasisOpen(context);\n }\n\n function Bundle(context, beta) {\n this._basis = new Basis(context);\n this._beta = beta;\n }\n\n Bundle.prototype = {\n lineStart: function() {\n this._x = [];\n this._y = [];\n this._basis.lineStart();\n },\n lineEnd: function() {\n var x = this._x,\n y = this._y,\n j = x.length - 1;\n\n if (j > 0) {\n var x0 = x[0],\n y0 = y[0],\n dx = x[j] - x0,\n dy = y[j] - y0,\n i = -1,\n t;\n\n while (++i <= j) {\n t = i / j;\n this._basis.point(\n this._beta * x[i] + (1 - this._beta) * (x0 + t * dx),\n this._beta * y[i] + (1 - this._beta) * (y0 + t * dy)\n );\n }\n }\n\n this._x = this._y = null;\n this._basis.lineEnd();\n },\n point: function(x, y) {\n this._x.push(+x);\n this._y.push(+y);\n }\n };\n\n var bundle = (function custom(beta) {\n\n function bundle(context) {\n return beta === 1 ? new Basis(context) : new Bundle(context, beta);\n }\n\n bundle.beta = function(beta) {\n return custom(+beta);\n };\n\n return bundle;\n })(0.85);\n\n function point$1(that, x, y) {\n that._context.bezierCurveTo(\n that._x1 + that._k * (that._x2 - that._x0),\n that._y1 + that._k * (that._y2 - that._y0),\n that._x2 + that._k * (that._x1 - x),\n that._y2 + that._k * (that._y1 - y),\n that._x2,\n that._y2\n );\n }\n\n function Cardinal(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n }\n\n Cardinal.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: point$1(this, this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; this._x1 = x, this._y1 = y; break;\n case 2: this._point = 3; // proceed\n default: point$1(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var cardinal = (function custom(tension) {\n\n function cardinal(context) {\n return new Cardinal(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n })(0);\n\n function CardinalClosed(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n }\n\n CardinalClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point$1(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var cardinalClosed = (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalClosed(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n })(0);\n\n function CardinalOpen(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n }\n\n CardinalOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;\n case 3: this._point = 4; // proceed\n default: point$1(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var cardinalOpen = (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalOpen(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n })(0);\n\n function point$2(that, x, y) {\n var x1 = that._x1,\n y1 = that._y1,\n x2 = that._x2,\n y2 = that._y2;\n\n if (that._l01_a > epsilon$1) {\n var a = 2 * that._l01_2a + 3 * that._l01_a * that._l12_a + that._l12_2a,\n n = 3 * that._l01_a * (that._l01_a + that._l12_a);\n x1 = (x1 * a - that._x0 * that._l12_2a + that._x2 * that._l01_2a) / n;\n y1 = (y1 * a - that._y0 * that._l12_2a + that._y2 * that._l01_2a) / n;\n }\n\n if (that._l23_a > epsilon$1) {\n var b = 2 * that._l23_2a + 3 * that._l23_a * that._l12_a + that._l12_2a,\n m = 3 * that._l23_a * (that._l23_a + that._l12_a);\n x2 = (x2 * b + that._x1 * that._l23_2a - x * that._l12_2a) / m;\n y2 = (y2 * b + that._y1 * that._l23_2a - y * that._l12_2a) / m;\n }\n\n that._context.bezierCurveTo(x1, y1, x2, y2, that._x2, that._y2);\n }\n\n function CatmullRom(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n }\n\n CatmullRom.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: this.point(this, this._x2, this._y2); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; // proceed\n default: point$2(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var catmullRom = (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRom(context, alpha) : new Cardinal(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n })(0.5);\n\n function CatmullRomClosed(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n }\n\n CatmullRomClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point$2(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var catmullRomClosed = (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRomClosed(context, alpha) : new CardinalClosed(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n })(0.5);\n\n function CatmullRomOpen(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n }\n\n CatmullRomOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;\n case 3: this._point = 4; // proceed\n default: point$2(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var catmullRomOpen = (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRomOpen(context, alpha) : new CardinalOpen(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n })(0.5);\n\n function LinearClosed(context) {\n this._context = context;\n }\n\n LinearClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._point) this._context.closePath();\n },\n point: function(x, y) {\n x = +x, y = +y;\n if (this._point) this._context.lineTo(x, y);\n else this._point = 1, this._context.moveTo(x, y);\n }\n };\n\n function linearClosed(context) {\n return new LinearClosed(context);\n }\n\n function sign(x) {\n return x < 0 ? -1 : 1;\n }\n\n // Calculate the slopes of the tangents (Hermite-type interpolation) based on\n // the following paper: Steffen, M. 1990. A Simple Method for Monotonic\n // Interpolation in One Dimension. Astronomy and Astrophysics, Vol. 239, NO.\n // NOV(II), P. 443, 1990.\n function slope3(that, x2, y2) {\n var h0 = that._x1 - that._x0,\n h1 = x2 - that._x1,\n s0 = (that._y1 - that._y0) / (h0 || h1 < 0 && -0),\n s1 = (y2 - that._y1) / (h1 || h0 < 0 && -0),\n p = (s0 * h1 + s1 * h0) / (h0 + h1);\n return (sign(s0) + sign(s1)) * Math.min(Math.abs(s0), Math.abs(s1), 0.5 * Math.abs(p)) || 0;\n }\n\n // Calculate a one-sided slope.\n function slope2(that, t) {\n var h = that._x1 - that._x0;\n return h ? (3 * (that._y1 - that._y0) / h - t) / 2 : t;\n }\n\n // According to https://en.wikipedia.org/wiki/Cubic_Hermite_spline#Representations\n // \"you can express cubic Hermite interpolation in terms of cubic Bézier curves\n // with respect to the four values p0, p0 + m0 / 3, p1 - m1 / 3, p1\".\n function point$3(that, t0, t1) {\n var x0 = that._x0,\n y0 = that._y0,\n x1 = that._x1,\n y1 = that._y1,\n dx = (x1 - x0) / 3;\n that._context.bezierCurveTo(x0 + dx, y0 + dx * t0, x1 - dx, y1 - dx * t1, x1, y1);\n }\n\n function MonotoneX(context) {\n this._context = context;\n }\n\n MonotoneX.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 =\n this._t0 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x1, this._y1); break;\n case 3: point$3(this, this._t0, slope2(this, this._t0)); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n var t1 = NaN;\n\n x = +x, y = +y;\n if (x === this._x1 && y === this._y1) return; // Ignore coincident points.\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; point$3(this, slope2(this, t1 = slope3(this, x, y)), t1); break;\n default: point$3(this, this._t0, t1 = slope3(this, x, y)); break;\n }\n\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n this._t0 = t1;\n }\n }\n\n function MonotoneY(context) {\n this._context = new ReflectContext(context);\n }\n\n (MonotoneY.prototype = Object.create(MonotoneX.prototype)).point = function(x, y) {\n MonotoneX.prototype.point.call(this, y, x);\n };\n\n function ReflectContext(context) {\n this._context = context;\n }\n\n ReflectContext.prototype = {\n moveTo: function(x, y) { this._context.moveTo(y, x); },\n closePath: function() { this._context.closePath(); },\n lineTo: function(x, y) { this._context.lineTo(y, x); },\n bezierCurveTo: function(x1, y1, x2, y2, x, y) { this._context.bezierCurveTo(y1, x1, y2, x2, y, x); }\n };\n\n function monotoneX(context) {\n return new MonotoneX(context);\n }\n\n function monotoneY(context) {\n return new MonotoneY(context);\n }\n\n function Natural(context) {\n this._context = context;\n }\n\n Natural.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x = [];\n this._y = [];\n },\n lineEnd: function() {\n var x = this._x,\n y = this._y,\n n = x.length;\n\n if (n) {\n this._line ? this._context.lineTo(x[0], y[0]) : this._context.moveTo(x[0], y[0]);\n if (n === 2) {\n this._context.lineTo(x[1], y[1]);\n } else {\n var px = controlPoints(x),\n py = controlPoints(y);\n for (var i0 = 0, i1 = 1; i1 < n; ++i0, ++i1) {\n this._context.bezierCurveTo(px[0][i0], py[0][i0], px[1][i0], py[1][i0], x[i1], y[i1]);\n }\n }\n }\n\n if (this._line || (this._line !== 0 && n === 1)) this._context.closePath();\n this._line = 1 - this._line;\n this._x = this._y = null;\n },\n point: function(x, y) {\n this._x.push(+x);\n this._y.push(+y);\n }\n };\n\n // See https://www.particleincell.com/2012/bezier-splines/ for derivation.\n function controlPoints(x) {\n var i,\n n = x.length - 1,\n m,\n a = new Array(n),\n b = new Array(n),\n r = new Array(n);\n a[0] = 0, b[0] = 2, r[0] = x[0] + 2 * x[1];\n for (i = 1; i < n - 1; ++i) a[i] = 1, b[i] = 4, r[i] = 4 * x[i] + 2 * x[i + 1];\n a[n - 1] = 2, b[n - 1] = 7, r[n - 1] = 8 * x[n - 1] + x[n];\n for (i = 1; i < n; ++i) m = a[i] / b[i - 1], b[i] -= m, r[i] -= m * r[i - 1];\n a[n - 1] = r[n - 1] / b[n - 1];\n for (i = n - 2; i >= 0; --i) a[i] = (r[i] - a[i + 1]) / b[i];\n b[n - 1] = (x[n] + a[n - 1]) / 2;\n for (i = 0; i < n - 1; ++i) b[i] = 2 * x[i + 1] - a[i + 1];\n return [a, b];\n }\n\n function natural(context) {\n return new Natural(context);\n }\n\n function Step(context, t) {\n this._context = context;\n this._t = t;\n }\n\n Step.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x = this._y = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (0 < this._t && this._t < 1 && this._point === 2) this._context.lineTo(this._x, this._y);\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n if (this._line >= 0) this._t = 1 - this._t, this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; // proceed\n default: {\n if (this._t <= 0) {\n this._context.lineTo(this._x, y);\n this._context.lineTo(x, y);\n } else {\n var x1 = this._x * (1 - this._t) + x * this._t;\n this._context.lineTo(x1, this._y);\n this._context.lineTo(x1, y);\n }\n break;\n }\n }\n this._x = x, this._y = y;\n }\n };\n\n function step(context) {\n return new Step(context, 0.5);\n }\n\n function stepBefore(context) {\n return new Step(context, 0);\n }\n\n function stepAfter(context) {\n return new Step(context, 1);\n }\n\n var slice$2 = Array.prototype.slice;\n\n function none(series, order) {\n if (!((n = series.length) > 1)) return;\n for (var i = 1, s0, s1 = series[order[0]], n, m = s1.length; i < n; ++i) {\n s0 = s1, s1 = series[order[i]];\n for (var j = 0; j < m; ++j) {\n s1[j][1] += s1[j][0] = isNaN(s0[j][1]) ? s0[j][0] : s0[j][1];\n }\n }\n }\n\n function none$1(series) {\n var n = series.length, o = new Array(n);\n while (--n >= 0) o[n] = n;\n return o;\n }\n\n function stackValue(d, key) {\n return d[key];\n }\n\n function stack() {\n var keys = constant$1([]),\n order = none$1,\n offset = none,\n value = stackValue;\n\n function stack(data) {\n var kz = keys.apply(this, arguments),\n i,\n m = data.length,\n n = kz.length,\n sz = new Array(n),\n oz;\n\n for (i = 0; i < n; ++i) {\n for (var ki = kz[i], si = sz[i] = new Array(m), j = 0, sij; j < m; ++j) {\n si[j] = sij = [0, +value(data[j], ki, j, data)];\n sij.data = data[j];\n }\n si.key = ki;\n }\n\n for (i = 0, oz = order(sz); i < n; ++i) {\n sz[oz[i]].index = i;\n }\n\n offset(sz, oz);\n return sz;\n }\n\n stack.keys = function(_) {\n return arguments.length ? (keys = typeof _ === \"function\" ? _ : constant$1(slice$2.call(_)), stack) : keys;\n };\n\n stack.value = function(_) {\n return arguments.length ? (value = typeof _ === \"function\" ? _ : constant$1(+_), stack) : value;\n };\n\n stack.order = function(_) {\n return arguments.length ? (order = _ == null ? none$1 : typeof _ === \"function\" ? _ : constant$1(slice$2.call(_)), stack) : order;\n };\n\n stack.offset = function(_) {\n return arguments.length ? (offset = _ == null ? none : _, stack) : offset;\n };\n\n return stack;\n }\n\n function expand(series, order) {\n if (!((n = series.length) > 0)) return;\n for (var i, n, j = 0, m = series[0].length, y; j < m; ++j) {\n for (y = i = 0; i < n; ++i) y += series[i][j][1] || 0;\n if (y) for (i = 0; i < n; ++i) series[i][j][1] /= y;\n }\n none(series, order);\n }\n\n function silhouette(series, order) {\n if (!((n = series.length) > 0)) return;\n for (var j = 0, s0 = series[order[0]], n, m = s0.length; j < m; ++j) {\n for (var i = 0, y = 0; i < n; ++i) y += series[i][j][1] || 0;\n s0[j][1] += s0[j][0] = -y / 2;\n }\n none(series, order);\n }\n\n function wiggle(series, order) {\n if (!((n = series.length) > 0) || !((m = (s0 = series[order[0]]).length) > 0)) return;\n for (var y = 0, j = 1, s0, m, n; j < m; ++j) {\n for (var i = 0, s1 = 0, s2 = 0; i < n; ++i) {\n var si = series[order[i]],\n sij0 = si[j][1] || 0,\n sij1 = si[j - 1][1] || 0,\n s3 = (sij0 - sij1) / 2;\n for (var k = 0; k < i; ++k) {\n var sk = series[order[k]],\n skj0 = sk[j][1] || 0,\n skj1 = sk[j - 1][1] || 0;\n s3 += skj0 - skj1;\n }\n s1 += sij0, s2 += s3 * sij0;\n }\n s0[j - 1][1] += s0[j - 1][0] = y;\n if (s1) y -= s2 / s1;\n }\n s0[j - 1][1] += s0[j - 1][0] = y;\n none(series, order);\n }\n\n function ascending$1(series) {\n var sums = series.map(sum$1);\n return none$1(series).sort(function(a, b) { return sums[a] - sums[b]; });\n }\n\n function sum$1(series) {\n var s = 0, i = -1, n = series.length, v;\n while (++i < n) if (v = +series[i][1]) s += v;\n return s;\n }\n\n function descending$2(series) {\n return ascending$1(series).reverse();\n }\n\n function insideOut(series) {\n var n = series.length,\n i,\n j,\n sums = series.map(sum$1),\n order = none$1(series).sort(function(a, b) { return sums[b] - sums[a]; }),\n top = 0,\n bottom = 0,\n tops = [],\n bottoms = [];\n\n for (i = 0; i < n; ++i) {\n j = order[i];\n if (top < bottom) {\n top += sums[j];\n tops.push(j);\n } else {\n bottom += sums[j];\n bottoms.push(j);\n }\n }\n\n return bottoms.reverse().concat(tops);\n }\n\n function reverse(series) {\n return none$1(series).reverse();\n }\n\n function define(constructor, factory, prototype) {\n constructor.prototype = factory.prototype = prototype;\n prototype.constructor = constructor;\n }\n\n function extend(parent, definition) {\n var prototype = Object.create(parent.prototype);\n for (var key in definition) prototype[key] = definition[key];\n return prototype;\n }\n\n function Color() {}\n\n var darker = 0.7;\n var brighter = 1 / darker;\n\n var reHex3 = /^#([0-9a-f]{3})$/;\n var reHex6 = /^#([0-9a-f]{6})$/;\n var reRgbInteger = /^rgb\\(\\s*([-+]?\\d+)\\s*,\\s*([-+]?\\d+)\\s*,\\s*([-+]?\\d+)\\s*\\)$/;\n var reRgbPercent = /^rgb\\(\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*\\)$/;\n var reRgbaInteger = /^rgba\\(\\s*([-+]?\\d+)\\s*,\\s*([-+]?\\d+)\\s*,\\s*([-+]?\\d+)\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)\\s*\\)$/;\n var reRgbaPercent = /^rgba\\(\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)\\s*\\)$/;\n var reHslPercent = /^hsl\\(\\s*([-+]?\\d+(?:\\.\\d+)?)\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*\\)$/;\n var reHslaPercent = /^hsla\\(\\s*([-+]?\\d+(?:\\.\\d+)?)\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)\\s*\\)$/;\n var named = {\n aliceblue: 0xf0f8ff,\n antiquewhite: 0xfaebd7,\n aqua: 0x00ffff,\n aquamarine: 0x7fffd4,\n azure: 0xf0ffff,\n beige: 0xf5f5dc,\n bisque: 0xffe4c4,\n black: 0x000000,\n blanchedalmond: 0xffebcd,\n blue: 0x0000ff,\n blueviolet: 0x8a2be2,\n brown: 0xa52a2a,\n burlywood: 0xdeb887,\n cadetblue: 0x5f9ea0,\n chartreuse: 0x7fff00,\n chocolate: 0xd2691e,\n coral: 0xff7f50,\n cornflowerblue: 0x6495ed,\n cornsilk: 0xfff8dc,\n crimson: 0xdc143c,\n cyan: 0x00ffff,\n darkblue: 0x00008b,\n darkcyan: 0x008b8b,\n darkgoldenrod: 0xb8860b,\n darkgray: 0xa9a9a9,\n darkgreen: 0x006400,\n darkgrey: 0xa9a9a9,\n darkkhaki: 0xbdb76b,\n darkmagenta: 0x8b008b,\n darkolivegreen: 0x556b2f,\n darkorange: 0xff8c00,\n darkorchid: 0x9932cc,\n darkred: 0x8b0000,\n darksalmon: 0xe9967a,\n darkseagreen: 0x8fbc8f,\n darkslateblue: 0x483d8b,\n darkslategray: 0x2f4f4f,\n darkslategrey: 0x2f4f4f,\n darkturquoise: 0x00ced1,\n darkviolet: 0x9400d3,\n deeppink: 0xff1493,\n deepskyblue: 0x00bfff,\n dimgray: 0x696969,\n dimgrey: 0x696969,\n dodgerblue: 0x1e90ff,\n firebrick: 0xb22222,\n floralwhite: 0xfffaf0,\n forestgreen: 0x228b22,\n fuchsia: 0xff00ff,\n gainsboro: 0xdcdcdc,\n ghostwhite: 0xf8f8ff,\n gold: 0xffd700,\n goldenrod: 0xdaa520,\n gray: 0x808080,\n green: 0x008000,\n greenyellow: 0xadff2f,\n grey: 0x808080,\n honeydew: 0xf0fff0,\n hotpink: 0xff69b4,\n indianred: 0xcd5c5c,\n indigo: 0x4b0082,\n ivory: 0xfffff0,\n khaki: 0xf0e68c,\n lavender: 0xe6e6fa,\n lavenderblush: 0xfff0f5,\n lawngreen: 0x7cfc00,\n lemonchiffon: 0xfffacd,\n lightblue: 0xadd8e6,\n lightcoral: 0xf08080,\n lightcyan: 0xe0ffff,\n lightgoldenrodyellow: 0xfafad2,\n lightgray: 0xd3d3d3,\n lightgreen: 0x90ee90,\n lightgrey: 0xd3d3d3,\n lightpink: 0xffb6c1,\n lightsalmon: 0xffa07a,\n lightseagreen: 0x20b2aa,\n lightskyblue: 0x87cefa,\n lightslategray: 0x778899,\n lightslategrey: 0x778899,\n lightsteelblue: 0xb0c4de,\n lightyellow: 0xffffe0,\n lime: 0x00ff00,\n limegreen: 0x32cd32,\n linen: 0xfaf0e6,\n magenta: 0xff00ff,\n maroon: 0x800000,\n mediumaquamarine: 0x66cdaa,\n mediumblue: 0x0000cd,\n mediumorchid: 0xba55d3,\n mediumpurple: 0x9370db,\n mediumseagreen: 0x3cb371,\n mediumslateblue: 0x7b68ee,\n mediumspringgreen: 0x00fa9a,\n mediumturquoise: 0x48d1cc,\n mediumvioletred: 0xc71585,\n midnightblue: 0x191970,\n mintcream: 0xf5fffa,\n mistyrose: 0xffe4e1,\n moccasin: 0xffe4b5,\n navajowhite: 0xffdead,\n navy: 0x000080,\n oldlace: 0xfdf5e6,\n olive: 0x808000,\n olivedrab: 0x6b8e23,\n orange: 0xffa500,\n orangered: 0xff4500,\n orchid: 0xda70d6,\n palegoldenrod: 0xeee8aa,\n palegreen: 0x98fb98,\n paleturquoise: 0xafeeee,\n palevioletred: 0xdb7093,\n papayawhip: 0xffefd5,\n peachpuff: 0xffdab9,\n peru: 0xcd853f,\n pink: 0xffc0cb,\n plum: 0xdda0dd,\n powderblue: 0xb0e0e6,\n purple: 0x800080,\n rebeccapurple: 0x663399,\n red: 0xff0000,\n rosybrown: 0xbc8f8f,\n royalblue: 0x4169e1,\n saddlebrown: 0x8b4513,\n salmon: 0xfa8072,\n sandybrown: 0xf4a460,\n seagreen: 0x2e8b57,\n seashell: 0xfff5ee,\n sienna: 0xa0522d,\n silver: 0xc0c0c0,\n skyblue: 0x87ceeb,\n slateblue: 0x6a5acd,\n slategray: 0x708090,\n slategrey: 0x708090,\n snow: 0xfffafa,\n springgreen: 0x00ff7f,\n steelblue: 0x4682b4,\n tan: 0xd2b48c,\n teal: 0x008080,\n thistle: 0xd8bfd8,\n tomato: 0xff6347,\n turquoise: 0x40e0d0,\n violet: 0xee82ee,\n wheat: 0xf5deb3,\n white: 0xffffff,\n whitesmoke: 0xf5f5f5,\n yellow: 0xffff00,\n yellowgreen: 0x9acd32\n };\n\n define(Color, color, {\n displayable: function() {\n return this.rgb().displayable();\n },\n toString: function() {\n return this.rgb() + \"\";\n }\n });\n\n function color(format) {\n var m;\n format = (format + \"\").trim().toLowerCase();\n return (m = reHex3.exec(format)) ? (m = parseInt(m[1], 16), new Rgb((m >> 8 & 0xf) | (m >> 4 & 0x0f0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1)) // #f00\n : (m = reHex6.exec(format)) ? rgbn(parseInt(m[1], 16)) // #ff0000\n : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)\n : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)\n : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)\n : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)\n : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)\n : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)\n : named.hasOwnProperty(format) ? rgbn(named[format])\n : format === \"transparent\" ? new Rgb(NaN, NaN, NaN, 0)\n : null;\n }\n\n function rgbn(n) {\n return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);\n }\n\n function rgba(r, g, b, a) {\n if (a <= 0) r = g = b = NaN;\n return new Rgb(r, g, b, a);\n }\n\n function rgbConvert(o) {\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Rgb;\n o = o.rgb();\n return new Rgb(o.r, o.g, o.b, o.opacity);\n }\n\n function colorRgb(r, g, b, opacity) {\n return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);\n }\n\n function Rgb(r, g, b, opacity) {\n this.r = +r;\n this.g = +g;\n this.b = +b;\n this.opacity = +opacity;\n }\n\n define(Rgb, colorRgb, extend(Color, {\n brighter: function(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n darker: function(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n rgb: function() {\n return this;\n },\n displayable: function() {\n return (0 <= this.r && this.r <= 255)\n && (0 <= this.g && this.g <= 255)\n && (0 <= this.b && this.b <= 255)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n toString: function() {\n var a = this.opacity; a = isNaN(a) ? 1 : Math.max(0, Math.min(1, a));\n return (a === 1 ? \"rgb(\" : \"rgba(\")\n + Math.max(0, Math.min(255, Math.round(this.r) || 0)) + \", \"\n + Math.max(0, Math.min(255, Math.round(this.g) || 0)) + \", \"\n + Math.max(0, Math.min(255, Math.round(this.b) || 0))\n + (a === 1 ? \")\" : \", \" + a + \")\");\n }\n }));\n\n function hsla(h, s, l, a) {\n if (a <= 0) h = s = l = NaN;\n else if (l <= 0 || l >= 1) h = s = NaN;\n else if (s <= 0) h = NaN;\n return new Hsl(h, s, l, a);\n }\n\n function hslConvert(o) {\n if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Hsl;\n if (o instanceof Hsl) return o;\n o = o.rgb();\n var r = o.r / 255,\n g = o.g / 255,\n b = o.b / 255,\n min = Math.min(r, g, b),\n max = Math.max(r, g, b),\n h = NaN,\n s = max - min,\n l = (max + min) / 2;\n if (s) {\n if (r === max) h = (g - b) / s + (g < b) * 6;\n else if (g === max) h = (b - r) / s + 2;\n else h = (r - g) / s + 4;\n s /= l < 0.5 ? max + min : 2 - max - min;\n h *= 60;\n } else {\n s = l > 0 && l < 1 ? 0 : h;\n }\n return new Hsl(h, s, l, o.opacity);\n }\n\n function colorHsl(h, s, l, opacity) {\n return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);\n }\n\n function Hsl(h, s, l, opacity) {\n this.h = +h;\n this.s = +s;\n this.l = +l;\n this.opacity = +opacity;\n }\n\n define(Hsl, colorHsl, extend(Color, {\n brighter: function(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n darker: function(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n rgb: function() {\n var h = this.h % 360 + (this.h < 0) * 360,\n s = isNaN(h) || isNaN(this.s) ? 0 : this.s,\n l = this.l,\n m2 = l + (l < 0.5 ? l : 1 - l) * s,\n m1 = 2 * l - m2;\n return new Rgb(\n hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),\n hsl2rgb(h, m1, m2),\n hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),\n this.opacity\n );\n },\n displayable: function() {\n return (0 <= this.s && this.s <= 1 || isNaN(this.s))\n && (0 <= this.l && this.l <= 1)\n && (0 <= this.opacity && this.opacity <= 1);\n }\n }));\n\n /* From FvD 13.37, CSS Color Module Level 3 */\n function hsl2rgb(h, m1, m2) {\n return (h < 60 ? m1 + (m2 - m1) * h / 60\n : h < 180 ? m2\n : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60\n : m1) * 255;\n }\n\n var deg2rad = Math.PI / 180;\n var rad2deg = 180 / Math.PI;\n\n var Kn = 18;\n var Xn = 0.950470;\n var Yn = 1;\n var Zn = 1.088830;\n var t0 = 4 / 29;\n var t1 = 6 / 29;\n var t2 = 3 * t1 * t1;\n var t3 = t1 * t1 * t1;\n function labConvert(o) {\n if (o instanceof Lab) return new Lab(o.l, o.a, o.b, o.opacity);\n if (o instanceof Hcl) {\n var h = o.h * deg2rad;\n return new Lab(o.l, Math.cos(h) * o.c, Math.sin(h) * o.c, o.opacity);\n }\n if (!(o instanceof Rgb)) o = rgbConvert(o);\n var b = rgb2xyz(o.r),\n a = rgb2xyz(o.g),\n l = rgb2xyz(o.b),\n x = xyz2lab((0.4124564 * b + 0.3575761 * a + 0.1804375 * l) / Xn),\n y = xyz2lab((0.2126729 * b + 0.7151522 * a + 0.0721750 * l) / Yn),\n z = xyz2lab((0.0193339 * b + 0.1191920 * a + 0.9503041 * l) / Zn);\n return new Lab(116 * y - 16, 500 * (x - y), 200 * (y - z), o.opacity);\n }\n\n function lab(l, a, b, opacity) {\n return arguments.length === 1 ? labConvert(l) : new Lab(l, a, b, opacity == null ? 1 : opacity);\n }\n\n function Lab(l, a, b, opacity) {\n this.l = +l;\n this.a = +a;\n this.b = +b;\n this.opacity = +opacity;\n }\n\n define(Lab, lab, extend(Color, {\n brighter: function(k) {\n return new Lab(this.l + Kn * (k == null ? 1 : k), this.a, this.b, this.opacity);\n },\n darker: function(k) {\n return new Lab(this.l - Kn * (k == null ? 1 : k), this.a, this.b, this.opacity);\n },\n rgb: function() {\n var y = (this.l + 16) / 116,\n x = isNaN(this.a) ? y : y + this.a / 500,\n z = isNaN(this.b) ? y : y - this.b / 200;\n y = Yn * lab2xyz(y);\n x = Xn * lab2xyz(x);\n z = Zn * lab2xyz(z);\n return new Rgb(\n xyz2rgb( 3.2404542 * x - 1.5371385 * y - 0.4985314 * z), // D65 -> sRGB\n xyz2rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z),\n xyz2rgb( 0.0556434 * x - 0.2040259 * y + 1.0572252 * z),\n this.opacity\n );\n }\n }));\n\n function xyz2lab(t) {\n return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0;\n }\n\n function lab2xyz(t) {\n return t > t1 ? t * t * t : t2 * (t - t0);\n }\n\n function xyz2rgb(x) {\n return 255 * (x <= 0.0031308 ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055);\n }\n\n function rgb2xyz(x) {\n return (x /= 255) <= 0.04045 ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4);\n }\n\n function hclConvert(o) {\n if (o instanceof Hcl) return new Hcl(o.h, o.c, o.l, o.opacity);\n if (!(o instanceof Lab)) o = labConvert(o);\n var h = Math.atan2(o.b, o.a) * rad2deg;\n return new Hcl(h < 0 ? h + 360 : h, Math.sqrt(o.a * o.a + o.b * o.b), o.l, o.opacity);\n }\n\n function colorHcl(h, c, l, opacity) {\n return arguments.length === 1 ? hclConvert(h) : new Hcl(h, c, l, opacity == null ? 1 : opacity);\n }\n\n function Hcl(h, c, l, opacity) {\n this.h = +h;\n this.c = +c;\n this.l = +l;\n this.opacity = +opacity;\n }\n\n define(Hcl, colorHcl, extend(Color, {\n brighter: function(k) {\n return new Hcl(this.h, this.c, this.l + Kn * (k == null ? 1 : k), this.opacity);\n },\n darker: function(k) {\n return new Hcl(this.h, this.c, this.l - Kn * (k == null ? 1 : k), this.opacity);\n },\n rgb: function() {\n return labConvert(this).rgb();\n }\n }));\n\n var A = -0.14861;\n var B = +1.78277;\n var C = -0.29227;\n var D = -0.90649;\n var E = +1.97294;\n var ED = E * D;\n var EB = E * B;\n var BC_DA = B * C - D * A;\n function cubehelixConvert(o) {\n if (o instanceof Cubehelix) return new Cubehelix(o.h, o.s, o.l, o.opacity);\n if (!(o instanceof Rgb)) o = rgbConvert(o);\n var r = o.r / 255,\n g = o.g / 255,\n b = o.b / 255,\n l = (BC_DA * b + ED * r - EB * g) / (BC_DA + ED - EB),\n bl = b - l,\n k = (E * (g - l) - C * bl) / D,\n s = Math.sqrt(k * k + bl * bl) / (E * l * (1 - l)), // NaN if l=0 or l=1\n h = s ? Math.atan2(k, bl) * rad2deg - 120 : NaN;\n return new Cubehelix(h < 0 ? h + 360 : h, s, l, o.opacity);\n }\n\n function cubehelix(h, s, l, opacity) {\n return arguments.length === 1 ? cubehelixConvert(h) : new Cubehelix(h, s, l, opacity == null ? 1 : opacity);\n }\n\n function Cubehelix(h, s, l, opacity) {\n this.h = +h;\n this.s = +s;\n this.l = +l;\n this.opacity = +opacity;\n }\n\n define(Cubehelix, cubehelix, extend(Color, {\n brighter: function(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Cubehelix(this.h, this.s, this.l * k, this.opacity);\n },\n darker: function(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Cubehelix(this.h, this.s, this.l * k, this.opacity);\n },\n rgb: function() {\n var h = isNaN(this.h) ? 0 : (this.h + 120) * deg2rad,\n l = +this.l,\n a = isNaN(this.s) ? 0 : this.s * l * (1 - l),\n cosh = Math.cos(h),\n sinh = Math.sin(h);\n return new Rgb(\n 255 * (l + a * (A * cosh + B * sinh)),\n 255 * (l + a * (C * cosh + D * sinh)),\n 255 * (l + a * (E * cosh)),\n this.opacity\n );\n }\n }));\n\n function basis$1(t1, v0, v1, v2, v3) {\n var t2 = t1 * t1, t3 = t2 * t1;\n return ((1 - 3 * t1 + 3 * t2 - t3) * v0\n + (4 - 6 * t2 + 3 * t3) * v1\n + (1 + 3 * t1 + 3 * t2 - 3 * t3) * v2\n + t3 * v3) / 6;\n }\n\n function basis$2(values) {\n var n = values.length - 1;\n return function(t) {\n var i = t <= 0 ? (t = 0) : t >= 1 ? (t = 1, n - 1) : Math.floor(t * n),\n v1 = values[i],\n v2 = values[i + 1],\n v0 = i > 0 ? values[i - 1] : 2 * v1 - v2,\n v3 = i < n - 1 ? values[i + 2] : 2 * v2 - v1;\n return basis$1((t - i / n) * n, v0, v1, v2, v3);\n };\n }\n\n function basisClosed$1(values) {\n var n = values.length;\n return function(t) {\n var i = Math.floor(((t %= 1) < 0 ? ++t : t) * n),\n v0 = values[(i + n - 1) % n],\n v1 = values[i % n],\n v2 = values[(i + 1) % n],\n v3 = values[(i + 2) % n];\n return basis$1((t - i / n) * n, v0, v1, v2, v3);\n };\n }\n\n function constant$2(x) {\n return function() {\n return x;\n };\n }\n\n function linear$1(a, d) {\n return function(t) {\n return a + t * d;\n };\n }\n\n function exponential$1(a, b, y) {\n return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {\n return Math.pow(a + t * b, y);\n };\n }\n\n function hue(a, b) {\n var d = b - a;\n return d ? linear$1(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant$2(isNaN(a) ? b : a);\n }\n\n function gamma(y) {\n return (y = +y) === 1 ? nogamma : function(a, b) {\n return b - a ? exponential$1(a, b, y) : constant$2(isNaN(a) ? b : a);\n };\n }\n\n function nogamma(a, b) {\n var d = b - a;\n return d ? linear$1(a, d) : constant$2(isNaN(a) ? b : a);\n }\n\n var interpolateRgb = (function rgbGamma(y) {\n var color = gamma(y);\n\n function rgb(start, end) {\n var r = color((start = colorRgb(start)).r, (end = colorRgb(end)).r),\n g = color(start.g, end.g),\n b = color(start.b, end.b),\n opacity = color(start.opacity, end.opacity);\n return function(t) {\n start.r = r(t);\n start.g = g(t);\n start.b = b(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n rgb.gamma = rgbGamma;\n\n return rgb;\n })(1);\n\n function rgbSpline(spline) {\n return function(colors) {\n var n = colors.length,\n r = new Array(n),\n g = new Array(n),\n b = new Array(n),\n i, color;\n for (i = 0; i < n; ++i) {\n color = colorRgb(colors[i]);\n r[i] = color.r || 0;\n g[i] = color.g || 0;\n b[i] = color.b || 0;\n }\n r = spline(r);\n g = spline(g);\n b = spline(b);\n color.opacity = 1;\n return function(t) {\n color.r = r(t);\n color.g = g(t);\n color.b = b(t);\n return color + \"\";\n };\n };\n }\n\n var rgbBasis = rgbSpline(basis$2);\n var rgbBasisClosed = rgbSpline(basisClosed$1);\n\n function array$1(a, b) {\n var nb = b ? b.length : 0,\n na = a ? Math.min(nb, a.length) : 0,\n x = new Array(nb),\n c = new Array(nb),\n i;\n\n for (i = 0; i < na; ++i) x[i] = interpolate(a[i], b[i]);\n for (; i < nb; ++i) c[i] = b[i];\n\n return function(t) {\n for (i = 0; i < na; ++i) c[i] = x[i](t);\n return c;\n };\n }\n\n function date(a, b) {\n var d = new Date;\n return a = +a, b -= a, function(t) {\n return d.setTime(a + b * t), d;\n };\n }\n\n function interpolateNumber(a, b) {\n return a = +a, b -= a, function(t) {\n return a + b * t;\n };\n }\n\n function object(a, b) {\n var i = {},\n c = {},\n k;\n\n if (a === null || typeof a !== \"object\") a = {};\n if (b === null || typeof b !== \"object\") b = {};\n\n for (k in b) {\n if (k in a) {\n i[k] = interpolate(a[k], b[k]);\n } else {\n c[k] = b[k];\n }\n }\n\n return function(t) {\n for (k in i) c[k] = i[k](t);\n return c;\n };\n }\n\n var reA = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g;\n var reB = new RegExp(reA.source, \"g\");\n function zero(b) {\n return function() {\n return b;\n };\n }\n\n function one(b) {\n return function(t) {\n return b(t) + \"\";\n };\n }\n\n function interpolateString(a, b) {\n var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b\n am, // current match in a\n bm, // current match in b\n bs, // string preceding current number in b, if any\n i = -1, // index in s\n s = [], // string constants and placeholders\n q = []; // number interpolators\n\n // Coerce inputs to strings.\n a = a + \"\", b = b + \"\";\n\n // Interpolate pairs of numbers in a & b.\n while ((am = reA.exec(a))\n && (bm = reB.exec(b))) {\n if ((bs = bm.index) > bi) { // a string precedes the next number in b\n bs = b.slice(bi, bs);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match\n if (s[i]) s[i] += bm; // coalesce with previous string\n else s[++i] = bm;\n } else { // interpolate non-matching numbers\n s[++i] = null;\n q.push({i: i, x: interpolateNumber(am, bm)});\n }\n bi = reB.lastIndex;\n }\n\n // Add remains of b.\n if (bi < b.length) {\n bs = b.slice(bi);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n\n // Special optimization for only a single match.\n // Otherwise, interpolate each of the numbers and rejoin the string.\n return s.length < 2 ? (q[0]\n ? one(q[0].x)\n : zero(b))\n : (b = q.length, function(t) {\n for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n });\n }\n\n function interpolate(a, b) {\n var t = typeof b, c;\n return b == null || t === \"boolean\" ? constant$2(b)\n : (t === \"number\" ? interpolateNumber\n : t === \"string\" ? ((c = color(b)) ? (b = c, interpolateRgb) : interpolateString)\n : b instanceof color ? interpolateRgb\n : b instanceof Date ? date\n : Array.isArray(b) ? array$1\n : isNaN(b) ? object\n : interpolateNumber)(a, b);\n }\n\n function interpolateRound(a, b) {\n return a = +a, b -= a, function(t) {\n return Math.round(a + b * t);\n };\n }\n\n var degrees = 180 / Math.PI;\n\n var identity$2 = {\n translateX: 0,\n translateY: 0,\n rotate: 0,\n skewX: 0,\n scaleX: 1,\n scaleY: 1\n };\n\n function decompose(a, b, c, d, e, f) {\n var scaleX, scaleY, skewX;\n if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;\n if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;\n if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;\n if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;\n return {\n translateX: e,\n translateY: f,\n rotate: Math.atan2(b, a) * degrees,\n skewX: Math.atan(skewX) * degrees,\n scaleX: scaleX,\n scaleY: scaleY\n };\n }\n\n var cssNode;\n var cssRoot;\n var cssView;\n var svgNode;\n function parseCss(value) {\n if (value === \"none\") return identity$2;\n if (!cssNode) cssNode = document.createElement(\"DIV\"), cssRoot = document.documentElement, cssView = document.defaultView;\n cssNode.style.transform = value;\n value = cssView.getComputedStyle(cssRoot.appendChild(cssNode), null).getPropertyValue(\"transform\");\n cssRoot.removeChild(cssNode);\n value = value.slice(7, -1).split(\",\");\n return decompose(+value[0], +value[1], +value[2], +value[3], +value[4], +value[5]);\n }\n\n function parseSvg(value) {\n if (value == null) return identity$2;\n if (!svgNode) svgNode = document.createElementNS(\"http://www.w3.org/2000/svg\", \"g\");\n svgNode.setAttribute(\"transform\", value);\n if (!(value = svgNode.transform.baseVal.consolidate())) return identity$2;\n value = value.matrix;\n return decompose(value.a, value.b, value.c, value.d, value.e, value.f);\n }\n\n function interpolateTransform(parse, pxComma, pxParen, degParen) {\n\n function pop(s) {\n return s.length ? s.pop() + \" \" : \"\";\n }\n\n function translate(xa, ya, xb, yb, s, q) {\n if (xa !== xb || ya !== yb) {\n var i = s.push(\"translate(\", null, pxComma, null, pxParen);\n q.push({i: i - 4, x: interpolateNumber(xa, xb)}, {i: i - 2, x: interpolateNumber(ya, yb)});\n } else if (xb || yb) {\n s.push(\"translate(\" + xb + pxComma + yb + pxParen);\n }\n }\n\n function rotate(a, b, s, q) {\n if (a !== b) {\n if (a - b > 180) b += 360; else if (b - a > 180) a += 360; // shortest path\n q.push({i: s.push(pop(s) + \"rotate(\", null, degParen) - 2, x: interpolateNumber(a, b)});\n } else if (b) {\n s.push(pop(s) + \"rotate(\" + b + degParen);\n }\n }\n\n function skewX(a, b, s, q) {\n if (a !== b) {\n q.push({i: s.push(pop(s) + \"skewX(\", null, degParen) - 2, x: interpolateNumber(a, b)});\n } else if (b) {\n s.push(pop(s) + \"skewX(\" + b + degParen);\n }\n }\n\n function scale(xa, ya, xb, yb, s, q) {\n if (xa !== xb || ya !== yb) {\n var i = s.push(pop(s) + \"scale(\", null, \",\", null, \")\");\n q.push({i: i - 4, x: interpolateNumber(xa, xb)}, {i: i - 2, x: interpolateNumber(ya, yb)});\n } else if (xb !== 1 || yb !== 1) {\n s.push(pop(s) + \"scale(\" + xb + \",\" + yb + \")\");\n }\n }\n\n return function(a, b) {\n var s = [], // string constants and placeholders\n q = []; // number interpolators\n a = parse(a), b = parse(b);\n translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q);\n rotate(a.rotate, b.rotate, s, q);\n skewX(a.skewX, b.skewX, s, q);\n scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q);\n a = b = null; // gc\n return function(t) {\n var i = -1, n = q.length, o;\n while (++i < n) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n };\n };\n }\n\n var interpolateTransform$1 = interpolateTransform(parseCss, \"px, \", \"px)\", \"deg)\");\n var interpolateTransform$2 = interpolateTransform(parseSvg, \", \", \")\", \")\");\n\n var rho = Math.SQRT2;\n var rho2 = 2;\n var rho4 = 4;\n var epsilon2 = 1e-12;\n function cosh(x) {\n return ((x = Math.exp(x)) + 1 / x) / 2;\n }\n\n function sinh(x) {\n return ((x = Math.exp(x)) - 1 / x) / 2;\n }\n\n function tanh(x) {\n return ((x = Math.exp(2 * x)) - 1) / (x + 1);\n }\n\n // p0 = [ux0, uy0, w0]\n // p1 = [ux1, uy1, w1]\n function interpolateZoom(p0, p1) {\n var ux0 = p0[0], uy0 = p0[1], w0 = p0[2],\n ux1 = p1[0], uy1 = p1[1], w1 = p1[2],\n dx = ux1 - ux0,\n dy = uy1 - uy0,\n d2 = dx * dx + dy * dy,\n i,\n S;\n\n // Special case for u0 ≅ u1.\n if (d2 < epsilon2) {\n S = Math.log(w1 / w0) / rho;\n i = function(t) {\n return [\n ux0 + t * dx,\n uy0 + t * dy,\n w0 * Math.exp(rho * t * S)\n ];\n }\n }\n\n // General case.\n else {\n var d1 = Math.sqrt(d2),\n b0 = (w1 * w1 - w0 * w0 + rho4 * d2) / (2 * w0 * rho2 * d1),\n b1 = (w1 * w1 - w0 * w0 - rho4 * d2) / (2 * w1 * rho2 * d1),\n r0 = Math.log(Math.sqrt(b0 * b0 + 1) - b0),\n r1 = Math.log(Math.sqrt(b1 * b1 + 1) - b1);\n S = (r1 - r0) / rho;\n i = function(t) {\n var s = t * S,\n coshr0 = cosh(r0),\n u = w0 / (rho2 * d1) * (coshr0 * tanh(rho * s + r0) - sinh(r0));\n return [\n ux0 + u * dx,\n uy0 + u * dy,\n w0 * coshr0 / cosh(rho * s + r0)\n ];\n }\n }\n\n i.duration = S * 1000;\n\n return i;\n }\n\n function hsl(hue) {\n return function(start, end) {\n var h = hue((start = colorHsl(start)).h, (end = colorHsl(end)).h),\n s = nogamma(start.s, end.s),\n l = nogamma(start.l, end.l),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.h = h(t);\n start.s = s(t);\n start.l = l(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n }\n\n var hsl$1 = hsl(hue);\n var hslLong = hsl(nogamma);\n\n function lab$1(start, end) {\n var l = nogamma((start = lab(start)).l, (end = lab(end)).l),\n a = nogamma(start.a, end.a),\n b = nogamma(start.b, end.b),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.l = l(t);\n start.a = a(t);\n start.b = b(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n function hcl(hue) {\n return function(start, end) {\n var h = hue((start = colorHcl(start)).h, (end = colorHcl(end)).h),\n c = nogamma(start.c, end.c),\n l = nogamma(start.l, end.l),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.h = h(t);\n start.c = c(t);\n start.l = l(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n }\n\n var hcl$1 = hcl(hue);\n var hclLong = hcl(nogamma);\n\n function cubehelix$1(hue) {\n return (function cubehelixGamma(y) {\n y = +y;\n\n function cubehelix$$(start, end) {\n var h = hue((start = cubehelix(start)).h, (end = cubehelix(end)).h),\n s = nogamma(start.s, end.s),\n l = nogamma(start.l, end.l),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.h = h(t);\n start.s = s(t);\n start.l = l(Math.pow(t, y));\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n cubehelix$$.gamma = cubehelixGamma;\n\n return cubehelix$$;\n })(1);\n }\n\n var cubehelix$2 = cubehelix$1(hue);\n var interpolateCubehelixLong = cubehelix$1(nogamma);\n\n function quantize(interpolator, n) {\n var samples = new Array(n);\n for (var i = 0; i < n; ++i) samples[i] = interpolator(i / (n - 1));\n return samples;\n }\n\n var noop$1 = {value: function() {}};\n\n function dispatch() {\n for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {\n if (!(t = arguments[i] + \"\") || (t in _)) throw new Error(\"illegal type: \" + t);\n _[t] = [];\n }\n return new Dispatch(_);\n }\n\n function Dispatch(_) {\n this._ = _;\n }\n\n function parseTypenames(typenames, types) {\n return typenames.trim().split(/^|\\s+/).map(function(t) {\n var name = \"\", i = t.indexOf(\".\");\n if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n if (t && !types.hasOwnProperty(t)) throw new Error(\"unknown type: \" + t);\n return {type: t, name: name};\n });\n }\n\n Dispatch.prototype = dispatch.prototype = {\n constructor: Dispatch,\n on: function(typename, callback) {\n var _ = this._,\n T = parseTypenames(typename + \"\", _),\n t,\n i = -1,\n n = T.length;\n\n // If no callback was specified, return the callback of the given type and name.\n if (arguments.length < 2) {\n while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;\n return;\n }\n\n // If a type was specified, set the callback for the given type and name.\n // Otherwise, if a null callback was specified, remove callbacks of the given name.\n if (callback != null && typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n while (++i < n) {\n if (t = (typename = T[i]).type) _[t] = set$1(_[t], typename.name, callback);\n else if (callback == null) for (t in _) _[t] = set$1(_[t], typename.name, null);\n }\n\n return this;\n },\n copy: function() {\n var copy = {}, _ = this._;\n for (var t in _) copy[t] = _[t].slice();\n return new Dispatch(copy);\n },\n call: function(type, that) {\n if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n },\n apply: function(type, that, args) {\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n }\n };\n\n function get(type, name) {\n for (var i = 0, n = type.length, c; i < n; ++i) {\n if ((c = type[i]).name === name) {\n return c.value;\n }\n }\n }\n\n function set$1(type, name, callback) {\n for (var i = 0, n = type.length; i < n; ++i) {\n if (type[i].name === name) {\n type[i] = noop$1, type = type.slice(0, i).concat(type.slice(i + 1));\n break;\n }\n }\n if (callback != null) type.push({name: name, value: callback});\n return type;\n }\n\n function objectConverter(columns) {\n return new Function(\"d\", \"return {\" + columns.map(function(name, i) {\n return JSON.stringify(name) + \": d[\" + i + \"]\";\n }).join(\",\") + \"}\");\n }\n\n function customConverter(columns, f) {\n var object = objectConverter(columns);\n return function(row, i) {\n return f(object(row), i, columns);\n };\n }\n\n // Compute unique columns in order of discovery.\n function inferColumns(rows) {\n var columnSet = Object.create(null),\n columns = [];\n\n rows.forEach(function(row) {\n for (var column in row) {\n if (!(column in columnSet)) {\n columns.push(columnSet[column] = column);\n }\n }\n });\n\n return columns;\n }\n\n function dsv(delimiter) {\n var reFormat = new RegExp(\"[\\\"\" + delimiter + \"\\n]\"),\n delimiterCode = delimiter.charCodeAt(0);\n\n function parse(text, f) {\n var convert, columns, rows = parseRows(text, function(row, i) {\n if (convert) return convert(row, i - 1);\n columns = row, convert = f ? customConverter(row, f) : objectConverter(row);\n });\n rows.columns = columns;\n return rows;\n }\n\n function parseRows(text, f) {\n var EOL = {}, // sentinel value for end-of-line\n EOF = {}, // sentinel value for end-of-file\n rows = [], // output rows\n N = text.length,\n I = 0, // current character index\n n = 0, // the current line number\n t, // the current token\n eol; // is the current token followed by EOL?\n\n function token() {\n if (I >= N) return EOF; // special case: end of file\n if (eol) return eol = false, EOL; // special case: end of line\n\n // special case: quotes\n var j = I, c;\n if (text.charCodeAt(j) === 34) {\n var i = j;\n while (i++ < N) {\n if (text.charCodeAt(i) === 34) {\n if (text.charCodeAt(i + 1) !== 34) break;\n ++i;\n }\n }\n I = i + 2;\n c = text.charCodeAt(i + 1);\n if (c === 13) {\n eol = true;\n if (text.charCodeAt(i + 2) === 10) ++I;\n } else if (c === 10) {\n eol = true;\n }\n return text.slice(j + 1, i).replace(/\"\"/g, \"\\\"\");\n }\n\n // common case: find next delimiter or newline\n while (I < N) {\n var k = 1;\n c = text.charCodeAt(I++);\n if (c === 10) eol = true; // \\n\n else if (c === 13) { eol = true; if (text.charCodeAt(I) === 10) ++I, ++k; } // \\r|\\r\\n\n else if (c !== delimiterCode) continue;\n return text.slice(j, I - k);\n }\n\n // special case: last token before EOF\n return text.slice(j);\n }\n\n while ((t = token()) !== EOF) {\n var a = [];\n while (t !== EOL && t !== EOF) {\n a.push(t);\n t = token();\n }\n if (f && (a = f(a, n++)) == null) continue;\n rows.push(a);\n }\n\n return rows;\n }\n\n function format(rows, columns) {\n if (columns == null) columns = inferColumns(rows);\n return [columns.map(formatValue).join(delimiter)].concat(rows.map(function(row) {\n return columns.map(function(column) {\n return formatValue(row[column]);\n }).join(delimiter);\n })).join(\"\\n\");\n }\n\n function formatRows(rows) {\n return rows.map(formatRow).join(\"\\n\");\n }\n\n function formatRow(row) {\n return row.map(formatValue).join(delimiter);\n }\n\n function formatValue(text) {\n return text == null ? \"\"\n : reFormat.test(text += \"\") ? \"\\\"\" + text.replace(/\\\"/g, \"\\\"\\\"\") + \"\\\"\"\n : text;\n }\n\n return {\n parse: parse,\n parseRows: parseRows,\n format: format,\n formatRows: formatRows\n };\n }\n\n var csv = dsv(\",\");\n\n var csvParse = csv.parse;\n var csvParseRows = csv.parseRows;\n var csvFormat = csv.format;\n var csvFormatRows = csv.formatRows;\n\n var tsv = dsv(\"\\t\");\n\n var tsvParse = tsv.parse;\n var tsvParseRows = tsv.parseRows;\n var tsvFormat = tsv.format;\n var tsvFormatRows = tsv.formatRows;\n\n function request(url, callback) {\n var request,\n event = dispatch(\"beforesend\", \"progress\", \"load\", \"error\"),\n mimeType,\n headers = map$1(),\n xhr = new XMLHttpRequest,\n user = null,\n password = null,\n response,\n responseType,\n timeout = 0;\n\n // If IE does not support CORS, use XDomainRequest.\n if (typeof XDomainRequest !== \"undefined\"\n && !(\"withCredentials\" in xhr)\n && /^(http(s)?:)?\\/\\//.test(url)) xhr = new XDomainRequest;\n\n \"onload\" in xhr\n ? xhr.onload = xhr.onerror = xhr.ontimeout = respond\n : xhr.onreadystatechange = function(o) { xhr.readyState > 3 && respond(o); };\n\n function respond(o) {\n var status = xhr.status, result;\n if (!status && hasResponse(xhr)\n || status >= 200 && status < 300\n || status === 304) {\n if (response) {\n try {\n result = response.call(request, xhr);\n } catch (e) {\n event.call(\"error\", request, e);\n return;\n }\n } else {\n result = xhr;\n }\n event.call(\"load\", request, result);\n } else {\n event.call(\"error\", request, o);\n }\n }\n\n xhr.onprogress = function(e) {\n event.call(\"progress\", request, e);\n };\n\n request = {\n header: function(name, value) {\n name = (name + \"\").toLowerCase();\n if (arguments.length < 2) return headers.get(name);\n if (value == null) headers.remove(name);\n else headers.set(name, value + \"\");\n return request;\n },\n\n // If mimeType is non-null and no Accept header is set, a default is used.\n mimeType: function(value) {\n if (!arguments.length) return mimeType;\n mimeType = value == null ? null : value + \"\";\n return request;\n },\n\n // Specifies what type the response value should take;\n // for instance, arraybuffer, blob, document, or text.\n responseType: function(value) {\n if (!arguments.length) return responseType;\n responseType = value;\n return request;\n },\n\n timeout: function(value) {\n if (!arguments.length) return timeout;\n timeout = +value;\n return request;\n },\n\n user: function(value) {\n return arguments.length < 1 ? user : (user = value == null ? null : value + \"\", request);\n },\n\n password: function(value) {\n return arguments.length < 1 ? password : (password = value == null ? null : value + \"\", request);\n },\n\n // Specify how to convert the response content to a specific type;\n // changes the callback value on \"load\" events.\n response: function(value) {\n response = value;\n return request;\n },\n\n // Alias for send(\"GET\", …).\n get: function(data, callback) {\n return request.send(\"GET\", data, callback);\n },\n\n // Alias for send(\"POST\", …).\n post: function(data, callback) {\n return request.send(\"POST\", data, callback);\n },\n\n // If callback is non-null, it will be used for error and load events.\n send: function(method, data, callback) {\n xhr.open(method, url, true, user, password);\n if (mimeType != null && !headers.has(\"accept\")) headers.set(\"accept\", mimeType + \",*/*\");\n if (xhr.setRequestHeader) headers.each(function(value, name) { xhr.setRequestHeader(name, value); });\n if (mimeType != null && xhr.overrideMimeType) xhr.overrideMimeType(mimeType);\n if (responseType != null) xhr.responseType = responseType;\n if (timeout > 0) xhr.timeout = timeout;\n if (callback == null && typeof data === \"function\") callback = data, data = null;\n if (callback != null && callback.length === 1) callback = fixCallback(callback);\n if (callback != null) request.on(\"error\", callback).on(\"load\", function(xhr) { callback(null, xhr); });\n event.call(\"beforesend\", request, xhr);\n xhr.send(data == null ? null : data);\n return request;\n },\n\n abort: function() {\n xhr.abort();\n return request;\n },\n\n on: function() {\n var value = event.on.apply(event, arguments);\n return value === event ? request : value;\n }\n };\n\n if (callback != null) {\n if (typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n return request.get(callback);\n }\n\n return request;\n }\n\n function fixCallback(callback) {\n return function(error, xhr) {\n callback(error == null ? xhr : null);\n };\n }\n\n function hasResponse(xhr) {\n var type = xhr.responseType;\n return type && type !== \"text\"\n ? xhr.response // null on error\n : xhr.responseText; // \"\" on error\n }\n\n function type(defaultMimeType, response) {\n return function(url, callback) {\n var r = request(url).mimeType(defaultMimeType).response(response);\n if (callback != null) {\n if (typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n return r.get(callback);\n }\n return r;\n };\n }\n\n var html = type(\"text/html\", function(xhr) {\n return document.createRange().createContextualFragment(xhr.responseText);\n });\n\n var json = type(\"application/json\", function(xhr) {\n return JSON.parse(xhr.responseText);\n });\n\n var text = type(\"text/plain\", function(xhr) {\n return xhr.responseText;\n });\n\n var xml = type(\"application/xml\", function(xhr) {\n var xml = xhr.responseXML;\n if (!xml) throw new Error(\"parse error\");\n return xml;\n });\n\n function dsv$1(defaultMimeType, parse) {\n return function(url, row, callback) {\n if (arguments.length < 3) callback = row, row = null;\n var r = request(url).mimeType(defaultMimeType);\n r.row = function(_) { return arguments.length ? r.response(responseOf(parse, row = _)) : row; };\n r.row(row);\n return callback ? r.get(callback) : r;\n };\n }\n\n function responseOf(parse, row) {\n return function(request) {\n return parse(request.responseText, row);\n };\n }\n\n var csv$1 = dsv$1(\"text/csv\", csvParse);\n\n var tsv$1 = dsv$1(\"text/tab-separated-values\", tsvParse);\n\n var frame = 0;\n var timeout = 0;\n var interval = 0;\n var pokeDelay = 1000;\n var taskHead;\n var taskTail;\n var clockLast = 0;\n var clockNow = 0;\n var clockSkew = 0;\n var clock = typeof performance === \"object\" && performance.now ? performance : Date;\n var setFrame = typeof requestAnimationFrame === \"function\"\n ? (clock === Date ? function(f) { requestAnimationFrame(function() { f(clock.now()); }); } : requestAnimationFrame)\n : function(f) { setTimeout(f, 17); };\n function now() {\n return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);\n }\n\n function clearNow() {\n clockNow = 0;\n }\n\n function Timer() {\n this._call =\n this._time =\n this._next = null;\n }\n\n Timer.prototype = timer.prototype = {\n constructor: Timer,\n restart: function(callback, delay, time) {\n if (typeof callback !== \"function\") throw new TypeError(\"callback is not a function\");\n time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);\n if (!this._next && taskTail !== this) {\n if (taskTail) taskTail._next = this;\n else taskHead = this;\n taskTail = this;\n }\n this._call = callback;\n this._time = time;\n sleep();\n },\n stop: function() {\n if (this._call) {\n this._call = null;\n this._time = Infinity;\n sleep();\n }\n }\n };\n\n function timer(callback, delay, time) {\n var t = new Timer;\n t.restart(callback, delay, time);\n return t;\n }\n\n function timerFlush() {\n now(); // Get the current time, if not already set.\n ++frame; // Pretend we’ve set an alarm, if we haven’t already.\n var t = taskHead, e;\n while (t) {\n if ((e = clockNow - t._time) >= 0) t._call.call(null, e);\n t = t._next;\n }\n --frame;\n }\n\n function wake(time) {\n clockNow = (clockLast = time || clock.now()) + clockSkew;\n frame = timeout = 0;\n try {\n timerFlush();\n } finally {\n frame = 0;\n nap();\n clockNow = 0;\n }\n }\n\n function poke$1() {\n var now = clock.now(), delay = now - clockLast;\n if (delay > pokeDelay) clockSkew -= delay, clockLast = now;\n }\n\n function nap() {\n var t0, t1 = taskHead, t2, time = Infinity;\n while (t1) {\n if (t1._call) {\n if (time > t1._time) time = t1._time;\n t0 = t1, t1 = t1._next;\n } else {\n t2 = t1._next, t1._next = null;\n t1 = t0 ? t0._next = t2 : taskHead = t2;\n }\n }\n taskTail = t0;\n sleep(time);\n }\n\n function sleep(time) {\n if (frame) return; // Soonest alarm already set, or will be.\n if (timeout) timeout = clearTimeout(timeout);\n var delay = time - clockNow;\n if (delay > 24) {\n if (time < Infinity) timeout = setTimeout(wake, delay);\n if (interval) interval = clearInterval(interval);\n } else {\n if (!interval) interval = setInterval(poke$1, pokeDelay);\n frame = 1, setFrame(wake);\n }\n }\n\n function timeout$1(callback, delay, time) {\n var t = new Timer;\n delay = delay == null ? 0 : +delay;\n t.restart(function(elapsed) {\n t.stop();\n callback(elapsed + delay);\n }, delay, time);\n return t;\n }\n\n function interval$1(callback, delay, time) {\n var t = new Timer, total = delay;\n if (delay == null) return t.restart(callback, delay, time), t;\n delay = +delay, time = time == null ? now() : +time;\n t.restart(function tick(elapsed) {\n elapsed += total;\n t.restart(tick, total += delay, time);\n callback(elapsed);\n }, delay, time);\n return t;\n }\n\nvar t0$1 = new Date;\nvar t1$1 = new Date;\n function newInterval(floori, offseti, count, field) {\n\n function interval(date) {\n return floori(date = new Date(+date)), date;\n }\n\n interval.floor = interval;\n\n interval.ceil = function(date) {\n return floori(date = new Date(date - 1)), offseti(date, 1), floori(date), date;\n };\n\n interval.round = function(date) {\n var d0 = interval(date),\n d1 = interval.ceil(date);\n return date - d0 < d1 - date ? d0 : d1;\n };\n\n interval.offset = function(date, step) {\n return offseti(date = new Date(+date), step == null ? 1 : Math.floor(step)), date;\n };\n\n interval.range = function(start, stop, step) {\n var range = [];\n start = interval.ceil(start);\n step = step == null ? 1 : Math.floor(step);\n if (!(start < stop) || !(step > 0)) return range; // also handles Invalid Date\n do range.push(new Date(+start)); while (offseti(start, step), floori(start), start < stop)\n return range;\n };\n\n interval.filter = function(test) {\n return newInterval(function(date) {\n while (floori(date), !test(date)) date.setTime(date - 1);\n }, function(date, step) {\n while (--step >= 0) while (offseti(date, 1), !test(date));\n });\n };\n\n if (count) {\n interval.count = function(start, end) {\n t0$1.setTime(+start), t1$1.setTime(+end);\n floori(t0$1), floori(t1$1);\n return Math.floor(count(t0$1, t1$1));\n };\n\n interval.every = function(step) {\n step = Math.floor(step);\n return !isFinite(step) || !(step > 0) ? null\n : !(step > 1) ? interval\n : interval.filter(field\n ? function(d) { return field(d) % step === 0; }\n : function(d) { return interval.count(0, d) % step === 0; });\n };\n }\n\n return interval;\n }\n\n var millisecond = newInterval(function() {\n // noop\n }, function(date, step) {\n date.setTime(+date + step);\n }, function(start, end) {\n return end - start;\n });\n\n // An optimized implementation for this simple case.\n millisecond.every = function(k) {\n k = Math.floor(k);\n if (!isFinite(k) || !(k > 0)) return null;\n if (!(k > 1)) return millisecond;\n return newInterval(function(date) {\n date.setTime(Math.floor(date / k) * k);\n }, function(date, step) {\n date.setTime(+date + step * k);\n }, function(start, end) {\n return (end - start) / k;\n });\n };\n\n var milliseconds = millisecond.range;\n\n var durationSecond = 1e3;\n var durationMinute = 6e4;\n var durationHour = 36e5;\n var durationDay = 864e5;\n var durationWeek = 6048e5;\n\n var second = newInterval(function(date) {\n date.setTime(Math.floor(date / durationSecond) * durationSecond);\n }, function(date, step) {\n date.setTime(+date + step * durationSecond);\n }, function(start, end) {\n return (end - start) / durationSecond;\n }, function(date) {\n return date.getUTCSeconds();\n });\n\n var seconds = second.range;\n\n var minute = newInterval(function(date) {\n date.setTime(Math.floor(date / durationMinute) * durationMinute);\n }, function(date, step) {\n date.setTime(+date + step * durationMinute);\n }, function(start, end) {\n return (end - start) / durationMinute;\n }, function(date) {\n return date.getMinutes();\n });\n\n var minutes = minute.range;\n\n var hour = newInterval(function(date) {\n var offset = date.getTimezoneOffset() * durationMinute % durationHour;\n if (offset < 0) offset += durationHour;\n date.setTime(Math.floor((+date - offset) / durationHour) * durationHour + offset);\n }, function(date, step) {\n date.setTime(+date + step * durationHour);\n }, function(start, end) {\n return (end - start) / durationHour;\n }, function(date) {\n return date.getHours();\n });\n\n var hours = hour.range;\n\n var day = newInterval(function(date) {\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setDate(date.getDate() + step);\n }, function(start, end) {\n return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationDay;\n }, function(date) {\n return date.getDate() - 1;\n });\n\n var days = day.range;\n\n function weekday(i) {\n return newInterval(function(date) {\n date.setDate(date.getDate() - (date.getDay() + 7 - i) % 7);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setDate(date.getDate() + step * 7);\n }, function(start, end) {\n return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationWeek;\n });\n }\n\n var timeWeek = weekday(0);\n var timeMonday = weekday(1);\n var tuesday = weekday(2);\n var wednesday = weekday(3);\n var thursday = weekday(4);\n var friday = weekday(5);\n var saturday = weekday(6);\n\n var sundays = timeWeek.range;\n var mondays = timeMonday.range;\n var tuesdays = tuesday.range;\n var wednesdays = wednesday.range;\n var thursdays = thursday.range;\n var fridays = friday.range;\n var saturdays = saturday.range;\n\n var month = newInterval(function(date) {\n date.setDate(1);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setMonth(date.getMonth() + step);\n }, function(start, end) {\n return end.getMonth() - start.getMonth() + (end.getFullYear() - start.getFullYear()) * 12;\n }, function(date) {\n return date.getMonth();\n });\n\n var months = month.range;\n\n var year = newInterval(function(date) {\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setFullYear(date.getFullYear() + step);\n }, function(start, end) {\n return end.getFullYear() - start.getFullYear();\n }, function(date) {\n return date.getFullYear();\n });\n\n // An optimized implementation for this simple case.\n year.every = function(k) {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : newInterval(function(date) {\n date.setFullYear(Math.floor(date.getFullYear() / k) * k);\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setFullYear(date.getFullYear() + step * k);\n });\n };\n\n var years = year.range;\n\n var utcMinute = newInterval(function(date) {\n date.setUTCSeconds(0, 0);\n }, function(date, step) {\n date.setTime(+date + step * durationMinute);\n }, function(start, end) {\n return (end - start) / durationMinute;\n }, function(date) {\n return date.getUTCMinutes();\n });\n\n var utcMinutes = utcMinute.range;\n\n var utcHour = newInterval(function(date) {\n date.setUTCMinutes(0, 0, 0);\n }, function(date, step) {\n date.setTime(+date + step * durationHour);\n }, function(start, end) {\n return (end - start) / durationHour;\n }, function(date) {\n return date.getUTCHours();\n });\n\n var utcHours = utcHour.range;\n\n var utcDay = newInterval(function(date) {\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCDate(date.getUTCDate() + step);\n }, function(start, end) {\n return (end - start) / durationDay;\n }, function(date) {\n return date.getUTCDate() - 1;\n });\n\n var utcDays = utcDay.range;\n\n function utcWeekday(i) {\n return newInterval(function(date) {\n date.setUTCDate(date.getUTCDate() - (date.getUTCDay() + 7 - i) % 7);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCDate(date.getUTCDate() + step * 7);\n }, function(start, end) {\n return (end - start) / durationWeek;\n });\n }\n\n var utcWeek = utcWeekday(0);\n var utcMonday = utcWeekday(1);\n var utcTuesday = utcWeekday(2);\n var utcWednesday = utcWeekday(3);\n var utcThursday = utcWeekday(4);\n var utcFriday = utcWeekday(5);\n var utcSaturday = utcWeekday(6);\n\n var utcSundays = utcWeek.range;\n var utcMondays = utcMonday.range;\n var utcTuesdays = utcTuesday.range;\n var utcWednesdays = utcWednesday.range;\n var utcThursdays = utcThursday.range;\n var utcFridays = utcFriday.range;\n var utcSaturdays = utcSaturday.range;\n\n var utcMonth = newInterval(function(date) {\n date.setUTCDate(1);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCMonth(date.getUTCMonth() + step);\n }, function(start, end) {\n return end.getUTCMonth() - start.getUTCMonth() + (end.getUTCFullYear() - start.getUTCFullYear()) * 12;\n }, function(date) {\n return date.getUTCMonth();\n });\n\n var utcMonths = utcMonth.range;\n\n var utcYear = newInterval(function(date) {\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCFullYear(date.getUTCFullYear() + step);\n }, function(start, end) {\n return end.getUTCFullYear() - start.getUTCFullYear();\n }, function(date) {\n return date.getUTCFullYear();\n });\n\n // An optimized implementation for this simple case.\n utcYear.every = function(k) {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : newInterval(function(date) {\n date.setUTCFullYear(Math.floor(date.getUTCFullYear() / k) * k);\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCFullYear(date.getUTCFullYear() + step * k);\n });\n };\n\n var utcYears = utcYear.range;\n\n // Computes the decimal coefficient and exponent of the specified number x with\n // significant digits p, where x is positive and p is in [1, 21] or undefined.\n // For example, formatDecimal(1.23) returns [\"123\", 0].\n function formatDecimal(x, p) {\n if ((i = (x = p ? x.toExponential(p - 1) : x.toExponential()).indexOf(\"e\")) < 0) return null; // NaN, ±Infinity\n var i, coefficient = x.slice(0, i);\n\n // The string returned by toExponential either has the form \\d\\.\\d+e[-+]\\d+\n // (e.g., 1.2e+3) or the form \\de[-+]\\d+ (e.g., 1e+3).\n return [\n coefficient.length > 1 ? coefficient[0] + coefficient.slice(2) : coefficient,\n +x.slice(i + 1)\n ];\n }\n\n function exponent$1(x) {\n return x = formatDecimal(Math.abs(x)), x ? x[1] : NaN;\n }\n\n function formatGroup(grouping, thousands) {\n return function(value, width) {\n var i = value.length,\n t = [],\n j = 0,\n g = grouping[0],\n length = 0;\n\n while (i > 0 && g > 0) {\n if (length + g + 1 > width) g = Math.max(1, width - length);\n t.push(value.substring(i -= g, i + g));\n if ((length += g + 1) > width) break;\n g = grouping[j = (j + 1) % grouping.length];\n }\n\n return t.reverse().join(thousands);\n };\n }\n\n function formatDefault(x, p) {\n x = x.toPrecision(p);\n\n out: for (var n = x.length, i = 1, i0 = -1, i1; i < n; ++i) {\n switch (x[i]) {\n case \".\": i0 = i1 = i; break;\n case \"0\": if (i0 === 0) i0 = i; i1 = i; break;\n case \"e\": break out;\n default: if (i0 > 0) i0 = 0; break;\n }\n }\n\n return i0 > 0 ? x.slice(0, i0) + x.slice(i1 + 1) : x;\n }\n\n var prefixExponent;\n\n function formatPrefixAuto(x, p) {\n var d = formatDecimal(x, p);\n if (!d) return x + \"\";\n var coefficient = d[0],\n exponent = d[1],\n i = exponent - (prefixExponent = Math.max(-8, Math.min(8, Math.floor(exponent / 3))) * 3) + 1,\n n = coefficient.length;\n return i === n ? coefficient\n : i > n ? coefficient + new Array(i - n + 1).join(\"0\")\n : i > 0 ? coefficient.slice(0, i) + \".\" + coefficient.slice(i)\n : \"0.\" + new Array(1 - i).join(\"0\") + formatDecimal(x, Math.max(0, p + i - 1))[0]; // less than 1y!\n }\n\n function formatRounded(x, p) {\n var d = formatDecimal(x, p);\n if (!d) return x + \"\";\n var coefficient = d[0],\n exponent = d[1];\n return exponent < 0 ? \"0.\" + new Array(-exponent).join(\"0\") + coefficient\n : coefficient.length > exponent + 1 ? coefficient.slice(0, exponent + 1) + \".\" + coefficient.slice(exponent + 1)\n : coefficient + new Array(exponent - coefficient.length + 2).join(\"0\");\n }\n\n var formatTypes = {\n \"\": formatDefault,\n \"%\": function(x, p) { return (x * 100).toFixed(p); },\n \"b\": function(x) { return Math.round(x).toString(2); },\n \"c\": function(x) { return x + \"\"; },\n \"d\": function(x) { return Math.round(x).toString(10); },\n \"e\": function(x, p) { return x.toExponential(p); },\n \"f\": function(x, p) { return x.toFixed(p); },\n \"g\": function(x, p) { return x.toPrecision(p); },\n \"o\": function(x) { return Math.round(x).toString(8); },\n \"p\": function(x, p) { return formatRounded(x * 100, p); },\n \"r\": formatRounded,\n \"s\": formatPrefixAuto,\n \"X\": function(x) { return Math.round(x).toString(16).toUpperCase(); },\n \"x\": function(x) { return Math.round(x).toString(16); }\n };\n\n // [[fill]align][sign][symbol][0][width][,][.precision][type]\n var re = /^(?:(.)?([<>=^]))?([+\\-\\( ])?([$#])?(0)?(\\d+)?(,)?(\\.\\d+)?([a-z%])?$/i;\n\n function formatSpecifier(specifier) {\n return new FormatSpecifier(specifier);\n }\n\n function FormatSpecifier(specifier) {\n if (!(match = re.exec(specifier))) throw new Error(\"invalid format: \" + specifier);\n\n var match,\n fill = match[1] || \" \",\n align = match[2] || \">\",\n sign = match[3] || \"-\",\n symbol = match[4] || \"\",\n zero = !!match[5],\n width = match[6] && +match[6],\n comma = !!match[7],\n precision = match[8] && +match[8].slice(1),\n type = match[9] || \"\";\n\n // The \"n\" type is an alias for \",g\".\n if (type === \"n\") comma = true, type = \"g\";\n\n // Map invalid types to the default format.\n else if (!formatTypes[type]) type = \"\";\n\n // If zero fill is specified, padding goes after sign and before digits.\n if (zero || (fill === \"0\" && align === \"=\")) zero = true, fill = \"0\", align = \"=\";\n\n this.fill = fill;\n this.align = align;\n this.sign = sign;\n this.symbol = symbol;\n this.zero = zero;\n this.width = width;\n this.comma = comma;\n this.precision = precision;\n this.type = type;\n }\n\n FormatSpecifier.prototype.toString = function() {\n return this.fill\n + this.align\n + this.sign\n + this.symbol\n + (this.zero ? \"0\" : \"\")\n + (this.width == null ? \"\" : Math.max(1, this.width | 0))\n + (this.comma ? \",\" : \"\")\n + (this.precision == null ? \"\" : \".\" + Math.max(0, this.precision | 0))\n + this.type;\n };\n\n var prefixes = [\"y\",\"z\",\"a\",\"f\",\"p\",\"n\",\"\\xB5\",\"m\",\"\",\"k\",\"M\",\"G\",\"T\",\"P\",\"E\",\"Z\",\"Y\"];\n\n function identity$3(x) {\n return x;\n }\n\n function formatLocale(locale) {\n var group = locale.grouping && locale.thousands ? formatGroup(locale.grouping, locale.thousands) : identity$3,\n currency = locale.currency,\n decimal = locale.decimal;\n\n function newFormat(specifier) {\n specifier = formatSpecifier(specifier);\n\n var fill = specifier.fill,\n align = specifier.align,\n sign = specifier.sign,\n symbol = specifier.symbol,\n zero = specifier.zero,\n width = specifier.width,\n comma = specifier.comma,\n precision = specifier.precision,\n type = specifier.type;\n\n // Compute the prefix and suffix.\n // For SI-prefix, the suffix is lazily computed.\n var prefix = symbol === \"$\" ? currency[0] : symbol === \"#\" && /[boxX]/.test(type) ? \"0\" + type.toLowerCase() : \"\",\n suffix = symbol === \"$\" ? currency[1] : /[%p]/.test(type) ? \"%\" : \"\";\n\n // What format function should we use?\n // Is this an integer type?\n // Can this type generate exponential notation?\n var formatType = formatTypes[type],\n maybeSuffix = !type || /[defgprs%]/.test(type);\n\n // Set the default precision if not specified,\n // or clamp the specified precision to the supported range.\n // For significant precision, it must be in [1, 21].\n // For fixed precision, it must be in [0, 20].\n precision = precision == null ? (type ? 6 : 12)\n : /[gprs]/.test(type) ? Math.max(1, Math.min(21, precision))\n : Math.max(0, Math.min(20, precision));\n\n function format(value) {\n var valuePrefix = prefix,\n valueSuffix = suffix,\n i, n, c;\n\n if (type === \"c\") {\n valueSuffix = formatType(value) + valueSuffix;\n value = \"\";\n } else {\n value = +value;\n\n // Convert negative to positive, and compute the prefix.\n // Note that -0 is not less than 0, but 1 / -0 is!\n var valueNegative = (value < 0 || 1 / value < 0) && (value *= -1, true);\n\n // Perform the initial formatting.\n value = formatType(value, precision);\n\n // If the original value was negative, it may be rounded to zero during\n // formatting; treat this as (positive) zero.\n if (valueNegative) {\n i = -1, n = value.length;\n valueNegative = false;\n while (++i < n) {\n if (c = value.charCodeAt(i), (48 < c && c < 58)\n || (type === \"x\" && 96 < c && c < 103)\n || (type === \"X\" && 64 < c && c < 71)) {\n valueNegative = true;\n break;\n }\n }\n }\n\n // Compute the prefix and suffix.\n valuePrefix = (valueNegative ? (sign === \"(\" ? sign : \"-\") : sign === \"-\" || sign === \"(\" ? \"\" : sign) + valuePrefix;\n valueSuffix = valueSuffix + (type === \"s\" ? prefixes[8 + prefixExponent / 3] : \"\") + (valueNegative && sign === \"(\" ? \")\" : \"\");\n\n // Break the formatted value into the integer “value†part that can be\n // grouped, and fractional or exponential “suffix†part that is not.\n if (maybeSuffix) {\n i = -1, n = value.length;\n while (++i < n) {\n if (c = value.charCodeAt(i), 48 > c || c > 57) {\n valueSuffix = (c === 46 ? decimal + value.slice(i + 1) : value.slice(i)) + valueSuffix;\n value = value.slice(0, i);\n break;\n }\n }\n }\n }\n\n // If the fill character is not \"0\", grouping is applied before padding.\n if (comma && !zero) value = group(value, Infinity);\n\n // Compute the padding.\n var length = valuePrefix.length + value.length + valueSuffix.length,\n padding = length < width ? new Array(width - length + 1).join(fill) : \"\";\n\n // If the fill character is \"0\", grouping is applied after padding.\n if (comma && zero) value = group(padding + value, padding.length ? width - valueSuffix.length : Infinity), padding = \"\";\n\n // Reconstruct the final output based on the desired alignment.\n switch (align) {\n case \"<\": return valuePrefix + value + valueSuffix + padding;\n case \"=\": return valuePrefix + padding + value + valueSuffix;\n case \"^\": return padding.slice(0, length = padding.length >> 1) + valuePrefix + value + valueSuffix + padding.slice(length);\n }\n return padding + valuePrefix + value + valueSuffix;\n }\n\n format.toString = function() {\n return specifier + \"\";\n };\n\n return format;\n }\n\n function formatPrefix(specifier, value) {\n var f = newFormat((specifier = formatSpecifier(specifier), specifier.type = \"f\", specifier)),\n e = Math.max(-8, Math.min(8, Math.floor(exponent$1(value) / 3))) * 3,\n k = Math.pow(10, -e),\n prefix = prefixes[8 + e / 3];\n return function(value) {\n return f(k * value) + prefix;\n };\n }\n\n return {\n format: newFormat,\n formatPrefix: formatPrefix\n };\n }\n\n var locale;\n exports.format;\n exports.formatPrefix;\n\n defaultLocale({\n decimal: \".\",\n thousands: \",\",\n grouping: [3],\n currency: [\"$\", \"\"]\n });\n\n function defaultLocale(definition) {\n locale = formatLocale(definition);\n exports.format = locale.format;\n exports.formatPrefix = locale.formatPrefix;\n return locale;\n }\n\n function precisionFixed(step) {\n return Math.max(0, -exponent$1(Math.abs(step)));\n }\n\n function precisionPrefix(step, value) {\n return Math.max(0, Math.max(-8, Math.min(8, Math.floor(exponent$1(value) / 3))) * 3 - exponent$1(Math.abs(step)));\n }\n\n function precisionRound(step, max) {\n step = Math.abs(step), max = Math.abs(max) - step;\n return Math.max(0, exponent$1(max) - exponent$1(step)) + 1;\n }\n\n function localDate(d) {\n if (0 <= d.y && d.y < 100) {\n var date = new Date(-1, d.m, d.d, d.H, d.M, d.S, d.L);\n date.setFullYear(d.y);\n return date;\n }\n return new Date(d.y, d.m, d.d, d.H, d.M, d.S, d.L);\n }\n\n function utcDate(d) {\n if (0 <= d.y && d.y < 100) {\n var date = new Date(Date.UTC(-1, d.m, d.d, d.H, d.M, d.S, d.L));\n date.setUTCFullYear(d.y);\n return date;\n }\n return new Date(Date.UTC(d.y, d.m, d.d, d.H, d.M, d.S, d.L));\n }\n\n function newYear(y) {\n return {y: y, m: 0, d: 1, H: 0, M: 0, S: 0, L: 0};\n }\n\n function formatLocale$1(locale) {\n var locale_dateTime = locale.dateTime,\n locale_date = locale.date,\n locale_time = locale.time,\n locale_periods = locale.periods,\n locale_weekdays = locale.days,\n locale_shortWeekdays = locale.shortDays,\n locale_months = locale.months,\n locale_shortMonths = locale.shortMonths;\n\n var periodRe = formatRe(locale_periods),\n periodLookup = formatLookup(locale_periods),\n weekdayRe = formatRe(locale_weekdays),\n weekdayLookup = formatLookup(locale_weekdays),\n shortWeekdayRe = formatRe(locale_shortWeekdays),\n shortWeekdayLookup = formatLookup(locale_shortWeekdays),\n monthRe = formatRe(locale_months),\n monthLookup = formatLookup(locale_months),\n shortMonthRe = formatRe(locale_shortMonths),\n shortMonthLookup = formatLookup(locale_shortMonths);\n\n var formats = {\n \"a\": formatShortWeekday,\n \"A\": formatWeekday,\n \"b\": formatShortMonth,\n \"B\": formatMonth,\n \"c\": null,\n \"d\": formatDayOfMonth,\n \"e\": formatDayOfMonth,\n \"H\": formatHour24,\n \"I\": formatHour12,\n \"j\": formatDayOfYear,\n \"L\": formatMilliseconds,\n \"m\": formatMonthNumber,\n \"M\": formatMinutes,\n \"p\": formatPeriod,\n \"S\": formatSeconds,\n \"U\": formatWeekNumberSunday,\n \"w\": formatWeekdayNumber,\n \"W\": formatWeekNumberMonday,\n \"x\": null,\n \"X\": null,\n \"y\": formatYear,\n \"Y\": formatFullYear,\n \"Z\": formatZone,\n \"%\": formatLiteralPercent\n };\n\n var utcFormats = {\n \"a\": formatUTCShortWeekday,\n \"A\": formatUTCWeekday,\n \"b\": formatUTCShortMonth,\n \"B\": formatUTCMonth,\n \"c\": null,\n \"d\": formatUTCDayOfMonth,\n \"e\": formatUTCDayOfMonth,\n \"H\": formatUTCHour24,\n \"I\": formatUTCHour12,\n \"j\": formatUTCDayOfYear,\n \"L\": formatUTCMilliseconds,\n \"m\": formatUTCMonthNumber,\n \"M\": formatUTCMinutes,\n \"p\": formatUTCPeriod,\n \"S\": formatUTCSeconds,\n \"U\": formatUTCWeekNumberSunday,\n \"w\": formatUTCWeekdayNumber,\n \"W\": formatUTCWeekNumberMonday,\n \"x\": null,\n \"X\": null,\n \"y\": formatUTCYear,\n \"Y\": formatUTCFullYear,\n \"Z\": formatUTCZone,\n \"%\": formatLiteralPercent\n };\n\n var parses = {\n \"a\": parseShortWeekday,\n \"A\": parseWeekday,\n \"b\": parseShortMonth,\n \"B\": parseMonth,\n \"c\": parseLocaleDateTime,\n \"d\": parseDayOfMonth,\n \"e\": parseDayOfMonth,\n \"H\": parseHour24,\n \"I\": parseHour24,\n \"j\": parseDayOfYear,\n \"L\": parseMilliseconds,\n \"m\": parseMonthNumber,\n \"M\": parseMinutes,\n \"p\": parsePeriod,\n \"S\": parseSeconds,\n \"U\": parseWeekNumberSunday,\n \"w\": parseWeekdayNumber,\n \"W\": parseWeekNumberMonday,\n \"x\": parseLocaleDate,\n \"X\": parseLocaleTime,\n \"y\": parseYear,\n \"Y\": parseFullYear,\n \"Z\": parseZone,\n \"%\": parseLiteralPercent\n };\n\n // These recursive directive definitions must be deferred.\n formats.x = newFormat(locale_date, formats);\n formats.X = newFormat(locale_time, formats);\n formats.c = newFormat(locale_dateTime, formats);\n utcFormats.x = newFormat(locale_date, utcFormats);\n utcFormats.X = newFormat(locale_time, utcFormats);\n utcFormats.c = newFormat(locale_dateTime, utcFormats);\n\n function newFormat(specifier, formats) {\n return function(date) {\n var string = [],\n i = -1,\n j = 0,\n n = specifier.length,\n c,\n pad,\n format;\n\n if (!(date instanceof Date)) date = new Date(+date);\n\n while (++i < n) {\n if (specifier.charCodeAt(i) === 37) {\n string.push(specifier.slice(j, i));\n if ((pad = pads[c = specifier.charAt(++i)]) != null) c = specifier.charAt(++i);\n else pad = c === \"e\" ? \" \" : \"0\";\n if (format = formats[c]) c = format(date, pad);\n string.push(c);\n j = i + 1;\n }\n }\n\n string.push(specifier.slice(j, i));\n return string.join(\"\");\n };\n }\n\n function newParse(specifier, newDate) {\n return function(string) {\n var d = newYear(1900),\n i = parseSpecifier(d, specifier, string += \"\", 0);\n if (i != string.length) return null;\n\n // The am-pm flag is 0 for AM, and 1 for PM.\n if (\"p\" in d) d.H = d.H % 12 + d.p * 12;\n\n // Convert day-of-week and week-of-year to day-of-year.\n if (\"W\" in d || \"U\" in d) {\n if (!(\"w\" in d)) d.w = \"W\" in d ? 1 : 0;\n var day = \"Z\" in d ? utcDate(newYear(d.y)).getUTCDay() : newDate(newYear(d.y)).getDay();\n d.m = 0;\n d.d = \"W\" in d ? (d.w + 6) % 7 + d.W * 7 - (day + 5) % 7 : d.w + d.U * 7 - (day + 6) % 7;\n }\n\n // If a time zone is specified, all fields are interpreted as UTC and then\n // offset according to the specified time zone.\n if (\"Z\" in d) {\n d.H += d.Z / 100 | 0;\n d.M += d.Z % 100;\n return utcDate(d);\n }\n\n // Otherwise, all fields are in local time.\n return newDate(d);\n };\n }\n\n function parseSpecifier(d, specifier, string, j) {\n var i = 0,\n n = specifier.length,\n m = string.length,\n c,\n parse;\n\n while (i < n) {\n if (j >= m) return -1;\n c = specifier.charCodeAt(i++);\n if (c === 37) {\n c = specifier.charAt(i++);\n parse = parses[c in pads ? specifier.charAt(i++) : c];\n if (!parse || ((j = parse(d, string, j)) < 0)) return -1;\n } else if (c != string.charCodeAt(j++)) {\n return -1;\n }\n }\n\n return j;\n }\n\n function parsePeriod(d, string, i) {\n var n = periodRe.exec(string.slice(i));\n return n ? (d.p = periodLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseShortWeekday(d, string, i) {\n var n = shortWeekdayRe.exec(string.slice(i));\n return n ? (d.w = shortWeekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseWeekday(d, string, i) {\n var n = weekdayRe.exec(string.slice(i));\n return n ? (d.w = weekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseShortMonth(d, string, i) {\n var n = shortMonthRe.exec(string.slice(i));\n return n ? (d.m = shortMonthLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseMonth(d, string, i) {\n var n = monthRe.exec(string.slice(i));\n return n ? (d.m = monthLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseLocaleDateTime(d, string, i) {\n return parseSpecifier(d, locale_dateTime, string, i);\n }\n\n function parseLocaleDate(d, string, i) {\n return parseSpecifier(d, locale_date, string, i);\n }\n\n function parseLocaleTime(d, string, i) {\n return parseSpecifier(d, locale_time, string, i);\n }\n\n function formatShortWeekday(d) {\n return locale_shortWeekdays[d.getDay()];\n }\n\n function formatWeekday(d) {\n return locale_weekdays[d.getDay()];\n }\n\n function formatShortMonth(d) {\n return locale_shortMonths[d.getMonth()];\n }\n\n function formatMonth(d) {\n return locale_months[d.getMonth()];\n }\n\n function formatPeriod(d) {\n return locale_periods[+(d.getHours() >= 12)];\n }\n\n function formatUTCShortWeekday(d) {\n return locale_shortWeekdays[d.getUTCDay()];\n }\n\n function formatUTCWeekday(d) {\n return locale_weekdays[d.getUTCDay()];\n }\n\n function formatUTCShortMonth(d) {\n return locale_shortMonths[d.getUTCMonth()];\n }\n\n function formatUTCMonth(d) {\n return locale_months[d.getUTCMonth()];\n }\n\n function formatUTCPeriod(d) {\n return locale_periods[+(d.getUTCHours() >= 12)];\n }\n\n return {\n format: function(specifier) {\n var f = newFormat(specifier += \"\", formats);\n f.toString = function() { return specifier; };\n return f;\n },\n parse: function(specifier) {\n var p = newParse(specifier += \"\", localDate);\n p.toString = function() { return specifier; };\n return p;\n },\n utcFormat: function(specifier) {\n var f = newFormat(specifier += \"\", utcFormats);\n f.toString = function() { return specifier; };\n return f;\n },\n utcParse: function(specifier) {\n var p = newParse(specifier, utcDate);\n p.toString = function() { return specifier; };\n return p;\n }\n };\n }\n\n var pads = {\"-\": \"\", \"_\": \" \", \"0\": \"0\"};\n var numberRe = /^\\s*\\d+/;\n var percentRe = /^%/;\n var requoteRe = /[\\\\\\^\\$\\*\\+\\?\\|\\[\\]\\(\\)\\.\\{\\}]/g;\n function pad(value, fill, width) {\n var sign = value < 0 ? \"-\" : \"\",\n string = (sign ? -value : value) + \"\",\n length = string.length;\n return sign + (length < width ? new Array(width - length + 1).join(fill) + string : string);\n }\n\n function requote(s) {\n return s.replace(requoteRe, \"\\\\$&\");\n }\n\n function formatRe(names) {\n return new RegExp(\"^(?:\" + names.map(requote).join(\"|\") + \")\", \"i\");\n }\n\n function formatLookup(names) {\n var map = {}, i = -1, n = names.length;\n while (++i < n) map[names[i].toLowerCase()] = i;\n return map;\n }\n\n function parseWeekdayNumber(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 1));\n return n ? (d.w = +n[0], i + n[0].length) : -1;\n }\n\n function parseWeekNumberSunday(d, string, i) {\n var n = numberRe.exec(string.slice(i));\n return n ? (d.U = +n[0], i + n[0].length) : -1;\n }\n\n function parseWeekNumberMonday(d, string, i) {\n var n = numberRe.exec(string.slice(i));\n return n ? (d.W = +n[0], i + n[0].length) : -1;\n }\n\n function parseFullYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 4));\n return n ? (d.y = +n[0], i + n[0].length) : -1;\n }\n\n function parseYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.y = +n[0] + (+n[0] > 68 ? 1900 : 2000), i + n[0].length) : -1;\n }\n\n function parseZone(d, string, i) {\n var n = /^(Z)|([+-]\\d\\d)(?:\\:?(\\d\\d))?/.exec(string.slice(i, i + 6));\n return n ? (d.Z = n[1] ? 0 : -(n[2] + (n[3] || \"00\")), i + n[0].length) : -1;\n }\n\n function parseMonthNumber(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.m = n[0] - 1, i + n[0].length) : -1;\n }\n\n function parseDayOfMonth(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.d = +n[0], i + n[0].length) : -1;\n }\n\n function parseDayOfYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 3));\n return n ? (d.m = 0, d.d = +n[0], i + n[0].length) : -1;\n }\n\n function parseHour24(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.H = +n[0], i + n[0].length) : -1;\n }\n\n function parseMinutes(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.M = +n[0], i + n[0].length) : -1;\n }\n\n function parseSeconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.S = +n[0], i + n[0].length) : -1;\n }\n\n function parseMilliseconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 3));\n return n ? (d.L = +n[0], i + n[0].length) : -1;\n }\n\n function parseLiteralPercent(d, string, i) {\n var n = percentRe.exec(string.slice(i, i + 1));\n return n ? i + n[0].length : -1;\n }\n\n function formatDayOfMonth(d, p) {\n return pad(d.getDate(), p, 2);\n }\n\n function formatHour24(d, p) {\n return pad(d.getHours(), p, 2);\n }\n\n function formatHour12(d, p) {\n return pad(d.getHours() % 12 || 12, p, 2);\n }\n\n function formatDayOfYear(d, p) {\n return pad(1 + day.count(year(d), d), p, 3);\n }\n\n function formatMilliseconds(d, p) {\n return pad(d.getMilliseconds(), p, 3);\n }\n\n function formatMonthNumber(d, p) {\n return pad(d.getMonth() + 1, p, 2);\n }\n\n function formatMinutes(d, p) {\n return pad(d.getMinutes(), p, 2);\n }\n\n function formatSeconds(d, p) {\n return pad(d.getSeconds(), p, 2);\n }\n\n function formatWeekNumberSunday(d, p) {\n return pad(timeWeek.count(year(d), d), p, 2);\n }\n\n function formatWeekdayNumber(d) {\n return d.getDay();\n }\n\n function formatWeekNumberMonday(d, p) {\n return pad(timeMonday.count(year(d), d), p, 2);\n }\n\n function formatYear(d, p) {\n return pad(d.getFullYear() % 100, p, 2);\n }\n\n function formatFullYear(d, p) {\n return pad(d.getFullYear() % 10000, p, 4);\n }\n\n function formatZone(d) {\n var z = d.getTimezoneOffset();\n return (z > 0 ? \"-\" : (z *= -1, \"+\"))\n + pad(z / 60 | 0, \"0\", 2)\n + pad(z % 60, \"0\", 2);\n }\n\n function formatUTCDayOfMonth(d, p) {\n return pad(d.getUTCDate(), p, 2);\n }\n\n function formatUTCHour24(d, p) {\n return pad(d.getUTCHours(), p, 2);\n }\n\n function formatUTCHour12(d, p) {\n return pad(d.getUTCHours() % 12 || 12, p, 2);\n }\n\n function formatUTCDayOfYear(d, p) {\n return pad(1 + utcDay.count(utcYear(d), d), p, 3);\n }\n\n function formatUTCMilliseconds(d, p) {\n return pad(d.getUTCMilliseconds(), p, 3);\n }\n\n function formatUTCMonthNumber(d, p) {\n return pad(d.getUTCMonth() + 1, p, 2);\n }\n\n function formatUTCMinutes(d, p) {\n return pad(d.getUTCMinutes(), p, 2);\n }\n\n function formatUTCSeconds(d, p) {\n return pad(d.getUTCSeconds(), p, 2);\n }\n\n function formatUTCWeekNumberSunday(d, p) {\n return pad(utcWeek.count(utcYear(d), d), p, 2);\n }\n\n function formatUTCWeekdayNumber(d) {\n return d.getUTCDay();\n }\n\n function formatUTCWeekNumberMonday(d, p) {\n return pad(utcMonday.count(utcYear(d), d), p, 2);\n }\n\n function formatUTCYear(d, p) {\n return pad(d.getUTCFullYear() % 100, p, 2);\n }\n\n function formatUTCFullYear(d, p) {\n return pad(d.getUTCFullYear() % 10000, p, 4);\n }\n\n function formatUTCZone() {\n return \"+0000\";\n }\n\n function formatLiteralPercent() {\n return \"%\";\n }\n\n var locale$1;\n exports.timeFormat;\n exports.timeParse;\n exports.utcFormat;\n exports.utcParse;\n\n defaultLocale$1({\n dateTime: \"%x, %X\",\n date: \"%-m/%-d/%Y\",\n time: \"%-I:%M:%S %p\",\n periods: [\"AM\", \"PM\"],\n days: [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\"],\n shortDays: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n months: [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"],\n shortMonths: [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"]\n });\n\n function defaultLocale$1(definition) {\n locale$1 = formatLocale$1(definition);\n exports.timeFormat = locale$1.format;\n exports.timeParse = locale$1.parse;\n exports.utcFormat = locale$1.utcFormat;\n exports.utcParse = locale$1.utcParse;\n return locale$1;\n }\n\n var isoSpecifier = \"%Y-%m-%dT%H:%M:%S.%LZ\";\n\n function formatIsoNative(date) {\n return date.toISOString();\n }\n\n var formatIso = Date.prototype.toISOString\n ? formatIsoNative\n : exports.utcFormat(isoSpecifier);\n\n function parseIsoNative(string) {\n var date = new Date(string);\n return isNaN(date) ? null : date;\n }\n\n var parseIso = +new Date(\"2000-01-01T00:00:00.000Z\")\n ? parseIsoNative\n : exports.utcParse(isoSpecifier);\n\n var array$2 = Array.prototype;\n\n var map$2 = array$2.map;\n var slice$3 = array$2.slice;\n\n var implicit = {name: \"implicit\"};\n\n function ordinal(range) {\n var index = map$1(),\n domain = [],\n unknown = implicit;\n\n range = range == null ? [] : slice$3.call(range);\n\n function scale(d) {\n var key = d + \"\", i = index.get(key);\n if (!i) {\n if (unknown !== implicit) return unknown;\n index.set(key, i = domain.push(d));\n }\n return range[(i - 1) % range.length];\n }\n\n scale.domain = function(_) {\n if (!arguments.length) return domain.slice();\n domain = [], index = map$1();\n var i = -1, n = _.length, d, key;\n while (++i < n) if (!index.has(key = (d = _[i]) + \"\")) index.set(key, domain.push(d));\n return scale;\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = slice$3.call(_), scale) : range.slice();\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n scale.copy = function() {\n return ordinal()\n .domain(domain)\n .range(range)\n .unknown(unknown);\n };\n\n return scale;\n }\n\n function band() {\n var scale = ordinal().unknown(undefined),\n domain = scale.domain,\n ordinalRange = scale.range,\n range$$ = [0, 1],\n step,\n bandwidth,\n round = false,\n paddingInner = 0,\n paddingOuter = 0,\n align = 0.5;\n\n delete scale.unknown;\n\n function rescale() {\n var n = domain().length,\n reverse = range$$[1] < range$$[0],\n start = range$$[reverse - 0],\n stop = range$$[1 - reverse];\n step = (stop - start) / Math.max(1, n - paddingInner + paddingOuter * 2);\n if (round) step = Math.floor(step);\n start += (stop - start - step * (n - paddingInner)) * align;\n bandwidth = step * (1 - paddingInner);\n if (round) start = Math.round(start), bandwidth = Math.round(bandwidth);\n var values = range(n).map(function(i) { return start + step * i; });\n return ordinalRange(reverse ? values.reverse() : values);\n }\n\n scale.domain = function(_) {\n return arguments.length ? (domain(_), rescale()) : domain();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range$$ = [+_[0], +_[1]], rescale()) : range$$.slice();\n };\n\n scale.rangeRound = function(_) {\n return range$$ = [+_[0], +_[1]], round = true, rescale();\n };\n\n scale.bandwidth = function() {\n return bandwidth;\n };\n\n scale.step = function() {\n return step;\n };\n\n scale.round = function(_) {\n return arguments.length ? (round = !!_, rescale()) : round;\n };\n\n scale.padding = function(_) {\n return arguments.length ? (paddingInner = paddingOuter = Math.max(0, Math.min(1, _)), rescale()) : paddingInner;\n };\n\n scale.paddingInner = function(_) {\n return arguments.length ? (paddingInner = Math.max(0, Math.min(1, _)), rescale()) : paddingInner;\n };\n\n scale.paddingOuter = function(_) {\n return arguments.length ? (paddingOuter = Math.max(0, Math.min(1, _)), rescale()) : paddingOuter;\n };\n\n scale.align = function(_) {\n return arguments.length ? (align = Math.max(0, Math.min(1, _)), rescale()) : align;\n };\n\n scale.copy = function() {\n return band()\n .domain(domain())\n .range(range$$)\n .round(round)\n .paddingInner(paddingInner)\n .paddingOuter(paddingOuter)\n .align(align);\n };\n\n return rescale();\n }\n\n function pointish(scale) {\n var copy = scale.copy;\n\n scale.padding = scale.paddingOuter;\n delete scale.paddingInner;\n delete scale.paddingOuter;\n\n scale.copy = function() {\n return pointish(copy());\n };\n\n return scale;\n }\n\n function point$4() {\n return pointish(band().paddingInner(1));\n }\n\n function constant$3(x) {\n return function() {\n return x;\n };\n }\n\n function number$1(x) {\n return +x;\n }\n\n var unit = [0, 1];\n\n function deinterpolate(a, b) {\n return (b -= (a = +a))\n ? function(x) { return (x - a) / b; }\n : constant$3(b);\n }\n\n function deinterpolateClamp(deinterpolate) {\n return function(a, b) {\n var d = deinterpolate(a = +a, b = +b);\n return function(x) { return x <= a ? 0 : x >= b ? 1 : d(x); };\n };\n }\n\n function reinterpolateClamp(reinterpolate) {\n return function(a, b) {\n var r = reinterpolate(a = +a, b = +b);\n return function(t) { return t <= 0 ? a : t >= 1 ? b : r(t); };\n };\n }\n\n function bimap(domain, range, deinterpolate, reinterpolate) {\n var d0 = domain[0], d1 = domain[1], r0 = range[0], r1 = range[1];\n if (d1 < d0) d0 = deinterpolate(d1, d0), r0 = reinterpolate(r1, r0);\n else d0 = deinterpolate(d0, d1), r0 = reinterpolate(r0, r1);\n return function(x) { return r0(d0(x)); };\n }\n\n function polymap(domain, range, deinterpolate, reinterpolate) {\n var j = Math.min(domain.length, range.length) - 1,\n d = new Array(j),\n r = new Array(j),\n i = -1;\n\n // Reverse descending domains.\n if (domain[j] < domain[0]) {\n domain = domain.slice().reverse();\n range = range.slice().reverse();\n }\n\n while (++i < j) {\n d[i] = deinterpolate(domain[i], domain[i + 1]);\n r[i] = reinterpolate(range[i], range[i + 1]);\n }\n\n return function(x) {\n var i = bisectRight(domain, x, 1, j) - 1;\n return r[i](d[i](x));\n };\n }\n\n function copy(source, target) {\n return target\n .domain(source.domain())\n .range(source.range())\n .interpolate(source.interpolate())\n .clamp(source.clamp());\n }\n\n // deinterpolate(a, b)(x) takes a domain value x in [a,b] and returns the corresponding parameter t in [0,1].\n // reinterpolate(a, b)(t) takes a parameter t in [0,1] and returns the corresponding domain value x in [a,b].\n function continuous(deinterpolate$$, reinterpolate) {\n var domain = unit,\n range = unit,\n interpolate$$ = interpolate,\n clamp = false,\n piecewise,\n output,\n input;\n\n function rescale() {\n piecewise = Math.min(domain.length, range.length) > 2 ? polymap : bimap;\n output = input = null;\n return scale;\n }\n\n function scale(x) {\n return (output || (output = piecewise(domain, range, clamp ? deinterpolateClamp(deinterpolate$$) : deinterpolate$$, interpolate$$)))(+x);\n }\n\n scale.invert = function(y) {\n return (input || (input = piecewise(range, domain, deinterpolate, clamp ? reinterpolateClamp(reinterpolate) : reinterpolate)))(+y);\n };\n\n scale.domain = function(_) {\n return arguments.length ? (domain = map$2.call(_, number$1), rescale()) : domain.slice();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = slice$3.call(_), rescale()) : range.slice();\n };\n\n scale.rangeRound = function(_) {\n return range = slice$3.call(_), interpolate$$ = interpolateRound, rescale();\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (clamp = !!_, rescale()) : clamp;\n };\n\n scale.interpolate = function(_) {\n return arguments.length ? (interpolate$$ = _, rescale()) : interpolate$$;\n };\n\n return rescale();\n }\n\n function tickFormat(domain, count, specifier) {\n var start = domain[0],\n stop = domain[domain.length - 1],\n step = tickStep(start, stop, count == null ? 10 : count),\n precision;\n specifier = formatSpecifier(specifier == null ? \",f\" : specifier);\n switch (specifier.type) {\n case \"s\": {\n var value = Math.max(Math.abs(start), Math.abs(stop));\n if (specifier.precision == null && !isNaN(precision = precisionPrefix(step, value))) specifier.precision = precision;\n return exports.formatPrefix(specifier, value);\n }\n case \"\":\n case \"e\":\n case \"g\":\n case \"p\":\n case \"r\": {\n if (specifier.precision == null && !isNaN(precision = precisionRound(step, Math.max(Math.abs(start), Math.abs(stop))))) specifier.precision = precision - (specifier.type === \"e\");\n break;\n }\n case \"f\":\n case \"%\": {\n if (specifier.precision == null && !isNaN(precision = precisionFixed(step))) specifier.precision = precision - (specifier.type === \"%\") * 2;\n break;\n }\n }\n return exports.format(specifier);\n }\n\n function linearish(scale) {\n var domain = scale.domain;\n\n scale.ticks = function(count) {\n var d = domain();\n return ticks(d[0], d[d.length - 1], count == null ? 10 : count);\n };\n\n scale.tickFormat = function(count, specifier) {\n return tickFormat(domain(), count, specifier);\n };\n\n scale.nice = function(count) {\n var d = domain(),\n i = d.length - 1,\n n = count == null ? 10 : count,\n start = d[0],\n stop = d[i],\n step = tickStep(start, stop, n);\n\n if (step) {\n step = tickStep(Math.floor(start / step) * step, Math.ceil(stop / step) * step, n);\n d[0] = Math.floor(start / step) * step;\n d[i] = Math.ceil(stop / step) * step;\n domain(d);\n }\n\n return scale;\n };\n\n return scale;\n }\n\n function linear$2() {\n var scale = continuous(deinterpolate, interpolateNumber);\n\n scale.copy = function() {\n return copy(scale, linear$2());\n };\n\n return linearish(scale);\n }\n\n function identity$4() {\n var domain = [0, 1];\n\n function scale(x) {\n return +x;\n }\n\n scale.invert = scale;\n\n scale.domain = scale.range = function(_) {\n return arguments.length ? (domain = map$2.call(_, number$1), scale) : domain.slice();\n };\n\n scale.copy = function() {\n return identity$4().domain(domain);\n };\n\n return linearish(scale);\n }\n\n function nice(domain, interval) {\n domain = domain.slice();\n\n var i0 = 0,\n i1 = domain.length - 1,\n x0 = domain[i0],\n x1 = domain[i1],\n t;\n\n if (x1 < x0) {\n t = i0, i0 = i1, i1 = t;\n t = x0, x0 = x1, x1 = t;\n }\n\n domain[i0] = interval.floor(x0);\n domain[i1] = interval.ceil(x1);\n return domain;\n }\n\n function deinterpolate$1(a, b) {\n return (b = Math.log(b / a))\n ? function(x) { return Math.log(x / a) / b; }\n : constant$3(b);\n }\n\n function reinterpolate(a, b) {\n return a < 0\n ? function(t) { return -Math.pow(-b, t) * Math.pow(-a, 1 - t); }\n : function(t) { return Math.pow(b, t) * Math.pow(a, 1 - t); };\n }\n\n function pow10(x) {\n return isFinite(x) ? +(\"1e\" + x) : x < 0 ? 0 : x;\n }\n\n function powp(base) {\n return base === 10 ? pow10\n : base === Math.E ? Math.exp\n : function(x) { return Math.pow(base, x); };\n }\n\n function logp(base) {\n return base === Math.E ? Math.log\n : base === 10 && Math.log10\n || base === 2 && Math.log2\n || (base = Math.log(base), function(x) { return Math.log(x) / base; });\n }\n\n function reflect(f) {\n return function(x) {\n return -f(-x);\n };\n }\n\n function log() {\n var scale = continuous(deinterpolate$1, reinterpolate).domain([1, 10]),\n domain = scale.domain,\n base = 10,\n logs = logp(10),\n pows = powp(10);\n\n function rescale() {\n logs = logp(base), pows = powp(base);\n if (domain()[0] < 0) logs = reflect(logs), pows = reflect(pows);\n return scale;\n }\n\n scale.base = function(_) {\n return arguments.length ? (base = +_, rescale()) : base;\n };\n\n scale.domain = function(_) {\n return arguments.length ? (domain(_), rescale()) : domain();\n };\n\n scale.ticks = function(count) {\n var d = domain(),\n u = d[0],\n v = d[d.length - 1],\n r;\n\n if (r = v < u) i = u, u = v, v = i;\n\n var i = logs(u),\n j = logs(v),\n p,\n k,\n t,\n n = count == null ? 10 : +count,\n z = [];\n\n if (!(base % 1) && j - i < n) {\n i = Math.round(i) - 1, j = Math.round(j) + 1;\n if (u > 0) for (; i < j; ++i) {\n for (k = 1, p = pows(i); k < base; ++k) {\n t = p * k;\n if (t < u) continue;\n if (t > v) break;\n z.push(t);\n }\n } else for (; i < j; ++i) {\n for (k = base - 1, p = pows(i); k >= 1; --k) {\n t = p * k;\n if (t < u) continue;\n if (t > v) break;\n z.push(t);\n }\n }\n } else {\n z = ticks(i, j, Math.min(j - i, n)).map(pows);\n }\n\n return r ? z.reverse() : z;\n };\n\n scale.tickFormat = function(count, specifier) {\n if (specifier == null) specifier = base === 10 ? \".0e\" : \",\";\n if (typeof specifier !== \"function\") specifier = exports.format(specifier);\n if (count === Infinity) return specifier;\n if (count == null) count = 10;\n var k = Math.max(1, base * count / scale.ticks().length); // TODO fast estimate?\n return function(d) {\n var i = d / pows(Math.round(logs(d)));\n if (i * base < base - 0.5) i *= base;\n return i <= k ? specifier(d) : \"\";\n };\n };\n\n scale.nice = function() {\n return domain(nice(domain(), {\n floor: function(x) { return pows(Math.floor(logs(x))); },\n ceil: function(x) { return pows(Math.ceil(logs(x))); }\n }));\n };\n\n scale.copy = function() {\n return copy(scale, log().base(base));\n };\n\n return scale;\n }\n\n function raise(x, exponent) {\n return x < 0 ? -Math.pow(-x, exponent) : Math.pow(x, exponent);\n }\n\n function pow() {\n var exponent = 1,\n scale = continuous(deinterpolate, reinterpolate),\n domain = scale.domain;\n\n function deinterpolate(a, b) {\n return (b = raise(b, exponent) - (a = raise(a, exponent)))\n ? function(x) { return (raise(x, exponent) - a) / b; }\n : constant$3(b);\n }\n\n function reinterpolate(a, b) {\n b = raise(b, exponent) - (a = raise(a, exponent));\n return function(t) { return raise(a + b * t, 1 / exponent); };\n }\n\n scale.exponent = function(_) {\n return arguments.length ? (exponent = +_, domain(domain())) : exponent;\n };\n\n scale.copy = function() {\n return copy(scale, pow().exponent(exponent));\n };\n\n return linearish(scale);\n }\n\n function sqrt() {\n return pow().exponent(0.5);\n }\n\n function quantile() {\n var domain = [],\n range = [],\n thresholds = [];\n\n function rescale() {\n var i = 0, n = Math.max(1, range.length);\n thresholds = new Array(n - 1);\n while (++i < n) thresholds[i - 1] = threshold(domain, i / n);\n return scale;\n }\n\n function scale(x) {\n if (!isNaN(x = +x)) return range[bisectRight(thresholds, x)];\n }\n\n scale.invertExtent = function(y) {\n var i = range.indexOf(y);\n return i < 0 ? [NaN, NaN] : [\n i > 0 ? thresholds[i - 1] : domain[0],\n i < thresholds.length ? thresholds[i] : domain[domain.length - 1]\n ];\n };\n\n scale.domain = function(_) {\n if (!arguments.length) return domain.slice();\n domain = [];\n for (var i = 0, n = _.length, d; i < n; ++i) if (d = _[i], d != null && !isNaN(d = +d)) domain.push(d);\n domain.sort(ascending);\n return rescale();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = slice$3.call(_), rescale()) : range.slice();\n };\n\n scale.quantiles = function() {\n return thresholds.slice();\n };\n\n scale.copy = function() {\n return quantile()\n .domain(domain)\n .range(range);\n };\n\n return scale;\n }\n\n function quantize$1() {\n var x0 = 0,\n x1 = 1,\n n = 1,\n domain = [0.5],\n range = [0, 1];\n\n function scale(x) {\n if (x <= x) return range[bisectRight(domain, x, 0, n)];\n }\n\n function rescale() {\n var i = -1;\n domain = new Array(n);\n while (++i < n) domain[i] = ((i + 1) * x1 - (i - n) * x0) / (n + 1);\n return scale;\n }\n\n scale.domain = function(_) {\n return arguments.length ? (x0 = +_[0], x1 = +_[1], rescale()) : [x0, x1];\n };\n\n scale.range = function(_) {\n return arguments.length ? (n = (range = slice$3.call(_)).length - 1, rescale()) : range.slice();\n };\n\n scale.invertExtent = function(y) {\n var i = range.indexOf(y);\n return i < 0 ? [NaN, NaN]\n : i < 1 ? [x0, domain[0]]\n : i >= n ? [domain[n - 1], x1]\n : [domain[i - 1], domain[i]];\n };\n\n scale.copy = function() {\n return quantize$1()\n .domain([x0, x1])\n .range(range);\n };\n\n return linearish(scale);\n }\n\n function threshold$1() {\n var domain = [0.5],\n range = [0, 1],\n n = 1;\n\n function scale(x) {\n if (x <= x) return range[bisectRight(domain, x, 0, n)];\n }\n\n scale.domain = function(_) {\n return arguments.length ? (domain = slice$3.call(_), n = Math.min(domain.length, range.length - 1), scale) : domain.slice();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = slice$3.call(_), n = Math.min(domain.length, range.length - 1), scale) : range.slice();\n };\n\n scale.invertExtent = function(y) {\n var i = range.indexOf(y);\n return [domain[i - 1], domain[i]];\n };\n\n scale.copy = function() {\n return threshold$1()\n .domain(domain)\n .range(range);\n };\n\n return scale;\n }\n\nvar durationSecond$1 = 1000;\nvar durationMinute$1 = durationSecond$1 * 60;\nvar durationHour$1 = durationMinute$1 * 60;\nvar durationDay$1 = durationHour$1 * 24;\nvar durationWeek$1 = durationDay$1 * 7;\n var durationMonth = durationDay$1 * 30;\n var durationYear = durationDay$1 * 365;\n function date$1(t) {\n return new Date(t);\n }\n\n function number$2(t) {\n return t instanceof Date ? +t : +new Date(+t);\n }\n\n function calendar(year, month, week, day, hour, minute, second, millisecond, format) {\n var scale = continuous(deinterpolate, interpolateNumber),\n invert = scale.invert,\n domain = scale.domain;\n\n var formatMillisecond = format(\".%L\"),\n formatSecond = format(\":%S\"),\n formatMinute = format(\"%I:%M\"),\n formatHour = format(\"%I %p\"),\n formatDay = format(\"%a %d\"),\n formatWeek = format(\"%b %d\"),\n formatMonth = format(\"%B\"),\n formatYear = format(\"%Y\");\n\n var tickIntervals = [\n [second, 1, durationSecond$1],\n [second, 5, 5 * durationSecond$1],\n [second, 15, 15 * durationSecond$1],\n [second, 30, 30 * durationSecond$1],\n [minute, 1, durationMinute$1],\n [minute, 5, 5 * durationMinute$1],\n [minute, 15, 15 * durationMinute$1],\n [minute, 30, 30 * durationMinute$1],\n [ hour, 1, durationHour$1 ],\n [ hour, 3, 3 * durationHour$1 ],\n [ hour, 6, 6 * durationHour$1 ],\n [ hour, 12, 12 * durationHour$1 ],\n [ day, 1, durationDay$1 ],\n [ day, 2, 2 * durationDay$1 ],\n [ week, 1, durationWeek$1 ],\n [ month, 1, durationMonth ],\n [ month, 3, 3 * durationMonth ],\n [ year, 1, durationYear ]\n ];\n\n function tickFormat(date) {\n return (second(date) < date ? formatMillisecond\n : minute(date) < date ? formatSecond\n : hour(date) < date ? formatMinute\n : day(date) < date ? formatHour\n : month(date) < date ? (week(date) < date ? formatDay : formatWeek)\n : year(date) < date ? formatMonth\n : formatYear)(date);\n }\n\n function tickInterval(interval, start, stop, step) {\n if (interval == null) interval = 10;\n\n // If a desired tick count is specified, pick a reasonable tick interval\n // based on the extent of the domain and a rough estimate of tick size.\n // Otherwise, assume interval is already a time interval and use it.\n if (typeof interval === \"number\") {\n var target = Math.abs(stop - start) / interval,\n i = bisector(function(i) { return i[2]; }).right(tickIntervals, target);\n if (i === tickIntervals.length) {\n step = tickStep(start / durationYear, stop / durationYear, interval);\n interval = year;\n } else if (i) {\n i = tickIntervals[target / tickIntervals[i - 1][2] < tickIntervals[i][2] / target ? i - 1 : i];\n step = i[1];\n interval = i[0];\n } else {\n step = tickStep(start, stop, interval);\n interval = millisecond;\n }\n }\n\n return step == null ? interval : interval.every(step);\n }\n\n scale.invert = function(y) {\n return new Date(invert(y));\n };\n\n scale.domain = function(_) {\n return arguments.length ? domain(map$2.call(_, number$2)) : domain().map(date$1);\n };\n\n scale.ticks = function(interval, step) {\n var d = domain(),\n t0 = d[0],\n t1 = d[d.length - 1],\n r = t1 < t0,\n t;\n if (r) t = t0, t0 = t1, t1 = t;\n t = tickInterval(interval, t0, t1, step);\n t = t ? t.range(t0, t1 + 1) : []; // inclusive stop\n return r ? t.reverse() : t;\n };\n\n scale.tickFormat = function(count, specifier) {\n return specifier == null ? tickFormat : format(specifier);\n };\n\n scale.nice = function(interval, step) {\n var d = domain();\n return (interval = tickInterval(interval, d[0], d[d.length - 1], step))\n ? domain(nice(d, interval))\n : scale;\n };\n\n scale.copy = function() {\n return copy(scale, calendar(year, month, week, day, hour, minute, second, millisecond, format));\n };\n\n return scale;\n }\n\n function time() {\n return calendar(year, month, timeWeek, day, hour, minute, second, millisecond, exports.timeFormat).domain([new Date(2000, 0, 1), new Date(2000, 0, 2)]);\n }\n\n function utcTime() {\n return calendar(utcYear, utcMonth, utcWeek, utcDay, utcHour, utcMinute, second, millisecond, exports.utcFormat).domain([Date.UTC(2000, 0, 1), Date.UTC(2000, 0, 2)]);\n }\n\n function colors(s) {\n return s.match(/.{6}/g).map(function(x) {\n return \"#\" + x;\n });\n }\n\n var category10 = colors(\"1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf\");\n\n var category20b = colors(\"393b795254a36b6ecf9c9ede6379398ca252b5cf6bcedb9c8c6d31bd9e39e7ba52e7cb94843c39ad494ad6616be7969c7b4173a55194ce6dbdde9ed6\");\n\n var category20c = colors(\"3182bd6baed69ecae1c6dbefe6550dfd8d3cfdae6bfdd0a231a35474c476a1d99bc7e9c0756bb19e9ac8bcbddcdadaeb636363969696bdbdbdd9d9d9\");\n\n var category20 = colors(\"1f77b4aec7e8ff7f0effbb782ca02c98df8ad62728ff98969467bdc5b0d58c564bc49c94e377c2f7b6d27f7f7fc7c7c7bcbd22dbdb8d17becf9edae5\");\n\n var cubehelix$3 = interpolateCubehelixLong(cubehelix(300, 0.5, 0.0), cubehelix(-240, 0.5, 1.0));\n\n var warm = interpolateCubehelixLong(cubehelix(-100, 0.75, 0.35), cubehelix(80, 1.50, 0.8));\n\n var cool = interpolateCubehelixLong(cubehelix(260, 0.75, 0.35), cubehelix(80, 1.50, 0.8));\n\n var rainbow = cubehelix();\n\n function rainbow$1(t) {\n if (t < 0 || t > 1) t -= Math.floor(t);\n var ts = Math.abs(t - 0.5);\n rainbow.h = 360 * t - 100;\n rainbow.s = 1.5 - 1.5 * ts;\n rainbow.l = 0.8 - 0.9 * ts;\n return rainbow + \"\";\n }\n\n function ramp(range) {\n var n = range.length;\n return function(t) {\n return range[Math.max(0, Math.min(n - 1, Math.floor(t * n)))];\n };\n }\n\n var viridis = ramp(colors(\"44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725\"));\n\n var magma = ramp(colors(\"00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf\"));\n\n var inferno = ramp(colors(\"00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4\"));\n\n var plasma = ramp(colors(\"0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921\"));\n\n function sequential(interpolator) {\n var x0 = 0,\n x1 = 1,\n clamp = false;\n\n function scale(x) {\n var t = (x - x0) / (x1 - x0);\n return interpolator(clamp ? Math.max(0, Math.min(1, t)) : t);\n }\n\n scale.domain = function(_) {\n return arguments.length ? (x0 = +_[0], x1 = +_[1], scale) : [x0, x1];\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (clamp = !!_, scale) : clamp;\n };\n\n scale.interpolator = function(_) {\n return arguments.length ? (interpolator = _, scale) : interpolator;\n };\n\n scale.copy = function() {\n return sequential(interpolator).domain([x0, x1]).clamp(clamp);\n };\n\n return linearish(scale);\n }\n\n var xhtml = \"http://www.w3.org/1999/xhtml\";\n\n var namespaces = {\n svg: \"http://www.w3.org/2000/svg\",\n xhtml: xhtml,\n xlink: \"http://www.w3.org/1999/xlink\",\n xml: \"http://www.w3.org/XML/1998/namespace\",\n xmlns: \"http://www.w3.org/2000/xmlns/\"\n };\n\n function namespace(name) {\n var prefix = name += \"\", i = prefix.indexOf(\":\");\n if (i >= 0 && (prefix = name.slice(0, i)) !== \"xmlns\") name = name.slice(i + 1);\n return namespaces.hasOwnProperty(prefix) ? {space: namespaces[prefix], local: name} : name;\n }\n\n function creatorInherit(name) {\n return function() {\n var document = this.ownerDocument,\n uri = this.namespaceURI;\n return uri === xhtml && document.documentElement.namespaceURI === xhtml\n ? document.createElement(name)\n : document.createElementNS(uri, name);\n };\n }\n\n function creatorFixed(fullname) {\n return function() {\n return this.ownerDocument.createElementNS(fullname.space, fullname.local);\n };\n }\n\n function creator(name) {\n var fullname = namespace(name);\n return (fullname.local\n ? creatorFixed\n : creatorInherit)(fullname);\n }\n\n var nextId = 0;\n\n function local() {\n return new Local;\n }\n\n function Local() {\n this._ = \"@\" + (++nextId).toString(36);\n }\n\n Local.prototype = local.prototype = {\n constructor: Local,\n get: function(node) {\n var id = this._;\n while (!(id in node)) if (!(node = node.parentNode)) return;\n return node[id];\n },\n set: function(node, value) {\n return node[this._] = value;\n },\n remove: function(node) {\n return this._ in node && delete node[this._];\n },\n toString: function() {\n return this._;\n }\n };\n\n var matcher = function(selector) {\n return function() {\n return this.matches(selector);\n };\n };\n\n if (typeof document !== \"undefined\") {\n var element = document.documentElement;\n if (!element.matches) {\n var vendorMatches = element.webkitMatchesSelector\n || element.msMatchesSelector\n || element.mozMatchesSelector\n || element.oMatchesSelector;\n matcher = function(selector) {\n return function() {\n return vendorMatches.call(this, selector);\n };\n };\n }\n }\n\n var matcher$1 = matcher;\n\n var filterEvents = {};\n\n exports.event = null;\n\n if (typeof document !== \"undefined\") {\n var element$1 = document.documentElement;\n if (!(\"onmouseenter\" in element$1)) {\n filterEvents = {mouseenter: \"mouseover\", mouseleave: \"mouseout\"};\n }\n }\n\n function filterContextListener(listener, index, group) {\n listener = contextListener(listener, index, group);\n return function(event) {\n var related = event.relatedTarget;\n if (!related || (related !== this && !(related.compareDocumentPosition(this) & 8))) {\n listener.call(this, event);\n }\n };\n }\n\n function contextListener(listener, index, group) {\n return function(event1) {\n var event0 = exports.event; // Events can be reentrant (e.g., focus).\n exports.event = event1;\n try {\n listener.call(this, this.__data__, index, group);\n } finally {\n exports.event = event0;\n }\n };\n }\n\n function parseTypenames$1(typenames) {\n return typenames.trim().split(/^|\\s+/).map(function(t) {\n var name = \"\", i = t.indexOf(\".\");\n if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n return {type: t, name: name};\n });\n }\n\n function onRemove(typename) {\n return function() {\n var on = this.__on;\n if (!on) return;\n for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {\n if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {\n this.removeEventListener(o.type, o.listener, o.capture);\n } else {\n on[++i] = o;\n }\n }\n if (++i) on.length = i;\n else delete this.__on;\n };\n }\n\n function onAdd(typename, value, capture) {\n var wrap = filterEvents.hasOwnProperty(typename.type) ? filterContextListener : contextListener;\n return function(d, i, group) {\n var on = this.__on, o, listener = wrap(value, i, group);\n if (on) for (var j = 0, m = on.length; j < m; ++j) {\n if ((o = on[j]).type === typename.type && o.name === typename.name) {\n this.removeEventListener(o.type, o.listener, o.capture);\n this.addEventListener(o.type, o.listener = listener, o.capture = capture);\n o.value = value;\n return;\n }\n }\n this.addEventListener(typename.type, listener, capture);\n o = {type: typename.type, name: typename.name, value: value, listener: listener, capture: capture};\n if (!on) this.__on = [o];\n else on.push(o);\n };\n }\n\n function selection_on(typename, value, capture) {\n var typenames = parseTypenames$1(typename + \"\"), i, n = typenames.length, t;\n\n if (arguments.length < 2) {\n var on = this.node().__on;\n if (on) for (var j = 0, m = on.length, o; j < m; ++j) {\n for (i = 0, o = on[j]; i < n; ++i) {\n if ((t = typenames[i]).type === o.type && t.name === o.name) {\n return o.value;\n }\n }\n }\n return;\n }\n\n on = value ? onAdd : onRemove;\n if (capture == null) capture = false;\n for (i = 0; i < n; ++i) this.each(on(typenames[i], value, capture));\n return this;\n }\n\n function customEvent(event1, listener, that, args) {\n var event0 = exports.event;\n event1.sourceEvent = exports.event;\n exports.event = event1;\n try {\n return listener.apply(that, args);\n } finally {\n exports.event = event0;\n }\n }\n\n function sourceEvent() {\n var current = exports.event, source;\n while (source = current.sourceEvent) current = source;\n return current;\n }\n\n function point$5(node, event) {\n var svg = node.ownerSVGElement || node;\n\n if (svg.createSVGPoint) {\n var point = svg.createSVGPoint();\n point.x = event.clientX, point.y = event.clientY;\n point = point.matrixTransform(node.getScreenCTM().inverse());\n return [point.x, point.y];\n }\n\n var rect = node.getBoundingClientRect();\n return [event.clientX - rect.left - node.clientLeft, event.clientY - rect.top - node.clientTop];\n }\n\n function mouse(node) {\n var event = sourceEvent();\n if (event.changedTouches) event = event.changedTouches[0];\n return point$5(node, event);\n }\n\n function none$2() {}\n\n function selector(selector) {\n return selector == null ? none$2 : function() {\n return this.querySelector(selector);\n };\n }\n\n function selection_select(select) {\n if (typeof select !== \"function\") select = selector(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n if (\"__data__\" in node) subnode.__data__ = node.__data__;\n subgroup[i] = subnode;\n }\n }\n }\n\n return new Selection(subgroups, this._parents);\n }\n\n function empty() {\n return [];\n }\n\n function selectorAll(selector) {\n return selector == null ? empty : function() {\n return this.querySelectorAll(selector);\n };\n }\n\n function selection_selectAll(select) {\n if (typeof select !== \"function\") select = selectorAll(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n subgroups.push(select.call(node, node.__data__, i, group));\n parents.push(node);\n }\n }\n }\n\n return new Selection(subgroups, parents);\n }\n\n function selection_filter(match) {\n if (typeof match !== \"function\") match = matcher$1(match);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n subgroup.push(node);\n }\n }\n }\n\n return new Selection(subgroups, this._parents);\n }\n\n function sparse(update) {\n return new Array(update.length);\n }\n\n function selection_enter() {\n return new Selection(this._enter || this._groups.map(sparse), this._parents);\n }\n\n function EnterNode(parent, datum) {\n this.ownerDocument = parent.ownerDocument;\n this.namespaceURI = parent.namespaceURI;\n this._next = null;\n this._parent = parent;\n this.__data__ = datum;\n }\n\n EnterNode.prototype = {\n constructor: EnterNode,\n appendChild: function(child) { return this._parent.insertBefore(child, this._next); },\n insertBefore: function(child, next) { return this._parent.insertBefore(child, next); },\n querySelector: function(selector) { return this._parent.querySelector(selector); },\n querySelectorAll: function(selector) { return this._parent.querySelectorAll(selector); }\n };\n\n function constant$4(x) {\n return function() {\n return x;\n };\n }\n\n var keyPrefix = \"$\"; // Protect against keys like “__proto__â€.\n\n function bindIndex(parent, group, enter, update, exit, data) {\n var i = 0,\n node,\n groupLength = group.length,\n dataLength = data.length;\n\n // Put any non-null nodes that fit into update.\n // Put any null nodes into enter.\n // Put any remaining data into enter.\n for (; i < dataLength; ++i) {\n if (node = group[i]) {\n node.__data__ = data[i];\n update[i] = node;\n } else {\n enter[i] = new EnterNode(parent, data[i]);\n }\n }\n\n // Put any non-null nodes that don’t fit into exit.\n for (; i < groupLength; ++i) {\n if (node = group[i]) {\n exit[i] = node;\n }\n }\n }\n\n function bindKey(parent, group, enter, update, exit, data, key) {\n var i,\n node,\n nodeByKeyValue = {},\n groupLength = group.length,\n dataLength = data.length,\n keyValues = new Array(groupLength),\n keyValue;\n\n // Compute the key for each node.\n // If multiple nodes have the same key, the duplicates are added to exit.\n for (i = 0; i < groupLength; ++i) {\n if (node = group[i]) {\n keyValues[i] = keyValue = keyPrefix + key.call(node, node.__data__, i, group);\n if (keyValue in nodeByKeyValue) {\n exit[i] = node;\n } else {\n nodeByKeyValue[keyValue] = node;\n }\n }\n }\n\n // Compute the key for each datum.\n // If there a node associated with this key, join and add it to update.\n // If there is not (or the key is a duplicate), add it to enter.\n for (i = 0; i < dataLength; ++i) {\n keyValue = keyPrefix + key.call(parent, data[i], i, data);\n if (node = nodeByKeyValue[keyValue]) {\n update[i] = node;\n node.__data__ = data[i];\n nodeByKeyValue[keyValue] = null;\n } else {\n enter[i] = new EnterNode(parent, data[i]);\n }\n }\n\n // Add any remaining nodes that were not bound to data to exit.\n for (i = 0; i < groupLength; ++i) {\n if ((node = group[i]) && (nodeByKeyValue[keyValues[i]] === node)) {\n exit[i] = node;\n }\n }\n }\n\n function selection_data(value, key) {\n if (!value) {\n data = new Array(this.size()), j = -1;\n this.each(function(d) { data[++j] = d; });\n return data;\n }\n\n var bind = key ? bindKey : bindIndex,\n parents = this._parents,\n groups = this._groups;\n\n if (typeof value !== \"function\") value = constant$4(value);\n\n for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {\n var parent = parents[j],\n group = groups[j],\n groupLength = group.length,\n data = value.call(parent, parent && parent.__data__, j, parents),\n dataLength = data.length,\n enterGroup = enter[j] = new Array(dataLength),\n updateGroup = update[j] = new Array(dataLength),\n exitGroup = exit[j] = new Array(groupLength);\n\n bind(parent, group, enterGroup, updateGroup, exitGroup, data, key);\n\n // Now connect the enter nodes to their following update node, such that\n // appendChild can insert the materialized enter node before this node,\n // rather than at the end of the parent node.\n for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {\n if (previous = enterGroup[i0]) {\n if (i0 >= i1) i1 = i0 + 1;\n while (!(next = updateGroup[i1]) && ++i1 < dataLength);\n previous._next = next || null;\n }\n }\n }\n\n update = new Selection(update, parents);\n update._enter = enter;\n update._exit = exit;\n return update;\n }\n\n function selection_exit() {\n return new Selection(this._exit || this._groups.map(sparse), this._parents);\n }\n\n function selection_merge(selection) {\n\n for (var groups0 = this._groups, groups1 = selection._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group0[i] || group1[i]) {\n merge[i] = node;\n }\n }\n }\n\n for (; j < m0; ++j) {\n merges[j] = groups0[j];\n }\n\n return new Selection(merges, this._parents);\n }\n\n function selection_order() {\n\n for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {\n for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {\n if (node = group[i]) {\n if (next && next !== node.nextSibling) next.parentNode.insertBefore(node, next);\n next = node;\n }\n }\n }\n\n return this;\n }\n\n function selection_sort(compare) {\n if (!compare) compare = ascending$2;\n\n function compareNode(a, b) {\n return a && b ? compare(a.__data__, b.__data__) : !a - !b;\n }\n\n for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n sortgroup[i] = node;\n }\n }\n sortgroup.sort(compareNode);\n }\n\n return new Selection(sortgroups, this._parents).order();\n }\n\n function ascending$2(a, b) {\n return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n }\n\n function selection_call() {\n var callback = arguments[0];\n arguments[0] = this;\n callback.apply(null, arguments);\n return this;\n }\n\n function selection_nodes() {\n var nodes = new Array(this.size()), i = -1;\n this.each(function() { nodes[++i] = this; });\n return nodes;\n }\n\n function selection_node() {\n\n for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {\n var node = group[i];\n if (node) return node;\n }\n }\n\n return null;\n }\n\n function selection_size() {\n var size = 0;\n this.each(function() { ++size; });\n return size;\n }\n\n function selection_empty() {\n return !this.node();\n }\n\n function selection_each(callback) {\n\n for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {\n if (node = group[i]) callback.call(node, node.__data__, i, group);\n }\n }\n\n return this;\n }\n\n function attrRemove(name) {\n return function() {\n this.removeAttribute(name);\n };\n }\n\n function attrRemoveNS(fullname) {\n return function() {\n this.removeAttributeNS(fullname.space, fullname.local);\n };\n }\n\n function attrConstant(name, value) {\n return function() {\n this.setAttribute(name, value);\n };\n }\n\n function attrConstantNS(fullname, value) {\n return function() {\n this.setAttributeNS(fullname.space, fullname.local, value);\n };\n }\n\n function attrFunction(name, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.removeAttribute(name);\n else this.setAttribute(name, v);\n };\n }\n\n function attrFunctionNS(fullname, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.removeAttributeNS(fullname.space, fullname.local);\n else this.setAttributeNS(fullname.space, fullname.local, v);\n };\n }\n\n function selection_attr(name, value) {\n var fullname = namespace(name);\n\n if (arguments.length < 2) {\n var node = this.node();\n return fullname.local\n ? node.getAttributeNS(fullname.space, fullname.local)\n : node.getAttribute(fullname);\n }\n\n return this.each((value == null\n ? (fullname.local ? attrRemoveNS : attrRemove) : (typeof value === \"function\"\n ? (fullname.local ? attrFunctionNS : attrFunction)\n : (fullname.local ? attrConstantNS : attrConstant)))(fullname, value));\n }\n\n function window(node) {\n return (node.ownerDocument && node.ownerDocument.defaultView) // node is a Node\n || (node.document && node) // node is a Window\n || node.defaultView; // node is a Document\n }\n\n function styleRemove(name) {\n return function() {\n this.style.removeProperty(name);\n };\n }\n\n function styleConstant(name, value, priority) {\n return function() {\n this.style.setProperty(name, value, priority);\n };\n }\n\n function styleFunction(name, value, priority) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.style.removeProperty(name);\n else this.style.setProperty(name, v, priority);\n };\n }\n\n function selection_style(name, value, priority) {\n var node;\n return arguments.length > 1\n ? this.each((value == null\n ? styleRemove : typeof value === \"function\"\n ? styleFunction\n : styleConstant)(name, value, priority == null ? \"\" : priority))\n : window(node = this.node())\n .getComputedStyle(node, null)\n .getPropertyValue(name);\n }\n\n function propertyRemove(name) {\n return function() {\n delete this[name];\n };\n }\n\n function propertyConstant(name, value) {\n return function() {\n this[name] = value;\n };\n }\n\n function propertyFunction(name, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) delete this[name];\n else this[name] = v;\n };\n }\n\n function selection_property(name, value) {\n return arguments.length > 1\n ? this.each((value == null\n ? propertyRemove : typeof value === \"function\"\n ? propertyFunction\n : propertyConstant)(name, value))\n : this.node()[name];\n }\n\n function classArray(string) {\n return string.trim().split(/^|\\s+/);\n }\n\n function classList(node) {\n return node.classList || new ClassList(node);\n }\n\n function ClassList(node) {\n this._node = node;\n this._names = classArray(node.getAttribute(\"class\") || \"\");\n }\n\n ClassList.prototype = {\n add: function(name) {\n var i = this._names.indexOf(name);\n if (i < 0) {\n this._names.push(name);\n this._node.setAttribute(\"class\", this._names.join(\" \"));\n }\n },\n remove: function(name) {\n var i = this._names.indexOf(name);\n if (i >= 0) {\n this._names.splice(i, 1);\n this._node.setAttribute(\"class\", this._names.join(\" \"));\n }\n },\n contains: function(name) {\n return this._names.indexOf(name) >= 0;\n }\n };\n\n function classedAdd(node, names) {\n var list = classList(node), i = -1, n = names.length;\n while (++i < n) list.add(names[i]);\n }\n\n function classedRemove(node, names) {\n var list = classList(node), i = -1, n = names.length;\n while (++i < n) list.remove(names[i]);\n }\n\n function classedTrue(names) {\n return function() {\n classedAdd(this, names);\n };\n }\n\n function classedFalse(names) {\n return function() {\n classedRemove(this, names);\n };\n }\n\n function classedFunction(names, value) {\n return function() {\n (value.apply(this, arguments) ? classedAdd : classedRemove)(this, names);\n };\n }\n\n function selection_classed(name, value) {\n var names = classArray(name + \"\");\n\n if (arguments.length < 2) {\n var list = classList(this.node()), i = -1, n = names.length;\n while (++i < n) if (!list.contains(names[i])) return false;\n return true;\n }\n\n return this.each((typeof value === \"function\"\n ? classedFunction : value\n ? classedTrue\n : classedFalse)(names, value));\n }\n\n function textRemove() {\n this.textContent = \"\";\n }\n\n function textConstant(value) {\n return function() {\n this.textContent = value;\n };\n }\n\n function textFunction(value) {\n return function() {\n var v = value.apply(this, arguments);\n this.textContent = v == null ? \"\" : v;\n };\n }\n\n function selection_text(value) {\n return arguments.length\n ? this.each(value == null\n ? textRemove : (typeof value === \"function\"\n ? textFunction\n : textConstant)(value))\n : this.node().textContent;\n }\n\n function htmlRemove() {\n this.innerHTML = \"\";\n }\n\n function htmlConstant(value) {\n return function() {\n this.innerHTML = value;\n };\n }\n\n function htmlFunction(value) {\n return function() {\n var v = value.apply(this, arguments);\n this.innerHTML = v == null ? \"\" : v;\n };\n }\n\n function selection_html(value) {\n return arguments.length\n ? this.each(value == null\n ? htmlRemove : (typeof value === \"function\"\n ? htmlFunction\n : htmlConstant)(value))\n : this.node().innerHTML;\n }\n\n function raise$1() {\n if (this.nextSibling) this.parentNode.appendChild(this);\n }\n\n function selection_raise() {\n return this.each(raise$1);\n }\n\n function lower() {\n if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);\n }\n\n function selection_lower() {\n return this.each(lower);\n }\n\n function selection_append(name) {\n var create = typeof name === \"function\" ? name : creator(name);\n return this.select(function() {\n return this.appendChild(create.apply(this, arguments));\n });\n }\n\n function constantNull() {\n return null;\n }\n\n function selection_insert(name, before) {\n var create = typeof name === \"function\" ? name : creator(name),\n select = before == null ? constantNull : typeof before === \"function\" ? before : selector(before);\n return this.select(function() {\n return this.insertBefore(create.apply(this, arguments), select.apply(this, arguments) || null);\n });\n }\n\n function remove() {\n var parent = this.parentNode;\n if (parent) parent.removeChild(this);\n }\n\n function selection_remove() {\n return this.each(remove);\n }\n\n function selection_datum(value) {\n return arguments.length\n ? this.property(\"__data__\", value)\n : this.node().__data__;\n }\n\n function dispatchEvent(node, type, params) {\n var window$$ = window(node),\n event = window$$.CustomEvent;\n\n if (event) {\n event = new event(type, params);\n } else {\n event = window$$.document.createEvent(\"Event\");\n if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;\n else event.initEvent(type, false, false);\n }\n\n node.dispatchEvent(event);\n }\n\n function dispatchConstant(type, params) {\n return function() {\n return dispatchEvent(this, type, params);\n };\n }\n\n function dispatchFunction(type, params) {\n return function() {\n return dispatchEvent(this, type, params.apply(this, arguments));\n };\n }\n\n function selection_dispatch(type, params) {\n return this.each((typeof params === \"function\"\n ? dispatchFunction\n : dispatchConstant)(type, params));\n }\n\n var root = [null];\n\n function Selection(groups, parents) {\n this._groups = groups;\n this._parents = parents;\n }\n\n function selection() {\n return new Selection([[document.documentElement]], root);\n }\n\n Selection.prototype = selection.prototype = {\n constructor: Selection,\n select: selection_select,\n selectAll: selection_selectAll,\n filter: selection_filter,\n data: selection_data,\n enter: selection_enter,\n exit: selection_exit,\n merge: selection_merge,\n order: selection_order,\n sort: selection_sort,\n call: selection_call,\n nodes: selection_nodes,\n node: selection_node,\n size: selection_size,\n empty: selection_empty,\n each: selection_each,\n attr: selection_attr,\n style: selection_style,\n property: selection_property,\n classed: selection_classed,\n text: selection_text,\n html: selection_html,\n raise: selection_raise,\n lower: selection_lower,\n append: selection_append,\n insert: selection_insert,\n remove: selection_remove,\n datum: selection_datum,\n on: selection_on,\n dispatch: selection_dispatch\n };\n\n function select(selector) {\n return typeof selector === \"string\"\n ? new Selection([[document.querySelector(selector)]], [document.documentElement])\n : new Selection([[selector]], root);\n }\n\n function selectAll(selector) {\n return typeof selector === \"string\"\n ? new Selection([document.querySelectorAll(selector)], [document.documentElement])\n : new Selection([selector == null ? [] : selector], root);\n }\n\n function touch(node, touches, identifier) {\n if (arguments.length < 3) identifier = touches, touches = sourceEvent().changedTouches;\n\n for (var i = 0, n = touches ? touches.length : 0, touch; i < n; ++i) {\n if ((touch = touches[i]).identifier === identifier) {\n return point$5(node, touch);\n }\n }\n\n return null;\n }\n\n function touches(node, touches) {\n if (touches == null) touches = sourceEvent().touches;\n\n for (var i = 0, n = touches ? touches.length : 0, points = new Array(n); i < n; ++i) {\n points[i] = point$5(node, touches[i]);\n }\n\n return points;\n }\n\n var emptyOn = dispatch(\"start\", \"end\", \"interrupt\");\n var emptyTween = [];\n\n var CREATED = 0;\n var SCHEDULED = 1;\n var STARTING = 2;\n var STARTED = 3;\n var ENDING = 4;\n var ENDED = 5;\n\n function schedule(node, name, id, index, group, timing) {\n var schedules = node.__transition;\n if (!schedules) node.__transition = {};\n else if (id in schedules) return;\n create(node, id, {\n name: name,\n index: index, // For context during callback.\n group: group, // For context during callback.\n on: emptyOn,\n tween: emptyTween,\n time: timing.time,\n delay: timing.delay,\n duration: timing.duration,\n ease: timing.ease,\n timer: null,\n state: CREATED\n });\n }\n\n function init(node, id) {\n var schedule = node.__transition;\n if (!schedule || !(schedule = schedule[id]) || schedule.state > CREATED) throw new Error(\"too late\");\n return schedule;\n }\n\n function set$2(node, id) {\n var schedule = node.__transition;\n if (!schedule || !(schedule = schedule[id]) || schedule.state > STARTING) throw new Error(\"too late\");\n return schedule;\n }\n\n function get$1(node, id) {\n var schedule = node.__transition;\n if (!schedule || !(schedule = schedule[id])) throw new Error(\"too late\");\n return schedule;\n }\n\n function create(node, id, self) {\n var schedules = node.__transition,\n tween;\n\n // Initialize the self timer when the transition is created.\n // Note the actual delay is not known until the first callback!\n schedules[id] = self;\n self.timer = timer(schedule, 0, self.time);\n\n // If the delay is greater than this first sleep, sleep some more;\n // otherwise, start immediately.\n function schedule(elapsed) {\n self.state = SCHEDULED;\n if (self.delay <= elapsed) start(elapsed - self.delay);\n else self.timer.restart(start, self.delay, self.time);\n }\n\n function start(elapsed) {\n var i, j, n, o;\n\n for (i in schedules) {\n o = schedules[i];\n if (o.name !== self.name) continue;\n\n // Interrupt the active transition, if any.\n // Dispatch the interrupt event.\n if (o.state === STARTED) {\n o.state = ENDED;\n o.timer.stop();\n o.on.call(\"interrupt\", node, node.__data__, o.index, o.group);\n delete schedules[i];\n }\n\n // Cancel any pre-empted transitions. No interrupt event is dispatched\n // because the cancelled transitions never started. Note that this also\n // removes this transition from the pending list!\n else if (+i < id) {\n o.state = ENDED;\n o.timer.stop();\n delete schedules[i];\n }\n }\n\n // Defer the first tick to end of the current frame; see mbostock/d3#1576.\n // Note the transition may be canceled after start and before the first tick!\n // Note this must be scheduled before the start event; see d3/d3-transition#16!\n // Assuming this is successful, subsequent callbacks go straight to tick.\n timeout$1(function() {\n if (self.state === STARTED) {\n self.timer.restart(tick, self.delay, self.time);\n tick(elapsed);\n }\n });\n\n // Dispatch the start event.\n // Note this must be done before the tween are initialized.\n self.state = STARTING;\n self.on.call(\"start\", node, node.__data__, self.index, self.group);\n if (self.state !== STARTING) return; // interrupted\n self.state = STARTED;\n\n // Initialize the tween, deleting null tween.\n tween = new Array(n = self.tween.length);\n for (i = 0, j = -1; i < n; ++i) {\n if (o = self.tween[i].value.call(node, node.__data__, self.index, self.group)) {\n tween[++j] = o;\n }\n }\n tween.length = j + 1;\n }\n\n function tick(elapsed) {\n var t = elapsed < self.duration ? self.ease.call(null, elapsed / self.duration) : (self.state = ENDING, 1),\n i = -1,\n n = tween.length;\n\n while (++i < n) {\n tween[i].call(null, t);\n }\n\n // Dispatch the end event.\n if (self.state === ENDING) {\n self.state = ENDED;\n self.timer.stop();\n self.on.call(\"end\", node, node.__data__, self.index, self.group);\n for (i in schedules) if (+i !== id) return void delete schedules[id];\n delete node.__transition;\n }\n }\n }\n\n function interrupt(node, name) {\n var schedules = node.__transition,\n schedule,\n active,\n empty = true,\n i;\n\n if (!schedules) return;\n\n name = name == null ? null : name + \"\";\n\n for (i in schedules) {\n if ((schedule = schedules[i]).name !== name) { empty = false; continue; }\n active = schedule.state === STARTED;\n schedule.state = ENDED;\n schedule.timer.stop();\n if (active) schedule.on.call(\"interrupt\", node, node.__data__, schedule.index, schedule.group);\n delete schedules[i];\n }\n\n if (empty) delete node.__transition;\n }\n\n function selection_interrupt(name) {\n return this.each(function() {\n interrupt(this, name);\n });\n }\n\n function tweenRemove(id, name) {\n var tween0, tween1;\n return function() {\n var schedule = set$2(this, id),\n tween = schedule.tween;\n\n // If this node shared tween with the previous node,\n // just assign the updated shared tween and we’re done!\n // Otherwise, copy-on-write.\n if (tween !== tween0) {\n tween1 = tween0 = tween;\n for (var i = 0, n = tween1.length; i < n; ++i) {\n if (tween1[i].name === name) {\n tween1 = tween1.slice();\n tween1.splice(i, 1);\n break;\n }\n }\n }\n\n schedule.tween = tween1;\n };\n }\n\n function tweenFunction(id, name, value) {\n var tween0, tween1;\n if (typeof value !== \"function\") throw new Error;\n return function() {\n var schedule = set$2(this, id),\n tween = schedule.tween;\n\n // If this node shared tween with the previous node,\n // just assign the updated shared tween and we’re done!\n // Otherwise, copy-on-write.\n if (tween !== tween0) {\n tween1 = (tween0 = tween).slice();\n for (var t = {name: name, value: value}, i = 0, n = tween1.length; i < n; ++i) {\n if (tween1[i].name === name) {\n tween1[i] = t;\n break;\n }\n }\n if (i === n) tween1.push(t);\n }\n\n schedule.tween = tween1;\n };\n }\n\n function transition_tween(name, value) {\n var id = this._id;\n\n name += \"\";\n\n if (arguments.length < 2) {\n var tween = get$1(this.node(), id).tween;\n for (var i = 0, n = tween.length, t; i < n; ++i) {\n if ((t = tween[i]).name === name) {\n return t.value;\n }\n }\n return null;\n }\n\n return this.each((value == null ? tweenRemove : tweenFunction)(id, name, value));\n }\n\n function tweenValue(transition, name, value) {\n var id = transition._id;\n\n transition.each(function() {\n var schedule = set$2(this, id);\n (schedule.value || (schedule.value = {}))[name] = value.apply(this, arguments);\n });\n\n return function(node) {\n return get$1(node, id).value[name];\n };\n }\n\n function interpolate$1(a, b) {\n var c;\n return (typeof b === \"number\" ? interpolateNumber\n : b instanceof color ? interpolateRgb\n : (c = color(b)) ? (b = c, interpolateRgb)\n : interpolateString)(a, b);\n }\n\n function attrRemove$1(name) {\n return function() {\n this.removeAttribute(name);\n };\n }\n\n function attrRemoveNS$1(fullname) {\n return function() {\n this.removeAttributeNS(fullname.space, fullname.local);\n };\n }\n\n function attrConstant$1(name, interpolate, value1) {\n var value00,\n interpolate0;\n return function() {\n var value0 = this.getAttribute(name);\n return value0 === value1 ? null\n : value0 === value00 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value1);\n };\n }\n\n function attrConstantNS$1(fullname, interpolate, value1) {\n var value00,\n interpolate0;\n return function() {\n var value0 = this.getAttributeNS(fullname.space, fullname.local);\n return value0 === value1 ? null\n : value0 === value00 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value1);\n };\n }\n\n function attrFunction$1(name, interpolate, value) {\n var value00,\n value10,\n interpolate0;\n return function() {\n var value0, value1 = value(this);\n if (value1 == null) return void this.removeAttribute(name);\n value0 = this.getAttribute(name);\n return value0 === value1 ? null\n : value0 === value00 && value1 === value10 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value10 = value1);\n };\n }\n\n function attrFunctionNS$1(fullname, interpolate, value) {\n var value00,\n value10,\n interpolate0;\n return function() {\n var value0, value1 = value(this);\n if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);\n value0 = this.getAttributeNS(fullname.space, fullname.local);\n return value0 === value1 ? null\n : value0 === value00 && value1 === value10 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value10 = value1);\n };\n }\n\n function transition_attr(name, value) {\n var fullname = namespace(name), i = fullname === \"transform\" ? interpolateTransform$2 : interpolate$1;\n return this.attrTween(name, typeof value === \"function\"\n ? (fullname.local ? attrFunctionNS$1 : attrFunction$1)(fullname, i, tweenValue(this, \"attr.\" + name, value))\n : value == null ? (fullname.local ? attrRemoveNS$1 : attrRemove$1)(fullname)\n : (fullname.local ? attrConstantNS$1 : attrConstant$1)(fullname, i, value));\n }\n\n function attrTweenNS(fullname, value) {\n function tween() {\n var node = this, i = value.apply(node, arguments);\n return i && function(t) {\n node.setAttributeNS(fullname.space, fullname.local, i(t));\n };\n }\n tween._value = value;\n return tween;\n }\n\n function attrTween(name, value) {\n function tween() {\n var node = this, i = value.apply(node, arguments);\n return i && function(t) {\n node.setAttribute(name, i(t));\n };\n }\n tween._value = value;\n return tween;\n }\n\n function transition_attrTween(name, value) {\n var key = \"attr.\" + name;\n if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n if (value == null) return this.tween(key, null);\n if (typeof value !== \"function\") throw new Error;\n var fullname = namespace(name);\n return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));\n }\n\n function delayFunction(id, value) {\n return function() {\n init(this, id).delay = +value.apply(this, arguments);\n };\n }\n\n function delayConstant(id, value) {\n return value = +value, function() {\n init(this, id).delay = value;\n };\n }\n\n function transition_delay(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each((typeof value === \"function\"\n ? delayFunction\n : delayConstant)(id, value))\n : get$1(this.node(), id).delay;\n }\n\n function durationFunction(id, value) {\n return function() {\n set$2(this, id).duration = +value.apply(this, arguments);\n };\n }\n\n function durationConstant(id, value) {\n return value = +value, function() {\n set$2(this, id).duration = value;\n };\n }\n\n function transition_duration(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each((typeof value === \"function\"\n ? durationFunction\n : durationConstant)(id, value))\n : get$1(this.node(), id).duration;\n }\n\n function easeConstant(id, value) {\n if (typeof value !== \"function\") throw new Error;\n return function() {\n set$2(this, id).ease = value;\n };\n }\n\n function transition_ease(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each(easeConstant(id, value))\n : get$1(this.node(), id).ease;\n }\n\n function transition_filter(match) {\n if (typeof match !== \"function\") match = matcher$1(match);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n subgroup.push(node);\n }\n }\n }\n\n return new Transition(subgroups, this._parents, this._name, this._id);\n }\n\n function transition_merge(transition) {\n if (transition._id !== this._id) throw new Error;\n\n for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group0[i] || group1[i]) {\n merge[i] = node;\n }\n }\n }\n\n for (; j < m0; ++j) {\n merges[j] = groups0[j];\n }\n\n return new Transition(merges, this._parents, this._name, this._id);\n }\n\n function start$1(name) {\n return (name + \"\").trim().split(/^|\\s+/).every(function(t) {\n var i = t.indexOf(\".\");\n if (i >= 0) t = t.slice(0, i);\n return !t || t === \"start\";\n });\n }\n\n function onFunction(id, name, listener) {\n var on0, on1, sit = start$1(name) ? init : set$2;\n return function() {\n var schedule = sit(this, id),\n on = schedule.on;\n\n // If this node shared a dispatch with the previous node,\n // just assign the updated shared dispatch and we’re done!\n // Otherwise, copy-on-write.\n if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);\n\n schedule.on = on1;\n };\n }\n\n function transition_on(name, listener) {\n var id = this._id;\n\n return arguments.length < 2\n ? get$1(this.node(), id).on.on(name)\n : this.each(onFunction(id, name, listener));\n }\n\n function removeFunction(id) {\n return function() {\n var parent = this.parentNode;\n for (var i in this.__transition) if (+i !== id) return;\n if (parent) parent.removeChild(this);\n };\n }\n\n function transition_remove() {\n return this.on(\"end.remove\", removeFunction(this._id));\n }\n\n function transition_select(select) {\n var name = this._name,\n id = this._id;\n\n if (typeof select !== \"function\") select = selector(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n if (\"__data__\" in node) subnode.__data__ = node.__data__;\n subgroup[i] = subnode;\n schedule(subgroup[i], name, id, i, subgroup, get$1(node, id));\n }\n }\n }\n\n return new Transition(subgroups, this._parents, name, id);\n }\n\n function transition_selectAll(select) {\n var name = this._name,\n id = this._id;\n\n if (typeof select !== \"function\") select = selectorAll(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n for (var children = select.call(node, node.__data__, i, group), child, inherit = get$1(node, id), k = 0, l = children.length; k < l; ++k) {\n if (child = children[k]) {\n schedule(child, name, id, k, children, inherit);\n }\n }\n subgroups.push(children);\n parents.push(node);\n }\n }\n }\n\n return new Transition(subgroups, parents, name, id);\n }\n\n var Selection$1 = selection.prototype.constructor;\n\n function transition_selection() {\n return new Selection$1(this._groups, this._parents);\n }\n\n function styleRemove$1(name, interpolate) {\n var value00,\n value10,\n interpolate0;\n return function() {\n var style = window(this).getComputedStyle(this, null),\n value0 = style.getPropertyValue(name),\n value1 = (this.style.removeProperty(name), style.getPropertyValue(name));\n return value0 === value1 ? null\n : value0 === value00 && value1 === value10 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value10 = value1);\n };\n }\n\n function styleRemoveEnd(name) {\n return function() {\n this.style.removeProperty(name);\n };\n }\n\n function styleConstant$1(name, interpolate, value1) {\n var value00,\n interpolate0;\n return function() {\n var value0 = window(this).getComputedStyle(this, null).getPropertyValue(name);\n return value0 === value1 ? null\n : value0 === value00 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value1);\n };\n }\n\n function styleFunction$1(name, interpolate, value) {\n var value00,\n value10,\n interpolate0;\n return function() {\n var style = window(this).getComputedStyle(this, null),\n value0 = style.getPropertyValue(name),\n value1 = value(this);\n if (value1 == null) value1 = (this.style.removeProperty(name), style.getPropertyValue(name));\n return value0 === value1 ? null\n : value0 === value00 && value1 === value10 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value10 = value1);\n };\n }\n\n function transition_style(name, value, priority) {\n var i = (name += \"\") === \"transform\" ? interpolateTransform$1 : interpolate$1;\n return value == null ? this\n .styleTween(name, styleRemove$1(name, i))\n .on(\"end.style.\" + name, styleRemoveEnd(name))\n : this.styleTween(name, typeof value === \"function\"\n ? styleFunction$1(name, i, tweenValue(this, \"style.\" + name, value))\n : styleConstant$1(name, i, value), priority);\n }\n\n function styleTween(name, value, priority) {\n function tween() {\n var node = this, i = value.apply(node, arguments);\n return i && function(t) {\n node.style.setProperty(name, i(t), priority);\n };\n }\n tween._value = value;\n return tween;\n }\n\n function transition_styleTween(name, value, priority) {\n var key = \"style.\" + (name += \"\");\n if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n if (value == null) return this.tween(key, null);\n if (typeof value !== \"function\") throw new Error;\n return this.tween(key, styleTween(name, value, priority == null ? \"\" : priority));\n }\n\n function textConstant$1(value) {\n return function() {\n this.textContent = value;\n };\n }\n\n function textFunction$1(value) {\n return function() {\n var value1 = value(this);\n this.textContent = value1 == null ? \"\" : value1;\n };\n }\n\n function transition_text(value) {\n return this.tween(\"text\", typeof value === \"function\"\n ? textFunction$1(tweenValue(this, \"text\", value))\n : textConstant$1(value == null ? \"\" : value + \"\"));\n }\n\n function transition_transition() {\n var name = this._name,\n id0 = this._id,\n id1 = newId();\n\n for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n var inherit = get$1(node, id0);\n schedule(node, name, id1, i, group, {\n time: inherit.time + inherit.delay + inherit.duration,\n delay: 0,\n duration: inherit.duration,\n ease: inherit.ease\n });\n }\n }\n }\n\n return new Transition(groups, this._parents, name, id1);\n }\n\n var id = 0;\n\n function Transition(groups, parents, name, id) {\n this._groups = groups;\n this._parents = parents;\n this._name = name;\n this._id = id;\n }\n\n function transition(name) {\n return selection().transition(name);\n }\n\n function newId() {\n return ++id;\n }\n\n var selection_prototype = selection.prototype;\n\n Transition.prototype = transition.prototype = {\n constructor: Transition,\n select: transition_select,\n selectAll: transition_selectAll,\n filter: transition_filter,\n merge: transition_merge,\n selection: transition_selection,\n transition: transition_transition,\n call: selection_prototype.call,\n nodes: selection_prototype.nodes,\n node: selection_prototype.node,\n size: selection_prototype.size,\n empty: selection_prototype.empty,\n each: selection_prototype.each,\n on: transition_on,\n attr: transition_attr,\n attrTween: transition_attrTween,\n style: transition_style,\n styleTween: transition_styleTween,\n text: transition_text,\n remove: transition_remove,\n tween: transition_tween,\n delay: transition_delay,\n duration: transition_duration,\n ease: transition_ease\n };\n\n var defaultTiming = {\n time: null, // Set on use.\n delay: 0,\n duration: 250,\n ease: easeCubicInOut\n };\n\n function inherit(node, id) {\n var timing;\n while (!(timing = node.__transition) || !(timing = timing[id])) {\n if (!(node = node.parentNode)) {\n return defaultTiming.time = now(), defaultTiming;\n }\n }\n return timing;\n }\n\n function selection_transition(name) {\n var id,\n timing;\n\n if (name instanceof Transition) {\n id = name._id, name = name._name;\n } else {\n id = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + \"\";\n }\n\n for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n schedule(node, name, id, i, group, timing || inherit(node, id));\n }\n }\n }\n\n return new Transition(groups, this._parents, name, id);\n }\n\n selection.prototype.interrupt = selection_interrupt;\n selection.prototype.transition = selection_transition;\n\n var root$1 = [null];\n\n function active(node, name) {\n var schedules = node.__transition,\n schedule,\n i;\n\n if (schedules) {\n name = name == null ? null : name + \"\";\n for (i in schedules) {\n if ((schedule = schedules[i]).state > SCHEDULED && schedule.name === name) {\n return new Transition([[node]], root$1, name, +i);\n }\n }\n }\n\n return null;\n }\n\n var slice$4 = Array.prototype.slice;\n\n function identity$5(x) {\n return x;\n }\n\n var top = 1;\n var right = 2;\n var bottom = 3;\n var left = 4;\nvar epsilon$2 = 1e-6;\n function translateX(scale0, scale1, d) {\n var x = scale0(d);\n return \"translate(\" + (isFinite(x) ? x : scale1(d)) + \",0)\";\n }\n\n function translateY(scale0, scale1, d) {\n var y = scale0(d);\n return \"translate(0,\" + (isFinite(y) ? y : scale1(d)) + \")\";\n }\n\n function center(scale) {\n var width = scale.bandwidth() / 2;\n return function(d) {\n return scale(d) + width;\n };\n }\n\n function entering() {\n return !this.__axis;\n }\n\n function axis(orient, scale) {\n var tickArguments = [],\n tickValues = null,\n tickFormat = null,\n tickSizeInner = 6,\n tickSizeOuter = 6,\n tickPadding = 3;\n\n function axis(context) {\n var values = tickValues == null ? (scale.ticks ? scale.ticks.apply(scale, tickArguments) : scale.domain()) : tickValues,\n format = tickFormat == null ? (scale.tickFormat ? scale.tickFormat.apply(scale, tickArguments) : identity$5) : tickFormat,\n spacing = Math.max(tickSizeInner, 0) + tickPadding,\n transform = orient === top || orient === bottom ? translateX : translateY,\n range = scale.range(),\n range0 = range[0] + 0.5,\n range1 = range[range.length - 1] + 0.5,\n position = (scale.bandwidth ? center : identity$5)(scale.copy()),\n selection = context.selection ? context.selection() : context,\n path = selection.selectAll(\".domain\").data([null]),\n tick = selection.selectAll(\".tick\").data(values, scale).order(),\n tickExit = tick.exit(),\n tickEnter = tick.enter().append(\"g\").attr(\"class\", \"tick\"),\n line = tick.select(\"line\"),\n text = tick.select(\"text\"),\n k = orient === top || orient === left ? -1 : 1,\n x, y = orient === left || orient === right ? (x = \"x\", \"y\") : (x = \"y\", \"x\");\n\n path = path.merge(path.enter().insert(\"path\", \".tick\")\n .attr(\"class\", \"domain\")\n .attr(\"stroke\", \"#000\"));\n\n tick = tick.merge(tickEnter);\n\n line = line.merge(tickEnter.append(\"line\")\n .attr(\"stroke\", \"#000\")\n .attr(x + \"2\", k * tickSizeInner)\n .attr(y + \"1\", 0.5)\n .attr(y + \"2\", 0.5));\n\n text = text.merge(tickEnter.append(\"text\")\n .attr(\"fill\", \"#000\")\n .attr(x, k * spacing)\n .attr(y, 0.5)\n .attr(\"dy\", orient === top ? \"0em\" : orient === bottom ? \".71em\" : \".32em\"));\n\n if (context !== selection) {\n path = path.transition(context);\n tick = tick.transition(context);\n line = line.transition(context);\n text = text.transition(context);\n\n tickExit = tickExit.transition(context)\n .attr(\"opacity\", epsilon$2)\n .attr(\"transform\", function(d) { return transform(position, this.parentNode.__axis || position, d); });\n\n tickEnter\n .attr(\"opacity\", epsilon$2)\n .attr(\"transform\", function(d) { return transform(this.parentNode.__axis || position, position, d); });\n }\n\n tickExit.remove();\n\n path\n .attr(\"d\", orient === left || orient == right\n ? \"M\" + k * tickSizeOuter + \",\" + range0 + \"H0.5V\" + range1 + \"H\" + k * tickSizeOuter\n : \"M\" + range0 + \",\" + k * tickSizeOuter + \"V0.5H\" + range1 + \"V\" + k * tickSizeOuter);\n\n tick\n .attr(\"opacity\", 1)\n .attr(\"transform\", function(d) { return transform(position, position, d); });\n\n line\n .attr(x + \"2\", k * tickSizeInner);\n\n text\n .attr(x, k * spacing)\n .text(format);\n\n selection.filter(entering)\n .attr(\"fill\", \"none\")\n .attr(\"font-size\", 10)\n .attr(\"font-family\", \"sans-serif\")\n .attr(\"text-anchor\", orient === right ? \"start\" : orient === left ? \"end\" : \"middle\");\n\n selection\n .each(function() { this.__axis = position; });\n }\n\n axis.scale = function(_) {\n return arguments.length ? (scale = _, axis) : scale;\n };\n\n axis.ticks = function() {\n return tickArguments = slice$4.call(arguments), axis;\n };\n\n axis.tickArguments = function(_) {\n return arguments.length ? (tickArguments = _ == null ? [] : slice$4.call(_), axis) : tickArguments.slice();\n };\n\n axis.tickValues = function(_) {\n return arguments.length ? (tickValues = _ == null ? null : slice$4.call(_), axis) : tickValues && tickValues.slice();\n };\n\n axis.tickFormat = function(_) {\n return arguments.length ? (tickFormat = _, axis) : tickFormat;\n };\n\n axis.tickSize = function(_) {\n return arguments.length ? (tickSizeInner = tickSizeOuter = +_, axis) : tickSizeInner;\n };\n\n axis.tickSizeInner = function(_) {\n return arguments.length ? (tickSizeInner = +_, axis) : tickSizeInner;\n };\n\n axis.tickSizeOuter = function(_) {\n return arguments.length ? (tickSizeOuter = +_, axis) : tickSizeOuter;\n };\n\n axis.tickPadding = function(_) {\n return arguments.length ? (tickPadding = +_, axis) : tickPadding;\n };\n\n return axis;\n }\n\n function axisTop(scale) {\n return axis(top, scale);\n }\n\n function axisRight(scale) {\n return axis(right, scale);\n }\n\n function axisBottom(scale) {\n return axis(bottom, scale);\n }\n\n function axisLeft(scale) {\n return axis(left, scale);\n }\n\n function defaultSeparation(a, b) {\n return a.parent === b.parent ? 1 : 2;\n }\n\n function meanX(children) {\n return children.reduce(meanXReduce, 0) / children.length;\n }\n\n function meanXReduce(x, c) {\n return x + c.x;\n }\n\n function maxY(children) {\n return 1 + children.reduce(maxYReduce, 0);\n }\n\n function maxYReduce(y, c) {\n return Math.max(y, c.y);\n }\n\n function leafLeft(node) {\n var children;\n while (children = node.children) node = children[0];\n return node;\n }\n\n function leafRight(node) {\n var children;\n while (children = node.children) node = children[children.length - 1];\n return node;\n }\n\n function cluster() {\n var separation = defaultSeparation,\n dx = 1,\n dy = 1,\n nodeSize = false;\n\n function cluster(root) {\n var previousNode,\n x = 0;\n\n // First walk, computing the initial x & y values.\n root.eachAfter(function(node) {\n var children = node.children;\n if (children) {\n node.x = meanX(children);\n node.y = maxY(children);\n } else {\n node.x = previousNode ? x += separation(node, previousNode) : 0;\n node.y = 0;\n previousNode = node;\n }\n });\n\n var left = leafLeft(root),\n right = leafRight(root),\n x0 = left.x - separation(left, right) / 2,\n x1 = right.x + separation(right, left) / 2;\n\n // Second walk, normalizing x & y to the desired size.\n return root.eachAfter(nodeSize ? function(node) {\n node.x = (node.x - root.x) * dx;\n node.y = (root.y - node.y) * dy;\n } : function(node) {\n node.x = (node.x - x0) / (x1 - x0) * dx;\n node.y = (1 - (root.y ? node.y / root.y : 1)) * dy;\n });\n }\n\n cluster.separation = function(x) {\n return arguments.length ? (separation = x, cluster) : separation;\n };\n\n cluster.size = function(x) {\n return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? null : [dx, dy]);\n };\n\n cluster.nodeSize = function(x) {\n return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? [dx, dy] : null);\n };\n\n return cluster;\n }\n\n function node_each(callback) {\n var node = this, current, next = [node], children, i, n;\n do {\n current = next.reverse(), next = [];\n while (node = current.pop()) {\n callback(node), children = node.children;\n if (children) for (i = 0, n = children.length; i < n; ++i) {\n next.push(children[i]);\n }\n }\n } while (next.length);\n return this;\n }\n\n function node_eachBefore(callback) {\n var node = this, nodes = [node], children, i;\n while (node = nodes.pop()) {\n callback(node), children = node.children;\n if (children) for (i = children.length - 1; i >= 0; --i) {\n nodes.push(children[i]);\n }\n }\n return this;\n }\n\n function node_eachAfter(callback) {\n var node = this, nodes = [node], next = [], children, i, n;\n while (node = nodes.pop()) {\n next.push(node), children = node.children;\n if (children) for (i = 0, n = children.length; i < n; ++i) {\n nodes.push(children[i]);\n }\n }\n while (node = next.pop()) {\n callback(node);\n }\n return this;\n }\n\n function node_sum(value) {\n return this.eachAfter(function(node) {\n var sum = +value(node.data) || 0,\n children = node.children,\n i = children && children.length;\n while (--i >= 0) sum += children[i].value;\n node.value = sum;\n });\n }\n\n function node_sort(compare) {\n return this.eachBefore(function(node) {\n if (node.children) {\n node.children.sort(compare);\n }\n });\n }\n\n function node_path(end) {\n var start = this,\n ancestor = leastCommonAncestor(start, end),\n nodes = [start];\n while (start !== ancestor) {\n start = start.parent;\n nodes.push(start);\n }\n var k = nodes.length;\n while (end !== ancestor) {\n nodes.splice(k, 0, end);\n end = end.parent;\n }\n return nodes;\n }\n\n function leastCommonAncestor(a, b) {\n if (a === b) return a;\n var aNodes = a.ancestors(),\n bNodes = b.ancestors(),\n c = null;\n a = aNodes.pop();\n b = bNodes.pop();\n while (a === b) {\n c = a;\n a = aNodes.pop();\n b = bNodes.pop();\n }\n return c;\n }\n\n function node_ancestors() {\n var node = this, nodes = [node];\n while (node = node.parent) {\n nodes.push(node);\n }\n return nodes;\n }\n\n function node_descendants() {\n var nodes = [];\n this.each(function(node) {\n nodes.push(node);\n });\n return nodes;\n }\n\n function node_leaves() {\n var leaves = [];\n this.eachBefore(function(node) {\n if (!node.children) {\n leaves.push(node);\n }\n });\n return leaves;\n }\n\n function node_links() {\n var root = this, links = [];\n root.each(function(node) {\n if (node !== root) { // Don’t include the root’s parent, if any.\n links.push({source: node.parent, target: node});\n }\n });\n return links;\n }\n\n function hierarchy(data, children) {\n var root = new Node(data),\n valued = +data.value && (root.value = data.value),\n node,\n nodes = [root],\n child,\n childs,\n i,\n n;\n\n if (children == null) children = defaultChildren;\n\n while (node = nodes.pop()) {\n if (valued) node.value = +node.data.value;\n if ((childs = children(node.data)) && (n = childs.length)) {\n node.children = new Array(n);\n for (i = n - 1; i >= 0; --i) {\n nodes.push(child = node.children[i] = new Node(childs[i]));\n child.parent = node;\n child.depth = node.depth + 1;\n }\n }\n }\n\n return root.eachBefore(computeHeight);\n }\n\n function node_copy() {\n return hierarchy(this).eachBefore(copyData);\n }\n\n function defaultChildren(d) {\n return d.children;\n }\n\n function copyData(node) {\n node.data = node.data.data;\n }\n\n function computeHeight(node) {\n var height = 0;\n do node.height = height;\n while ((node = node.parent) && (node.height < ++height));\n }\n\n function Node(data) {\n this.data = data;\n this.depth =\n this.height = 0;\n this.parent = null;\n }\n\n Node.prototype = hierarchy.prototype = {\n constructor: Node,\n each: node_each,\n eachAfter: node_eachAfter,\n eachBefore: node_eachBefore,\n sum: node_sum,\n sort: node_sort,\n path: node_path,\n ancestors: node_ancestors,\n descendants: node_descendants,\n leaves: node_leaves,\n links: node_links,\n copy: node_copy\n };\n\n function Node$2(value) {\n this._ = value;\n this.next = null;\n }\n\n function shuffle$1(array) {\n var i,\n n = (array = array.slice()).length,\n head = null,\n node = head;\n\n while (n) {\n var next = new Node$2(array[n - 1]);\n if (node) node = node.next = next;\n else node = head = next;\n array[i] = array[--n];\n }\n\n return {\n head: head,\n tail: node\n };\n }\n\n function enclose(circles) {\n return encloseN(shuffle$1(circles), []);\n }\n\n function encloses(a, b) {\n var dx = b.x - a.x,\n dy = b.y - a.y,\n dr = a.r - b.r;\n return dr * dr + 1e-6 > dx * dx + dy * dy;\n }\n\n // Returns the smallest circle that contains circles L and intersects circles B.\n function encloseN(L, B) {\n var circle,\n l0 = null,\n l1 = L.head,\n l2,\n p1;\n\n switch (B.length) {\n case 1: circle = enclose1(B[0]); break;\n case 2: circle = enclose2(B[0], B[1]); break;\n case 3: circle = enclose3(B[0], B[1], B[2]); break;\n }\n\n while (l1) {\n p1 = l1._, l2 = l1.next;\n if (!circle || !encloses(circle, p1)) {\n\n // Temporarily truncate L before l1.\n if (l0) L.tail = l0, l0.next = null;\n else L.head = L.tail = null;\n\n B.push(p1);\n circle = encloseN(L, B); // Note: reorders L!\n B.pop();\n\n // Move l1 to the front of L and reconnect the truncated list L.\n if (L.head) l1.next = L.head, L.head = l1;\n else l1.next = null, L.head = L.tail = l1;\n l0 = L.tail, l0.next = l2;\n\n } else {\n l0 = l1;\n }\n l1 = l2;\n }\n\n L.tail = l0;\n return circle;\n }\n\n function enclose1(a) {\n return {\n x: a.x,\n y: a.y,\n r: a.r\n };\n }\n\n function enclose2(a, b) {\n var x1 = a.x, y1 = a.y, r1 = a.r,\n x2 = b.x, y2 = b.y, r2 = b.r,\n x21 = x2 - x1, y21 = y2 - y1, r21 = r2 - r1,\n l = Math.sqrt(x21 * x21 + y21 * y21);\n return {\n x: (x1 + x2 + x21 / l * r21) / 2,\n y: (y1 + y2 + y21 / l * r21) / 2,\n r: (l + r1 + r2) / 2\n };\n }\n\n function enclose3(a, b, c) {\n var x1 = a.x, y1 = a.y, r1 = a.r,\n x2 = b.x, y2 = b.y, r2 = b.r,\n x3 = c.x, y3 = c.y, r3 = c.r,\n a2 = 2 * (x1 - x2),\n b2 = 2 * (y1 - y2),\n c2 = 2 * (r2 - r1),\n d2 = x1 * x1 + y1 * y1 - r1 * r1 - x2 * x2 - y2 * y2 + r2 * r2,\n a3 = 2 * (x1 - x3),\n b3 = 2 * (y1 - y3),\n c3 = 2 * (r3 - r1),\n d3 = x1 * x1 + y1 * y1 - r1 * r1 - x3 * x3 - y3 * y3 + r3 * r3,\n ab = a3 * b2 - a2 * b3,\n xa = (b2 * d3 - b3 * d2) / ab - x1,\n xb = (b3 * c2 - b2 * c3) / ab,\n ya = (a3 * d2 - a2 * d3) / ab - y1,\n yb = (a2 * c3 - a3 * c2) / ab,\n A = xb * xb + yb * yb - 1,\n B = 2 * (xa * xb + ya * yb + r1),\n C = xa * xa + ya * ya - r1 * r1,\n r = (-B - Math.sqrt(B * B - 4 * A * C)) / (2 * A);\n return {\n x: xa + xb * r + x1,\n y: ya + yb * r + y1,\n r: r\n };\n }\n\n function place(a, b, c) {\n var ax = a.x,\n ay = a.y,\n da = b.r + c.r,\n db = a.r + c.r,\n dx = b.x - ax,\n dy = b.y - ay,\n dc = dx * dx + dy * dy;\n if (dc) {\n var x = 0.5 + ((db *= db) - (da *= da)) / (2 * dc),\n y = Math.sqrt(Math.max(0, 2 * da * (db + dc) - (db -= dc) * db - da * da)) / (2 * dc);\n c.x = ax + x * dx + y * dy;\n c.y = ay + x * dy - y * dx;\n } else {\n c.x = ax + db;\n c.y = ay;\n }\n }\n\n function intersects(a, b) {\n var dx = b.x - a.x,\n dy = b.y - a.y,\n dr = a.r + b.r;\n return dr * dr > dx * dx + dy * dy;\n }\n\n function distance2(circle, x, y) {\n var dx = circle.x - x,\n dy = circle.y - y;\n return dx * dx + dy * dy;\n }\n\n function Node$1(circle) {\n this._ = circle;\n this.next = null;\n this.previous = null;\n }\n\n function packEnclose(circles) {\n if (!(n = circles.length)) return 0;\n\n var a, b, c, n;\n\n // Place the first circle.\n a = circles[0], a.x = 0, a.y = 0;\n if (!(n > 1)) return a.r;\n\n // Place the second circle.\n b = circles[1], a.x = -b.r, b.x = a.r, b.y = 0;\n if (!(n > 2)) return a.r + b.r;\n\n // Place the third circle.\n place(b, a, c = circles[2]);\n\n // Initialize the weighted centroid.\n var aa = a.r * a.r,\n ba = b.r * b.r,\n ca = c.r * c.r,\n oa = aa + ba + ca,\n ox = aa * a.x + ba * b.x + ca * c.x,\n oy = aa * a.y + ba * b.y + ca * c.y,\n cx, cy, i, j, k, sj, sk;\n\n // Initialize the front-chain using the first three circles a, b and c.\n a = new Node$1(a), b = new Node$1(b), c = new Node$1(c);\n a.next = c.previous = b;\n b.next = a.previous = c;\n c.next = b.previous = a;\n\n // Attempt to place each remaining circle…\n pack: for (i = 3; i < n; ++i) {\n place(a._, b._, c = circles[i]), c = new Node$1(c);\n\n // If there are only three elements in the front-chain…\n if ((k = a.previous) === (j = b.next)) {\n // If the new circle intersects the third circle,\n // rotate the front chain to try the next position.\n if (intersects(j._, c._)) {\n a = b, b = j, --i;\n continue pack;\n }\n }\n\n // Find the closest intersecting circle on the front-chain, if any.\n else {\n sj = j._.r, sk = k._.r;\n do {\n if (sj <= sk) {\n if (intersects(j._, c._)) {\n b = j, a.next = b, b.previous = a, --i;\n continue pack;\n }\n j = j.next, sj += j._.r;\n } else {\n if (intersects(k._, c._)) {\n a = k, a.next = b, b.previous = a, --i;\n continue pack;\n }\n k = k.previous, sk += k._.r;\n }\n } while (j !== k.next);\n }\n\n // Success! Insert the new circle c between a and b.\n c.previous = a, c.next = b, a.next = b.previous = b = c;\n\n // Update the weighted centroid.\n oa += ca = c._.r * c._.r;\n ox += ca * c._.x;\n oy += ca * c._.y;\n\n // Compute the new closest circle a to centroid.\n aa = distance2(a._, cx = ox / oa, cy = oy / oa);\n while ((c = c.next) !== b) {\n if ((ca = distance2(c._, cx, cy)) < aa) {\n a = c, aa = ca;\n }\n }\n b = a.next;\n }\n\n // Compute the enclosing circle of the front chain.\n a = [b._], c = b; while ((c = c.next) !== b) a.push(c._); c = enclose(a);\n\n // Translate the circles to put the enclosing circle around the origin.\n for (i = 0; i < n; ++i) a = circles[i], a.x -= c.x, a.y -= c.y;\n\n return c.r;\n }\n\n function siblings(circles) {\n packEnclose(circles);\n return circles;\n }\n\n function optional(f) {\n return f == null ? null : required(f);\n }\n\n function required(f) {\n if (typeof f !== \"function\") throw new Error;\n return f;\n }\n\n function constantZero() {\n return 0;\n }\n\n function constant$5(x) {\n return function() {\n return x;\n };\n }\n\n function defaultRadius(d) {\n return Math.sqrt(d.value);\n }\n\n function index() {\n var radius = null,\n dx = 1,\n dy = 1,\n padding = constantZero;\n\n function pack(root) {\n root.x = dx / 2, root.y = dy / 2;\n if (radius) {\n root.eachBefore(radiusLeaf(radius))\n .eachAfter(packChildren(padding, 0.5))\n .eachBefore(translateChild(1));\n } else {\n root.eachBefore(radiusLeaf(defaultRadius))\n .eachAfter(packChildren(constantZero, 1))\n .eachAfter(packChildren(padding, root.r / Math.min(dx, dy)))\n .eachBefore(translateChild(Math.min(dx, dy) / (2 * root.r)));\n }\n return root;\n }\n\n pack.radius = function(x) {\n return arguments.length ? (radius = optional(x), pack) : radius;\n };\n\n pack.size = function(x) {\n return arguments.length ? (dx = +x[0], dy = +x[1], pack) : [dx, dy];\n };\n\n pack.padding = function(x) {\n return arguments.length ? (padding = typeof x === \"function\" ? x : constant$5(+x), pack) : padding;\n };\n\n return pack;\n }\n\n function radiusLeaf(radius) {\n return function(node) {\n if (!node.children) {\n node.r = Math.max(0, +radius(node) || 0);\n }\n };\n }\n\n function packChildren(padding, k) {\n return function(node) {\n if (children = node.children) {\n var children,\n i,\n n = children.length,\n r = padding(node) * k || 0,\n e;\n\n if (r) for (i = 0; i < n; ++i) children[i].r += r;\n e = packEnclose(children);\n if (r) for (i = 0; i < n; ++i) children[i].r -= r;\n node.r = e + r;\n }\n };\n }\n\n function translateChild(k) {\n return function(node) {\n var parent = node.parent;\n node.r *= k;\n if (parent) {\n node.x = parent.x + k * node.x;\n node.y = parent.y + k * node.y;\n }\n };\n }\n\n function roundNode(node) {\n node.x0 = Math.round(node.x0);\n node.y0 = Math.round(node.y0);\n node.x1 = Math.round(node.x1);\n node.y1 = Math.round(node.y1);\n }\n\n function treemapDice(parent, x0, y0, x1, y1) {\n var nodes = parent.children,\n node,\n i = -1,\n n = nodes.length,\n k = parent.value && (x1 - x0) / parent.value;\n\n while (++i < n) {\n node = nodes[i], node.y0 = y0, node.y1 = y1;\n node.x0 = x0, node.x1 = x0 += node.value * k;\n }\n }\n\n function partition() {\n var dx = 1,\n dy = 1,\n padding = 0,\n round = false;\n\n function partition(root) {\n var n = root.height + 1;\n root.x0 =\n root.y0 = padding;\n root.x1 = dx;\n root.y1 = dy / n;\n root.eachBefore(positionNode(dy, n));\n if (round) root.eachBefore(roundNode);\n return root;\n }\n\n function positionNode(dy, n) {\n return function(node) {\n if (node.children) {\n treemapDice(node, node.x0, dy * (node.depth + 1) / n, node.x1, dy * (node.depth + 2) / n);\n }\n var x0 = node.x0,\n y0 = node.y0,\n x1 = node.x1 - padding,\n y1 = node.y1 - padding;\n if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n node.x0 = x0;\n node.y0 = y0;\n node.x1 = x1;\n node.y1 = y1;\n };\n }\n\n partition.round = function(x) {\n return arguments.length ? (round = !!x, partition) : round;\n };\n\n partition.size = function(x) {\n return arguments.length ? (dx = +x[0], dy = +x[1], partition) : [dx, dy];\n };\n\n partition.padding = function(x) {\n return arguments.length ? (padding = +x, partition) : padding;\n };\n\n return partition;\n }\n\nvar keyPrefix$1 = \"$\";\n var preroot = {depth: -1};\n var ambiguous = {};\n function defaultId(d) {\n return d.id;\n }\n\n function defaultParentId(d) {\n return d.parentId;\n }\n\n function stratify() {\n var id = defaultId,\n parentId = defaultParentId;\n\n function stratify(data) {\n var d,\n i,\n n = data.length,\n root,\n parent,\n node,\n nodes = new Array(n),\n nodeId,\n nodeKey,\n nodeByKey = {};\n\n for (i = 0; i < n; ++i) {\n d = data[i], node = nodes[i] = new Node(d);\n if ((nodeId = id(d, i, data)) != null && (nodeId += \"\")) {\n nodeKey = keyPrefix$1 + (node.id = nodeId);\n nodeByKey[nodeKey] = nodeKey in nodeByKey ? ambiguous : node;\n }\n }\n\n for (i = 0; i < n; ++i) {\n node = nodes[i], nodeId = parentId(data[i], i, data);\n if (nodeId == null || !(nodeId += \"\")) {\n if (root) throw new Error(\"multiple roots\");\n root = node;\n } else {\n parent = nodeByKey[keyPrefix$1 + nodeId];\n if (!parent) throw new Error(\"missing: \" + nodeId);\n if (parent === ambiguous) throw new Error(\"ambiguous: \" + nodeId);\n if (parent.children) parent.children.push(node);\n else parent.children = [node];\n node.parent = parent;\n }\n }\n\n if (!root) throw new Error(\"no root\");\n root.parent = preroot;\n root.eachBefore(function(node) { node.depth = node.parent.depth + 1; --n; }).eachBefore(computeHeight);\n root.parent = null;\n if (n > 0) throw new Error(\"cycle\");\n\n return root;\n }\n\n stratify.id = function(x) {\n return arguments.length ? (id = required(x), stratify) : id;\n };\n\n stratify.parentId = function(x) {\n return arguments.length ? (parentId = required(x), stratify) : parentId;\n };\n\n return stratify;\n }\n\n function defaultSeparation$1(a, b) {\n return a.parent === b.parent ? 1 : 2;\n }\n\n // function radialSeparation(a, b) {\n // return (a.parent === b.parent ? 1 : 2) / a.depth;\n // }\n\n // This function is used to traverse the left contour of a subtree (or\n // subforest). It returns the successor of v on this contour. This successor is\n // either given by the leftmost child of v or by the thread of v. The function\n // returns null if and only if v is on the highest level of its subtree.\n function nextLeft(v) {\n var children = v.children;\n return children ? children[0] : v.t;\n }\n\n // This function works analogously to nextLeft.\n function nextRight(v) {\n var children = v.children;\n return children ? children[children.length - 1] : v.t;\n }\n\n // Shifts the current subtree rooted at w+. This is done by increasing\n // prelim(w+) and mod(w+) by shift.\n function moveSubtree(wm, wp, shift) {\n var change = shift / (wp.i - wm.i);\n wp.c -= change;\n wp.s += shift;\n wm.c += change;\n wp.z += shift;\n wp.m += shift;\n }\n\n // All other shifts, applied to the smaller subtrees between w- and w+, are\n // performed by this function. To prepare the shifts, we have to adjust\n // change(w+), shift(w+), and change(w-).\n function executeShifts(v) {\n var shift = 0,\n change = 0,\n children = v.children,\n i = children.length,\n w;\n while (--i >= 0) {\n w = children[i];\n w.z += shift;\n w.m += shift;\n shift += w.s + (change += w.c);\n }\n }\n\n // If vi-’s ancestor is a sibling of v, returns vi-’s ancestor. Otherwise,\n // returns the specified (default) ancestor.\n function nextAncestor(vim, v, ancestor) {\n return vim.a.parent === v.parent ? vim.a : ancestor;\n }\n\n function TreeNode(node, i) {\n this._ = node;\n this.parent = null;\n this.children = null;\n this.A = null; // default ancestor\n this.a = this; // ancestor\n this.z = 0; // prelim\n this.m = 0; // mod\n this.c = 0; // change\n this.s = 0; // shift\n this.t = null; // thread\n this.i = i; // number\n }\n\n TreeNode.prototype = Object.create(Node.prototype);\n\n function treeRoot(root) {\n var tree = new TreeNode(root, 0),\n node,\n nodes = [tree],\n child,\n children,\n i,\n n;\n\n while (node = nodes.pop()) {\n if (children = node._.children) {\n node.children = new Array(n = children.length);\n for (i = n - 1; i >= 0; --i) {\n nodes.push(child = node.children[i] = new TreeNode(children[i], i));\n child.parent = node;\n }\n }\n }\n\n (tree.parent = new TreeNode(null, 0)).children = [tree];\n return tree;\n }\n\n // Node-link tree diagram using the Reingold-Tilford \"tidy\" algorithm\n function tree() {\n var separation = defaultSeparation$1,\n dx = 1,\n dy = 1,\n nodeSize = null;\n\n function tree(root) {\n var t = treeRoot(root);\n\n // Compute the layout using Buchheim et al.’s algorithm.\n t.eachAfter(firstWalk), t.parent.m = -t.z;\n t.eachBefore(secondWalk);\n\n // If a fixed node size is specified, scale x and y.\n if (nodeSize) root.eachBefore(sizeNode);\n\n // If a fixed tree size is specified, scale x and y based on the extent.\n // Compute the left-most, right-most, and depth-most nodes for extents.\n else {\n var left = root,\n right = root,\n bottom = root;\n root.eachBefore(function(node) {\n if (node.x < left.x) left = node;\n if (node.x > right.x) right = node;\n if (node.depth > bottom.depth) bottom = node;\n });\n var s = left === right ? 1 : separation(left, right) / 2,\n tx = s - left.x,\n kx = dx / (right.x + s + tx),\n ky = dy / (bottom.depth || 1);\n root.eachBefore(function(node) {\n node.x = (node.x + tx) * kx;\n node.y = node.depth * ky;\n });\n }\n\n return root;\n }\n\n // Computes a preliminary x-coordinate for v. Before that, FIRST WALK is\n // applied recursively to the children of v, as well as the function\n // APPORTION. After spacing out the children by calling EXECUTE SHIFTS, the\n // node v is placed to the midpoint of its outermost children.\n function firstWalk(v) {\n var children = v.children,\n siblings = v.parent.children,\n w = v.i ? siblings[v.i - 1] : null;\n if (children) {\n executeShifts(v);\n var midpoint = (children[0].z + children[children.length - 1].z) / 2;\n if (w) {\n v.z = w.z + separation(v._, w._);\n v.m = v.z - midpoint;\n } else {\n v.z = midpoint;\n }\n } else if (w) {\n v.z = w.z + separation(v._, w._);\n }\n v.parent.A = apportion(v, w, v.parent.A || siblings[0]);\n }\n\n // Computes all real x-coordinates by summing up the modifiers recursively.\n function secondWalk(v) {\n v._.x = v.z + v.parent.m;\n v.m += v.parent.m;\n }\n\n // The core of the algorithm. Here, a new subtree is combined with the\n // previous subtrees. Threads are used to traverse the inside and outside\n // contours of the left and right subtree up to the highest common level. The\n // vertices used for the traversals are vi+, vi-, vo-, and vo+, where the\n // superscript o means outside and i means inside, the subscript - means left\n // subtree and + means right subtree. For summing up the modifiers along the\n // contour, we use respective variables si+, si-, so-, and so+. Whenever two\n // nodes of the inside contours conflict, we compute the left one of the\n // greatest uncommon ancestors using the function ANCESTOR and call MOVE\n // SUBTREE to shift the subtree and prepare the shifts of smaller subtrees.\n // Finally, we add a new thread (if necessary).\n function apportion(v, w, ancestor) {\n if (w) {\n var vip = v,\n vop = v,\n vim = w,\n vom = vip.parent.children[0],\n sip = vip.m,\n sop = vop.m,\n sim = vim.m,\n som = vom.m,\n shift;\n while (vim = nextRight(vim), vip = nextLeft(vip), vim && vip) {\n vom = nextLeft(vom);\n vop = nextRight(vop);\n vop.a = v;\n shift = vim.z + sim - vip.z - sip + separation(vim._, vip._);\n if (shift > 0) {\n moveSubtree(nextAncestor(vim, v, ancestor), v, shift);\n sip += shift;\n sop += shift;\n }\n sim += vim.m;\n sip += vip.m;\n som += vom.m;\n sop += vop.m;\n }\n if (vim && !nextRight(vop)) {\n vop.t = vim;\n vop.m += sim - sop;\n }\n if (vip && !nextLeft(vom)) {\n vom.t = vip;\n vom.m += sip - som;\n ancestor = v;\n }\n }\n return ancestor;\n }\n\n function sizeNode(node) {\n node.x *= dx;\n node.y = node.depth * dy;\n }\n\n tree.separation = function(x) {\n return arguments.length ? (separation = x, tree) : separation;\n };\n\n tree.size = function(x) {\n return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], tree) : (nodeSize ? null : [dx, dy]);\n };\n\n tree.nodeSize = function(x) {\n return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], tree) : (nodeSize ? [dx, dy] : null);\n };\n\n return tree;\n }\n\n function treemapSlice(parent, x0, y0, x1, y1) {\n var nodes = parent.children,\n node,\n i = -1,\n n = nodes.length,\n k = parent.value && (y1 - y0) / parent.value;\n\n while (++i < n) {\n node = nodes[i], node.x0 = x0, node.x1 = x1;\n node.y0 = y0, node.y1 = y0 += node.value * k;\n }\n }\n\n var phi = (1 + Math.sqrt(5)) / 2;\n\n function squarifyRatio(ratio, parent, x0, y0, x1, y1) {\n var rows = [],\n nodes = parent.children,\n row,\n nodeValue,\n i0 = 0,\n i1,\n n = nodes.length,\n dx, dy,\n value = parent.value,\n sumValue,\n minValue,\n maxValue,\n newRatio,\n minRatio,\n alpha,\n beta;\n\n while (i0 < n) {\n dx = x1 - x0, dy = y1 - y0;\n minValue = maxValue = sumValue = nodes[i0].value;\n alpha = Math.max(dy / dx, dx / dy) / (value * ratio);\n beta = sumValue * sumValue * alpha;\n minRatio = Math.max(maxValue / beta, beta / minValue);\n\n // Keep adding nodes while the aspect ratio maintains or improves.\n for (i1 = i0 + 1; i1 < n; ++i1) {\n sumValue += nodeValue = nodes[i1].value;\n if (nodeValue < minValue) minValue = nodeValue;\n if (nodeValue > maxValue) maxValue = nodeValue;\n beta = sumValue * sumValue * alpha;\n newRatio = Math.max(maxValue / beta, beta / minValue);\n if (newRatio > minRatio) { sumValue -= nodeValue; break; }\n minRatio = newRatio;\n }\n\n // Position and record the row orientation.\n rows.push(row = {value: sumValue, dice: dx < dy, children: nodes.slice(i0, i1)});\n if (row.dice) treemapDice(row, x0, y0, x1, value ? y0 += dy * sumValue / value : y1);\n else treemapSlice(row, x0, y0, value ? x0 += dx * sumValue / value : x1, y1);\n value -= sumValue, i0 = i1;\n }\n\n return rows;\n }\n\n var squarify = (function custom(ratio) {\n\n function squarify(parent, x0, y0, x1, y1) {\n squarifyRatio(ratio, parent, x0, y0, x1, y1);\n }\n\n squarify.ratio = function(x) {\n return custom((x = +x) > 1 ? x : 1);\n };\n\n return squarify;\n })(phi);\n\n function index$1() {\n var tile = squarify,\n round = false,\n dx = 1,\n dy = 1,\n paddingStack = [0],\n paddingInner = constantZero,\n paddingTop = constantZero,\n paddingRight = constantZero,\n paddingBottom = constantZero,\n paddingLeft = constantZero;\n\n function treemap(root) {\n root.x0 =\n root.y0 = 0;\n root.x1 = dx;\n root.y1 = dy;\n root.eachBefore(positionNode);\n paddingStack = [0];\n if (round) root.eachBefore(roundNode);\n return root;\n }\n\n function positionNode(node) {\n var p = paddingStack[node.depth],\n x0 = node.x0 + p,\n y0 = node.y0 + p,\n x1 = node.x1 - p,\n y1 = node.y1 - p;\n if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n node.x0 = x0;\n node.y0 = y0;\n node.x1 = x1;\n node.y1 = y1;\n if (node.children) {\n p = paddingStack[node.depth + 1] = paddingInner(node) / 2;\n x0 += paddingLeft(node) - p;\n y0 += paddingTop(node) - p;\n x1 -= paddingRight(node) - p;\n y1 -= paddingBottom(node) - p;\n if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n tile(node, x0, y0, x1, y1);\n }\n }\n\n treemap.round = function(x) {\n return arguments.length ? (round = !!x, treemap) : round;\n };\n\n treemap.size = function(x) {\n return arguments.length ? (dx = +x[0], dy = +x[1], treemap) : [dx, dy];\n };\n\n treemap.tile = function(x) {\n return arguments.length ? (tile = required(x), treemap) : tile;\n };\n\n treemap.padding = function(x) {\n return arguments.length ? treemap.paddingInner(x).paddingOuter(x) : treemap.paddingInner();\n };\n\n treemap.paddingInner = function(x) {\n return arguments.length ? (paddingInner = typeof x === \"function\" ? x : constant$5(+x), treemap) : paddingInner;\n };\n\n treemap.paddingOuter = function(x) {\n return arguments.length ? treemap.paddingTop(x).paddingRight(x).paddingBottom(x).paddingLeft(x) : treemap.paddingTop();\n };\n\n treemap.paddingTop = function(x) {\n return arguments.length ? (paddingTop = typeof x === \"function\" ? x : constant$5(+x), treemap) : paddingTop;\n };\n\n treemap.paddingRight = function(x) {\n return arguments.length ? (paddingRight = typeof x === \"function\" ? x : constant$5(+x), treemap) : paddingRight;\n };\n\n treemap.paddingBottom = function(x) {\n return arguments.length ? (paddingBottom = typeof x === \"function\" ? x : constant$5(+x), treemap) : paddingBottom;\n };\n\n treemap.paddingLeft = function(x) {\n return arguments.length ? (paddingLeft = typeof x === \"function\" ? x : constant$5(+x), treemap) : paddingLeft;\n };\n\n return treemap;\n }\n\n function binary(parent, x0, y0, x1, y1) {\n var nodes = parent.children,\n i, n = nodes.length,\n sum, sums = new Array(n + 1);\n\n for (sums[0] = sum = i = 0; i < n; ++i) {\n sums[i + 1] = sum += nodes[i].value;\n }\n\n partition(0, n, parent.value, x0, y0, x1, y1);\n\n function partition(i, j, value, x0, y0, x1, y1) {\n if (i >= j - 1) {\n var node = nodes[i];\n node.x0 = x0, node.y0 = y0;\n node.x1 = x1, node.y1 = y1;\n return;\n }\n\n var valueOffset = sums[i],\n valueTarget = (value / 2) + valueOffset,\n k = i + 1,\n hi = j - 1;\n\n while (k < hi) {\n var mid = k + hi >>> 1;\n if (sums[mid] < valueTarget) k = mid + 1;\n else hi = mid;\n }\n\n var valueLeft = sums[k] - valueOffset,\n valueRight = value - valueLeft;\n\n if ((y1 - y0) > (x1 - x0)) {\n var yk = (y0 * valueRight + y1 * valueLeft) / value;\n partition(i, k, valueLeft, x0, y0, x1, yk);\n partition(k, j, valueRight, x0, yk, x1, y1);\n } else {\n var xk = (x0 * valueRight + x1 * valueLeft) / value;\n partition(i, k, valueLeft, x0, y0, xk, y1);\n partition(k, j, valueRight, xk, y0, x1, y1);\n }\n }\n }\n\n function sliceDice(parent, x0, y0, x1, y1) {\n (parent.depth & 1 ? treemapSlice : treemapDice)(parent, x0, y0, x1, y1);\n }\n\n var resquarify = (function custom(ratio) {\n\n function resquarify(parent, x0, y0, x1, y1) {\n if ((rows = parent._squarify) && (rows.ratio === ratio)) {\n var rows,\n row,\n nodes,\n i,\n j = -1,\n n,\n m = rows.length,\n value = parent.value;\n\n while (++j < m) {\n row = rows[j], nodes = row.children;\n for (i = row.value = 0, n = nodes.length; i < n; ++i) row.value += nodes[i].value;\n if (row.dice) treemapDice(row, x0, y0, x1, y0 += (y1 - y0) * row.value / value);\n else treemapSlice(row, x0, y0, x0 += (x1 - x0) * row.value / value, y1);\n value -= row.value;\n }\n } else {\n parent._squarify = rows = squarifyRatio(ratio, parent, x0, y0, x1, y1);\n rows.ratio = ratio;\n }\n }\n\n resquarify.ratio = function(x) {\n return custom((x = +x) > 1 ? x : 1);\n };\n\n return resquarify;\n })(phi);\n\n function center$1(x, y) {\n var nodes;\n\n if (x == null) x = 0;\n if (y == null) y = 0;\n\n function force() {\n var i,\n n = nodes.length,\n node,\n sx = 0,\n sy = 0;\n\n for (i = 0; i < n; ++i) {\n node = nodes[i], sx += node.x, sy += node.y;\n }\n\n for (sx = sx / n - x, sy = sy / n - y, i = 0; i < n; ++i) {\n node = nodes[i], node.x -= sx, node.y -= sy;\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n };\n\n force.x = function(_) {\n return arguments.length ? (x = +_, force) : x;\n };\n\n force.y = function(_) {\n return arguments.length ? (y = +_, force) : y;\n };\n\n return force;\n }\n\n function constant$6(x) {\n return function() {\n return x;\n };\n }\n\n function jiggle() {\n return (Math.random() - 0.5) * 1e-6;\n }\n\n function x$1(d) {\n return d.x + d.vx;\n }\n\n function y$1(d) {\n return d.y + d.vy;\n }\n\n function collide(radius) {\n var nodes,\n radii,\n strength = 1,\n iterations = 1;\n\n if (typeof radius !== \"function\") radius = constant$6(radius == null ? 1 : +radius);\n\n function force() {\n var i, n = nodes.length,\n tree,\n node,\n xi,\n yi,\n ri,\n ri2;\n\n for (var k = 0; k < iterations; ++k) {\n tree = quadtree(nodes, x$1, y$1).visitAfter(prepare);\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n ri = radii[i], ri2 = ri * ri;\n xi = node.x + node.vx;\n yi = node.y + node.vy;\n tree.visit(apply);\n }\n }\n\n function apply(quad, x0, y0, x1, y1) {\n var data = quad.data, rj = quad.r, r = ri + rj;\n if (data) {\n if (data.index > i) {\n var x = xi - data.x - data.vx,\n y = yi - data.y - data.vy,\n l = x * x + y * y;\n if (l < r * r) {\n if (x === 0) x = jiggle(), l += x * x;\n if (y === 0) y = jiggle(), l += y * y;\n l = (r - (l = Math.sqrt(l))) / l * strength;\n node.vx += (x *= l) * (r = (rj *= rj) / (ri2 + rj));\n node.vy += (y *= l) * r;\n data.vx -= x * (r = 1 - r);\n data.vy -= y * r;\n }\n }\n return;\n }\n return x0 > xi + r || x1 < xi - r || y0 > yi + r || y1 < yi - r;\n }\n }\n\n function prepare(quad) {\n if (quad.data) return quad.r = radii[quad.data.index];\n for (var i = quad.r = 0; i < 4; ++i) {\n if (quad[i] && quad[i].r > quad.r) {\n quad.r = quad[i].r;\n }\n }\n }\n\n force.initialize = function(_) {\n var i, n = (nodes = _).length; radii = new Array(n);\n for (i = 0; i < n; ++i) radii[i] = +radius(nodes[i], i, nodes);\n };\n\n force.iterations = function(_) {\n return arguments.length ? (iterations = +_, force) : iterations;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = +_, force) : strength;\n };\n\n force.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant$6(+_), force) : radius;\n };\n\n return force;\n }\n\n function index$2(d, i) {\n return i;\n }\n\n function link(links) {\n var id = index$2,\n strength = defaultStrength,\n strengths,\n distance = constant$6(30),\n distances,\n nodes,\n count,\n bias,\n iterations = 1;\n\n if (links == null) links = [];\n\n function defaultStrength(link) {\n return 1 / Math.min(count[link.source.index], count[link.target.index]);\n }\n\n function force(alpha) {\n for (var k = 0, n = links.length; k < iterations; ++k) {\n for (var i = 0, link, source, target, x, y, l, b; i < n; ++i) {\n link = links[i], source = link.source, target = link.target;\n x = target.x + target.vx - source.x - source.vx || jiggle();\n y = target.y + target.vy - source.y - source.vy || jiggle();\n l = Math.sqrt(x * x + y * y);\n l = (l - distances[i]) / l * alpha * strengths[i];\n x *= l, y *= l;\n target.vx -= x * (b = bias[i]);\n target.vy -= y * b;\n source.vx += x * (b = 1 - b);\n source.vy += y * b;\n }\n }\n }\n\n function initialize() {\n if (!nodes) return;\n\n var i,\n n = nodes.length,\n m = links.length,\n nodeById = map$1(nodes, id),\n link;\n\n for (i = 0, count = new Array(n); i < n; ++i) {\n count[i] = 0;\n }\n\n for (i = 0; i < m; ++i) {\n link = links[i], link.index = i;\n if (typeof link.source !== \"object\") link.source = nodeById.get(link.source);\n if (typeof link.target !== \"object\") link.target = nodeById.get(link.target);\n ++count[link.source.index], ++count[link.target.index];\n }\n\n for (i = 0, bias = new Array(m); i < m; ++i) {\n link = links[i], bias[i] = count[link.source.index] / (count[link.source.index] + count[link.target.index]);\n }\n\n strengths = new Array(m), initializeStrength();\n distances = new Array(m), initializeDistance();\n }\n\n function initializeStrength() {\n if (!nodes) return;\n\n for (var i = 0, n = links.length; i < n; ++i) {\n strengths[i] = +strength(links[i], i, links);\n }\n }\n\n function initializeDistance() {\n if (!nodes) return;\n\n for (var i = 0, n = links.length; i < n; ++i) {\n distances[i] = +distance(links[i], i, links);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.links = function(_) {\n return arguments.length ? (links = _, initialize(), force) : links;\n };\n\n force.id = function(_) {\n return arguments.length ? (id = _, force) : id;\n };\n\n force.iterations = function(_) {\n return arguments.length ? (iterations = +_, force) : iterations;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initializeStrength(), force) : strength;\n };\n\n force.distance = function(_) {\n return arguments.length ? (distance = typeof _ === \"function\" ? _ : constant$6(+_), initializeDistance(), force) : distance;\n };\n\n return force;\n }\n\n function x$2(d) {\n return d.x;\n }\n\n function y$2(d) {\n return d.y;\n }\n\n var initialRadius = 10;\n var initialAngle = Math.PI * (3 - Math.sqrt(5));\n function simulation(nodes) {\n var simulation,\n alpha = 1,\n alphaMin = 0.001,\n alphaDecay = 1 - Math.pow(alphaMin, 1 / 300),\n alphaTarget = 0,\n velocityDecay = 0.6,\n forces = map$1(),\n stepper = timer(step),\n event = dispatch(\"tick\", \"end\");\n\n if (nodes == null) nodes = [];\n\n function step() {\n tick();\n event.call(\"tick\", simulation);\n if (alpha < alphaMin) {\n stepper.stop();\n event.call(\"end\", simulation);\n }\n }\n\n function tick() {\n var i, n = nodes.length, node;\n\n alpha += (alphaTarget - alpha) * alphaDecay;\n\n forces.each(function(force) {\n force(alpha);\n });\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n if (node.fx == null) node.x += node.vx *= velocityDecay;\n else node.x = node.fx, node.vx = 0;\n if (node.fy == null) node.y += node.vy *= velocityDecay;\n else node.y = node.fy, node.vy = 0;\n }\n }\n\n function initializeNodes() {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.index = i;\n if (isNaN(node.x) || isNaN(node.y)) {\n var radius = initialRadius * Math.sqrt(i), angle = i * initialAngle;\n node.x = radius * Math.cos(angle);\n node.y = radius * Math.sin(angle);\n }\n if (isNaN(node.vx) || isNaN(node.vy)) {\n node.vx = node.vy = 0;\n }\n }\n }\n\n function initializeForce(force) {\n if (force.initialize) force.initialize(nodes);\n return force;\n }\n\n initializeNodes();\n\n return simulation = {\n tick: tick,\n\n restart: function() {\n return stepper.restart(step), simulation;\n },\n\n stop: function() {\n return stepper.stop(), simulation;\n },\n\n nodes: function(_) {\n return arguments.length ? (nodes = _, initializeNodes(), forces.each(initializeForce), simulation) : nodes;\n },\n\n alpha: function(_) {\n return arguments.length ? (alpha = +_, simulation) : alpha;\n },\n\n alphaMin: function(_) {\n return arguments.length ? (alphaMin = +_, simulation) : alphaMin;\n },\n\n alphaDecay: function(_) {\n return arguments.length ? (alphaDecay = +_, simulation) : +alphaDecay;\n },\n\n alphaTarget: function(_) {\n return arguments.length ? (alphaTarget = +_, simulation) : alphaTarget;\n },\n\n velocityDecay: function(_) {\n return arguments.length ? (velocityDecay = 1 - _, simulation) : 1 - velocityDecay;\n },\n\n force: function(name, _) {\n return arguments.length > 1 ? ((_ == null ? forces.remove(name) : forces.set(name, initializeForce(_))), simulation) : forces.get(name);\n },\n\n find: function(x, y, radius) {\n var i = 0,\n n = nodes.length,\n dx,\n dy,\n d2,\n node,\n closest;\n\n if (radius == null) radius = Infinity;\n else radius *= radius;\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n dx = x - node.x;\n dy = y - node.y;\n d2 = dx * dx + dy * dy;\n if (d2 < radius) closest = node, radius = d2;\n }\n\n return closest;\n },\n\n on: function(name, _) {\n return arguments.length > 1 ? (event.on(name, _), simulation) : event.on(name);\n }\n };\n }\n\n function manyBody() {\n var nodes,\n node,\n alpha,\n strength = constant$6(-30),\n strengths,\n distanceMin2 = 1,\n distanceMax2 = Infinity,\n theta2 = 0.81;\n\n function force(_) {\n var i, n = nodes.length, tree = quadtree(nodes, x$2, y$2).visitAfter(accumulate);\n for (alpha = _, i = 0; i < n; ++i) node = nodes[i], tree.visit(apply);\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n for (i = 0; i < n; ++i) strengths[i] = +strength(nodes[i], i, nodes);\n }\n\n function accumulate(quad) {\n var strength = 0, q, c, x, y, i;\n\n // For internal nodes, accumulate forces from child quadrants.\n if (quad.length) {\n for (x = y = i = 0; i < 4; ++i) {\n if ((q = quad[i]) && (c = q.value)) {\n strength += c, x += c * q.x, y += c * q.y;\n }\n }\n quad.x = x / strength;\n quad.y = y / strength;\n }\n\n // For leaf nodes, accumulate forces from coincident quadrants.\n else {\n q = quad;\n q.x = q.data.x;\n q.y = q.data.y;\n do strength += strengths[q.data.index];\n while (q = q.next);\n }\n\n quad.value = strength;\n }\n\n function apply(quad, x1, _, x2) {\n if (!quad.value) return true;\n\n var x = quad.x - node.x,\n y = quad.y - node.y,\n w = x2 - x1,\n l = x * x + y * y;\n\n // Apply the Barnes-Hut approximation if possible.\n // Limit forces for very close nodes; randomize direction if coincident.\n if (w * w / theta2 < l) {\n if (l < distanceMax2) {\n if (x === 0) x = jiggle(), l += x * x;\n if (y === 0) y = jiggle(), l += y * y;\n if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n node.vx += x * quad.value * alpha / l;\n node.vy += y * quad.value * alpha / l;\n }\n return true;\n }\n\n // Otherwise, process points directly.\n else if (quad.length || l >= distanceMax2) return;\n\n // Limit forces for very close nodes; randomize direction if coincident.\n if (quad.data !== node || quad.next) {\n if (x === 0) x = jiggle(), l += x * x;\n if (y === 0) y = jiggle(), l += y * y;\n if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n }\n\n do if (quad.data !== node) {\n w = strengths[quad.data.index] * alpha / l;\n node.vx += x * w;\n node.vy += y * w;\n } while (quad = quad.next);\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : strength;\n };\n\n force.distanceMin = function(_) {\n return arguments.length ? (distanceMin2 = _ * _, force) : Math.sqrt(distanceMin2);\n };\n\n force.distanceMax = function(_) {\n return arguments.length ? (distanceMax2 = _ * _, force) : Math.sqrt(distanceMax2);\n };\n\n force.theta = function(_) {\n return arguments.length ? (theta2 = _ * _, force) : Math.sqrt(theta2);\n };\n\n return force;\n }\n\n function x$3(x) {\n var strength = constant$6(0.1),\n nodes,\n strengths,\n xz;\n\n if (typeof x !== \"function\") x = constant$6(x == null ? 0 : +x);\n\n function force(alpha) {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.vx += (xz[i] - node.x) * strengths[i] * alpha;\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n xz = new Array(n);\n for (i = 0; i < n; ++i) {\n strengths[i] = isNaN(xz[i] = +x(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : strength;\n };\n\n force.x = function(_) {\n return arguments.length ? (x = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : x;\n };\n\n return force;\n }\n\n function y$3(y) {\n var strength = constant$6(0.1),\n nodes,\n strengths,\n yz;\n\n if (typeof y !== \"function\") y = constant$6(y == null ? 0 : +y);\n\n function force(alpha) {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.vy += (yz[i] - node.y) * strengths[i] * alpha;\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n yz = new Array(n);\n for (i = 0; i < n; ++i) {\n strengths[i] = isNaN(yz[i] = +y(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : strength;\n };\n\n force.y = function(_) {\n return arguments.length ? (y = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : y;\n };\n\n return force;\n }\n\n function nopropagation() {\n exports.event.stopImmediatePropagation();\n }\n\n function noevent() {\n exports.event.preventDefault();\n exports.event.stopImmediatePropagation();\n }\n\n function dragDisable(view) {\n var root = view.document.documentElement,\n selection = select(view).on(\"dragstart.drag\", noevent, true);\n if (\"onselectstart\" in root) {\n selection.on(\"selectstart.drag\", noevent, true);\n } else {\n root.__noselect = root.style.MozUserSelect;\n root.style.MozUserSelect = \"none\";\n }\n }\n\n function dragEnable(view, noclick) {\n var root = view.document.documentElement,\n selection = select(view).on(\"dragstart.drag\", null);\n if (noclick) {\n selection.on(\"click.drag\", noevent, true);\n setTimeout(function() { selection.on(\"click.drag\", null); }, 0);\n }\n if (\"onselectstart\" in root) {\n selection.on(\"selectstart.drag\", null);\n } else {\n root.style.MozUserSelect = root.__noselect;\n delete root.__noselect;\n }\n }\n\n function constant$7(x) {\n return function() {\n return x;\n };\n }\n\n function DragEvent(target, type, subject, id, active, x, y, dx, dy, dispatch) {\n this.target = target;\n this.type = type;\n this.subject = subject;\n this.identifier = id;\n this.active = active;\n this.x = x;\n this.y = y;\n this.dx = dx;\n this.dy = dy;\n this._ = dispatch;\n }\n\n DragEvent.prototype.on = function() {\n var value = this._.on.apply(this._, arguments);\n return value === this._ ? this : value;\n };\n\n // Ignore right-click, since that should open the context menu.\n function defaultFilter() {\n return !exports.event.button;\n }\n\n function defaultContainer() {\n return this.parentNode;\n }\n\n function defaultSubject(d) {\n return d == null ? {x: exports.event.x, y: exports.event.y} : d;\n }\n\n function drag() {\n var filter = defaultFilter,\n container = defaultContainer,\n subject = defaultSubject,\n gestures = {},\n listeners = dispatch(\"start\", \"drag\", \"end\"),\n active = 0,\n mousemoving,\n touchending;\n\n function drag(selection) {\n selection\n .on(\"mousedown.drag\", mousedowned)\n .on(\"touchstart.drag\", touchstarted)\n .on(\"touchmove.drag\", touchmoved)\n .on(\"touchend.drag touchcancel.drag\", touchended)\n .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\");\n }\n\n function mousedowned() {\n if (touchending || !filter.apply(this, arguments)) return;\n var gesture = beforestart(\"mouse\", container.apply(this, arguments), mouse, this, arguments);\n if (!gesture) return;\n select(exports.event.view).on(\"mousemove.drag\", mousemoved, true).on(\"mouseup.drag\", mouseupped, true);\n dragDisable(exports.event.view);\n nopropagation();\n mousemoving = false;\n gesture(\"start\");\n }\n\n function mousemoved() {\n noevent();\n mousemoving = true;\n gestures.mouse(\"drag\");\n }\n\n function mouseupped() {\n select(exports.event.view).on(\"mousemove.drag mouseup.drag\", null);\n dragEnable(exports.event.view, mousemoving);\n noevent();\n gestures.mouse(\"end\");\n }\n\n function touchstarted() {\n if (!filter.apply(this, arguments)) return;\n var touches = exports.event.changedTouches,\n c = container.apply(this, arguments),\n n = touches.length, i, gesture;\n\n for (i = 0; i < n; ++i) {\n if (gesture = beforestart(touches[i].identifier, c, touch, this, arguments)) {\n nopropagation();\n gesture(\"start\");\n }\n }\n }\n\n function touchmoved() {\n var touches = exports.event.changedTouches,\n n = touches.length, i, gesture;\n\n for (i = 0; i < n; ++i) {\n if (gesture = gestures[touches[i].identifier]) {\n noevent();\n gesture(\"drag\");\n }\n }\n }\n\n function touchended() {\n var touches = exports.event.changedTouches,\n n = touches.length, i, gesture;\n\n if (touchending) clearTimeout(touchending);\n touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!\n for (i = 0; i < n; ++i) {\n if (gesture = gestures[touches[i].identifier]) {\n nopropagation();\n gesture(\"end\");\n }\n }\n }\n\n function beforestart(id, container, point, that, args) {\n var p = point(container, id), s, dx, dy,\n sublisteners = listeners.copy();\n\n if (!customEvent(new DragEvent(drag, \"beforestart\", s, id, active, p[0], p[1], 0, 0, sublisteners), function() {\n if ((exports.event.subject = s = subject.apply(that, args)) == null) return false;\n dx = s.x - p[0] || 0;\n dy = s.y - p[1] || 0;\n return true;\n })) return;\n\n return function gesture(type) {\n var p0 = p, n;\n switch (type) {\n case \"start\": gestures[id] = gesture, n = active++; break;\n case \"end\": delete gestures[id], --active; // nobreak\n case \"drag\": p = point(container, id), n = active; break;\n }\n customEvent(new DragEvent(drag, type, s, id, n, p[0] + dx, p[1] + dy, p[0] - p0[0], p[1] - p0[1], sublisteners), sublisteners.apply, sublisteners, [type, that, args]);\n };\n }\n\n drag.filter = function(_) {\n return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant$7(!!_), drag) : filter;\n };\n\n drag.container = function(_) {\n return arguments.length ? (container = typeof _ === \"function\" ? _ : constant$7(_), drag) : container;\n };\n\n drag.subject = function(_) {\n return arguments.length ? (subject = typeof _ === \"function\" ? _ : constant$7(_), drag) : subject;\n };\n\n drag.on = function() {\n var value = listeners.on.apply(listeners, arguments);\n return value === listeners ? drag : value;\n };\n\n return drag;\n }\n\n function constant$8(x) {\n return function() {\n return x;\n };\n }\n\n function x$4(d) {\n return d[0];\n }\n\n function y$4(d) {\n return d[1];\n }\n\n function RedBlackTree() {\n this._ = null; // root node\n }\n\n function RedBlackNode(node) {\n node.U = // parent node\n node.C = // color - true for red, false for black\n node.L = // left node\n node.R = // right node\n node.P = // previous node\n node.N = null; // next node\n }\n\n RedBlackTree.prototype = {\n constructor: RedBlackTree,\n\n insert: function(after, node) {\n var parent, grandpa, uncle;\n\n if (after) {\n node.P = after;\n node.N = after.N;\n if (after.N) after.N.P = node;\n after.N = node;\n if (after.R) {\n after = after.R;\n while (after.L) after = after.L;\n after.L = node;\n } else {\n after.R = node;\n }\n parent = after;\n } else if (this._) {\n after = RedBlackFirst(this._);\n node.P = null;\n node.N = after;\n after.P = after.L = node;\n parent = after;\n } else {\n node.P = node.N = null;\n this._ = node;\n parent = null;\n }\n node.L = node.R = null;\n node.U = parent;\n node.C = true;\n\n after = node;\n while (parent && parent.C) {\n grandpa = parent.U;\n if (parent === grandpa.L) {\n uncle = grandpa.R;\n if (uncle && uncle.C) {\n parent.C = uncle.C = false;\n grandpa.C = true;\n after = grandpa;\n } else {\n if (after === parent.R) {\n RedBlackRotateLeft(this, parent);\n after = parent;\n parent = after.U;\n }\n parent.C = false;\n grandpa.C = true;\n RedBlackRotateRight(this, grandpa);\n }\n } else {\n uncle = grandpa.L;\n if (uncle && uncle.C) {\n parent.C = uncle.C = false;\n grandpa.C = true;\n after = grandpa;\n } else {\n if (after === parent.L) {\n RedBlackRotateRight(this, parent);\n after = parent;\n parent = after.U;\n }\n parent.C = false;\n grandpa.C = true;\n RedBlackRotateLeft(this, grandpa);\n }\n }\n parent = after.U;\n }\n this._.C = false;\n },\n\n remove: function(node) {\n if (node.N) node.N.P = node.P;\n if (node.P) node.P.N = node.N;\n node.N = node.P = null;\n\n var parent = node.U,\n sibling,\n left = node.L,\n right = node.R,\n next,\n red;\n\n if (!left) next = right;\n else if (!right) next = left;\n else next = RedBlackFirst(right);\n\n if (parent) {\n if (parent.L === node) parent.L = next;\n else parent.R = next;\n } else {\n this._ = next;\n }\n\n if (left && right) {\n red = next.C;\n next.C = node.C;\n next.L = left;\n left.U = next;\n if (next !== right) {\n parent = next.U;\n next.U = node.U;\n node = next.R;\n parent.L = node;\n next.R = right;\n right.U = next;\n } else {\n next.U = parent;\n parent = next;\n node = next.R;\n }\n } else {\n red = node.C;\n node = next;\n }\n\n if (node) node.U = parent;\n if (red) return;\n if (node && node.C) { node.C = false; return; }\n\n do {\n if (node === this._) break;\n if (node === parent.L) {\n sibling = parent.R;\n if (sibling.C) {\n sibling.C = false;\n parent.C = true;\n RedBlackRotateLeft(this, parent);\n sibling = parent.R;\n }\n if ((sibling.L && sibling.L.C)\n || (sibling.R && sibling.R.C)) {\n if (!sibling.R || !sibling.R.C) {\n sibling.L.C = false;\n sibling.C = true;\n RedBlackRotateRight(this, sibling);\n sibling = parent.R;\n }\n sibling.C = parent.C;\n parent.C = sibling.R.C = false;\n RedBlackRotateLeft(this, parent);\n node = this._;\n break;\n }\n } else {\n sibling = parent.L;\n if (sibling.C) {\n sibling.C = false;\n parent.C = true;\n RedBlackRotateRight(this, parent);\n sibling = parent.L;\n }\n if ((sibling.L && sibling.L.C)\n || (sibling.R && sibling.R.C)) {\n if (!sibling.L || !sibling.L.C) {\n sibling.R.C = false;\n sibling.C = true;\n RedBlackRotateLeft(this, sibling);\n sibling = parent.L;\n }\n sibling.C = parent.C;\n parent.C = sibling.L.C = false;\n RedBlackRotateRight(this, parent);\n node = this._;\n break;\n }\n }\n sibling.C = true;\n node = parent;\n parent = parent.U;\n } while (!node.C);\n\n if (node) node.C = false;\n }\n };\n\n function RedBlackRotateLeft(tree, node) {\n var p = node,\n q = node.R,\n parent = p.U;\n\n if (parent) {\n if (parent.L === p) parent.L = q;\n else parent.R = q;\n } else {\n tree._ = q;\n }\n\n q.U = parent;\n p.U = q;\n p.R = q.L;\n if (p.R) p.R.U = p;\n q.L = p;\n }\n\n function RedBlackRotateRight(tree, node) {\n var p = node,\n q = node.L,\n parent = p.U;\n\n if (parent) {\n if (parent.L === p) parent.L = q;\n else parent.R = q;\n } else {\n tree._ = q;\n }\n\n q.U = parent;\n p.U = q;\n p.L = q.R;\n if (p.L) p.L.U = p;\n q.R = p;\n }\n\n function RedBlackFirst(node) {\n while (node.L) node = node.L;\n return node;\n }\n\n function createEdge(left, right, v0, v1) {\n var edge = [null, null],\n index = edges.push(edge) - 1;\n edge.left = left;\n edge.right = right;\n if (v0) setEdgeEnd(edge, left, right, v0);\n if (v1) setEdgeEnd(edge, right, left, v1);\n cells[left.index].halfedges.push(index);\n cells[right.index].halfedges.push(index);\n return edge;\n }\n\n function createBorderEdge(left, v0, v1) {\n var edge = [v0, v1];\n edge.left = left;\n return edge;\n }\n\n function setEdgeEnd(edge, left, right, vertex) {\n if (!edge[0] && !edge[1]) {\n edge[0] = vertex;\n edge.left = left;\n edge.right = right;\n } else if (edge.left === right) {\n edge[1] = vertex;\n } else {\n edge[0] = vertex;\n }\n }\n\n // Liang–Barsky line clipping.\n function clipEdge(edge, x0, y0, x1, y1) {\n var a = edge[0],\n b = edge[1],\n ax = a[0],\n ay = a[1],\n bx = b[0],\n by = b[1],\n t0 = 0,\n t1 = 1,\n dx = bx - ax,\n dy = by - ay,\n r;\n\n r = x0 - ax;\n if (!dx && r > 0) return;\n r /= dx;\n if (dx < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dx > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = x1 - ax;\n if (!dx && r < 0) return;\n r /= dx;\n if (dx < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dx > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n r = y0 - ay;\n if (!dy && r > 0) return;\n r /= dy;\n if (dy < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dy > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = y1 - ay;\n if (!dy && r < 0) return;\n r /= dy;\n if (dy < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dy > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n if (!(t0 > 0) && !(t1 < 1)) return true; // TODO Better check?\n\n if (t0 > 0) edge[0] = [ax + t0 * dx, ay + t0 * dy];\n if (t1 < 1) edge[1] = [ax + t1 * dx, ay + t1 * dy];\n return true;\n }\n\n function connectEdge(edge, x0, y0, x1, y1) {\n var v1 = edge[1];\n if (v1) return true;\n\n var v0 = edge[0],\n left = edge.left,\n right = edge.right,\n lx = left[0],\n ly = left[1],\n rx = right[0],\n ry = right[1],\n fx = (lx + rx) / 2,\n fy = (ly + ry) / 2,\n fm,\n fb;\n\n if (ry === ly) {\n if (fx < x0 || fx >= x1) return;\n if (lx > rx) {\n if (!v0) v0 = [fx, y0];\n else if (v0[1] >= y1) return;\n v1 = [fx, y1];\n } else {\n if (!v0) v0 = [fx, y1];\n else if (v0[1] < y0) return;\n v1 = [fx, y0];\n }\n } else {\n fm = (lx - rx) / (ry - ly);\n fb = fy - fm * fx;\n if (fm < -1 || fm > 1) {\n if (lx > rx) {\n if (!v0) v0 = [(y0 - fb) / fm, y0];\n else if (v0[1] >= y1) return;\n v1 = [(y1 - fb) / fm, y1];\n } else {\n if (!v0) v0 = [(y1 - fb) / fm, y1];\n else if (v0[1] < y0) return;\n v1 = [(y0 - fb) / fm, y0];\n }\n } else {\n if (ly < ry) {\n if (!v0) v0 = [x0, fm * x0 + fb];\n else if (v0[0] >= x1) return;\n v1 = [x1, fm * x1 + fb];\n } else {\n if (!v0) v0 = [x1, fm * x1 + fb];\n else if (v0[0] < x0) return;\n v1 = [x0, fm * x0 + fb];\n }\n }\n }\n\n edge[0] = v0;\n edge[1] = v1;\n return true;\n }\n\n function clipEdges(x0, y0, x1, y1) {\n var i = edges.length,\n edge;\n\n while (i--) {\n if (!connectEdge(edge = edges[i], x0, y0, x1, y1)\n || !clipEdge(edge, x0, y0, x1, y1)\n || !(Math.abs(edge[0][0] - edge[1][0]) > epsilon$3\n || Math.abs(edge[0][1] - edge[1][1]) > epsilon$3)) {\n delete edges[i];\n }\n }\n }\n\n function createCell(site) {\n return cells[site.index] = {\n site: site,\n halfedges: []\n };\n }\n\n function cellHalfedgeAngle(cell, edge) {\n var site = cell.site,\n va = edge.left,\n vb = edge.right;\n if (site === vb) vb = va, va = site;\n if (vb) return Math.atan2(vb[1] - va[1], vb[0] - va[0]);\n if (site === va) va = edge[1], vb = edge[0];\n else va = edge[0], vb = edge[1];\n return Math.atan2(va[0] - vb[0], vb[1] - va[1]);\n }\n\n function cellHalfedgeStart(cell, edge) {\n return edge[+(edge.left !== cell.site)];\n }\n\n function cellHalfedgeEnd(cell, edge) {\n return edge[+(edge.left === cell.site)];\n }\n\n function sortCellHalfedges() {\n for (var i = 0, n = cells.length, cell, halfedges, j, m; i < n; ++i) {\n if ((cell = cells[i]) && (m = (halfedges = cell.halfedges).length)) {\n var index = new Array(m),\n array = new Array(m);\n for (j = 0; j < m; ++j) index[j] = j, array[j] = cellHalfedgeAngle(cell, edges[halfedges[j]]);\n index.sort(function(i, j) { return array[j] - array[i]; });\n for (j = 0; j < m; ++j) array[j] = halfedges[index[j]];\n for (j = 0; j < m; ++j) halfedges[j] = array[j];\n }\n }\n }\n\n function clipCells(x0, y0, x1, y1) {\n var nCells = cells.length,\n iCell,\n cell,\n site,\n iHalfedge,\n halfedges,\n nHalfedges,\n start,\n startX,\n startY,\n end,\n endX,\n endY,\n cover = true;\n\n for (iCell = 0; iCell < nCells; ++iCell) {\n if (cell = cells[iCell]) {\n site = cell.site;\n halfedges = cell.halfedges;\n iHalfedge = halfedges.length;\n\n // Remove any dangling clipped edges.\n while (iHalfedge--) {\n if (!edges[halfedges[iHalfedge]]) {\n halfedges.splice(iHalfedge, 1);\n }\n }\n\n // Insert any border edges as necessary.\n iHalfedge = 0, nHalfedges = halfedges.length;\n while (iHalfedge < nHalfedges) {\n end = cellHalfedgeEnd(cell, edges[halfedges[iHalfedge]]), endX = end[0], endY = end[1];\n start = cellHalfedgeStart(cell, edges[halfedges[++iHalfedge % nHalfedges]]), startX = start[0], startY = start[1];\n if (Math.abs(endX - startX) > epsilon$3 || Math.abs(endY - startY) > epsilon$3) {\n halfedges.splice(iHalfedge, 0, edges.push(createBorderEdge(site, end,\n Math.abs(endX - x0) < epsilon$3 && y1 - endY > epsilon$3 ? [x0, Math.abs(startX - x0) < epsilon$3 ? startY : y1]\n : Math.abs(endY - y1) < epsilon$3 && x1 - endX > epsilon$3 ? [Math.abs(startY - y1) < epsilon$3 ? startX : x1, y1]\n : Math.abs(endX - x1) < epsilon$3 && endY - y0 > epsilon$3 ? [x1, Math.abs(startX - x1) < epsilon$3 ? startY : y0]\n : Math.abs(endY - y0) < epsilon$3 && endX - x0 > epsilon$3 ? [Math.abs(startY - y0) < epsilon$3 ? startX : x0, y0]\n : null)) - 1);\n ++nHalfedges;\n }\n }\n\n if (nHalfedges) cover = false;\n }\n }\n\n // If there weren’t any edges, have the closest site cover the extent.\n // It doesn’t matter which corner of the extent we measure!\n if (cover) {\n var dx, dy, d2, dc = Infinity;\n\n for (iCell = 0, cover = null; iCell < nCells; ++iCell) {\n if (cell = cells[iCell]) {\n site = cell.site;\n dx = site[0] - x0;\n dy = site[1] - y0;\n d2 = dx * dx + dy * dy;\n if (d2 < dc) dc = d2, cover = cell;\n }\n }\n\n if (cover) {\n var v00 = [x0, y0], v01 = [x0, y1], v11 = [x1, y1], v10 = [x1, y0];\n cover.halfedges.push(\n edges.push(createBorderEdge(site = cover.site, v00, v01)) - 1,\n edges.push(createBorderEdge(site, v01, v11)) - 1,\n edges.push(createBorderEdge(site, v11, v10)) - 1,\n edges.push(createBorderEdge(site, v10, v00)) - 1\n );\n }\n }\n\n // Lastly delete any cells with no edges; these were entirely clipped.\n for (iCell = 0; iCell < nCells; ++iCell) {\n if (cell = cells[iCell]) {\n if (!cell.halfedges.length) {\n delete cells[iCell];\n }\n }\n }\n }\n\n var circlePool = [];\n\n var firstCircle;\n\n function Circle() {\n RedBlackNode(this);\n this.x =\n this.y =\n this.arc =\n this.site =\n this.cy = null;\n }\n\n function attachCircle(arc) {\n var lArc = arc.P,\n rArc = arc.N;\n\n if (!lArc || !rArc) return;\n\n var lSite = lArc.site,\n cSite = arc.site,\n rSite = rArc.site;\n\n if (lSite === rSite) return;\n\n var bx = cSite[0],\n by = cSite[1],\n ax = lSite[0] - bx,\n ay = lSite[1] - by,\n cx = rSite[0] - bx,\n cy = rSite[1] - by;\n\n var d = 2 * (ax * cy - ay * cx);\n if (d >= -epsilon2$1) return;\n\n var ha = ax * ax + ay * ay,\n hc = cx * cx + cy * cy,\n x = (cy * ha - ay * hc) / d,\n y = (ax * hc - cx * ha) / d;\n\n var circle = circlePool.pop() || new Circle;\n circle.arc = arc;\n circle.site = cSite;\n circle.x = x + bx;\n circle.y = (circle.cy = y + by) + Math.sqrt(x * x + y * y); // y bottom\n\n arc.circle = circle;\n\n var before = null,\n node = circles._;\n\n while (node) {\n if (circle.y < node.y || (circle.y === node.y && circle.x <= node.x)) {\n if (node.L) node = node.L;\n else { before = node.P; break; }\n } else {\n if (node.R) node = node.R;\n else { before = node; break; }\n }\n }\n\n circles.insert(before, circle);\n if (!before) firstCircle = circle;\n }\n\n function detachCircle(arc) {\n var circle = arc.circle;\n if (circle) {\n if (!circle.P) firstCircle = circle.N;\n circles.remove(circle);\n circlePool.push(circle);\n RedBlackNode(circle);\n arc.circle = null;\n }\n }\n\n var beachPool = [];\n\n function Beach() {\n RedBlackNode(this);\n this.edge =\n this.site =\n this.circle = null;\n }\n\n function createBeach(site) {\n var beach = beachPool.pop() || new Beach;\n beach.site = site;\n return beach;\n }\n\n function detachBeach(beach) {\n detachCircle(beach);\n beaches.remove(beach);\n beachPool.push(beach);\n RedBlackNode(beach);\n }\n\n function removeBeach(beach) {\n var circle = beach.circle,\n x = circle.x,\n y = circle.cy,\n vertex = [x, y],\n previous = beach.P,\n next = beach.N,\n disappearing = [beach];\n\n detachBeach(beach);\n\n var lArc = previous;\n while (lArc.circle\n && Math.abs(x - lArc.circle.x) < epsilon$3\n && Math.abs(y - lArc.circle.cy) < epsilon$3) {\n previous = lArc.P;\n disappearing.unshift(lArc);\n detachBeach(lArc);\n lArc = previous;\n }\n\n disappearing.unshift(lArc);\n detachCircle(lArc);\n\n var rArc = next;\n while (rArc.circle\n && Math.abs(x - rArc.circle.x) < epsilon$3\n && Math.abs(y - rArc.circle.cy) < epsilon$3) {\n next = rArc.N;\n disappearing.push(rArc);\n detachBeach(rArc);\n rArc = next;\n }\n\n disappearing.push(rArc);\n detachCircle(rArc);\n\n var nArcs = disappearing.length,\n iArc;\n for (iArc = 1; iArc < nArcs; ++iArc) {\n rArc = disappearing[iArc];\n lArc = disappearing[iArc - 1];\n setEdgeEnd(rArc.edge, lArc.site, rArc.site, vertex);\n }\n\n lArc = disappearing[0];\n rArc = disappearing[nArcs - 1];\n rArc.edge = createEdge(lArc.site, rArc.site, null, vertex);\n\n attachCircle(lArc);\n attachCircle(rArc);\n }\n\n function addBeach(site) {\n var x = site[0],\n directrix = site[1],\n lArc,\n rArc,\n dxl,\n dxr,\n node = beaches._;\n\n while (node) {\n dxl = leftBreakPoint(node, directrix) - x;\n if (dxl > epsilon$3) node = node.L; else {\n dxr = x - rightBreakPoint(node, directrix);\n if (dxr > epsilon$3) {\n if (!node.R) {\n lArc = node;\n break;\n }\n node = node.R;\n } else {\n if (dxl > -epsilon$3) {\n lArc = node.P;\n rArc = node;\n } else if (dxr > -epsilon$3) {\n lArc = node;\n rArc = node.N;\n } else {\n lArc = rArc = node;\n }\n break;\n }\n }\n }\n\n createCell(site);\n var newArc = createBeach(site);\n beaches.insert(lArc, newArc);\n\n if (!lArc && !rArc) return;\n\n if (lArc === rArc) {\n detachCircle(lArc);\n rArc = createBeach(lArc.site);\n beaches.insert(newArc, rArc);\n newArc.edge = rArc.edge = createEdge(lArc.site, newArc.site);\n attachCircle(lArc);\n attachCircle(rArc);\n return;\n }\n\n if (!rArc) { // && lArc\n newArc.edge = createEdge(lArc.site, newArc.site);\n return;\n }\n\n // else lArc !== rArc\n detachCircle(lArc);\n detachCircle(rArc);\n\n var lSite = lArc.site,\n ax = lSite[0],\n ay = lSite[1],\n bx = site[0] - ax,\n by = site[1] - ay,\n rSite = rArc.site,\n cx = rSite[0] - ax,\n cy = rSite[1] - ay,\n d = 2 * (bx * cy - by * cx),\n hb = bx * bx + by * by,\n hc = cx * cx + cy * cy,\n vertex = [(cy * hb - by * hc) / d + ax, (bx * hc - cx * hb) / d + ay];\n\n setEdgeEnd(rArc.edge, lSite, rSite, vertex);\n newArc.edge = createEdge(lSite, site, null, vertex);\n rArc.edge = createEdge(site, rSite, null, vertex);\n attachCircle(lArc);\n attachCircle(rArc);\n }\n\n function leftBreakPoint(arc, directrix) {\n var site = arc.site,\n rfocx = site[0],\n rfocy = site[1],\n pby2 = rfocy - directrix;\n\n if (!pby2) return rfocx;\n\n var lArc = arc.P;\n if (!lArc) return -Infinity;\n\n site = lArc.site;\n var lfocx = site[0],\n lfocy = site[1],\n plby2 = lfocy - directrix;\n\n if (!plby2) return lfocx;\n\n var hl = lfocx - rfocx,\n aby2 = 1 / pby2 - 1 / plby2,\n b = hl / plby2;\n\n if (aby2) return (-b + Math.sqrt(b * b - 2 * aby2 * (hl * hl / (-2 * plby2) - lfocy + plby2 / 2 + rfocy - pby2 / 2))) / aby2 + rfocx;\n\n return (rfocx + lfocx) / 2;\n }\n\n function rightBreakPoint(arc, directrix) {\n var rArc = arc.N;\n if (rArc) return leftBreakPoint(rArc, directrix);\n var site = arc.site;\n return site[1] === directrix ? site[0] : Infinity;\n }\n\n var epsilon$3 = 1e-6;\n var epsilon2$1 = 1e-12;\n var beaches;\n var cells;\n var circles;\n var edges;\n\n function triangleArea(a, b, c) {\n return (a[0] - c[0]) * (b[1] - a[1]) - (a[0] - b[0]) * (c[1] - a[1]);\n }\n\n function lexicographic(a, b) {\n return b[1] - a[1]\n || b[0] - a[0];\n }\n\n function Diagram(sites, extent) {\n var site = sites.sort(lexicographic).pop(),\n x,\n y,\n circle;\n\n edges = [];\n cells = new Array(sites.length);\n beaches = new RedBlackTree;\n circles = new RedBlackTree;\n\n while (true) {\n circle = firstCircle;\n if (site && (!circle || site[1] < circle.y || (site[1] === circle.y && site[0] < circle.x))) {\n if (site[0] !== x || site[1] !== y) {\n addBeach(site);\n x = site[0], y = site[1];\n }\n site = sites.pop();\n } else if (circle) {\n removeBeach(circle.arc);\n } else {\n break;\n }\n }\n\n sortCellHalfedges();\n\n if (extent) {\n var x0 = +extent[0][0],\n y0 = +extent[0][1],\n x1 = +extent[1][0],\n y1 = +extent[1][1];\n clipEdges(x0, y0, x1, y1);\n clipCells(x0, y0, x1, y1);\n }\n\n this.edges = edges;\n this.cells = cells;\n\n beaches =\n circles =\n edges =\n cells = null;\n }\n\n Diagram.prototype = {\n constructor: Diagram,\n\n polygons: function() {\n var edges = this.edges;\n\n return this.cells.map(function(cell) {\n var polygon = cell.halfedges.map(function(i) { return cellHalfedgeStart(cell, edges[i]); });\n polygon.data = cell.site.data;\n return polygon;\n });\n },\n\n triangles: function() {\n var triangles = [],\n edges = this.edges;\n\n this.cells.forEach(function(cell, i) {\n var site = cell.site,\n halfedges = cell.halfedges,\n j = -1,\n m = halfedges.length,\n s0,\n e1 = edges[halfedges[m - 1]],\n s1 = e1.left === site ? e1.right : e1.left;\n\n while (++j < m) {\n s0 = s1;\n e1 = edges[halfedges[j]];\n s1 = e1.left === site ? e1.right : e1.left;\n if (i < s0.index && i < s1.index && triangleArea(site, s0, s1) < 0) {\n triangles.push([site.data, s0.data, s1.data]);\n }\n }\n });\n\n return triangles;\n },\n\n links: function() {\n return this.edges.filter(function(edge) {\n return edge.right;\n }).map(function(edge) {\n return {\n source: edge.left.data,\n target: edge.right.data\n };\n });\n }\n }\n\n function voronoi() {\n var x = x$4,\n y = y$4,\n extent = null;\n\n function voronoi(data) {\n return new Diagram(data.map(function(d, i) {\n var s = [Math.round(x(d, i, data) / epsilon$3) * epsilon$3, Math.round(y(d, i, data) / epsilon$3) * epsilon$3];\n s.index = i;\n s.data = d;\n return s;\n }), extent);\n }\n\n voronoi.polygons = function(data) {\n return voronoi(data).polygons();\n };\n\n voronoi.links = function(data) {\n return voronoi(data).links();\n };\n\n voronoi.triangles = function(data) {\n return voronoi(data).triangles();\n };\n\n voronoi.x = function(_) {\n return arguments.length ? (x = typeof _ === \"function\" ? _ : constant$8(+_), voronoi) : x;\n };\n\n voronoi.y = function(_) {\n return arguments.length ? (y = typeof _ === \"function\" ? _ : constant$8(+_), voronoi) : y;\n };\n\n voronoi.extent = function(_) {\n return arguments.length ? (extent = _ == null ? null : [[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]], voronoi) : extent && [[extent[0][0], extent[0][1]], [extent[1][0], extent[1][1]]];\n };\n\n voronoi.size = function(_) {\n return arguments.length ? (extent = _ == null ? null : [[0, 0], [+_[0], +_[1]]], voronoi) : extent && [extent[1][0] - extent[0][0], extent[1][1] - extent[0][1]];\n };\n\n return voronoi;\n }\n\n function constant$9(x) {\n return function() {\n return x;\n };\n }\n\n function ZoomEvent(target, type, transform) {\n this.target = target;\n this.type = type;\n this.transform = transform;\n }\n\n function Transform(k, x, y) {\n this.k = k;\n this.x = x;\n this.y = y;\n }\n\n Transform.prototype = {\n constructor: Transform,\n scale: function(k) {\n return k === 1 ? this : new Transform(this.k * k, this.x, this.y);\n },\n translate: function(x, y) {\n return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y);\n },\n apply: function(point) {\n return [point[0] * this.k + this.x, point[1] * this.k + this.y];\n },\n applyX: function(x) {\n return x * this.k + this.x;\n },\n applyY: function(y) {\n return y * this.k + this.y;\n },\n invert: function(location) {\n return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k];\n },\n invertX: function(x) {\n return (x - this.x) / this.k;\n },\n invertY: function(y) {\n return (y - this.y) / this.k;\n },\n rescaleX: function(x) {\n return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x));\n },\n rescaleY: function(y) {\n return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y));\n },\n toString: function() {\n return \"translate(\" + this.x + \",\" + this.y + \") scale(\" + this.k + \")\";\n }\n };\n\n var identity$6 = new Transform(1, 0, 0);\n\n transform.prototype = Transform.prototype;\n\n function transform(node) {\n return node.__zoom || identity$6;\n }\n\n function nopropagation$1() {\n exports.event.stopImmediatePropagation();\n }\n\n function noevent$1() {\n exports.event.preventDefault();\n exports.event.stopImmediatePropagation();\n }\n\n // Ignore right-click, since that should open the context menu.\n function defaultFilter$1() {\n return !exports.event.button;\n }\n\n function defaultExtent() {\n var e = this, w, h;\n if (e instanceof SVGElement) {\n e = e.ownerSVGElement || e;\n w = e.width.baseVal.value;\n h = e.height.baseVal.value;\n } else {\n w = e.clientWidth;\n h = e.clientHeight;\n }\n return [[0, 0], [w, h]];\n }\n\n function defaultTransform() {\n return this.__zoom || identity$6;\n }\n\n function zoom() {\n var filter = defaultFilter$1,\n extent = defaultExtent,\n k0 = 0,\n k1 = Infinity,\n x0 = -k1,\n x1 = k1,\n y0 = x0,\n y1 = x1,\n duration = 250,\n gestures = [],\n listeners = dispatch(\"start\", \"zoom\", \"end\"),\n touchstarting,\n touchending,\n touchDelay = 500,\n wheelDelay = 150;\n\n function zoom(selection) {\n selection\n .on(\"wheel.zoom\", wheeled)\n .on(\"mousedown.zoom\", mousedowned)\n .on(\"dblclick.zoom\", dblclicked)\n .on(\"touchstart.zoom\", touchstarted)\n .on(\"touchmove.zoom\", touchmoved)\n .on(\"touchend.zoom touchcancel.zoom\", touchended)\n .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\")\n .property(\"__zoom\", defaultTransform);\n }\n\n zoom.transform = function(collection, transform) {\n var selection = collection.selection ? collection.selection() : collection;\n selection.property(\"__zoom\", defaultTransform);\n if (collection !== selection) {\n schedule(collection, transform);\n } else {\n selection.interrupt().each(function() {\n gesture(this, arguments)\n .start()\n .zoom(null, typeof transform === \"function\" ? transform.apply(this, arguments) : transform)\n .end();\n });\n }\n };\n\n zoom.scaleBy = function(selection, k) {\n zoom.scaleTo(selection, function() {\n var k0 = this.__zoom.k,\n k1 = typeof k === \"function\" ? k.apply(this, arguments) : k;\n return k0 * k1;\n });\n };\n\n zoom.scaleTo = function(selection, k) {\n zoom.transform(selection, function() {\n var e = extent.apply(this, arguments),\n t0 = this.__zoom,\n p0 = centroid(e),\n p1 = t0.invert(p0),\n k1 = typeof k === \"function\" ? k.apply(this, arguments) : k;\n return constrain(translate(scale(t0, k1), p0, p1), e);\n });\n };\n\n zoom.translateBy = function(selection, x, y) {\n zoom.transform(selection, function() {\n return constrain(this.__zoom.translate(\n typeof x === \"function\" ? x.apply(this, arguments) : x,\n typeof y === \"function\" ? y.apply(this, arguments) : y\n ), extent.apply(this, arguments));\n });\n };\n\n function scale(transform, k) {\n k = Math.max(k0, Math.min(k1, k));\n return k === transform.k ? transform : new Transform(k, transform.x, transform.y);\n }\n\n function translate(transform, p0, p1) {\n var x = p0[0] - p1[0] * transform.k, y = p0[1] - p1[1] * transform.k;\n return x === transform.x && y === transform.y ? transform : new Transform(transform.k, x, y);\n }\n\n function constrain(transform, extent) {\n var dx = Math.min(0, transform.invertX(extent[0][0]) - x0) || Math.max(0, transform.invertX(extent[1][0]) - x1),\n dy = Math.min(0, transform.invertY(extent[0][1]) - y0) || Math.max(0, transform.invertY(extent[1][1]) - y1);\n return dx || dy ? transform.translate(dx, dy) : transform;\n }\n\n function centroid(extent) {\n return [(+extent[0][0] + +extent[1][0]) / 2, (+extent[0][1] + +extent[1][1]) / 2];\n }\n\n function schedule(transition, transform, center) {\n transition\n .on(\"start.zoom\", function() { gesture(this, arguments).start(); })\n .on(\"interrupt.zoom end.zoom\", function() { gesture(this, arguments).end(); })\n .tween(\"zoom\", function() {\n var that = this,\n args = arguments,\n g = gesture(that, args),\n e = extent.apply(that, args),\n p = center || centroid(e),\n w = Math.max(e[1][0] - e[0][0], e[1][1] - e[0][1]),\n a = that.__zoom,\n b = typeof transform === \"function\" ? transform.apply(that, args) : transform,\n i = interpolateZoom(a.invert(p).concat(w / a.k), b.invert(p).concat(w / b.k));\n return function(t) {\n if (t === 1) t = b; // Avoid rounding error on end.\n else { var l = i(t), k = w / l[2]; t = new Transform(k, p[0] - l[0] * k, p[1] - l[1] * k); }\n g.zoom(null, t);\n };\n });\n }\n\n function gesture(that, args) {\n for (var i = 0, n = gestures.length, g; i < n; ++i) {\n if ((g = gestures[i]).that === that) {\n return g;\n }\n }\n return new Gesture(that, args);\n }\n\n function Gesture(that, args) {\n this.that = that;\n this.args = args;\n this.index = -1;\n this.active = 0;\n this.extent = extent.apply(that, args);\n }\n\n Gesture.prototype = {\n start: function() {\n if (++this.active === 1) {\n this.index = gestures.push(this) - 1;\n this.emit(\"start\");\n }\n return this;\n },\n zoom: function(key, transform) {\n if (this.mouse && key !== \"mouse\") this.mouse[1] = transform.invert(this.mouse[0]);\n if (this.touch0 && key !== \"touch\") this.touch0[1] = transform.invert(this.touch0[0]);\n if (this.touch1 && key !== \"touch\") this.touch1[1] = transform.invert(this.touch1[0]);\n this.that.__zoom = transform;\n this.emit(\"zoom\");\n return this;\n },\n end: function() {\n if (--this.active === 0) {\n gestures.splice(this.index, 1);\n this.index = -1;\n this.emit(\"end\");\n }\n return this;\n },\n emit: function(type) {\n customEvent(new ZoomEvent(zoom, type, this.that.__zoom), listeners.apply, listeners, [type, this.that, this.args]);\n }\n };\n\n function wheeled() {\n if (!filter.apply(this, arguments)) return;\n var g = gesture(this, arguments),\n t = this.__zoom,\n k = Math.max(k0, Math.min(k1, t.k * Math.pow(2, -exports.event.deltaY * (exports.event.deltaMode ? 120 : 1) / 500))),\n p = mouse(this);\n\n // If the mouse is in the same location as before, reuse it.\n // If there were recent wheel events, reset the wheel idle timeout.\n if (g.wheel) {\n if (g.mouse[0][0] !== p[0] || g.mouse[0][1] !== p[1]) {\n g.mouse[1] = t.invert(g.mouse[0] = p);\n }\n clearTimeout(g.wheel);\n }\n\n // If this wheel event won’t trigger a transform change, ignore it.\n else if (t.k === k) return;\n\n // Otherwise, capture the mouse point and location at the start.\n else {\n g.mouse = [p, t.invert(p)];\n interrupt(this);\n g.start();\n }\n\n noevent$1();\n g.wheel = setTimeout(wheelidled, wheelDelay);\n g.zoom(\"mouse\", constrain(translate(scale(t, k), g.mouse[0], g.mouse[1]), g.extent));\n\n function wheelidled() {\n g.wheel = null;\n g.end();\n }\n }\n\n function mousedowned() {\n if (touchending || !filter.apply(this, arguments)) return;\n var g = gesture(this, arguments),\n v = select(exports.event.view).on(\"mousemove.zoom\", mousemoved, true).on(\"mouseup.zoom\", mouseupped, true),\n p = mouse(this);\n\n dragDisable(exports.event.view);\n nopropagation$1();\n g.mouse = [p, this.__zoom.invert(p)];\n interrupt(this);\n g.start();\n\n function mousemoved() {\n noevent$1();\n g.moved = true;\n g.zoom(\"mouse\", constrain(translate(g.that.__zoom, g.mouse[0] = mouse(g.that), g.mouse[1]), g.extent));\n }\n\n function mouseupped() {\n v.on(\"mousemove.zoom mouseup.zoom\", null);\n dragEnable(exports.event.view, g.moved);\n noevent$1();\n g.end();\n }\n }\n\n function dblclicked() {\n if (!filter.apply(this, arguments)) return;\n var t0 = this.__zoom,\n p0 = mouse(this),\n p1 = t0.invert(p0),\n k1 = t0.k * (exports.event.shiftKey ? 0.5 : 2),\n t1 = constrain(translate(scale(t0, k1), p0, p1), extent.apply(this, arguments));\n\n noevent$1();\n if (duration > 0) select(this).transition().duration(duration).call(schedule, t1, p0);\n else select(this).call(zoom.transform, t1);\n }\n\n function touchstarted() {\n if (!filter.apply(this, arguments)) return;\n var g = gesture(this, arguments),\n touches = exports.event.changedTouches,\n n = touches.length, i, t, p;\n\n nopropagation$1();\n for (i = 0; i < n; ++i) {\n t = touches[i], p = touch(this, touches, t.identifier);\n p = [p, this.__zoom.invert(p), t.identifier];\n if (!g.touch0) g.touch0 = p;\n else if (!g.touch1) g.touch1 = p;\n }\n if (touchstarting) {\n touchstarting = clearTimeout(touchstarting);\n if (!g.touch1) return g.end(), dblclicked.apply(this, arguments);\n }\n if (exports.event.touches.length === n) {\n touchstarting = setTimeout(function() { touchstarting = null; }, touchDelay);\n interrupt(this);\n g.start();\n }\n }\n\n function touchmoved() {\n var g = gesture(this, arguments),\n touches = exports.event.changedTouches,\n n = touches.length, i, t, p, l;\n\n noevent$1();\n if (touchstarting) touchstarting = clearTimeout(touchstarting);\n for (i = 0; i < n; ++i) {\n t = touches[i], p = touch(this, touches, t.identifier);\n if (g.touch0 && g.touch0[2] === t.identifier) g.touch0[0] = p;\n else if (g.touch1 && g.touch1[2] === t.identifier) g.touch1[0] = p;\n }\n t = g.that.__zoom;\n if (g.touch1) {\n var p0 = g.touch0[0], l0 = g.touch0[1],\n p1 = g.touch1[0], l1 = g.touch1[1],\n dp = (dp = p1[0] - p0[0]) * dp + (dp = p1[1] - p0[1]) * dp,\n dl = (dl = l1[0] - l0[0]) * dl + (dl = l1[1] - l0[1]) * dl;\n t = scale(t, Math.sqrt(dp / dl));\n p = [(p0[0] + p1[0]) / 2, (p0[1] + p1[1]) / 2];\n l = [(l0[0] + l1[0]) / 2, (l0[1] + l1[1]) / 2];\n }\n else if (g.touch0) p = g.touch0[0], l = g.touch0[1];\n else return;\n g.zoom(\"touch\", constrain(translate(t, p, l), g.extent));\n }\n\n function touchended() {\n var g = gesture(this, arguments),\n touches = exports.event.changedTouches,\n n = touches.length, i, t;\n\n nopropagation$1();\n if (touchending) clearTimeout(touchending);\n touchending = setTimeout(function() { touchending = null; }, touchDelay);\n for (i = 0; i < n; ++i) {\n t = touches[i];\n if (g.touch0 && g.touch0[2] === t.identifier) delete g.touch0;\n else if (g.touch1 && g.touch1[2] === t.identifier) delete g.touch1;\n }\n if (g.touch1 && !g.touch0) g.touch0 = g.touch1, delete g.touch1;\n if (!g.touch0) g.end();\n }\n\n zoom.filter = function(_) {\n return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant$9(!!_), zoom) : filter;\n };\n\n zoom.extent = function(_) {\n return arguments.length ? (extent = typeof _ === \"function\" ? _ : constant$9([[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]]), zoom) : extent;\n };\n\n zoom.scaleExtent = function(_) {\n return arguments.length ? (k0 = +_[0], k1 = +_[1], zoom) : [k0, k1];\n };\n\n zoom.translateExtent = function(_) {\n return arguments.length ? (x0 = +_[0][0], x1 = +_[1][0], y0 = +_[0][1], y1 = +_[1][1], zoom) : [[x0, y0], [x1, y1]];\n };\n\n zoom.duration = function(_) {\n return arguments.length ? (duration = +_, zoom) : duration;\n };\n\n zoom.on = function() {\n var value = listeners.on.apply(listeners, arguments);\n return value === listeners ? zoom : value;\n };\n\n return zoom;\n }\n\n function constant$10(x) {\n return function() {\n return x;\n };\n }\n\n function BrushEvent(target, type, selection) {\n this.target = target;\n this.type = type;\n this.selection = selection;\n }\n\n function nopropagation$2() {\n exports.event.stopImmediatePropagation();\n }\n\n function noevent$2() {\n exports.event.preventDefault();\n exports.event.stopImmediatePropagation();\n }\n\n var MODE_DRAG = {name: \"drag\"};\n var MODE_SPACE = {name: \"space\"};\n var MODE_HANDLE = {name: \"handle\"};\n var MODE_CENTER = {name: \"center\"};\n var X = {\n name: \"x\",\n handles: [\"e\", \"w\"].map(type$1),\n input: function(x, e) { return x && [[x[0], e[0][1]], [x[1], e[1][1]]]; },\n output: function(xy) { return xy && [xy[0][0], xy[1][0]]; }\n };\n\n var Y = {\n name: \"y\",\n handles: [\"n\", \"s\"].map(type$1),\n input: function(y, e) { return y && [[e[0][0], y[0]], [e[1][0], y[1]]]; },\n output: function(xy) { return xy && [xy[0][1], xy[1][1]]; }\n };\n\n var XY = {\n name: \"xy\",\n handles: [\"n\", \"e\", \"s\", \"w\", \"nw\", \"ne\", \"se\", \"sw\"].map(type$1),\n input: function(xy) { return xy; },\n output: function(xy) { return xy; }\n };\n\n var cursors = {\n overlay: \"crosshair\",\n selection: \"move\",\n n: \"ns-resize\",\n e: \"ew-resize\",\n s: \"ns-resize\",\n w: \"ew-resize\",\n nw: \"nwse-resize\",\n ne: \"nesw-resize\",\n se: \"nwse-resize\",\n sw: \"nesw-resize\"\n };\n\n var flipX = {\n e: \"w\",\n w: \"e\",\n nw: \"ne\",\n ne: \"nw\",\n se: \"sw\",\n sw: \"se\"\n };\n\n var flipY = {\n n: \"s\",\n s: \"n\",\n nw: \"sw\",\n ne: \"se\",\n se: \"ne\",\n sw: \"nw\"\n };\n\n var signsX = {\n overlay: +1,\n selection: +1,\n n: null,\n e: +1,\n s: null,\n w: -1,\n nw: -1,\n ne: +1,\n se: +1,\n sw: -1\n };\n\n var signsY = {\n overlay: +1,\n selection: +1,\n n: -1,\n e: null,\n s: +1,\n w: null,\n nw: -1,\n ne: -1,\n se: +1,\n sw: +1\n };\n\n function type$1(t) {\n return {type: t};\n }\n\n // Ignore right-click, since that should open the context menu.\n function defaultFilter$2() {\n return !exports.event.button;\n }\n\n function defaultExtent$1() {\n var svg = this.ownerSVGElement || this;\n return [[0, 0], [svg.width.baseVal.value, svg.height.baseVal.value]];\n }\n\n // Like d3.local, but with the name “__brush†rather than auto-generated.\n function local$1(node) {\n while (!node.__brush) if (!(node = node.parentNode)) return;\n return node.__brush;\n }\n\n function empty$1(extent) {\n return extent[0][0] === extent[1][0]\n || extent[0][1] === extent[1][1];\n }\n\n function brushSelection(node) {\n var state = node.__brush;\n return state ? state.dim.output(state.selection) : null;\n }\n\n function brushX() {\n return brush$1(X);\n }\n\n function brushY() {\n return brush$1(Y);\n }\n\n function brush() {\n return brush$1(XY);\n }\n\n function brush$1(dim) {\n var extent = defaultExtent$1,\n filter = defaultFilter$2,\n listeners = dispatch(brush, \"start\", \"brush\", \"end\"),\n handleSize = 6,\n touchending;\n\n function brush(group) {\n var overlay = group\n .property(\"__brush\", initialize)\n .selectAll(\".overlay\")\n .data([type$1(\"overlay\")]);\n\n overlay.enter().append(\"rect\")\n .attr(\"class\", \"overlay\")\n .attr(\"pointer-events\", \"all\")\n .attr(\"cursor\", cursors.overlay)\n .merge(overlay)\n .each(function() {\n var extent = local$1(this).extent;\n select(this)\n .attr(\"x\", extent[0][0])\n .attr(\"y\", extent[0][1])\n .attr(\"width\", extent[1][0] - extent[0][0])\n .attr(\"height\", extent[1][1] - extent[0][1]);\n });\n\n group.selectAll(\".selection\")\n .data([type$1(\"selection\")])\n .enter().append(\"rect\")\n .attr(\"class\", \"selection\")\n .attr(\"cursor\", cursors.selection)\n .attr(\"fill\", \"#777\")\n .attr(\"fill-opacity\", 0.3)\n .attr(\"stroke\", \"#fff\")\n .attr(\"shape-rendering\", \"crispEdges\");\n\n var handle = group.selectAll(\".handle\")\n .data(dim.handles, function(d) { return d.type; });\n\n handle.exit().remove();\n\n handle.enter().append(\"rect\")\n .attr(\"class\", function(d) { return \"handle handle--\" + d.type; })\n .attr(\"cursor\", function(d) { return cursors[d.type]; });\n\n group\n .each(redraw)\n .attr(\"fill\", \"none\")\n .attr(\"pointer-events\", \"all\")\n .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\")\n .on(\"mousedown.brush touchstart.brush\", started);\n }\n\n brush.move = function(group, selection) {\n if (group.selection) {\n group\n .on(\"start.brush\", function() { emitter(this, arguments).beforestart().start(); })\n .on(\"interrupt.brush end.brush\", function() { emitter(this, arguments).end(); })\n .tween(\"brush\", function() {\n var that = this,\n state = that.__brush,\n emit = emitter(that, arguments),\n selection0 = state.selection,\n selection1 = dim.input(typeof selection === \"function\" ? selection.apply(this, arguments) : selection, state.extent),\n i = interpolate(selection0, selection1);\n\n function tween(t) {\n state.selection = t === 1 && empty$1(selection1) ? null : i(t);\n redraw.call(that);\n emit.brush();\n }\n\n return selection0 && selection1 ? tween : tween(1);\n });\n } else {\n group\n .each(function() {\n var that = this,\n args = arguments,\n state = that.__brush,\n selection1 = dim.input(typeof selection === \"function\" ? selection.apply(that, args) : selection, state.extent),\n emit = emitter(that, args).beforestart();\n\n interrupt(that);\n state.selection = selection1 == null || empty$1(selection1) ? null : selection1;\n redraw.call(that);\n emit.start().brush().end();\n });\n }\n };\n\n function redraw() {\n var group = select(this),\n selection = local$1(this).selection;\n\n if (selection) {\n group.selectAll(\".selection\")\n .style(\"display\", null)\n .attr(\"x\", selection[0][0])\n .attr(\"y\", selection[0][1])\n .attr(\"width\", selection[1][0] - selection[0][0])\n .attr(\"height\", selection[1][1] - selection[0][1]);\n\n group.selectAll(\".handle\")\n .style(\"display\", null)\n .attr(\"x\", function(d) { return d.type[d.type.length - 1] === \"e\" ? selection[1][0] - handleSize / 2 : selection[0][0] - handleSize / 2; })\n .attr(\"y\", function(d) { return d.type[0] === \"s\" ? selection[1][1] - handleSize / 2 : selection[0][1] - handleSize / 2; })\n .attr(\"width\", function(d) { return d.type === \"n\" || d.type === \"s\" ? selection[1][0] - selection[0][0] + handleSize : handleSize; })\n .attr(\"height\", function(d) { return d.type === \"e\" || d.type === \"w\" ? selection[1][1] - selection[0][1] + handleSize : handleSize; });\n }\n\n else {\n group.selectAll(\".selection,.handle\")\n .style(\"display\", \"none\")\n .attr(\"x\", null)\n .attr(\"y\", null)\n .attr(\"width\", null)\n .attr(\"height\", null);\n }\n }\n\n function emitter(that, args) {\n return that.__brush.emitter || new Emitter(that, args);\n }\n\n function Emitter(that, args) {\n this.that = that;\n this.args = args;\n this.state = that.__brush;\n this.active = 0;\n }\n\n Emitter.prototype = {\n beforestart: function() {\n if (++this.active === 1) this.state.emitter = this, this.starting = true;\n return this;\n },\n start: function() {\n if (this.starting) this.starting = false, this.emit(\"start\");\n return this;\n },\n brush: function() {\n this.emit(\"brush\");\n return this;\n },\n end: function() {\n if (--this.active === 0) delete this.state.emitter, this.emit(\"end\");\n return this;\n },\n emit: function(type) {\n customEvent(new BrushEvent(brush, type, dim.output(this.state.selection)), listeners.apply, listeners, [type, this.that, this.args]);\n }\n };\n\n function started() {\n if (exports.event.touches) { if (exports.event.changedTouches.length < exports.event.touches.length) return noevent$2(); }\n else if (touchending) return;\n if (!filter.apply(this, arguments)) return;\n\n var that = this,\n type = exports.event.target.__data__.type,\n mode = (exports.event.metaKey ? type = \"overlay\" : type) === \"selection\" ? MODE_DRAG : (exports.event.altKey ? MODE_CENTER : MODE_HANDLE),\n signX = dim === Y ? null : signsX[type],\n signY = dim === X ? null : signsY[type],\n state = local$1(that),\n extent = state.extent,\n selection = state.selection,\n W = extent[0][0], w0, w1,\n N = extent[0][1], n0, n1,\n E = extent[1][0], e0, e1,\n S = extent[1][1], s0, s1,\n dx,\n dy,\n moving,\n shifting = signX && signY && exports.event.shiftKey,\n lockX,\n lockY,\n point0 = mouse(that),\n point = point0,\n emit = emitter(that, arguments).beforestart();\n\n if (type === \"overlay\") {\n state.selection = selection = [\n [w0 = dim === Y ? W : point0[0], n0 = dim === X ? N : point0[1]],\n [e0 = dim === Y ? E : w0, s0 = dim === X ? S : n0]\n ];\n } else {\n w0 = selection[0][0];\n n0 = selection[0][1];\n e0 = selection[1][0];\n s0 = selection[1][1];\n }\n\n w1 = w0;\n n1 = n0;\n e1 = e0;\n s1 = s0;\n\n var group = select(that)\n .attr(\"pointer-events\", \"none\");\n\n var overlay = group.selectAll(\".overlay\")\n .attr(\"cursor\", cursors[type]);\n\n if (exports.event.touches) {\n group\n .on(\"touchmove.brush\", moved, true)\n .on(\"touchend.brush touchcancel.brush\", ended, true);\n } else {\n var view = select(exports.event.view)\n .on(\"keydown.brush\", keydowned, true)\n .on(\"keyup.brush\", keyupped, true)\n .on(\"mousemove.brush\", moved, true)\n .on(\"mouseup.brush\", ended, true);\n\n dragDisable(exports.event.view);\n }\n\n nopropagation$2();\n interrupt(that);\n redraw.call(that);\n emit.start();\n\n function moved() {\n var point1 = mouse(that);\n if (shifting && !lockX && !lockY) {\n if (Math.abs(point1[0] - point[0]) > Math.abs(point1[1] - point[1])) lockY = true;\n else lockX = true;\n }\n point = point1;\n moving = true;\n noevent$2();\n move();\n }\n\n function move() {\n var t;\n\n dx = point[0] - point0[0];\n dy = point[1] - point0[1];\n\n switch (mode) {\n case MODE_SPACE:\n case MODE_DRAG: {\n if (signX) dx = Math.max(W - w0, Math.min(E - e0, dx)), w1 = w0 + dx, e1 = e0 + dx;\n if (signY) dy = Math.max(N - n0, Math.min(S - s0, dy)), n1 = n0 + dy, s1 = s0 + dy;\n break;\n }\n case MODE_HANDLE: {\n if (signX < 0) dx = Math.max(W - w0, Math.min(E - w0, dx)), w1 = w0 + dx, e1 = e0;\n else if (signX > 0) dx = Math.max(W - e0, Math.min(E - e0, dx)), w1 = w0, e1 = e0 + dx;\n if (signY < 0) dy = Math.max(N - n0, Math.min(S - n0, dy)), n1 = n0 + dy, s1 = s0;\n else if (signY > 0) dy = Math.max(N - s0, Math.min(S - s0, dy)), n1 = n0, s1 = s0 + dy;\n break;\n }\n case MODE_CENTER: {\n if (signX) w1 = Math.max(W, Math.min(E, w0 - dx * signX)), e1 = Math.max(W, Math.min(E, e0 + dx * signX));\n if (signY) n1 = Math.max(N, Math.min(S, n0 - dy * signY)), s1 = Math.max(N, Math.min(S, s0 + dy * signY));\n break;\n }\n }\n\n if (e1 < w1) {\n signX *= -1;\n t = w0, w0 = e0, e0 = t;\n t = w1, w1 = e1, e1 = t;\n if (type in flipX) overlay.attr(\"cursor\", cursors[type = flipX[type]]);\n }\n\n if (s1 < n1) {\n signY *= -1;\n t = n0, n0 = s0, s0 = t;\n t = n1, n1 = s1, s1 = t;\n if (type in flipY) overlay.attr(\"cursor\", cursors[type = flipY[type]]);\n }\n\n selection = state.selection; // May be set by brush.move!\n\n if (lockX) w1 = selection[0][0], e1 = selection[1][0];\n if (lockY) n1 = selection[0][1], s1 = selection[1][1];\n\n if (selection[0][0] !== w1\n || selection[0][1] !== n1\n || selection[1][0] !== e1\n || selection[1][1] !== s1) {\n state.selection = [[w1, n1], [e1, s1]];\n redraw.call(that);\n emit.brush();\n }\n }\n\n function ended() {\n nopropagation$2();\n if (exports.event.touches) {\n if (exports.event.touches.length) return;\n if (touchending) clearTimeout(touchending);\n touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!\n group.on(\"touchmove.brush touchend.brush touchcancel.brush\", null);\n } else {\n dragEnable(exports.event.view, moving);\n view.on(\"keydown.brush keyup.brush mousemove.brush mouseup.brush\", null);\n }\n group.attr(\"pointer-events\", \"all\");\n overlay.attr(\"cursor\", cursors.overlay);\n if (empty$1(selection)) state.selection = null, redraw.call(that);\n emit.end();\n }\n\n function keydowned() {\n switch (exports.event.keyCode) {\n case 16: { // SHIFT\n shifting = signX && signY;\n break;\n }\n case 18: { // ALT\n if (mode === MODE_HANDLE) {\n if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;\n if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;\n mode = MODE_CENTER;\n move();\n }\n break;\n }\n case 32: { // SPACE; takes priority over ALT\n if (mode === MODE_HANDLE || mode === MODE_CENTER) {\n if (signX < 0) e0 = e1 - dx; else if (signX > 0) w0 = w1 - dx;\n if (signY < 0) s0 = s1 - dy; else if (signY > 0) n0 = n1 - dy;\n mode = MODE_SPACE;\n overlay.attr(\"cursor\", cursors.selection);\n move();\n }\n break;\n }\n default: return;\n }\n noevent$2();\n }\n\n function keyupped() {\n switch (exports.event.keyCode) {\n case 16: { // SHIFT\n if (shifting) {\n lockX = lockY = shifting = false;\n move();\n }\n break;\n }\n case 18: { // ALT\n if (mode === MODE_CENTER) {\n if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;\n if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;\n mode = MODE_HANDLE;\n move();\n }\n break;\n }\n case 32: { // SPACE\n if (mode === MODE_SPACE) {\n if (exports.event.altKey) {\n if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;\n if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;\n mode = MODE_CENTER;\n } else {\n if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;\n if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;\n mode = MODE_HANDLE;\n }\n overlay.attr(\"cursor\", cursors[type]);\n move();\n }\n break;\n }\n default: return;\n }\n noevent$2();\n }\n }\n\n function initialize() {\n var state = this.__brush || {selection: null};\n state.extent = extent.apply(this, arguments);\n state.dim = dim;\n return state;\n }\n\n brush.extent = function(_) {\n return arguments.length ? (extent = typeof _ === \"function\" ? _ : constant$10([[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]]), brush) : extent;\n };\n\n brush.filter = function(_) {\n return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant$10(!!_), brush) : filter;\n };\n\n brush.handleSize = function(_) {\n return arguments.length ? (handleSize = +_, brush) : handleSize;\n };\n\n brush.on = function() {\n var value = listeners.on.apply(listeners, arguments);\n return value === listeners ? brush : value;\n };\n\n return brush;\n }\n\n var cos = Math.cos;\n var sin = Math.sin;\n var pi$3 = Math.PI;\n var halfPi$2 = pi$3 / 2;\n var tau$3 = pi$3 * 2;\n var max$1 = Math.max;\n\n function compareValue(compare) {\n return function(a, b) {\n return compare(\n a.source.value + a.target.value,\n b.source.value + b.target.value\n );\n };\n }\n\n function chord() {\n var padAngle = 0,\n sortGroups = null,\n sortSubgroups = null,\n sortChords = null;\n\n function chord(matrix) {\n var n = matrix.length,\n groupSums = [],\n groupIndex = range(n),\n subgroupIndex = [],\n chords = [],\n groups = chords.groups = new Array(n),\n subgroups = new Array(n * n),\n k,\n x,\n x0,\n dx,\n i,\n j;\n\n // Compute the sum.\n k = 0, i = -1; while (++i < n) {\n x = 0, j = -1; while (++j < n) {\n x += matrix[i][j];\n }\n groupSums.push(x);\n subgroupIndex.push(range(n));\n k += x;\n }\n\n // Sort groups…\n if (sortGroups) groupIndex.sort(function(a, b) {\n return sortGroups(groupSums[a], groupSums[b]);\n });\n\n // Sort subgroups…\n if (sortSubgroups) subgroupIndex.forEach(function(d, i) {\n d.sort(function(a, b) {\n return sortSubgroups(matrix[i][a], matrix[i][b]);\n });\n });\n\n // Convert the sum to scaling factor for [0, 2pi].\n // TODO Allow start and end angle to be specified?\n // TODO Allow padding to be specified as percentage?\n k = max$1(0, tau$3 - padAngle * n) / k;\n dx = k ? padAngle : tau$3 / n;\n\n // Compute the start and end angle for each group and subgroup.\n // Note: Opera has a bug reordering object literal properties!\n x = 0, i = -1; while (++i < n) {\n x0 = x, j = -1; while (++j < n) {\n var di = groupIndex[i],\n dj = subgroupIndex[di][j],\n v = matrix[di][dj],\n a0 = x,\n a1 = x += v * k;\n subgroups[dj * n + di] = {\n index: di,\n subindex: dj,\n startAngle: a0,\n endAngle: a1,\n value: v\n };\n }\n groups[di] = {\n index: di,\n startAngle: x0,\n endAngle: x,\n value: groupSums[di]\n };\n x += dx;\n }\n\n // Generate chords for each (non-empty) subgroup-subgroup link.\n i = -1; while (++i < n) {\n j = i - 1; while (++j < n) {\n var source = subgroups[j * n + i],\n target = subgroups[i * n + j];\n if (source.value || target.value) {\n chords.push(source.value < target.value\n ? {source: target, target: source}\n : {source: source, target: target});\n }\n }\n }\n\n return sortChords ? chords.sort(sortChords) : chords;\n }\n\n chord.padAngle = function(_) {\n return arguments.length ? (padAngle = max$1(0, _), chord) : padAngle;\n };\n\n chord.sortGroups = function(_) {\n return arguments.length ? (sortGroups = _, chord) : sortGroups;\n };\n\n chord.sortSubgroups = function(_) {\n return arguments.length ? (sortSubgroups = _, chord) : sortSubgroups;\n };\n\n chord.sortChords = function(_) {\n return arguments.length ? (_ == null ? sortChords = null : (sortChords = compareValue(_))._ = _, chord) : sortChords && sortChords._;\n };\n\n return chord;\n }\n\n var slice$5 = Array.prototype.slice;\n\n function constant$11(x) {\n return function() {\n return x;\n };\n }\n\n function defaultSource(d) {\n return d.source;\n }\n\n function defaultTarget(d) {\n return d.target;\n }\n\n function defaultRadius$1(d) {\n return d.radius;\n }\n\n function defaultStartAngle(d) {\n return d.startAngle;\n }\n\n function defaultEndAngle(d) {\n return d.endAngle;\n }\n\n function ribbon() {\n var source = defaultSource,\n target = defaultTarget,\n radius = defaultRadius$1,\n startAngle = defaultStartAngle,\n endAngle = defaultEndAngle,\n context = null;\n\n function ribbon() {\n var buffer,\n argv = slice$5.call(arguments),\n s = source.apply(this, argv),\n t = target.apply(this, argv),\n sr = +radius.apply(this, (argv[0] = s, argv)),\n sa0 = startAngle.apply(this, argv) - halfPi$2,\n sa1 = endAngle.apply(this, argv) - halfPi$2,\n sx0 = sr * cos(sa0),\n sy0 = sr * sin(sa0),\n tr = +radius.apply(this, (argv[0] = t, argv)),\n ta0 = startAngle.apply(this, argv) - halfPi$2,\n ta1 = endAngle.apply(this, argv) - halfPi$2;\n\n if (!context) context = buffer = path();\n\n context.moveTo(sx0, sy0);\n context.arc(0, 0, sr, sa0, sa1);\n if (sa0 !== ta0 || sa1 !== ta1) { // TODO sr !== tr?\n context.quadraticCurveTo(0, 0, tr * cos(ta0), tr * sin(ta0));\n context.arc(0, 0, tr, ta0, ta1);\n }\n context.quadraticCurveTo(0, 0, sx0, sy0);\n context.closePath();\n\n if (buffer) return context = null, buffer + \"\" || null;\n }\n\n ribbon.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant$11(+_), ribbon) : radius;\n };\n\n ribbon.startAngle = function(_) {\n return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant$11(+_), ribbon) : startAngle;\n };\n\n ribbon.endAngle = function(_) {\n return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant$11(+_), ribbon) : endAngle;\n };\n\n ribbon.source = function(_) {\n return arguments.length ? (source = _, ribbon) : source;\n };\n\n ribbon.target = function(_) {\n return arguments.length ? (target = _, ribbon) : target;\n };\n\n ribbon.context = function(_) {\n return arguments.length ? ((context = _ == null ? null : _), ribbon) : context;\n };\n\n return ribbon;\n }\n\n // Adds floating point numbers with twice the normal precision.\n // Reference: J. R. Shewchuk, Adaptive Precision Floating-Point Arithmetic and\n // Fast Robust Geometric Predicates, Discrete & Computational Geometry 18(3)\n // 305–363 (1997).\n // Code adapted from GeographicLib by Charles F. F. Karney,\n // http://geographiclib.sourceforge.net/\n\n function adder() {\n return new Adder;\n }\n\n function Adder() {\n this.reset();\n }\n\n Adder.prototype = {\n constructor: Adder,\n reset: function() {\n this.s = // rounded value\n this.t = 0; // exact error\n },\n add: function(y) {\n add$1(temp, y, this.t);\n add$1(this, temp.s, this.s);\n if (this.s) this.t += temp.t;\n else this.s = temp.t;\n },\n valueOf: function() {\n return this.s;\n }\n };\n\n var temp = new Adder;\n\n function add$1(adder, a, b) {\n var x = adder.s = a + b,\n bv = x - a,\n av = x - bv;\n adder.t = (a - av) + (b - bv);\n }\n\n var epsilon$4 = 1e-6;\n var epsilon2$2 = 1e-12;\n var pi$4 = Math.PI;\n var halfPi$3 = pi$4 / 2;\n var quarterPi = pi$4 / 4;\n var tau$4 = pi$4 * 2;\n\n var degrees$1 = 180 / pi$4;\n var radians = pi$4 / 180;\n\n var abs = Math.abs;\n var atan = Math.atan;\n var atan2 = Math.atan2;\n var cos$1 = Math.cos;\n var ceil = Math.ceil;\n var exp = Math.exp;\n var log$1 = Math.log;\n var pow$1 = Math.pow;\n var sin$1 = Math.sin;\n var sign$1 = Math.sign || function(x) { return x > 0 ? 1 : x < 0 ? -1 : 0; };\n var sqrt$1 = Math.sqrt;\n var tan = Math.tan;\n\n function acos(x) {\n return x > 1 ? 0 : x < -1 ? pi$4 : Math.acos(x);\n }\n\n function asin$1(x) {\n return x > 1 ? halfPi$3 : x < -1 ? -halfPi$3 : Math.asin(x);\n }\n\n function haversin(x) {\n return (x = sin$1(x / 2)) * x;\n }\n\n function noop$2() {}\n\n function streamGeometry(geometry, stream) {\n if (geometry && streamGeometryType.hasOwnProperty(geometry.type)) {\n streamGeometryType[geometry.type](geometry, stream);\n }\n }\n\n var streamObjectType = {\n Feature: function(feature, stream) {\n streamGeometry(feature.geometry, stream);\n },\n FeatureCollection: function(object, stream) {\n var features = object.features, i = -1, n = features.length;\n while (++i < n) streamGeometry(features[i].geometry, stream);\n }\n };\n\n var streamGeometryType = {\n Sphere: function(object, stream) {\n stream.sphere();\n },\n Point: function(object, stream) {\n object = object.coordinates;\n stream.point(object[0], object[1], object[2]);\n },\n MultiPoint: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) object = coordinates[i], stream.point(object[0], object[1], object[2]);\n },\n LineString: function(object, stream) {\n streamLine(object.coordinates, stream, 0);\n },\n MultiLineString: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) streamLine(coordinates[i], stream, 0);\n },\n Polygon: function(object, stream) {\n streamPolygon(object.coordinates, stream);\n },\n MultiPolygon: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) streamPolygon(coordinates[i], stream);\n },\n GeometryCollection: function(object, stream) {\n var geometries = object.geometries, i = -1, n = geometries.length;\n while (++i < n) streamGeometry(geometries[i], stream);\n }\n };\n\n function streamLine(coordinates, stream, closed) {\n var i = -1, n = coordinates.length - closed, coordinate;\n stream.lineStart();\n while (++i < n) coordinate = coordinates[i], stream.point(coordinate[0], coordinate[1], coordinate[2]);\n stream.lineEnd();\n }\n\n function streamPolygon(coordinates, stream) {\n var i = -1, n = coordinates.length;\n stream.polygonStart();\n while (++i < n) streamLine(coordinates[i], stream, 1);\n stream.polygonEnd();\n }\n\n function stream(object, stream) {\n if (object && streamObjectType.hasOwnProperty(object.type)) {\n streamObjectType[object.type](object, stream);\n } else {\n streamGeometry(object, stream);\n }\n }\n\n var areaRingSum;\n\n var areaSum;\n var lambda00;\n var phi00;\n var lambda0;\n var cosPhi0;\n var sinPhi0;\n var areaStream = {\n point: noop$2,\n lineStart: noop$2,\n lineEnd: noop$2,\n polygonStart: function() {\n areaRingSum.reset();\n areaStream.lineStart = areaRingStart;\n areaStream.lineEnd = areaRingEnd;\n },\n polygonEnd: function() {\n var areaRing = +areaRingSum;\n areaSum.add(areaRing < 0 ? tau$4 + areaRing : areaRing);\n this.lineStart = this.lineEnd = this.point = noop$2;\n },\n sphere: function() {\n areaSum.add(tau$4);\n }\n };\n\n function areaRingStart() {\n areaStream.point = areaPointFirst;\n }\n\n function areaRingEnd() {\n areaPoint(lambda00, phi00);\n }\n\n function areaPointFirst(lambda, phi) {\n areaStream.point = areaPoint;\n lambda00 = lambda, phi00 = phi;\n lambda *= radians, phi *= radians;\n lambda0 = lambda, cosPhi0 = cos$1(phi = phi / 2 + quarterPi), sinPhi0 = sin$1(phi);\n }\n\n function areaPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n phi = phi / 2 + quarterPi; // half the angular distance from south pole\n\n // Spherical excess E for a spherical triangle with vertices: south pole,\n // previous point, current point. Uses a formula derived from Cagnoli’s\n // theorem. See Todhunter, Spherical Trig. (1871), Sec. 103, Eq. (2).\n var dLambda = lambda - lambda0,\n sdLambda = dLambda >= 0 ? 1 : -1,\n adLambda = sdLambda * dLambda,\n cosPhi = cos$1(phi),\n sinPhi = sin$1(phi),\n k = sinPhi0 * sinPhi,\n u = cosPhi0 * cosPhi + k * cos$1(adLambda),\n v = k * sdLambda * sin$1(adLambda);\n areaRingSum.add(atan2(v, u));\n\n // Advance the previous points.\n lambda0 = lambda, cosPhi0 = cosPhi, sinPhi0 = sinPhi;\n }\n\n function area$2(object) {\n if (areaSum) areaSum.reset();\n else areaSum = adder(), areaRingSum = adder();\n stream(object, areaStream);\n return areaSum * 2;\n }\n\n function spherical(cartesian) {\n return [atan2(cartesian[1], cartesian[0]), asin$1(cartesian[2])];\n }\n\n function cartesian(spherical) {\n var lambda = spherical[0], phi = spherical[1], cosPhi = cos$1(phi);\n return [cosPhi * cos$1(lambda), cosPhi * sin$1(lambda), sin$1(phi)];\n }\n\n function cartesianDot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n }\n\n function cartesianCross(a, b) {\n return [a[1] * b[2] - a[2] * b[1], a[2] * b[0] - a[0] * b[2], a[0] * b[1] - a[1] * b[0]];\n }\n\n // TODO return a\n function cartesianAddInPlace(a, b) {\n a[0] += b[0], a[1] += b[1], a[2] += b[2];\n }\n\n function cartesianScale(vector, k) {\n return [vector[0] * k, vector[1] * k, vector[2] * k];\n }\n\n // TODO return d\n function cartesianNormalizeInPlace(d) {\n var l = sqrt$1(d[0] * d[0] + d[1] * d[1] + d[2] * d[2]);\n d[0] /= l, d[1] /= l, d[2] /= l;\n }\n\nvar lambda0$1;\n var phi0;\n var lambda1;\n var phi1;\n var lambda2;\nvar lambda00$1;\nvar phi00$1;\n var p0;\n var deltaSum;\n var ranges;\nvar range$1;\n var boundsStream = {\n point: boundsPoint,\n lineStart: boundsLineStart,\n lineEnd: boundsLineEnd,\n polygonStart: function() {\n boundsStream.point = boundsRingPoint;\n boundsStream.lineStart = boundsRingStart;\n boundsStream.lineEnd = boundsRingEnd;\n deltaSum.reset();\n areaStream.polygonStart();\n },\n polygonEnd: function() {\n areaStream.polygonEnd();\n boundsStream.point = boundsPoint;\n boundsStream.lineStart = boundsLineStart;\n boundsStream.lineEnd = boundsLineEnd;\n if (areaRingSum < 0) lambda0$1 = -(lambda1 = 180), phi0 = -(phi1 = 90);\n else if (deltaSum > epsilon$4) phi1 = 90;\n else if (deltaSum < -epsilon$4) phi0 = -90;\n range$1[0] = lambda0$1, range$1[1] = lambda1;\n }\n };\n\n function boundsPoint(lambda, phi) {\n ranges.push(range$1 = [lambda0$1 = lambda, lambda1 = lambda]);\n if (phi < phi0) phi0 = phi;\n if (phi > phi1) phi1 = phi;\n }\n\n function linePoint(lambda, phi) {\n var p = cartesian([lambda * radians, phi * radians]);\n if (p0) {\n var normal = cartesianCross(p0, p),\n equatorial = [normal[1], -normal[0], 0],\n inflection = cartesianCross(equatorial, normal);\n cartesianNormalizeInPlace(inflection);\n inflection = spherical(inflection);\n var delta = lambda - lambda2,\n sign = delta > 0 ? 1 : -1,\n lambdai = inflection[0] * degrees$1 * sign,\n phii,\n antimeridian = abs(delta) > 180;\n if (antimeridian ^ (sign * lambda2 < lambdai && lambdai < sign * lambda)) {\n phii = inflection[1] * degrees$1;\n if (phii > phi1) phi1 = phii;\n } else if (lambdai = (lambdai + 360) % 360 - 180, antimeridian ^ (sign * lambda2 < lambdai && lambdai < sign * lambda)) {\n phii = -inflection[1] * degrees$1;\n if (phii < phi0) phi0 = phii;\n } else {\n if (phi < phi0) phi0 = phi;\n if (phi > phi1) phi1 = phi;\n }\n if (antimeridian) {\n if (lambda < lambda2) {\n if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;\n } else {\n if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;\n }\n } else {\n if (lambda1 >= lambda0$1) {\n if (lambda < lambda0$1) lambda0$1 = lambda;\n if (lambda > lambda1) lambda1 = lambda;\n } else {\n if (lambda > lambda2) {\n if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;\n } else {\n if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;\n }\n }\n }\n } else {\n boundsPoint(lambda, phi);\n }\n p0 = p, lambda2 = lambda;\n }\n\n function boundsLineStart() {\n boundsStream.point = linePoint;\n }\n\n function boundsLineEnd() {\n range$1[0] = lambda0$1, range$1[1] = lambda1;\n boundsStream.point = boundsPoint;\n p0 = null;\n }\n\n function boundsRingPoint(lambda, phi) {\n if (p0) {\n var delta = lambda - lambda2;\n deltaSum.add(abs(delta) > 180 ? delta + (delta > 0 ? 360 : -360) : delta);\n } else {\n lambda00$1 = lambda, phi00$1 = phi;\n }\n areaStream.point(lambda, phi);\n linePoint(lambda, phi);\n }\n\n function boundsRingStart() {\n areaStream.lineStart();\n }\n\n function boundsRingEnd() {\n boundsRingPoint(lambda00$1, phi00$1);\n areaStream.lineEnd();\n if (abs(deltaSum) > epsilon$4) lambda0$1 = -(lambda1 = 180);\n range$1[0] = lambda0$1, range$1[1] = lambda1;\n p0 = null;\n }\n\n // Finds the left-right distance between two longitudes.\n // This is almost the same as (lambda1 - lambda0 + 360°) % 360°, except that we want\n // the distance between ±180° to be 360°.\n function angle(lambda0, lambda1) {\n return (lambda1 -= lambda0) < 0 ? lambda1 + 360 : lambda1;\n }\n\n function rangeCompare(a, b) {\n return a[0] - b[0];\n }\n\n function rangeContains(range, x) {\n return range[0] <= range[1] ? range[0] <= x && x <= range[1] : x < range[0] || range[1] < x;\n }\n\n function bounds(feature) {\n var i, n, a, b, merged, deltaMax, delta;\n\n if (deltaSum) deltaSum.reset();\n else deltaSum = adder();\n phi1 = lambda1 = -(lambda0$1 = phi0 = Infinity);\n ranges = [];\n stream(feature, boundsStream);\n\n // First, sort ranges by their minimum longitudes.\n if (n = ranges.length) {\n ranges.sort(rangeCompare);\n\n // Then, merge any ranges that overlap.\n for (i = 1, a = ranges[0], merged = [a]; i < n; ++i) {\n b = ranges[i];\n if (rangeContains(a, b[0]) || rangeContains(a, b[1])) {\n if (angle(a[0], b[1]) > angle(a[0], a[1])) a[1] = b[1];\n if (angle(b[0], a[1]) > angle(a[0], a[1])) a[0] = b[0];\n } else {\n merged.push(a = b);\n }\n }\n\n // Finally, find the largest gap between the merged ranges.\n // The final bounding box will be the inverse of this gap.\n for (deltaMax = -Infinity, n = merged.length - 1, i = 0, a = merged[n]; i <= n; a = b, ++i) {\n b = merged[i];\n if ((delta = angle(a[1], b[0])) > deltaMax) deltaMax = delta, lambda0$1 = b[0], lambda1 = a[1];\n }\n }\n\n ranges = range$1 = null;\n\n return lambda0$1 === Infinity || phi0 === Infinity\n ? [[NaN, NaN], [NaN, NaN]]\n : [[lambda0$1, phi0], [lambda1, phi1]];\n }\n\n var W0;\n var W1;\n var X0;\n var Y0;\n var Z0;\n var X1;\n var Y1;\n var Z1;\n var X2;\n var Y2;\n var Z2;\nvar lambda00$2;\nvar phi00$2;\n var x0;\n var y0;\n var z0;\n // previous point\n\n var centroidStream = {\n sphere: noop$2,\n point: centroidPoint,\n lineStart: centroidLineStart,\n lineEnd: centroidLineEnd,\n polygonStart: function() {\n centroidStream.lineStart = centroidRingStart;\n centroidStream.lineEnd = centroidRingEnd;\n },\n polygonEnd: function() {\n centroidStream.lineStart = centroidLineStart;\n centroidStream.lineEnd = centroidLineEnd;\n }\n };\n\n // Arithmetic mean of Cartesian vectors.\n function centroidPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos$1(phi);\n centroidPointCartesian(cosPhi * cos$1(lambda), cosPhi * sin$1(lambda), sin$1(phi));\n }\n\n function centroidPointCartesian(x, y, z) {\n ++W0;\n X0 += (x - X0) / W0;\n Y0 += (y - Y0) / W0;\n Z0 += (z - Z0) / W0;\n }\n\n function centroidLineStart() {\n centroidStream.point = centroidLinePointFirst;\n }\n\n function centroidLinePointFirst(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos$1(phi);\n x0 = cosPhi * cos$1(lambda);\n y0 = cosPhi * sin$1(lambda);\n z0 = sin$1(phi);\n centroidStream.point = centroidLinePoint;\n centroidPointCartesian(x0, y0, z0);\n }\n\n function centroidLinePoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos$1(phi),\n x = cosPhi * cos$1(lambda),\n y = cosPhi * sin$1(lambda),\n z = sin$1(phi),\n w = atan2(sqrt$1((w = y0 * z - z0 * y) * w + (w = z0 * x - x0 * z) * w + (w = x0 * y - y0 * x) * w), x0 * x + y0 * y + z0 * z);\n W1 += w;\n X1 += w * (x0 + (x0 = x));\n Y1 += w * (y0 + (y0 = y));\n Z1 += w * (z0 + (z0 = z));\n centroidPointCartesian(x0, y0, z0);\n }\n\n function centroidLineEnd() {\n centroidStream.point = centroidPoint;\n }\n\n // See J. E. Brock, The Inertia Tensor for a Spherical Triangle,\n // J. Applied Mechanics 42, 239 (1975).\n function centroidRingStart() {\n centroidStream.point = centroidRingPointFirst;\n }\n\n function centroidRingEnd() {\n centroidRingPoint(lambda00$2, phi00$2);\n centroidStream.point = centroidPoint;\n }\n\n function centroidRingPointFirst(lambda, phi) {\n lambda00$2 = lambda, phi00$2 = phi;\n lambda *= radians, phi *= radians;\n centroidStream.point = centroidRingPoint;\n var cosPhi = cos$1(phi);\n x0 = cosPhi * cos$1(lambda);\n y0 = cosPhi * sin$1(lambda);\n z0 = sin$1(phi);\n centroidPointCartesian(x0, y0, z0);\n }\n\n function centroidRingPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos$1(phi),\n x = cosPhi * cos$1(lambda),\n y = cosPhi * sin$1(lambda),\n z = sin$1(phi),\n cx = y0 * z - z0 * y,\n cy = z0 * x - x0 * z,\n cz = x0 * y - y0 * x,\n m = sqrt$1(cx * cx + cy * cy + cz * cz),\n u = x0 * x + y0 * y + z0 * z,\n v = m && -acos(u) / m, // area weight\n w = atan2(m, u); // line weight\n X2 += v * cx;\n Y2 += v * cy;\n Z2 += v * cz;\n W1 += w;\n X1 += w * (x0 + (x0 = x));\n Y1 += w * (y0 + (y0 = y));\n Z1 += w * (z0 + (z0 = z));\n centroidPointCartesian(x0, y0, z0);\n }\n\n function centroid$1(object) {\n W0 = W1 =\n X0 = Y0 = Z0 =\n X1 = Y1 = Z1 =\n X2 = Y2 = Z2 = 0;\n stream(object, centroidStream);\n\n var x = X2,\n y = Y2,\n z = Z2,\n m = x * x + y * y + z * z;\n\n // If the area-weighted ccentroid is undefined, fall back to length-weighted ccentroid.\n if (m < epsilon2$2) {\n x = X1, y = Y1, z = Z1;\n // If the feature has zero length, fall back to arithmetic mean of point vectors.\n if (W1 < epsilon$4) x = X0, y = Y0, z = Z0;\n m = x * x + y * y + z * z;\n // If the feature still has an undefined ccentroid, then return.\n if (m < epsilon2$2) return [NaN, NaN];\n }\n\n return [atan2(y, x) * degrees$1, asin$1(z / sqrt$1(m)) * degrees$1];\n }\n\n function constant$12(x) {\n return function() {\n return x;\n };\n }\n\n function compose(a, b) {\n\n function compose(x, y) {\n return x = a(x, y), b(x[0], x[1]);\n }\n\n if (a.invert && b.invert) compose.invert = function(x, y) {\n return x = b.invert(x, y), x && a.invert(x[0], x[1]);\n };\n\n return compose;\n }\n\n function rotationIdentity(lambda, phi) {\n return [lambda > pi$4 ? lambda - tau$4 : lambda < -pi$4 ? lambda + tau$4 : lambda, phi];\n }\n\n rotationIdentity.invert = rotationIdentity;\n\n function rotateRadians(deltaLambda, deltaPhi, deltaGamma) {\n return (deltaLambda %= tau$4) ? (deltaPhi || deltaGamma ? compose(rotationLambda(deltaLambda), rotationPhiGamma(deltaPhi, deltaGamma))\n : rotationLambda(deltaLambda))\n : (deltaPhi || deltaGamma ? rotationPhiGamma(deltaPhi, deltaGamma)\n : rotationIdentity);\n }\n\n function forwardRotationLambda(deltaLambda) {\n return function(lambda, phi) {\n return lambda += deltaLambda, [lambda > pi$4 ? lambda - tau$4 : lambda < -pi$4 ? lambda + tau$4 : lambda, phi];\n };\n }\n\n function rotationLambda(deltaLambda) {\n var rotation = forwardRotationLambda(deltaLambda);\n rotation.invert = forwardRotationLambda(-deltaLambda);\n return rotation;\n }\n\n function rotationPhiGamma(deltaPhi, deltaGamma) {\n var cosDeltaPhi = cos$1(deltaPhi),\n sinDeltaPhi = sin$1(deltaPhi),\n cosDeltaGamma = cos$1(deltaGamma),\n sinDeltaGamma = sin$1(deltaGamma);\n\n function rotation(lambda, phi) {\n var cosPhi = cos$1(phi),\n x = cos$1(lambda) * cosPhi,\n y = sin$1(lambda) * cosPhi,\n z = sin$1(phi),\n k = z * cosDeltaPhi + x * sinDeltaPhi;\n return [\n atan2(y * cosDeltaGamma - k * sinDeltaGamma, x * cosDeltaPhi - z * sinDeltaPhi),\n asin$1(k * cosDeltaGamma + y * sinDeltaGamma)\n ];\n }\n\n rotation.invert = function(lambda, phi) {\n var cosPhi = cos$1(phi),\n x = cos$1(lambda) * cosPhi,\n y = sin$1(lambda) * cosPhi,\n z = sin$1(phi),\n k = z * cosDeltaGamma - y * sinDeltaGamma;\n return [\n atan2(y * cosDeltaGamma + z * sinDeltaGamma, x * cosDeltaPhi + k * sinDeltaPhi),\n asin$1(k * cosDeltaPhi - x * sinDeltaPhi)\n ];\n };\n\n return rotation;\n }\n\n function rotation(rotate) {\n rotate = rotateRadians(rotate[0] * radians, rotate[1] * radians, rotate.length > 2 ? rotate[2] * radians : 0);\n\n function forward(coordinates) {\n coordinates = rotate(coordinates[0] * radians, coordinates[1] * radians);\n return coordinates[0] *= degrees$1, coordinates[1] *= degrees$1, coordinates;\n }\n\n forward.invert = function(coordinates) {\n coordinates = rotate.invert(coordinates[0] * radians, coordinates[1] * radians);\n return coordinates[0] *= degrees$1, coordinates[1] *= degrees$1, coordinates;\n };\n\n return forward;\n }\n\n // Generates a circle centered at [0°, 0°], with a given radius and precision.\n function circleStream(stream, radius, delta, direction, t0, t1) {\n if (!delta) return;\n var cosRadius = cos$1(radius),\n sinRadius = sin$1(radius),\n step = direction * delta;\n if (t0 == null) {\n t0 = radius + direction * tau$4;\n t1 = radius - step / 2;\n } else {\n t0 = circleRadius(cosRadius, t0);\n t1 = circleRadius(cosRadius, t1);\n if (direction > 0 ? t0 < t1 : t0 > t1) t0 += direction * tau$4;\n }\n for (var point, t = t0; direction > 0 ? t > t1 : t < t1; t -= step) {\n point = spherical([cosRadius, -sinRadius * cos$1(t), -sinRadius * sin$1(t)]);\n stream.point(point[0], point[1]);\n }\n }\n\n // Returns the signed angle of a cartesian point relative to [cosRadius, 0, 0].\n function circleRadius(cosRadius, point) {\n point = cartesian(point), point[0] -= cosRadius;\n cartesianNormalizeInPlace(point);\n var radius = acos(-point[1]);\n return ((-point[2] < 0 ? -radius : radius) + tau$4 - epsilon$4) % tau$4;\n }\n\n function circle$1() {\n var center = constant$12([0, 0]),\n radius = constant$12(90),\n precision = constant$12(6),\n ring,\n rotate,\n stream = {point: point};\n\n function point(x, y) {\n ring.push(x = rotate(x, y));\n x[0] *= degrees$1, x[1] *= degrees$1;\n }\n\n function circle() {\n var c = center.apply(this, arguments),\n r = radius.apply(this, arguments) * radians,\n p = precision.apply(this, arguments) * radians;\n ring = [];\n rotate = rotateRadians(-c[0] * radians, -c[1] * radians, 0).invert;\n circleStream(stream, r, p, 1);\n c = {type: \"Polygon\", coordinates: [ring]};\n ring = rotate = null;\n return c;\n }\n\n circle.center = function(_) {\n return arguments.length ? (center = typeof _ === \"function\" ? _ : constant$12([+_[0], +_[1]]), circle) : center;\n };\n\n circle.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant$12(+_), circle) : radius;\n };\n\n circle.precision = function(_) {\n return arguments.length ? (precision = typeof _ === \"function\" ? _ : constant$12(+_), circle) : precision;\n };\n\n return circle;\n }\n\n function clipBuffer() {\n var lines = [],\n line;\n return {\n point: function(x, y) {\n line.push([x, y]);\n },\n lineStart: function() {\n lines.push(line = []);\n },\n lineEnd: noop$2,\n rejoin: function() {\n if (lines.length > 1) lines.push(lines.pop().concat(lines.shift()));\n },\n result: function() {\n var result = lines;\n lines = [];\n line = null;\n return result;\n }\n };\n }\n\n function clipLine(a, b, x0, y0, x1, y1) {\n var ax = a[0],\n ay = a[1],\n bx = b[0],\n by = b[1],\n t0 = 0,\n t1 = 1,\n dx = bx - ax,\n dy = by - ay,\n r;\n\n r = x0 - ax;\n if (!dx && r > 0) return;\n r /= dx;\n if (dx < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dx > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = x1 - ax;\n if (!dx && r < 0) return;\n r /= dx;\n if (dx < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dx > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n r = y0 - ay;\n if (!dy && r > 0) return;\n r /= dy;\n if (dy < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dy > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = y1 - ay;\n if (!dy && r < 0) return;\n r /= dy;\n if (dy < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dy > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n if (t0 > 0) a[0] = ax + t0 * dx, a[1] = ay + t0 * dy;\n if (t1 < 1) b[0] = ax + t1 * dx, b[1] = ay + t1 * dy;\n return true;\n }\n\n function pointEqual(a, b) {\n return abs(a[0] - b[0]) < epsilon$4 && abs(a[1] - b[1]) < epsilon$4;\n }\n\n function Intersection(point, points, other, entry) {\n this.x = point;\n this.z = points;\n this.o = other; // another intersection\n this.e = entry; // is an entry?\n this.v = false; // visited\n this.n = this.p = null; // next & previous\n }\n\n // A generalized polygon clipping algorithm: given a polygon that has been cut\n // into its visible line segments, and rejoins the segments by interpolating\n // along the clip edge.\n function clipPolygon(segments, compareIntersection, startInside, interpolate, stream) {\n var subject = [],\n clip = [],\n i,\n n;\n\n segments.forEach(function(segment) {\n if ((n = segment.length - 1) <= 0) return;\n var n, p0 = segment[0], p1 = segment[n], x;\n\n // If the first and last points of a segment are coincident, then treat as a\n // closed ring. TODO if all rings are closed, then the winding order of the\n // exterior ring should be checked.\n if (pointEqual(p0, p1)) {\n stream.lineStart();\n for (i = 0; i < n; ++i) stream.point((p0 = segment[i])[0], p0[1]);\n stream.lineEnd();\n return;\n }\n\n subject.push(x = new Intersection(p0, segment, null, true));\n clip.push(x.o = new Intersection(p0, null, x, false));\n subject.push(x = new Intersection(p1, segment, null, false));\n clip.push(x.o = new Intersection(p1, null, x, true));\n });\n\n if (!subject.length) return;\n\n clip.sort(compareIntersection);\n link$1(subject);\n link$1(clip);\n\n for (i = 0, n = clip.length; i < n; ++i) {\n clip[i].e = startInside = !startInside;\n }\n\n var start = subject[0],\n points,\n point;\n\n while (1) {\n // Find first unvisited intersection.\n var current = start,\n isSubject = true;\n while (current.v) if ((current = current.n) === start) return;\n points = current.z;\n stream.lineStart();\n do {\n current.v = current.o.v = true;\n if (current.e) {\n if (isSubject) {\n for (i = 0, n = points.length; i < n; ++i) stream.point((point = points[i])[0], point[1]);\n } else {\n interpolate(current.x, current.n.x, 1, stream);\n }\n current = current.n;\n } else {\n if (isSubject) {\n points = current.p.z;\n for (i = points.length - 1; i >= 0; --i) stream.point((point = points[i])[0], point[1]);\n } else {\n interpolate(current.x, current.p.x, -1, stream);\n }\n current = current.p;\n }\n current = current.o;\n points = current.z;\n isSubject = !isSubject;\n } while (!current.v);\n stream.lineEnd();\n }\n }\n\n function link$1(array) {\n if (!(n = array.length)) return;\n var n,\n i = 0,\n a = array[0],\n b;\n while (++i < n) {\n a.n = b = array[i];\n b.p = a;\n a = b;\n }\n a.n = b = array[0];\n b.p = a;\n }\n\n var clipMax = 1e9;\n var clipMin = -clipMax;\n // TODO Use d3-polygon’s polygonContains here for the ring check?\n // TODO Eliminate duplicate buffering in clipBuffer and polygon.push?\n\n function clipExtent(x0, y0, x1, y1) {\n\n function visible(x, y) {\n return x0 <= x && x <= x1 && y0 <= y && y <= y1;\n }\n\n function interpolate(from, to, direction, stream) {\n var a = 0, a1 = 0;\n if (from == null\n || (a = corner(from, direction)) !== (a1 = corner(to, direction))\n || comparePoint(from, to) < 0 ^ direction > 0) {\n do stream.point(a === 0 || a === 3 ? x0 : x1, a > 1 ? y1 : y0);\n while ((a = (a + direction + 4) % 4) !== a1);\n } else {\n stream.point(to[0], to[1]);\n }\n }\n\n function corner(p, direction) {\n return abs(p[0] - x0) < epsilon$4 ? direction > 0 ? 0 : 3\n : abs(p[0] - x1) < epsilon$4 ? direction > 0 ? 2 : 1\n : abs(p[1] - y0) < epsilon$4 ? direction > 0 ? 1 : 0\n : direction > 0 ? 3 : 2; // abs(p[1] - y1) < epsilon\n }\n\n function compareIntersection(a, b) {\n return comparePoint(a.x, b.x);\n }\n\n function comparePoint(a, b) {\n var ca = corner(a, 1),\n cb = corner(b, 1);\n return ca !== cb ? ca - cb\n : ca === 0 ? b[1] - a[1]\n : ca === 1 ? a[0] - b[0]\n : ca === 2 ? a[1] - b[1]\n : b[0] - a[0];\n }\n\n return function(stream) {\n var activeStream = stream,\n bufferStream = clipBuffer(),\n segments,\n polygon,\n ring,\n x__, y__, v__, // first point\n x_, y_, v_, // previous point\n first,\n clean;\n\n var clipStream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: polygonStart,\n polygonEnd: polygonEnd\n };\n\n function point(x, y) {\n if (visible(x, y)) activeStream.point(x, y);\n }\n\n function polygonInside() {\n var winding = 0;\n\n for (var i = 0, n = polygon.length; i < n; ++i) {\n for (var ring = polygon[i], j = 1, m = ring.length, point = ring[0], a0, a1, b0 = point[0], b1 = point[1]; j < m; ++j) {\n a0 = b0, a1 = b1, point = ring[j], b0 = point[0], b1 = point[1];\n if (a1 <= y1) { if (b1 > y1 && (b0 - a0) * (y1 - a1) > (b1 - a1) * (x0 - a0)) ++winding; }\n else { if (b1 <= y1 && (b0 - a0) * (y1 - a1) < (b1 - a1) * (x0 - a0)) --winding; }\n }\n }\n\n return winding;\n }\n\n // Buffer geometry within a polygon and then clip it en masse.\n function polygonStart() {\n activeStream = bufferStream, segments = [], polygon = [], clean = true;\n }\n\n function polygonEnd() {\n var startInside = polygonInside(),\n cleanInside = clean && startInside,\n visible = (segments = merge(segments)).length;\n if (cleanInside || visible) {\n stream.polygonStart();\n if (cleanInside) {\n stream.lineStart();\n interpolate(null, null, 1, stream);\n stream.lineEnd();\n }\n if (visible) {\n clipPolygon(segments, compareIntersection, startInside, interpolate, stream);\n }\n stream.polygonEnd();\n }\n activeStream = stream, segments = polygon = ring = null;\n }\n\n function lineStart() {\n clipStream.point = linePoint;\n if (polygon) polygon.push(ring = []);\n first = true;\n v_ = false;\n x_ = y_ = NaN;\n }\n\n // TODO rather than special-case polygons, simply handle them separately.\n // Ideally, coincident intersection points should be jittered to avoid\n // clipping issues.\n function lineEnd() {\n if (segments) {\n linePoint(x__, y__);\n if (v__ && v_) bufferStream.rejoin();\n segments.push(bufferStream.result());\n }\n clipStream.point = point;\n if (v_) activeStream.lineEnd();\n }\n\n function linePoint(x, y) {\n var v = visible(x, y);\n if (polygon) ring.push([x, y]);\n if (first) {\n x__ = x, y__ = y, v__ = v;\n first = false;\n if (v) {\n activeStream.lineStart();\n activeStream.point(x, y);\n }\n } else {\n if (v && v_) activeStream.point(x, y);\n else {\n var a = [x_ = Math.max(clipMin, Math.min(clipMax, x_)), y_ = Math.max(clipMin, Math.min(clipMax, y_))],\n b = [x = Math.max(clipMin, Math.min(clipMax, x)), y = Math.max(clipMin, Math.min(clipMax, y))];\n if (clipLine(a, b, x0, y0, x1, y1)) {\n if (!v_) {\n activeStream.lineStart();\n activeStream.point(a[0], a[1]);\n }\n activeStream.point(b[0], b[1]);\n if (!v) activeStream.lineEnd();\n clean = false;\n } else if (v) {\n activeStream.lineStart();\n activeStream.point(x, y);\n clean = false;\n }\n }\n }\n x_ = x, y_ = y, v_ = v;\n }\n\n return clipStream;\n };\n }\n\n function extent$1() {\n var x0 = 0,\n y0 = 0,\n x1 = 960,\n y1 = 500,\n cache,\n cacheStream,\n clip;\n\n return clip = {\n stream: function(stream) {\n return cache && cacheStream === stream ? cache : cache = clipExtent(x0, y0, x1, y1)(cacheStream = stream);\n },\n extent: function(_) {\n return arguments.length ? (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1], cache = cacheStream = null, clip) : [[x0, y0], [x1, y1]];\n }\n };\n }\n\n var lengthSum;\nvar lambda0$2;\nvar sinPhi0$1;\nvar cosPhi0$1;\n var lengthStream = {\n sphere: noop$2,\n point: noop$2,\n lineStart: lengthLineStart,\n lineEnd: noop$2,\n polygonStart: noop$2,\n polygonEnd: noop$2\n };\n\n function lengthLineStart() {\n lengthStream.point = lengthPointFirst;\n lengthStream.lineEnd = lengthLineEnd;\n }\n\n function lengthLineEnd() {\n lengthStream.point = lengthStream.lineEnd = noop$2;\n }\n\n function lengthPointFirst(lambda, phi) {\n lambda *= radians, phi *= radians;\n lambda0$2 = lambda, sinPhi0$1 = sin$1(phi), cosPhi0$1 = cos$1(phi);\n lengthStream.point = lengthPoint;\n }\n\n function lengthPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var sinPhi = sin$1(phi),\n cosPhi = cos$1(phi),\n delta = abs(lambda - lambda0$2),\n cosDelta = cos$1(delta),\n sinDelta = sin$1(delta),\n x = cosPhi * sinDelta,\n y = cosPhi0$1 * sinPhi - sinPhi0$1 * cosPhi * cosDelta,\n z = sinPhi0$1 * sinPhi + cosPhi0$1 * cosPhi * cosDelta;\n lengthSum.add(atan2(sqrt$1(x * x + y * y), z));\n lambda0$2 = lambda, sinPhi0$1 = sinPhi, cosPhi0$1 = cosPhi;\n }\n\n function length$2(object) {\n if (lengthSum) lengthSum.reset();\n else lengthSum = adder();\n stream(object, lengthStream);\n return +lengthSum;\n }\n\n var coordinates = [null, null];\nvar object$1 = {type: \"LineString\", coordinates: coordinates};\n function distance(a, b) {\n coordinates[0] = a;\n coordinates[1] = b;\n return length$2(object$1);\n }\n\n function graticuleX(y0, y1, dy) {\n var y = range(y0, y1 - epsilon$4, dy).concat(y1);\n return function(x) { return y.map(function(y) { return [x, y]; }); };\n }\n\n function graticuleY(x0, x1, dx) {\n var x = range(x0, x1 - epsilon$4, dx).concat(x1);\n return function(y) { return x.map(function(x) { return [x, y]; }); };\n }\n\n function graticule() {\n var x1, x0, X1, X0,\n y1, y0, Y1, Y0,\n dx = 10, dy = dx, DX = 90, DY = 360,\n x, y, X, Y,\n precision = 2.5;\n\n function graticule() {\n return {type: \"MultiLineString\", coordinates: lines()};\n }\n\n function lines() {\n return range(ceil(X0 / DX) * DX, X1, DX).map(X)\n .concat(range(ceil(Y0 / DY) * DY, Y1, DY).map(Y))\n .concat(range(ceil(x0 / dx) * dx, x1, dx).filter(function(x) { return abs(x % DX) > epsilon$4; }).map(x))\n .concat(range(ceil(y0 / dy) * dy, y1, dy).filter(function(y) { return abs(y % DY) > epsilon$4; }).map(y));\n }\n\n graticule.lines = function() {\n return lines().map(function(coordinates) { return {type: \"LineString\", coordinates: coordinates}; });\n };\n\n graticule.outline = function() {\n return {\n type: \"Polygon\",\n coordinates: [\n X(X0).concat(\n Y(Y1).slice(1),\n X(X1).reverse().slice(1),\n Y(Y0).reverse().slice(1))\n ]\n };\n };\n\n graticule.extent = function(_) {\n if (!arguments.length) return graticule.extentMinor();\n return graticule.extentMajor(_).extentMinor(_);\n };\n\n graticule.extentMajor = function(_) {\n if (!arguments.length) return [[X0, Y0], [X1, Y1]];\n X0 = +_[0][0], X1 = +_[1][0];\n Y0 = +_[0][1], Y1 = +_[1][1];\n if (X0 > X1) _ = X0, X0 = X1, X1 = _;\n if (Y0 > Y1) _ = Y0, Y0 = Y1, Y1 = _;\n return graticule.precision(precision);\n };\n\n graticule.extentMinor = function(_) {\n if (!arguments.length) return [[x0, y0], [x1, y1]];\n x0 = +_[0][0], x1 = +_[1][0];\n y0 = +_[0][1], y1 = +_[1][1];\n if (x0 > x1) _ = x0, x0 = x1, x1 = _;\n if (y0 > y1) _ = y0, y0 = y1, y1 = _;\n return graticule.precision(precision);\n };\n\n graticule.step = function(_) {\n if (!arguments.length) return graticule.stepMinor();\n return graticule.stepMajor(_).stepMinor(_);\n };\n\n graticule.stepMajor = function(_) {\n if (!arguments.length) return [DX, DY];\n DX = +_[0], DY = +_[1];\n return graticule;\n };\n\n graticule.stepMinor = function(_) {\n if (!arguments.length) return [dx, dy];\n dx = +_[0], dy = +_[1];\n return graticule;\n };\n\n graticule.precision = function(_) {\n if (!arguments.length) return precision;\n precision = +_;\n x = graticuleX(y0, y1, 90);\n y = graticuleY(x0, x1, precision);\n X = graticuleX(Y0, Y1, 90);\n Y = graticuleY(X0, X1, precision);\n return graticule;\n };\n\n return graticule\n .extentMajor([[-180, -90 + epsilon$4], [180, 90 - epsilon$4]])\n .extentMinor([[-180, -80 - epsilon$4], [180, 80 + epsilon$4]]);\n }\n\n function interpolate$2(a, b) {\n var x0 = a[0] * radians,\n y0 = a[1] * radians,\n x1 = b[0] * radians,\n y1 = b[1] * radians,\n cy0 = cos$1(y0),\n sy0 = sin$1(y0),\n cy1 = cos$1(y1),\n sy1 = sin$1(y1),\n kx0 = cy0 * cos$1(x0),\n ky0 = cy0 * sin$1(x0),\n kx1 = cy1 * cos$1(x1),\n ky1 = cy1 * sin$1(x1),\n d = 2 * asin$1(sqrt$1(haversin(y1 - y0) + cy0 * cy1 * haversin(x1 - x0))),\n k = sin$1(d);\n\n var interpolate = d ? function(t) {\n var B = sin$1(t *= d) / k,\n A = sin$1(d - t) / k,\n x = A * kx0 + B * kx1,\n y = A * ky0 + B * ky1,\n z = A * sy0 + B * sy1;\n return [\n atan2(y, x) * degrees$1,\n atan2(z, sqrt$1(x * x + y * y)) * degrees$1\n ];\n } : function() {\n return [x0 * degrees$1, y0 * degrees$1];\n };\n\n interpolate.distance = d;\n\n return interpolate;\n }\n\n function identity$7(x) {\n return x;\n }\n\nvar areaSum$1 = adder();\nvar areaRingSum$1 = adder();\n var x00;\n var y00;\nvar x0$1;\nvar y0$1;\n var areaStream$1 = {\n point: noop$2,\n lineStart: noop$2,\n lineEnd: noop$2,\n polygonStart: function() {\n areaStream$1.lineStart = areaRingStart$1;\n areaStream$1.lineEnd = areaRingEnd$1;\n },\n polygonEnd: function() {\n areaStream$1.lineStart = areaStream$1.lineEnd = areaStream$1.point = noop$2;\n areaSum$1.add(abs(areaRingSum$1));\n areaRingSum$1.reset();\n },\n result: function() {\n var area = areaSum$1 / 2;\n areaSum$1.reset();\n return area;\n }\n };\n\n function areaRingStart$1() {\n areaStream$1.point = areaPointFirst$1;\n }\n\n function areaPointFirst$1(x, y) {\n areaStream$1.point = areaPoint$1;\n x00 = x0$1 = x, y00 = y0$1 = y;\n }\n\n function areaPoint$1(x, y) {\n areaRingSum$1.add(y0$1 * x - x0$1 * y);\n x0$1 = x, y0$1 = y;\n }\n\n function areaRingEnd$1() {\n areaPoint$1(x00, y00);\n }\n\nvar x0$2 = Infinity;\nvar y0$2 = x0$2;\n var x1 = -x0$2;\n var y1 = x1;\n var boundsStream$1 = {\n point: boundsPoint$1,\n lineStart: noop$2,\n lineEnd: noop$2,\n polygonStart: noop$2,\n polygonEnd: noop$2,\n result: function() {\n var bounds = [[x0$2, y0$2], [x1, y1]];\n x1 = y1 = -(y0$2 = x0$2 = Infinity);\n return bounds;\n }\n };\n\n function boundsPoint$1(x, y) {\n if (x < x0$2) x0$2 = x;\n if (x > x1) x1 = x;\n if (y < y0$2) y0$2 = y;\n if (y > y1) y1 = y;\n }\n\nvar X0$1 = 0;\nvar Y0$1 = 0;\nvar Z0$1 = 0;\nvar X1$1 = 0;\nvar Y1$1 = 0;\nvar Z1$1 = 0;\nvar X2$1 = 0;\nvar Y2$1 = 0;\nvar Z2$1 = 0;\nvar x00$1;\nvar y00$1;\nvar x0$3;\nvar y0$3;\n var centroidStream$1 = {\n point: centroidPoint$1,\n lineStart: centroidLineStart$1,\n lineEnd: centroidLineEnd$1,\n polygonStart: function() {\n centroidStream$1.lineStart = centroidRingStart$1;\n centroidStream$1.lineEnd = centroidRingEnd$1;\n },\n polygonEnd: function() {\n centroidStream$1.point = centroidPoint$1;\n centroidStream$1.lineStart = centroidLineStart$1;\n centroidStream$1.lineEnd = centroidLineEnd$1;\n },\n result: function() {\n var centroid = Z2$1 ? [X2$1 / Z2$1, Y2$1 / Z2$1]\n : Z1$1 ? [X1$1 / Z1$1, Y1$1 / Z1$1]\n : Z0$1 ? [X0$1 / Z0$1, Y0$1 / Z0$1]\n : [NaN, NaN];\n X0$1 = Y0$1 = Z0$1 =\n X1$1 = Y1$1 = Z1$1 =\n X2$1 = Y2$1 = Z2$1 = 0;\n return centroid;\n }\n };\n\n function centroidPoint$1(x, y) {\n X0$1 += x;\n Y0$1 += y;\n ++Z0$1;\n }\n\n function centroidLineStart$1() {\n centroidStream$1.point = centroidPointFirstLine;\n }\n\n function centroidPointFirstLine(x, y) {\n centroidStream$1.point = centroidPointLine;\n centroidPoint$1(x0$3 = x, y0$3 = y);\n }\n\n function centroidPointLine(x, y) {\n var dx = x - x0$3, dy = y - y0$3, z = sqrt$1(dx * dx + dy * dy);\n X1$1 += z * (x0$3 + x) / 2;\n Y1$1 += z * (y0$3 + y) / 2;\n Z1$1 += z;\n centroidPoint$1(x0$3 = x, y0$3 = y);\n }\n\n function centroidLineEnd$1() {\n centroidStream$1.point = centroidPoint$1;\n }\n\n function centroidRingStart$1() {\n centroidStream$1.point = centroidPointFirstRing;\n }\n\n function centroidRingEnd$1() {\n centroidPointRing(x00$1, y00$1);\n }\n\n function centroidPointFirstRing(x, y) {\n centroidStream$1.point = centroidPointRing;\n centroidPoint$1(x00$1 = x0$3 = x, y00$1 = y0$3 = y);\n }\n\n function centroidPointRing(x, y) {\n var dx = x - x0$3,\n dy = y - y0$3,\n z = sqrt$1(dx * dx + dy * dy);\n\n X1$1 += z * (x0$3 + x) / 2;\n Y1$1 += z * (y0$3 + y) / 2;\n Z1$1 += z;\n\n z = y0$3 * x - x0$3 * y;\n X2$1 += z * (x0$3 + x);\n Y2$1 += z * (y0$3 + y);\n Z2$1 += z * 3;\n centroidPoint$1(x0$3 = x, y0$3 = y);\n }\n\n function PathContext(context) {\n var pointRadius = 4.5;\n\n var stream = {\n point: point,\n\n // While inside a line, override point to moveTo then lineTo.\n lineStart: function() { stream.point = pointLineStart; },\n lineEnd: lineEnd,\n\n // While inside a polygon, override lineEnd to closePath.\n polygonStart: function() { stream.lineEnd = lineEndPolygon; },\n polygonEnd: function() { stream.lineEnd = lineEnd; stream.point = point; },\n\n pointRadius: function(_) {\n pointRadius = _;\n return stream;\n },\n\n result: noop$2\n };\n\n function point(x, y) {\n context.moveTo(x + pointRadius, y);\n context.arc(x, y, pointRadius, 0, tau$4);\n }\n\n function pointLineStart(x, y) {\n context.moveTo(x, y);\n stream.point = pointLine;\n }\n\n function pointLine(x, y) {\n context.lineTo(x, y);\n }\n\n function lineEnd() {\n stream.point = point;\n }\n\n function lineEndPolygon() {\n context.closePath();\n }\n\n return stream;\n }\n\n function PathString() {\n var pointCircle = circle$2(4.5),\n string = [];\n\n var stream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() {\n stream.lineEnd = lineEndPolygon;\n },\n polygonEnd: function() {\n stream.lineEnd = lineEnd;\n stream.point = point;\n },\n pointRadius: function(_) {\n pointCircle = circle$2(_);\n return stream;\n },\n result: function() {\n if (string.length) {\n var result = string.join(\"\");\n string = [];\n return result;\n }\n }\n };\n\n function point(x, y) {\n string.push(\"M\", x, \",\", y, pointCircle);\n }\n\n function pointLineStart(x, y) {\n string.push(\"M\", x, \",\", y);\n stream.point = pointLine;\n }\n\n function pointLine(x, y) {\n string.push(\"L\", x, \",\", y);\n }\n\n function lineStart() {\n stream.point = pointLineStart;\n }\n\n function lineEnd() {\n stream.point = point;\n }\n\n function lineEndPolygon() {\n string.push(\"Z\");\n }\n\n return stream;\n }\n\n function circle$2(radius) {\n return \"m0,\" + radius\n + \"a\" + radius + \",\" + radius + \" 0 1,1 0,\" + -2 * radius\n + \"a\" + radius + \",\" + radius + \" 0 1,1 0,\" + 2 * radius\n + \"z\";\n }\n\n function index$3() {\n var pointRadius = 4.5,\n projection,\n projectionStream,\n context,\n contextStream;\n\n function path(object) {\n if (object) {\n if (typeof pointRadius === \"function\") contextStream.pointRadius(+pointRadius.apply(this, arguments));\n stream(object, projectionStream(contextStream));\n }\n return contextStream.result();\n }\n\n path.area = function(object) {\n stream(object, projectionStream(areaStream$1));\n return areaStream$1.result();\n };\n\n path.bounds = function(object) {\n stream(object, projectionStream(boundsStream$1));\n return boundsStream$1.result();\n };\n\n path.centroid = function(object) {\n stream(object, projectionStream(centroidStream$1));\n return centroidStream$1.result();\n };\n\n path.projection = function(_) {\n return arguments.length ? (projectionStream = (projection = _) == null ? identity$7 : _.stream, path) : projection;\n };\n\n path.context = function(_) {\n if (!arguments.length) return context;\n contextStream = (context = _) == null ? new PathString : new PathContext(_);\n if (typeof pointRadius !== \"function\") contextStream.pointRadius(pointRadius);\n return path;\n };\n\n path.pointRadius = function(_) {\n if (!arguments.length) return pointRadius;\n pointRadius = typeof _ === \"function\" ? _ : (contextStream.pointRadius(+_), +_);\n return path;\n };\n\n return path.projection(null).context(null);\n }\n\n var sum$2 = adder();\n\n function polygonContains(polygon, point) {\n var lambda = point[0],\n phi = point[1],\n normal = [sin$1(lambda), -cos$1(lambda), 0],\n angle = 0,\n winding = 0;\n\n for (var i = 0, n = polygon.length; i < n; ++i) {\n if (!(m = (ring = polygon[i]).length)) continue;\n var ring,\n m,\n point0 = ring[m - 1],\n lambda0 = point0[0],\n phi0 = point0[1] / 2 + quarterPi,\n sinPhi0 = sin$1(phi0),\n cosPhi0 = cos$1(phi0);\n\n for (var j = 0; j < m; ++j, lambda0 = lambda1, sinPhi0 = sinPhi1, cosPhi0 = cosPhi1, point0 = point1) {\n var point1 = ring[j],\n lambda1 = point1[0],\n phi1 = point1[1] / 2 + quarterPi,\n sinPhi1 = sin$1(phi1),\n cosPhi1 = cos$1(phi1),\n delta = lambda1 - lambda0,\n sign = delta >= 0 ? 1 : -1,\n absDelta = sign * delta,\n antimeridian = absDelta > pi$4,\n k = sinPhi0 * sinPhi1;\n\n sum$2.add(atan2(k * sign * sin$1(absDelta), cosPhi0 * cosPhi1 + k * cos$1(absDelta)));\n angle += antimeridian ? delta + sign * tau$4 : delta;\n\n // Are the longitudes either side of the point’s meridian (lambda),\n // and are the latitudes smaller than the parallel (phi)?\n if (antimeridian ^ lambda0 >= lambda ^ lambda1 >= lambda) {\n var arc = cartesianCross(cartesian(point0), cartesian(point1));\n cartesianNormalizeInPlace(arc);\n var intersection = cartesianCross(normal, arc);\n cartesianNormalizeInPlace(intersection);\n var phiArc = (antimeridian ^ delta >= 0 ? -1 : 1) * asin$1(intersection[2]);\n if (phi > phiArc || phi === phiArc && (arc[0] || arc[1])) {\n winding += antimeridian ^ delta >= 0 ? 1 : -1;\n }\n }\n }\n }\n\n // First, determine whether the South pole is inside or outside:\n //\n // It is inside if:\n // * the polygon winds around it in a clockwise direction.\n // * the polygon does not (cumulatively) wind around it, but has a negative\n // (counter-clockwise) area.\n //\n // Second, count the (signed) number of times a segment crosses a lambda\n // from the point to the South pole. If it is zero, then the point is the\n // same side as the South pole.\n\n var contains = (angle < -epsilon$4 || angle < epsilon$4 && sum$2 < -epsilon$4) ^ (winding & 1);\n sum$2.reset();\n return contains;\n }\n\n function clip(pointVisible, clipLine, interpolate, start) {\n return function(rotate, sink) {\n var line = clipLine(sink),\n rotatedStart = rotate.invert(start[0], start[1]),\n ringBuffer = clipBuffer(),\n ringSink = clipLine(ringBuffer),\n polygonStarted = false,\n polygon,\n segments,\n ring;\n\n var clip = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() {\n clip.point = pointRing;\n clip.lineStart = ringStart;\n clip.lineEnd = ringEnd;\n segments = [];\n polygon = [];\n },\n polygonEnd: function() {\n clip.point = point;\n clip.lineStart = lineStart;\n clip.lineEnd = lineEnd;\n segments = merge(segments);\n var startInside = polygonContains(polygon, rotatedStart);\n if (segments.length) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n clipPolygon(segments, compareIntersection, startInside, interpolate, sink);\n } else if (startInside) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n sink.lineStart();\n interpolate(null, null, 1, sink);\n sink.lineEnd();\n }\n if (polygonStarted) sink.polygonEnd(), polygonStarted = false;\n segments = polygon = null;\n },\n sphere: function() {\n sink.polygonStart();\n sink.lineStart();\n interpolate(null, null, 1, sink);\n sink.lineEnd();\n sink.polygonEnd();\n }\n };\n\n function point(lambda, phi) {\n var point = rotate(lambda, phi);\n if (pointVisible(lambda = point[0], phi = point[1])) sink.point(lambda, phi);\n }\n\n function pointLine(lambda, phi) {\n var point = rotate(lambda, phi);\n line.point(point[0], point[1]);\n }\n\n function lineStart() {\n clip.point = pointLine;\n line.lineStart();\n }\n\n function lineEnd() {\n clip.point = point;\n line.lineEnd();\n }\n\n function pointRing(lambda, phi) {\n ring.push([lambda, phi]);\n var point = rotate(lambda, phi);\n ringSink.point(point[0], point[1]);\n }\n\n function ringStart() {\n ringSink.lineStart();\n ring = [];\n }\n\n function ringEnd() {\n pointRing(ring[0][0], ring[0][1]);\n ringSink.lineEnd();\n\n var clean = ringSink.clean(),\n ringSegments = ringBuffer.result(),\n i, n = ringSegments.length, m,\n segment,\n point;\n\n ring.pop();\n polygon.push(ring);\n ring = null;\n\n if (!n) return;\n\n // No intersections.\n if (clean & 1) {\n segment = ringSegments[0];\n if ((m = segment.length - 1) > 0) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n sink.lineStart();\n for (i = 0; i < m; ++i) sink.point((point = segment[i])[0], point[1]);\n sink.lineEnd();\n }\n return;\n }\n\n // Rejoin connected segments.\n // TODO reuse ringBuffer.rejoin()?\n if (n > 1 && clean & 2) ringSegments.push(ringSegments.pop().concat(ringSegments.shift()));\n\n segments.push(ringSegments.filter(validSegment));\n }\n\n return clip;\n };\n }\n\n function validSegment(segment) {\n return segment.length > 1;\n }\n\n // Intersections are sorted along the clip edge. For both antimeridian cutting\n // and circle clipping, the same comparison is used.\n function compareIntersection(a, b) {\n return ((a = a.x)[0] < 0 ? a[1] - halfPi$3 - epsilon$4 : halfPi$3 - a[1])\n - ((b = b.x)[0] < 0 ? b[1] - halfPi$3 - epsilon$4 : halfPi$3 - b[1]);\n }\n\n var clipAntimeridian = clip(\n function() { return true; },\n clipAntimeridianLine,\n clipAntimeridianInterpolate,\n [-pi$4, -halfPi$3]\n );\n\n // Takes a line and cuts into visible segments. Return values: 0 - there were\n // intersections or the line was empty; 1 - no intersections; 2 - there were\n // intersections, and the first and last segments should be rejoined.\n function clipAntimeridianLine(stream) {\n var lambda0 = NaN,\n phi0 = NaN,\n sign0 = NaN,\n clean; // no intersections\n\n return {\n lineStart: function() {\n stream.lineStart();\n clean = 1;\n },\n point: function(lambda1, phi1) {\n var sign1 = lambda1 > 0 ? pi$4 : -pi$4,\n delta = abs(lambda1 - lambda0);\n if (abs(delta - pi$4) < epsilon$4) { // line crosses a pole\n stream.point(lambda0, phi0 = (phi0 + phi1) / 2 > 0 ? halfPi$3 : -halfPi$3);\n stream.point(sign0, phi0);\n stream.lineEnd();\n stream.lineStart();\n stream.point(sign1, phi0);\n stream.point(lambda1, phi0);\n clean = 0;\n } else if (sign0 !== sign1 && delta >= pi$4) { // line crosses antimeridian\n if (abs(lambda0 - sign0) < epsilon$4) lambda0 -= sign0 * epsilon$4; // handle degeneracies\n if (abs(lambda1 - sign1) < epsilon$4) lambda1 -= sign1 * epsilon$4;\n phi0 = clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1);\n stream.point(sign0, phi0);\n stream.lineEnd();\n stream.lineStart();\n stream.point(sign1, phi0);\n clean = 0;\n }\n stream.point(lambda0 = lambda1, phi0 = phi1);\n sign0 = sign1;\n },\n lineEnd: function() {\n stream.lineEnd();\n lambda0 = phi0 = NaN;\n },\n clean: function() {\n return 2 - clean; // if intersections, rejoin first and last segments\n }\n };\n }\n\n function clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1) {\n var cosPhi0,\n cosPhi1,\n sinLambda0Lambda1 = sin$1(lambda0 - lambda1);\n return abs(sinLambda0Lambda1) > epsilon$4\n ? atan((sin$1(phi0) * (cosPhi1 = cos$1(phi1)) * sin$1(lambda1)\n - sin$1(phi1) * (cosPhi0 = cos$1(phi0)) * sin$1(lambda0))\n / (cosPhi0 * cosPhi1 * sinLambda0Lambda1))\n : (phi0 + phi1) / 2;\n }\n\n function clipAntimeridianInterpolate(from, to, direction, stream) {\n var phi;\n if (from == null) {\n phi = direction * halfPi$3;\n stream.point(-pi$4, phi);\n stream.point(0, phi);\n stream.point(pi$4, phi);\n stream.point(pi$4, 0);\n stream.point(pi$4, -phi);\n stream.point(0, -phi);\n stream.point(-pi$4, -phi);\n stream.point(-pi$4, 0);\n stream.point(-pi$4, phi);\n } else if (abs(from[0] - to[0]) > epsilon$4) {\n var lambda = from[0] < to[0] ? pi$4 : -pi$4;\n phi = direction * lambda / 2;\n stream.point(-lambda, phi);\n stream.point(0, phi);\n stream.point(lambda, phi);\n } else {\n stream.point(to[0], to[1]);\n }\n }\n\n function clipCircle(radius, delta) {\n var cr = cos$1(radius),\n smallRadius = cr > 0,\n notHemisphere = abs(cr) > epsilon$4; // TODO optimise for this common case\n\n function interpolate(from, to, direction, stream) {\n circleStream(stream, radius, delta, direction, from, to);\n }\n\n function visible(lambda, phi) {\n return cos$1(lambda) * cos$1(phi) > cr;\n }\n\n // Takes a line and cuts into visible segments. Return values used for polygon\n // clipping: 0 - there were intersections or the line was empty; 1 - no\n // intersections 2 - there were intersections, and the first and last segments\n // should be rejoined.\n function clipLine(stream) {\n var point0, // previous point\n c0, // code for previous point\n v0, // visibility of previous point\n v00, // visibility of first point\n clean; // no intersections\n return {\n lineStart: function() {\n v00 = v0 = false;\n clean = 1;\n },\n point: function(lambda, phi) {\n var point1 = [lambda, phi],\n point2,\n v = visible(lambda, phi),\n c = smallRadius\n ? v ? 0 : code(lambda, phi)\n : v ? code(lambda + (lambda < 0 ? pi$4 : -pi$4), phi) : 0;\n if (!point0 && (v00 = v0 = v)) stream.lineStart();\n // Handle degeneracies.\n // TODO ignore if not clipping polygons.\n if (v !== v0) {\n point2 = intersect(point0, point1);\n if (pointEqual(point0, point2) || pointEqual(point1, point2)) {\n point1[0] += epsilon$4;\n point1[1] += epsilon$4;\n v = visible(point1[0], point1[1]);\n }\n }\n if (v !== v0) {\n clean = 0;\n if (v) {\n // outside going in\n stream.lineStart();\n point2 = intersect(point1, point0);\n stream.point(point2[0], point2[1]);\n } else {\n // inside going out\n point2 = intersect(point0, point1);\n stream.point(point2[0], point2[1]);\n stream.lineEnd();\n }\n point0 = point2;\n } else if (notHemisphere && point0 && smallRadius ^ v) {\n var t;\n // If the codes for two points are different, or are both zero,\n // and there this segment intersects with the small circle.\n if (!(c & c0) && (t = intersect(point1, point0, true))) {\n clean = 0;\n if (smallRadius) {\n stream.lineStart();\n stream.point(t[0][0], t[0][1]);\n stream.point(t[1][0], t[1][1]);\n stream.lineEnd();\n } else {\n stream.point(t[1][0], t[1][1]);\n stream.lineEnd();\n stream.lineStart();\n stream.point(t[0][0], t[0][1]);\n }\n }\n }\n if (v && (!point0 || !pointEqual(point0, point1))) {\n stream.point(point1[0], point1[1]);\n }\n point0 = point1, v0 = v, c0 = c;\n },\n lineEnd: function() {\n if (v0) stream.lineEnd();\n point0 = null;\n },\n // Rejoin first and last segments if there were intersections and the first\n // and last points were visible.\n clean: function() {\n return clean | ((v00 && v0) << 1);\n }\n };\n }\n\n // Intersects the great circle between a and b with the clip circle.\n function intersect(a, b, two) {\n var pa = cartesian(a),\n pb = cartesian(b);\n\n // We have two planes, n1.p = d1 and n2.p = d2.\n // Find intersection line p(t) = c1 n1 + c2 n2 + t (n1 ⨯ n2).\n var n1 = [1, 0, 0], // normal\n n2 = cartesianCross(pa, pb),\n n2n2 = cartesianDot(n2, n2),\n n1n2 = n2[0], // cartesianDot(n1, n2),\n determinant = n2n2 - n1n2 * n1n2;\n\n // Two polar points.\n if (!determinant) return !two && a;\n\n var c1 = cr * n2n2 / determinant,\n c2 = -cr * n1n2 / determinant,\n n1xn2 = cartesianCross(n1, n2),\n A = cartesianScale(n1, c1),\n B = cartesianScale(n2, c2);\n cartesianAddInPlace(A, B);\n\n // Solve |p(t)|^2 = 1.\n var u = n1xn2,\n w = cartesianDot(A, u),\n uu = cartesianDot(u, u),\n t2 = w * w - uu * (cartesianDot(A, A) - 1);\n\n if (t2 < 0) return;\n\n var t = sqrt$1(t2),\n q = cartesianScale(u, (-w - t) / uu);\n cartesianAddInPlace(q, A);\n q = spherical(q);\n\n if (!two) return q;\n\n // Two intersection points.\n var lambda0 = a[0],\n lambda1 = b[0],\n phi0 = a[1],\n phi1 = b[1],\n z;\n\n if (lambda1 < lambda0) z = lambda0, lambda0 = lambda1, lambda1 = z;\n\n var delta = lambda1 - lambda0,\n polar = abs(delta - pi$4) < epsilon$4,\n meridian = polar || delta < epsilon$4;\n\n if (!polar && phi1 < phi0) z = phi0, phi0 = phi1, phi1 = z;\n\n // Check that the first point is between a and b.\n if (meridian\n ? polar\n ? phi0 + phi1 > 0 ^ q[1] < (abs(q[0] - lambda0) < epsilon$4 ? phi0 : phi1)\n : phi0 <= q[1] && q[1] <= phi1\n : delta > pi$4 ^ (lambda0 <= q[0] && q[0] <= lambda1)) {\n var q1 = cartesianScale(u, (-w + t) / uu);\n cartesianAddInPlace(q1, A);\n return [q, spherical(q1)];\n }\n }\n\n // Generates a 4-bit vector representing the location of a point relative to\n // the small circle's bounding box.\n function code(lambda, phi) {\n var r = smallRadius ? radius : pi$4 - radius,\n code = 0;\n if (lambda < -r) code |= 1; // left\n else if (lambda > r) code |= 2; // right\n if (phi < -r) code |= 4; // below\n else if (phi > r) code |= 8; // above\n return code;\n }\n\n return clip(visible, clipLine, interpolate, smallRadius ? [0, -radius] : [-pi$4, radius - pi$4]);\n }\n\n function transform$1(prototype) {\n return {\n stream: transform$2(prototype)\n };\n }\n\n function transform$2(prototype) {\n function T() {}\n var p = T.prototype = Object.create(Transform$1.prototype);\n for (var k in prototype) p[k] = prototype[k];\n return function(stream) {\n var t = new T;\n t.stream = stream;\n return t;\n };\n }\n\n function Transform$1() {}\n\n Transform$1.prototype = {\n point: function(x, y) { this.stream.point(x, y); },\n sphere: function() { this.stream.sphere(); },\n lineStart: function() { this.stream.lineStart(); },\n lineEnd: function() { this.stream.lineEnd(); },\n polygonStart: function() { this.stream.polygonStart(); },\n polygonEnd: function() { this.stream.polygonEnd(); }\n };\n\n var maxDepth = 16;\n var cosMinDistance = cos$1(30 * radians);\n // cos(minimum angular distance)\n\n function resample(project, delta2) {\n return +delta2 ? resample$1(project, delta2) : resampleNone(project);\n }\n\n function resampleNone(project) {\n return transform$2({\n point: function(x, y) {\n x = project(x, y);\n this.stream.point(x[0], x[1]);\n }\n });\n }\n\n function resample$1(project, delta2) {\n\n function resampleLineTo(x0, y0, lambda0, a0, b0, c0, x1, y1, lambda1, a1, b1, c1, depth, stream) {\n var dx = x1 - x0,\n dy = y1 - y0,\n d2 = dx * dx + dy * dy;\n if (d2 > 4 * delta2 && depth--) {\n var a = a0 + a1,\n b = b0 + b1,\n c = c0 + c1,\n m = sqrt$1(a * a + b * b + c * c),\n phi2 = asin$1(c /= m),\n lambda2 = abs(abs(c) - 1) < epsilon$4 || abs(lambda0 - lambda1) < epsilon$4 ? (lambda0 + lambda1) / 2 : atan2(b, a),\n p = project(lambda2, phi2),\n x2 = p[0],\n y2 = p[1],\n dx2 = x2 - x0,\n dy2 = y2 - y0,\n dz = dy * dx2 - dx * dy2;\n if (dz * dz / d2 > delta2 // perpendicular projected distance\n || abs((dx * dx2 + dy * dy2) / d2 - 0.5) > 0.3 // midpoint close to an end\n || a0 * a1 + b0 * b1 + c0 * c1 < cosMinDistance) { // angular distance\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x2, y2, lambda2, a /= m, b /= m, c, depth, stream);\n stream.point(x2, y2);\n resampleLineTo(x2, y2, lambda2, a, b, c, x1, y1, lambda1, a1, b1, c1, depth, stream);\n }\n }\n }\n return function(stream) {\n var lambda00, x00, y00, a00, b00, c00, // first point\n lambda0, x0, y0, a0, b0, c0; // previous point\n\n var resampleStream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() { stream.polygonStart(); resampleStream.lineStart = ringStart; },\n polygonEnd: function() { stream.polygonEnd(); resampleStream.lineStart = lineStart; }\n };\n\n function point(x, y) {\n x = project(x, y);\n stream.point(x[0], x[1]);\n }\n\n function lineStart() {\n x0 = NaN;\n resampleStream.point = linePoint;\n stream.lineStart();\n }\n\n function linePoint(lambda, phi) {\n var c = cartesian([lambda, phi]), p = project(lambda, phi);\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x0 = p[0], y0 = p[1], lambda0 = lambda, a0 = c[0], b0 = c[1], c0 = c[2], maxDepth, stream);\n stream.point(x0, y0);\n }\n\n function lineEnd() {\n resampleStream.point = point;\n stream.lineEnd();\n }\n\n function ringStart() {\n lineStart();\n resampleStream.point = ringPoint;\n resampleStream.lineEnd = ringEnd;\n }\n\n function ringPoint(lambda, phi) {\n linePoint(lambda00 = lambda, phi), x00 = x0, y00 = y0, a00 = a0, b00 = b0, c00 = c0;\n resampleStream.point = linePoint;\n }\n\n function ringEnd() {\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x00, y00, lambda00, a00, b00, c00, maxDepth, stream);\n resampleStream.lineEnd = lineEnd;\n lineEnd();\n }\n\n return resampleStream;\n };\n }\n\n var transformRadians = transform$2({\n point: function(x, y) {\n this.stream.point(x * radians, y * radians);\n }\n });\n\n function projection(project) {\n return projectionMutator(function() { return project; })();\n }\n\n function projectionMutator(projectAt) {\n var project,\n k = 150, // scale\n x = 480, y = 250, // translate\n dx, dy, lambda = 0, phi = 0, // center\n deltaLambda = 0, deltaPhi = 0, deltaGamma = 0, rotate, projectRotate, // rotate\n theta = null, preclip = clipAntimeridian, // clip angle\n x0 = null, y0, x1, y1, postclip = identity$7, // clip extent\n delta2 = 0.5, projectResample = resample(projectTransform, delta2), // precision\n cache,\n cacheStream;\n\n function projection(point) {\n point = projectRotate(point[0] * radians, point[1] * radians);\n return [point[0] * k + dx, dy - point[1] * k];\n }\n\n function invert(point) {\n point = projectRotate.invert((point[0] - dx) / k, (dy - point[1]) / k);\n return point && [point[0] * degrees$1, point[1] * degrees$1];\n }\n\n function projectTransform(x, y) {\n return x = project(x, y), [x[0] * k + dx, dy - x[1] * k];\n }\n\n projection.stream = function(stream) {\n return cache && cacheStream === stream ? cache : cache = transformRadians(preclip(rotate, projectResample(postclip(cacheStream = stream))));\n };\n\n projection.clipAngle = function(_) {\n return arguments.length ? (preclip = +_ ? clipCircle(theta = _ * radians, 6 * radians) : (theta = null, clipAntimeridian), reset()) : theta * degrees$1;\n };\n\n projection.clipExtent = function(_) {\n return arguments.length ? (postclip = _ == null ? (x0 = y0 = x1 = y1 = null, identity$7) : clipExtent(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n };\n\n projection.scale = function(_) {\n return arguments.length ? (k = +_, recenter()) : k;\n };\n\n projection.translate = function(_) {\n return arguments.length ? (x = +_[0], y = +_[1], recenter()) : [x, y];\n };\n\n projection.center = function(_) {\n return arguments.length ? (lambda = _[0] % 360 * radians, phi = _[1] % 360 * radians, recenter()) : [lambda * degrees$1, phi * degrees$1];\n };\n\n projection.rotate = function(_) {\n return arguments.length ? (deltaLambda = _[0] % 360 * radians, deltaPhi = _[1] % 360 * radians, deltaGamma = _.length > 2 ? _[2] % 360 * radians : 0, recenter()) : [deltaLambda * degrees$1, deltaPhi * degrees$1, deltaGamma * degrees$1];\n };\n\n projection.precision = function(_) {\n return arguments.length ? (projectResample = resample(projectTransform, delta2 = _ * _), reset()) : sqrt$1(delta2);\n };\n\n function recenter() {\n projectRotate = compose(rotate = rotateRadians(deltaLambda, deltaPhi, deltaGamma), project);\n var center = project(lambda, phi);\n dx = x - center[0] * k;\n dy = y + center[1] * k;\n return reset();\n }\n\n function reset() {\n cache = cacheStream = null;\n return projection;\n }\n\n return function() {\n project = projectAt.apply(this, arguments);\n projection.invert = project.invert && invert;\n return recenter();\n };\n }\n\n function conicProjection(projectAt) {\n var phi0 = 0,\n phi1 = pi$4 / 3,\n m = projectionMutator(projectAt),\n p = m(phi0, phi1);\n\n p.parallels = function(_) {\n return arguments.length ? m(phi0 = _[0] * radians, phi1 = _[1] * radians) : [phi0 * degrees$1, phi1 * degrees$1];\n };\n\n return p;\n }\n\n function conicEqualAreaRaw(y0, y1) {\n var sy0 = sin$1(y0),\n n = (sy0 + sin$1(y1)) / 2,\n c = 1 + sy0 * (2 * n - sy0),\n r0 = sqrt$1(c) / n;\n\n function project(x, y) {\n var r = sqrt$1(c - 2 * n * sin$1(y)) / n;\n return [r * sin$1(x *= n), r0 - r * cos$1(x)];\n }\n\n project.invert = function(x, y) {\n var r0y = r0 - y;\n return [atan2(x, r0y) / n, asin$1((c - (x * x + r0y * r0y) * n * n) / (2 * n))];\n };\n\n return project;\n }\n\n function conicEqualArea() {\n return conicProjection(conicEqualAreaRaw)\n .scale(155.424)\n .center([0, 33.6442]);\n }\n\n function albers() {\n return conicEqualArea()\n .parallels([29.5, 45.5])\n .scale(1070)\n .translate([480, 250])\n .rotate([96, 0])\n .center([-0.6, 38.7]);\n }\n\n // The projections must have mutually exclusive clip regions on the sphere,\n // as this will avoid emitting interleaving lines and polygons.\n function multiplex(streams) {\n var n = streams.length;\n return {\n point: function(x, y) { var i = -1; while (++i < n) streams[i].point(x, y); },\n sphere: function() { var i = -1; while (++i < n) streams[i].sphere(); },\n lineStart: function() { var i = -1; while (++i < n) streams[i].lineStart(); },\n lineEnd: function() { var i = -1; while (++i < n) streams[i].lineEnd(); },\n polygonStart: function() { var i = -1; while (++i < n) streams[i].polygonStart(); },\n polygonEnd: function() { var i = -1; while (++i < n) streams[i].polygonEnd(); }\n };\n }\n\n // A composite projection for the United States, configured by default for\n // 960×500. The projection also works quite well at 960×600 if you change the\n // scale to 1285 and adjust the translate accordingly. The set of standard\n // parallels for each region comes from USGS, which is published here:\n // http://egsc.usgs.gov/isb/pubs/MapProjections/projections.html#albers\n function albersUsa() {\n var cache,\n cacheStream,\n lower48 = albers(), lower48Point,\n alaska = conicEqualArea().rotate([154, 0]).center([-2, 58.5]).parallels([55, 65]), alaskaPoint, // EPSG:3338\n hawaii = conicEqualArea().rotate([157, 0]).center([-3, 19.9]).parallels([8, 18]), hawaiiPoint, // ESRI:102007\n point, pointStream = {point: function(x, y) { point = [x, y]; }};\n\n function albersUsa(coordinates) {\n var x = coordinates[0], y = coordinates[1];\n return point = null,\n (lower48Point.point(x, y), point)\n || (alaskaPoint.point(x, y), point)\n || (hawaiiPoint.point(x, y), point);\n }\n\n albersUsa.invert = function(coordinates) {\n var k = lower48.scale(),\n t = lower48.translate(),\n x = (coordinates[0] - t[0]) / k,\n y = (coordinates[1] - t[1]) / k;\n return (y >= 0.120 && y < 0.234 && x >= -0.425 && x < -0.214 ? alaska\n : y >= 0.166 && y < 0.234 && x >= -0.214 && x < -0.115 ? hawaii\n : lower48).invert(coordinates);\n };\n\n albersUsa.stream = function(stream) {\n return cache && cacheStream === stream ? cache : cache = multiplex([lower48.stream(cacheStream = stream), alaska.stream(stream), hawaii.stream(stream)]);\n };\n\n albersUsa.precision = function(_) {\n if (!arguments.length) return lower48.precision();\n lower48.precision(_), alaska.precision(_), hawaii.precision(_);\n return albersUsa;\n };\n\n albersUsa.scale = function(_) {\n if (!arguments.length) return lower48.scale();\n lower48.scale(_), alaska.scale(_ * 0.35), hawaii.scale(_);\n return albersUsa.translate(lower48.translate());\n };\n\n albersUsa.translate = function(_) {\n if (!arguments.length) return lower48.translate();\n var k = lower48.scale(), x = +_[0], y = +_[1];\n\n lower48Point = lower48\n .translate(_)\n .clipExtent([[x - 0.455 * k, y - 0.238 * k], [x + 0.455 * k, y + 0.238 * k]])\n .stream(pointStream);\n\n alaskaPoint = alaska\n .translate([x - 0.307 * k, y + 0.201 * k])\n .clipExtent([[x - 0.425 * k + epsilon$4, y + 0.120 * k + epsilon$4], [x - 0.214 * k - epsilon$4, y + 0.234 * k - epsilon$4]])\n .stream(pointStream);\n\n hawaiiPoint = hawaii\n .translate([x - 0.205 * k, y + 0.212 * k])\n .clipExtent([[x - 0.214 * k + epsilon$4, y + 0.166 * k + epsilon$4], [x - 0.115 * k - epsilon$4, y + 0.234 * k - epsilon$4]])\n .stream(pointStream);\n\n return albersUsa;\n };\n\n return albersUsa.scale(1070);\n }\n\n function azimuthalRaw(scale) {\n return function(x, y) {\n var cx = cos$1(x),\n cy = cos$1(y),\n k = scale(cx * cy);\n return [\n k * cy * sin$1(x),\n k * sin$1(y)\n ];\n }\n }\n\n function azimuthalInvert(angle) {\n return function(x, y) {\n var z = sqrt$1(x * x + y * y),\n c = angle(z),\n sc = sin$1(c),\n cc = cos$1(c);\n return [\n atan2(x * sc, z * cc),\n asin$1(z && y * sc / z)\n ];\n }\n }\n\n var azimuthalEqualAreaRaw = azimuthalRaw(function(cxcy) {\n return sqrt$1(2 / (1 + cxcy));\n });\n\n azimuthalEqualAreaRaw.invert = azimuthalInvert(function(z) {\n return 2 * asin$1(z / 2);\n });\n\n function azimuthalEqualArea() {\n return projection(azimuthalEqualAreaRaw)\n .scale(124.75)\n .clipAngle(180 - 1e-3);\n }\n\n var azimuthalEquidistantRaw = azimuthalRaw(function(c) {\n return (c = acos(c)) && c / sin$1(c);\n });\n\n azimuthalEquidistantRaw.invert = azimuthalInvert(function(z) {\n return z;\n });\n\n function azimuthalEquidistant() {\n return projection(azimuthalEquidistantRaw)\n .scale(79.4188)\n .clipAngle(180 - 1e-3);\n }\n\n function mercatorRaw(lambda, phi) {\n return [lambda, log$1(tan((halfPi$3 + phi) / 2))];\n }\n\n mercatorRaw.invert = function(x, y) {\n return [x, 2 * atan(exp(y)) - halfPi$3];\n };\n\n function mercator() {\n return mercatorProjection(mercatorRaw)\n .scale(961 / tau$4);\n }\n\n function mercatorProjection(project) {\n var m = projection(project),\n scale = m.scale,\n translate = m.translate,\n clipExtent = m.clipExtent,\n clipAuto;\n\n m.scale = function(_) {\n return arguments.length ? (scale(_), clipAuto && m.clipExtent(null), m) : scale();\n };\n\n m.translate = function(_) {\n return arguments.length ? (translate(_), clipAuto && m.clipExtent(null), m) : translate();\n };\n\n m.clipExtent = function(_) {\n if (!arguments.length) return clipAuto ? null : clipExtent();\n if (clipAuto = _ == null) {\n var k = pi$4 * scale(),\n t = translate();\n _ = [[t[0] - k, t[1] - k], [t[0] + k, t[1] + k]];\n }\n clipExtent(_);\n return m;\n };\n\n return m.clipExtent(null);\n }\n\n function tany(y) {\n return tan((halfPi$3 + y) / 2);\n }\n\n function conicConformalRaw(y0, y1) {\n var cy0 = cos$1(y0),\n n = y0 === y1 ? sin$1(y0) : log$1(cy0 / cos$1(y1)) / log$1(tany(y1) / tany(y0)),\n f = cy0 * pow$1(tany(y0), n) / n;\n\n if (!n) return mercatorRaw;\n\n function project(x, y) {\n if (f > 0) { if (y < -halfPi$3 + epsilon$4) y = -halfPi$3 + epsilon$4; }\n else { if (y > halfPi$3 - epsilon$4) y = halfPi$3 - epsilon$4; }\n var r = f / pow$1(tany(y), n);\n return [r * sin$1(n * x), f - r * cos$1(n * x)];\n }\n\n project.invert = function(x, y) {\n var fy = f - y, r = sign$1(n) * sqrt$1(x * x + fy * fy);\n return [atan2(x, fy) / n, 2 * atan(pow$1(f / r, 1 / n)) - halfPi$3];\n };\n\n return project;\n }\n\n function conicConformal() {\n return conicProjection(conicConformalRaw)\n .scale(109.5)\n .parallels([30, 30]);\n }\n\n function equirectangularRaw(lambda, phi) {\n return [lambda, phi];\n }\n\n equirectangularRaw.invert = equirectangularRaw;\n\n function equirectangular() {\n return projection(equirectangularRaw)\n .scale(152.63);\n }\n\n function conicEquidistantRaw(y0, y1) {\n var cy0 = cos$1(y0),\n n = y0 === y1 ? sin$1(y0) : (cy0 - cos$1(y1)) / (y1 - y0),\n g = cy0 / n + y0;\n\n if (abs(n) < epsilon$4) return equirectangularRaw;\n\n function project(x, y) {\n var gy = g - y, nx = n * x;\n return [gy * sin$1(nx), g - gy * cos$1(nx)];\n }\n\n project.invert = function(x, y) {\n var gy = g - y;\n return [atan2(x, gy) / n, g - sign$1(n) * sqrt$1(x * x + gy * gy)];\n };\n\n return project;\n }\n\n function conicEquidistant() {\n return conicProjection(conicEquidistantRaw)\n .scale(131.154)\n .center([0, 13.9389]);\n }\n\n function gnomonicRaw(x, y) {\n var cy = cos$1(y), k = cos$1(x) * cy;\n return [cy * sin$1(x) / k, sin$1(y) / k];\n }\n\n gnomonicRaw.invert = azimuthalInvert(atan);\n\n function gnomonic() {\n return projection(gnomonicRaw)\n .scale(144.049)\n .clipAngle(60);\n }\n\n function orthographicRaw(x, y) {\n return [cos$1(y) * sin$1(x), sin$1(y)];\n }\n\n orthographicRaw.invert = azimuthalInvert(asin$1);\n\n function orthographic() {\n return projection(orthographicRaw)\n .scale(249.5)\n .clipAngle(90 + epsilon$4);\n }\n\n function stereographicRaw(x, y) {\n var cy = cos$1(y), k = 1 + cos$1(x) * cy;\n return [cy * sin$1(x) / k, sin$1(y) / k];\n }\n\n stereographicRaw.invert = azimuthalInvert(function(z) {\n return 2 + atan(z);\n });\n\n function stereographic() {\n return projection(stereographicRaw)\n .scale(250)\n .clipAngle(142);\n }\n\n function transverseMercatorRaw(lambda, phi) {\n return [log$1(tan((halfPi$3 + phi) / 2)), -lambda];\n }\n\n transverseMercatorRaw.invert = function(x, y) {\n return [-y, 2 * atan(exp(x)) - halfPi$3];\n };\n\n function transverseMercator() {\n var m = mercatorProjection(transverseMercatorRaw),\n center = m.center,\n rotate = m.rotate;\n\n m.center = function(_) {\n return arguments.length ? center([-_[1], _[0]]) : (_ = center(), [_[1], -_[0]]);\n };\n\n m.rotate = function(_) {\n return arguments.length ? rotate([_[0], _[1], _.length > 2 ? _[2] + 90 : 90]) : (_ = rotate(), [_[0], _[1], _[2] - 90]);\n };\n\n return rotate([0, 0, 90])\n .scale(159.155);\n }\n\n exports.version = version;\n exports.bisect = bisectRight;\n exports.bisectRight = bisectRight;\n exports.bisectLeft = bisectLeft;\n exports.ascending = ascending;\n exports.bisector = bisector;\n exports.descending = descending;\n exports.deviation = deviation;\n exports.extent = extent;\n exports.histogram = histogram;\n exports.thresholdFreedmanDiaconis = freedmanDiaconis;\n exports.thresholdScott = scott;\n exports.thresholdSturges = sturges;\n exports.max = max;\n exports.mean = mean;\n exports.median = median;\n exports.merge = merge;\n exports.min = min;\n exports.pairs = pairs;\n exports.permute = permute;\n exports.quantile = threshold;\n exports.range = range;\n exports.scan = scan;\n exports.shuffle = shuffle;\n exports.sum = sum;\n exports.ticks = ticks;\n exports.tickStep = tickStep;\n exports.transpose = transpose;\n exports.variance = variance;\n exports.zip = zip;\n exports.entries = entries;\n exports.keys = keys;\n exports.values = values;\n exports.map = map$1;\n exports.set = set;\n exports.nest = nest;\n exports.randomUniform = uniform;\n exports.randomNormal = normal;\n exports.randomLogNormal = logNormal;\n exports.randomBates = bates;\n exports.randomIrwinHall = irwinHall;\n exports.randomExponential = exponential;\n exports.easeLinear = linear;\n exports.easeQuad = quadInOut;\n exports.easeQuadIn = quadIn;\n exports.easeQuadOut = quadOut;\n exports.easeQuadInOut = quadInOut;\n exports.easeCubic = easeCubicInOut;\n exports.easeCubicIn = cubicIn;\n exports.easeCubicOut = cubicOut;\n exports.easeCubicInOut = easeCubicInOut;\n exports.easePoly = polyInOut;\n exports.easePolyIn = polyIn;\n exports.easePolyOut = polyOut;\n exports.easePolyInOut = polyInOut;\n exports.easeSin = sinInOut;\n exports.easeSinIn = sinIn;\n exports.easeSinOut = sinOut;\n exports.easeSinInOut = sinInOut;\n exports.easeExp = expInOut;\n exports.easeExpIn = expIn;\n exports.easeExpOut = expOut;\n exports.easeExpInOut = expInOut;\n exports.easeCircle = circleInOut;\n exports.easeCircleIn = circleIn;\n exports.easeCircleOut = circleOut;\n exports.easeCircleInOut = circleInOut;\n exports.easeBounce = bounceOut;\n exports.easeBounceIn = bounceIn;\n exports.easeBounceOut = bounceOut;\n exports.easeBounceInOut = bounceInOut;\n exports.easeBack = backInOut;\n exports.easeBackIn = backIn;\n exports.easeBackOut = backOut;\n exports.easeBackInOut = backInOut;\n exports.easeElastic = elasticOut;\n exports.easeElasticIn = elasticIn;\n exports.easeElasticOut = elasticOut;\n exports.easeElasticInOut = elasticInOut;\n exports.polygonArea = area;\n exports.polygonCentroid = centroid;\n exports.polygonHull = hull;\n exports.polygonContains = contains;\n exports.polygonLength = length$1;\n exports.path = path;\n exports.quadtree = quadtree;\n exports.queue = queue;\n exports.arc = arc;\n exports.area = area$1;\n exports.line = line;\n exports.pie = pie;\n exports.radialArea = radialArea;\n exports.radialLine = radialLine$1;\n exports.symbol = symbol;\n exports.symbols = symbols;\n exports.symbolCircle = circle;\n exports.symbolCross = cross$1;\n exports.symbolDiamond = diamond;\n exports.symbolSquare = square;\n exports.symbolStar = star;\n exports.symbolTriangle = triangle;\n exports.symbolWye = wye;\n exports.curveBasisClosed = basisClosed;\n exports.curveBasisOpen = basisOpen;\n exports.curveBasis = basis;\n exports.curveBundle = bundle;\n exports.curveCardinalClosed = cardinalClosed;\n exports.curveCardinalOpen = cardinalOpen;\n exports.curveCardinal = cardinal;\n exports.curveCatmullRomClosed = catmullRomClosed;\n exports.curveCatmullRomOpen = catmullRomOpen;\n exports.curveCatmullRom = catmullRom;\n exports.curveLinearClosed = linearClosed;\n exports.curveLinear = curveLinear;\n exports.curveMonotoneX = monotoneX;\n exports.curveMonotoneY = monotoneY;\n exports.curveNatural = natural;\n exports.curveStep = step;\n exports.curveStepAfter = stepAfter;\n exports.curveStepBefore = stepBefore;\n exports.stack = stack;\n exports.stackOffsetExpand = expand;\n exports.stackOffsetNone = none;\n exports.stackOffsetSilhouette = silhouette;\n exports.stackOffsetWiggle = wiggle;\n exports.stackOrderAscending = ascending$1;\n exports.stackOrderDescending = descending$2;\n exports.stackOrderInsideOut = insideOut;\n exports.stackOrderNone = none$1;\n exports.stackOrderReverse = reverse;\n exports.color = color;\n exports.rgb = colorRgb;\n exports.hsl = colorHsl;\n exports.lab = lab;\n exports.hcl = colorHcl;\n exports.cubehelix = cubehelix;\n exports.interpolate = interpolate;\n exports.interpolateArray = array$1;\n exports.interpolateDate = date;\n exports.interpolateNumber = interpolateNumber;\n exports.interpolateObject = object;\n exports.interpolateRound = interpolateRound;\n exports.interpolateString = interpolateString;\n exports.interpolateTransformCss = interpolateTransform$1;\n exports.interpolateTransformSvg = interpolateTransform$2;\n exports.interpolateZoom = interpolateZoom;\n exports.interpolateRgb = interpolateRgb;\n exports.interpolateRgbBasis = rgbBasis;\n exports.interpolateRgbBasisClosed = rgbBasisClosed;\n exports.interpolateHsl = hsl$1;\n exports.interpolateHslLong = hslLong;\n exports.interpolateLab = lab$1;\n exports.interpolateHcl = hcl$1;\n exports.interpolateHclLong = hclLong;\n exports.interpolateCubehelix = cubehelix$2;\n exports.interpolateCubehelixLong = interpolateCubehelixLong;\n exports.interpolateBasis = basis$2;\n exports.interpolateBasisClosed = basisClosed$1;\n exports.quantize = quantize;\n exports.dispatch = dispatch;\n exports.dsvFormat = dsv;\n exports.csvParse = csvParse;\n exports.csvParseRows = csvParseRows;\n exports.csvFormat = csvFormat;\n exports.csvFormatRows = csvFormatRows;\n exports.tsvParse = tsvParse;\n exports.tsvParseRows = tsvParseRows;\n exports.tsvFormat = tsvFormat;\n exports.tsvFormatRows = tsvFormatRows;\n exports.request = request;\n exports.html = html;\n exports.json = json;\n exports.text = text;\n exports.xml = xml;\n exports.csv = csv$1;\n exports.tsv = tsv$1;\n exports.now = now;\n exports.timer = timer;\n exports.timerFlush = timerFlush;\n exports.timeout = timeout$1;\n exports.interval = interval$1;\n exports.timeInterval = newInterval;\n exports.timeMillisecond = millisecond;\n exports.timeMilliseconds = milliseconds;\n exports.timeSecond = second;\n exports.timeSeconds = seconds;\n exports.timeMinute = minute;\n exports.timeMinutes = minutes;\n exports.timeHour = hour;\n exports.timeHours = hours;\n exports.timeDay = day;\n exports.timeDays = days;\n exports.timeWeek = timeWeek;\n exports.timeWeeks = sundays;\n exports.timeSunday = timeWeek;\n exports.timeSundays = sundays;\n exports.timeMonday = timeMonday;\n exports.timeMondays = mondays;\n exports.timeTuesday = tuesday;\n exports.timeTuesdays = tuesdays;\n exports.timeWednesday = wednesday;\n exports.timeWednesdays = wednesdays;\n exports.timeThursday = thursday;\n exports.timeThursdays = thursdays;\n exports.timeFriday = friday;\n exports.timeFridays = fridays;\n exports.timeSaturday = saturday;\n exports.timeSaturdays = saturdays;\n exports.timeMonth = month;\n exports.timeMonths = months;\n exports.timeYear = year;\n exports.timeYears = years;\n exports.utcMillisecond = millisecond;\n exports.utcMilliseconds = milliseconds;\n exports.utcSecond = second;\n exports.utcSeconds = seconds;\n exports.utcMinute = utcMinute;\n exports.utcMinutes = utcMinutes;\n exports.utcHour = utcHour;\n exports.utcHours = utcHours;\n exports.utcDay = utcDay;\n exports.utcDays = utcDays;\n exports.utcWeek = utcWeek;\n exports.utcWeeks = utcSundays;\n exports.utcSunday = utcWeek;\n exports.utcSundays = utcSundays;\n exports.utcMonday = utcMonday;\n exports.utcMondays = utcMondays;\n exports.utcTuesday = utcTuesday;\n exports.utcTuesdays = utcTuesdays;\n exports.utcWednesday = utcWednesday;\n exports.utcWednesdays = utcWednesdays;\n exports.utcThursday = utcThursday;\n exports.utcThursdays = utcThursdays;\n exports.utcFriday = utcFriday;\n exports.utcFridays = utcFridays;\n exports.utcSaturday = utcSaturday;\n exports.utcSaturdays = utcSaturdays;\n exports.utcMonth = utcMonth;\n exports.utcMonths = utcMonths;\n exports.utcYear = utcYear;\n exports.utcYears = utcYears;\n exports.formatLocale = formatLocale;\n exports.formatDefaultLocale = defaultLocale;\n exports.formatSpecifier = formatSpecifier;\n exports.precisionFixed = precisionFixed;\n exports.precisionPrefix = precisionPrefix;\n exports.precisionRound = precisionRound;\n exports.isoFormat = formatIso;\n exports.isoParse = parseIso;\n exports.timeFormatLocale = formatLocale$1;\n exports.timeFormatDefaultLocale = defaultLocale$1;\n exports.scaleBand = band;\n exports.scalePoint = point$4;\n exports.scaleIdentity = identity$4;\n exports.scaleLinear = linear$2;\n exports.scaleLog = log;\n exports.scaleOrdinal = ordinal;\n exports.scaleImplicit = implicit;\n exports.scalePow = pow;\n exports.scaleSqrt = sqrt;\n exports.scaleQuantile = quantile;\n exports.scaleQuantize = quantize$1;\n exports.scaleThreshold = threshold$1;\n exports.scaleTime = time;\n exports.scaleUtc = utcTime;\n exports.schemeCategory10 = category10;\n exports.schemeCategory20b = category20b;\n exports.schemeCategory20c = category20c;\n exports.schemeCategory20 = category20;\n exports.scaleSequential = sequential;\n exports.interpolateCubehelixDefault = cubehelix$3;\n exports.interpolateRainbow = rainbow$1;\n exports.interpolateWarm = warm;\n exports.interpolateCool = cool;\n exports.interpolateViridis = viridis;\n exports.interpolateMagma = magma;\n exports.interpolateInferno = inferno;\n exports.interpolatePlasma = plasma;\n exports.creator = creator;\n exports.customEvent = customEvent;\n exports.local = local;\n exports.matcher = matcher$1;\n exports.mouse = mouse;\n exports.namespace = namespace;\n exports.namespaces = namespaces;\n exports.select = select;\n exports.selectAll = selectAll;\n exports.selection = selection;\n exports.selector = selector;\n exports.selectorAll = selectorAll;\n exports.touch = touch;\n exports.touches = touches;\n exports.window = window;\n exports.active = active;\n exports.interrupt = interrupt;\n exports.transition = transition;\n exports.axisTop = axisTop;\n exports.axisRight = axisRight;\n exports.axisBottom = axisBottom;\n exports.axisLeft = axisLeft;\n exports.cluster = cluster;\n exports.hierarchy = hierarchy;\n exports.pack = index;\n exports.packSiblings = siblings;\n exports.packEnclose = enclose;\n exports.partition = partition;\n exports.stratify = stratify;\n exports.tree = tree;\n exports.treemap = index$1;\n exports.treemapBinary = binary;\n exports.treemapDice = treemapDice;\n exports.treemapSlice = treemapSlice;\n exports.treemapSliceDice = sliceDice;\n exports.treemapSquarify = squarify;\n exports.treemapResquarify = resquarify;\n exports.forceCenter = center$1;\n exports.forceCollide = collide;\n exports.forceLink = link;\n exports.forceManyBody = manyBody;\n exports.forceSimulation = simulation;\n exports.forceX = x$3;\n exports.forceY = y$3;\n exports.drag = drag;\n exports.dragDisable = dragDisable;\n exports.dragEnable = dragEnable;\n exports.voronoi = voronoi;\n exports.zoom = zoom;\n exports.zoomIdentity = identity$6;\n exports.zoomTransform = transform;\n exports.brush = brush;\n exports.brushX = brushX;\n exports.brushY = brushY;\n exports.brushSelection = brushSelection;\n exports.chord = chord;\n exports.ribbon = ribbon;\n exports.geoAlbers = albers;\n exports.geoAlbersUsa = albersUsa;\n exports.geoArea = area$2;\n exports.geoAzimuthalEqualArea = azimuthalEqualArea;\n exports.geoAzimuthalEqualAreaRaw = azimuthalEqualAreaRaw;\n exports.geoAzimuthalEquidistant = azimuthalEquidistant;\n exports.geoAzimuthalEquidistantRaw = azimuthalEquidistantRaw;\n exports.geoBounds = bounds;\n exports.geoCentroid = centroid$1;\n exports.geoCircle = circle$1;\n exports.geoClipExtent = extent$1;\n exports.geoConicConformal = conicConformal;\n exports.geoConicConformalRaw = conicConformalRaw;\n exports.geoConicEqualArea = conicEqualArea;\n exports.geoConicEqualAreaRaw = conicEqualAreaRaw;\n exports.geoConicEquidistant = conicEquidistant;\n exports.geoConicEquidistantRaw = conicEquidistantRaw;\n exports.geoDistance = distance;\n exports.geoEquirectangular = equirectangular;\n exports.geoEquirectangularRaw = equirectangularRaw;\n exports.geoGnomonic = gnomonic;\n exports.geoGnomonicRaw = gnomonicRaw;\n exports.geoGraticule = graticule;\n exports.geoInterpolate = interpolate$2;\n exports.geoLength = length$2;\n exports.geoMercator = mercator;\n exports.geoMercatorRaw = mercatorRaw;\n exports.geoOrthographic = orthographic;\n exports.geoOrthographicRaw = orthographicRaw;\n exports.geoPath = index$3;\n exports.geoProjection = projection;\n exports.geoProjectionMutator = projectionMutator;\n exports.geoRotation = rotation;\n exports.geoStereographic = stereographic;\n exports.geoStereographicRaw = stereographicRaw;\n exports.geoStream = stream;\n exports.geoTransform = transform$1;\n exports.geoTransverseMercator = transverseMercator;\n exports.geoTransverseMercatorRaw = transverseMercatorRaw;\n\n Object.defineProperty(exports, '__esModule', { value: true });\n\n}));\n},{}],12:[function(require,module,exports){\n/*! DataTables 1.10.12\n * ©2008-2015 SpryMedia Ltd - datatables.net/license\n */\n\n/**\n * @summary DataTables\n * @description Paginate, search and order HTML tables\n * @version 1.10.12\n * @file jquery.dataTables.js\n * @author SpryMedia Ltd (www.sprymedia.co.uk)\n * @contact www.sprymedia.co.uk/contact\n * @copyright Copyright 2008-2015 SpryMedia Ltd.\n *\n * This source file is free software, available under the following license:\n * MIT license - http://datatables.net/license\n *\n * This source file is distributed in the hope that it will be useful, but\n * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY\n * or FITNESS FOR A PARTICULAR PURPOSE. See the license files for details.\n *\n * For details please refer to: http://www.datatables.net\n */\n\n/*jslint evil: true, undef: true, browser: true */\n/*globals $,require,jQuery,define,_selector_run,_selector_opts,_selector_first,_selector_row_indexes,_ext,_Api,_api_register,_api_registerPlural,_re_new_lines,_re_html,_re_formatted_numeric,_re_escape_regex,_empty,_intVal,_numToDecimal,_isNumber,_isHtml,_htmlNumeric,_pluck,_pluck_order,_range,_stripHtml,_unique,_fnBuildAjax,_fnAjaxUpdate,_fnAjaxParameters,_fnAjaxUpdateDraw,_fnAjaxDataSrc,_fnAddColumn,_fnColumnOptions,_fnAdjustColumnSizing,_fnVisibleToColumnIndex,_fnColumnIndexToVisible,_fnVisbleColumns,_fnGetColumns,_fnColumnTypes,_fnApplyColumnDefs,_fnHungarianMap,_fnCamelToHungarian,_fnLanguageCompat,_fnBrowserDetect,_fnAddData,_fnAddTr,_fnNodeToDataIndex,_fnNodeToColumnIndex,_fnGetCellData,_fnSetCellData,_fnSplitObjNotation,_fnGetObjectDataFn,_fnSetObjectDataFn,_fnGetDataMaster,_fnClearTable,_fnDeleteIndex,_fnInvalidate,_fnGetRowElements,_fnCreateTr,_fnBuildHead,_fnDrawHead,_fnDraw,_fnReDraw,_fnAddOptionsHtml,_fnDetectHeader,_fnGetUniqueThs,_fnFeatureHtmlFilter,_fnFilterComplete,_fnFilterCustom,_fnFilterColumn,_fnFilter,_fnFilterCreateSearch,_fnEscapeRegex,_fnFilterData,_fnFeatureHtmlInfo,_fnUpdateInfo,_fnInfoMacros,_fnInitialise,_fnInitComplete,_fnLengthChange,_fnFeatureHtmlLength,_fnFeatureHtmlPaginate,_fnPageChange,_fnFeatureHtmlProcessing,_fnProcessingDisplay,_fnFeatureHtmlTable,_fnScrollDraw,_fnApplyToChildren,_fnCalculateColumnWidths,_fnThrottle,_fnConvertToWidth,_fnGetWidestNode,_fnGetMaxLenString,_fnStringToCss,_fnSortFlatten,_fnSort,_fnSortAria,_fnSortListener,_fnSortAttachListener,_fnSortingClasses,_fnSortData,_fnSaveState,_fnLoadState,_fnSettingsFromNode,_fnLog,_fnMap,_fnBindAction,_fnCallbackReg,_fnCallbackFire,_fnLengthOverflow,_fnRenderer,_fnDataSource,_fnRowAttributes*/\n\n(function( factory ) {\n\t\"use strict\";\n\n\tif ( typeof define === 'function' && define.amd ) {\n\t\t// AMD\n\t\tdefine( ['jquery'], function ( $ ) {\n\t\t\treturn factory( $, window, document );\n\t\t} );\n\t}\n\telse if ( typeof exports === 'object' ) {\n\t\t// CommonJS\n\t\tmodule.exports = function (root, $) {\n\t\t\tif ( ! root ) {\n\t\t\t\t// CommonJS environments without a window global must pass a\n\t\t\t\t// root. This will give an error otherwise\n\t\t\t\troot = window;\n\t\t\t}\n\n\t\t\tif ( ! $ ) {\n\t\t\t\t$ = typeof window !== 'undefined' ? // jQuery's factory checks for a global window\n\t\t\t\t\trequire('jquery') :\n\t\t\t\t\trequire('jquery')( root );\n\t\t\t}\n\n\t\t\treturn factory( $, root, root.document );\n\t\t};\n\t}\n\telse {\n\t\t// Browser\n\t\tfactory( jQuery, window, document );\n\t}\n}\n(function( $, window, document, undefined ) {\n\t\"use strict\";\n\n\t/**\n\t * DataTables is a plug-in for the jQuery Javascript library. It is a highly\n\t * flexible tool, based upon the foundations of progressive enhancement,\n\t * which will add advanced interaction controls to any HTML table. For a\n\t * full list of features please refer to\n\t * [DataTables.net](href=\"http://datatables.net).\n\t *\n\t * Note that the `DataTable` object is not a global variable but is aliased\n\t * to `jQuery.fn.DataTable` and `jQuery.fn.dataTable` through which it may\n\t * be accessed.\n\t *\n\t * @class\n\t * @param {object} [init={}] Configuration object for DataTables. Options\n\t * are defined by {@link DataTable.defaults}\n\t * @requires jQuery 1.7+\n\t *\n\t * @example\n\t * // Basic initialisation\n\t * $(document).ready( function {\n\t * $('#example').dataTable();\n\t * } );\n\t *\n\t * @example\n\t * // Initialisation with configuration options - in this case, disable\n\t * // pagination and sorting.\n\t * $(document).ready( function {\n\t * $('#example').dataTable( {\n\t * \"paginate\": false,\n\t * \"sort\": false\n\t * } );\n\t * } );\n\t */\n\tvar DataTable = function ( options )\n\t{\n\t\t/**\n\t\t * Perform a jQuery selector action on the table's TR elements (from the tbody) and\n\t\t * return the resulting jQuery object.\n\t\t * @param {string|node|jQuery} sSelector jQuery selector or node collection to act on\n\t\t * @param {object} [oOpts] Optional parameters for modifying the rows to be included\n\t\t * @param {string} [oOpts.filter=none] Select TR elements that meet the current filter\n\t\t * criterion (\"applied\") or all TR elements (i.e. no filter).\n\t\t * @param {string} [oOpts.order=current] Order of the TR elements in the processed array.\n\t\t * Can be either 'current', whereby the current sorting of the table is used, or\n\t\t * 'original' whereby the original order the data was read into the table is used.\n\t\t * @param {string} [oOpts.page=all] Limit the selection to the currently displayed page\n\t\t * (\"current\") or not (\"all\"). If 'current' is given, then order is assumed to be\n\t\t * 'current' and filter is 'applied', regardless of what they might be given as.\n\t\t * @returns {object} jQuery object, filtered by the given selector.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Highlight every second row\n\t\t * oTable.$('tr:odd').css('backgroundColor', 'blue');\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Filter to rows with 'Webkit' in them, add a background colour and then\n\t\t * // remove the filter, thus highlighting the 'Webkit' rows only.\n\t\t * oTable.fnFilter('Webkit');\n\t\t * oTable.$('tr', {\"search\": \"applied\"}).css('backgroundColor', 'blue');\n\t\t * oTable.fnFilter('');\n\t\t * } );\n\t\t */\n\t\tthis.$ = function ( sSelector, oOpts )\n\t\t{\n\t\t\treturn this.api(true).$( sSelector, oOpts );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Almost identical to $ in operation, but in this case returns the data for the matched\n\t\t * rows - as such, the jQuery selector used should match TR row nodes or TD/TH cell nodes\n\t\t * rather than any descendants, so the data can be obtained for the row/cell. If matching\n\t\t * rows are found, the data returned is the original data array/object that was used to\n\t\t * create the row (or a generated array if from a DOM source).\n\t\t *\n\t\t * This method is often useful in-combination with $ where both functions are given the\n\t\t * same parameters and the array indexes will match identically.\n\t\t * @param {string|node|jQuery} sSelector jQuery selector or node collection to act on\n\t\t * @param {object} [oOpts] Optional parameters for modifying the rows to be included\n\t\t * @param {string} [oOpts.filter=none] Select elements that meet the current filter\n\t\t * criterion (\"applied\") or all elements (i.e. no filter).\n\t\t * @param {string} [oOpts.order=current] Order of the data in the processed array.\n\t\t * Can be either 'current', whereby the current sorting of the table is used, or\n\t\t * 'original' whereby the original order the data was read into the table is used.\n\t\t * @param {string} [oOpts.page=all] Limit the selection to the currently displayed page\n\t\t * (\"current\") or not (\"all\"). If 'current' is given, then order is assumed to be\n\t\t * 'current' and filter is 'applied', regardless of what they might be given as.\n\t\t * @returns {array} Data for the matched elements. If any elements, as a result of the\n\t\t * selector, were not TR, TD or TH elements in the DataTable, they will have a null\n\t\t * entry in the array.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Get the data from the first row in the table\n\t\t * var data = oTable._('tr:first');\n\t\t *\n\t\t * // Do something useful with the data\n\t\t * alert( \"First cell is: \"+data[0] );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Filter to 'Webkit' and get all data for\n\t\t * oTable.fnFilter('Webkit');\n\t\t * var data = oTable._('tr', {\"search\": \"applied\"});\n\t\t *\n\t\t * // Do something with the data\n\t\t * alert( data.length+\" rows matched the search\" );\n\t\t * } );\n\t\t */\n\t\tthis._ = function ( sSelector, oOpts )\n\t\t{\n\t\t\treturn this.api(true).rows( sSelector, oOpts ).data();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Create a DataTables Api instance, with the currently selected tables for\n\t\t * the Api's context.\n\t\t * @param {boolean} [traditional=false] Set the API instance's context to be\n\t\t * only the table referred to by the `DataTable.ext.iApiIndex` option, as was\n\t\t * used in the API presented by DataTables 1.9- (i.e. the traditional mode),\n\t\t * or if all tables captured in the jQuery object should be used.\n\t\t * @return {DataTables.Api}\n\t\t */\n\t\tthis.api = function ( traditional )\n\t\t{\n\t\t\treturn traditional ?\n\t\t\t\tnew _Api(\n\t\t\t\t\t_fnSettingsFromNode( this[ _ext.iApiIndex ] )\n\t\t\t\t) :\n\t\t\t\tnew _Api( this );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Add a single new row or multiple rows of data to the table. Please note\n\t\t * that this is suitable for client-side processing only - if you are using\n\t\t * server-side processing (i.e. \"bServerSide\": true), then to add data, you\n\t\t * must add it to the data source, i.e. the server-side, through an Ajax call.\n\t\t * @param {array|object} data The data to be added to the table. This can be:\n\t\t * <ul>\n\t\t * <li>1D array of data - add a single row with the data provided</li>\n\t\t * <li>2D array of arrays - add multiple rows in a single call</li>\n\t\t * <li>object - data object when using <i>mData</i></li>\n\t\t * <li>array of objects - multiple data objects when using <i>mData</i></li>\n\t\t * </ul>\n\t\t * @param {bool} [redraw=true] redraw the table or not\n\t\t * @returns {array} An array of integers, representing the list of indexes in\n\t\t * <i>aoData</i> ({@link DataTable.models.oSettings}) that have been added to\n\t\t * the table.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * // Global var for counter\n\t\t * var giCount = 2;\n\t\t *\n\t\t * $(document).ready(function() {\n\t\t * $('#example').dataTable();\n\t\t * } );\n\t\t *\n\t\t * function fnClickAddRow() {\n\t\t * $('#example').dataTable().fnAddData( [\n\t\t * giCount+\".1\",\n\t\t * giCount+\".2\",\n\t\t * giCount+\".3\",\n\t\t * giCount+\".4\" ]\n\t\t * );\n\t\t *\n\t\t * giCount++;\n\t\t * }\n\t\t */\n\t\tthis.fnAddData = function( data, redraw )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\n\t\t\t/* Check if we want to add multiple rows or not */\n\t\t\tvar rows = $.isArray(data) && ( $.isArray(data[0]) || $.isPlainObject(data[0]) ) ?\n\t\t\t\tapi.rows.add( data ) :\n\t\t\t\tapi.row.add( data );\n\t\t\n\t\t\tif ( redraw === undefined || redraw ) {\n\t\t\t\tapi.draw();\n\t\t\t}\n\t\t\n\t\t\treturn rows.flatten().toArray();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * This function will make DataTables recalculate the column sizes, based on the data\n\t\t * contained in the table and the sizes applied to the columns (in the DOM, CSS or\n\t\t * through the sWidth parameter). This can be useful when the width of the table's\n\t\t * parent element changes (for example a window resize).\n\t\t * @param {boolean} [bRedraw=true] Redraw the table or not, you will typically want to\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable( {\n\t\t * \"sScrollY\": \"200px\",\n\t\t * \"bPaginate\": false\n\t\t * } );\n\t\t *\n\t\t * $(window).bind('resize', function () {\n\t\t * oTable.fnAdjustColumnSizing();\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\tthis.fnAdjustColumnSizing = function ( bRedraw )\n\t\t{\n\t\t\tvar api = this.api( true ).columns.adjust();\n\t\t\tvar settings = api.settings()[0];\n\t\t\tvar scroll = settings.oScroll;\n\t\t\n\t\t\tif ( bRedraw === undefined || bRedraw ) {\n\t\t\t\tapi.draw( false );\n\t\t\t}\n\t\t\telse if ( scroll.sX !== \"\" || scroll.sY !== \"\" ) {\n\t\t\t\t/* If not redrawing, but scrolling, we want to apply the new column sizes anyway */\n\t\t\t\t_fnScrollDraw( settings );\n\t\t\t}\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Quickly and simply clear a table\n\t\t * @param {bool} [bRedraw=true] redraw the table or not\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Immediately 'nuke' the current rows (perhaps waiting for an Ajax callback...)\n\t\t * oTable.fnClearTable();\n\t\t * } );\n\t\t */\n\t\tthis.fnClearTable = function( bRedraw )\n\t\t{\n\t\t\tvar api = this.api( true ).clear();\n\t\t\n\t\t\tif ( bRedraw === undefined || bRedraw ) {\n\t\t\t\tapi.draw();\n\t\t\t}\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * The exact opposite of 'opening' a row, this function will close any rows which\n\t\t * are currently 'open'.\n\t\t * @param {node} nTr the table row to 'close'\n\t\t * @returns {int} 0 on success, or 1 if failed (can't find the row)\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable;\n\t\t *\n\t\t * // 'open' an information row when a row is clicked on\n\t\t * $('#example tbody tr').click( function () {\n\t\t * if ( oTable.fnIsOpen(this) ) {\n\t\t * oTable.fnClose( this );\n\t\t * } else {\n\t\t * oTable.fnOpen( this, \"Temporary row opened\", \"info_row\" );\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * oTable = $('#example').dataTable();\n\t\t * } );\n\t\t */\n\t\tthis.fnClose = function( nTr )\n\t\t{\n\t\t\tthis.api( true ).row( nTr ).child.hide();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Remove a row for the table\n\t\t * @param {mixed} target The index of the row from aoData to be deleted, or\n\t\t * the TR element you want to delete\n\t\t * @param {function|null} [callBack] Callback function\n\t\t * @param {bool} [redraw=true] Redraw the table or not\n\t\t * @returns {array} The row that was deleted\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Immediately remove the first row\n\t\t * oTable.fnDeleteRow( 0 );\n\t\t * } );\n\t\t */\n\t\tthis.fnDeleteRow = function( target, callback, redraw )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\tvar rows = api.rows( target );\n\t\t\tvar settings = rows.settings()[0];\n\t\t\tvar data = settings.aoData[ rows[0][0] ];\n\t\t\n\t\t\trows.remove();\n\t\t\n\t\t\tif ( callback ) {\n\t\t\t\tcallback.call( this, settings, data );\n\t\t\t}\n\t\t\n\t\t\tif ( redraw === undefined || redraw ) {\n\t\t\t\tapi.draw();\n\t\t\t}\n\t\t\n\t\t\treturn data;\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Restore the table to it's original state in the DOM by removing all of DataTables\n\t\t * enhancements, alterations to the DOM structure of the table and event listeners.\n\t\t * @param {boolean} [remove=false] Completely remove the table from the DOM\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * // This example is fairly pointless in reality, but shows how fnDestroy can be used\n\t\t * var oTable = $('#example').dataTable();\n\t\t * oTable.fnDestroy();\n\t\t * } );\n\t\t */\n\t\tthis.fnDestroy = function ( remove )\n\t\t{\n\t\t\tthis.api( true ).destroy( remove );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Redraw the table\n\t\t * @param {bool} [complete=true] Re-filter and resort (if enabled) the table before the draw.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Re-draw the table - you wouldn't want to do it here, but it's an example :-)\n\t\t * oTable.fnDraw();\n\t\t * } );\n\t\t */\n\t\tthis.fnDraw = function( complete )\n\t\t{\n\t\t\t// Note that this isn't an exact match to the old call to _fnDraw - it takes\n\t\t\t// into account the new data, but can hold position.\n\t\t\tthis.api( true ).draw( complete );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Filter the input based on data\n\t\t * @param {string} sInput String to filter the table on\n\t\t * @param {int|null} [iColumn] Column to limit filtering to\n\t\t * @param {bool} [bRegex=false] Treat as regular expression or not\n\t\t * @param {bool} [bSmart=true] Perform smart filtering or not\n\t\t * @param {bool} [bShowGlobal=true] Show the input global filter in it's input box(es)\n\t\t * @param {bool} [bCaseInsensitive=true] Do case-insensitive matching (true) or not (false)\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Sometime later - filter...\n\t\t * oTable.fnFilter( 'test string' );\n\t\t * } );\n\t\t */\n\t\tthis.fnFilter = function( sInput, iColumn, bRegex, bSmart, bShowGlobal, bCaseInsensitive )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\n\t\t\tif ( iColumn === null || iColumn === undefined ) {\n\t\t\t\tapi.search( sInput, bRegex, bSmart, bCaseInsensitive );\n\t\t\t}\n\t\t\telse {\n\t\t\t\tapi.column( iColumn ).search( sInput, bRegex, bSmart, bCaseInsensitive );\n\t\t\t}\n\t\t\n\t\t\tapi.draw();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Get the data for the whole table, an individual row or an individual cell based on the\n\t\t * provided parameters.\n\t\t * @param {int|node} [src] A TR row node, TD/TH cell node or an integer. If given as\n\t\t * a TR node then the data source for the whole row will be returned. If given as a\n\t\t * TD/TH cell node then iCol will be automatically calculated and the data for the\n\t\t * cell returned. If given as an integer, then this is treated as the aoData internal\n\t\t * data index for the row (see fnGetPosition) and the data for that row used.\n\t\t * @param {int} [col] Optional column index that you want the data of.\n\t\t * @returns {array|object|string} If mRow is undefined, then the data for all rows is\n\t\t * returned. If mRow is defined, just data for that row, and is iCol is\n\t\t * defined, only data for the designated cell is returned.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * // Row data\n\t\t * $(document).ready(function() {\n\t\t * oTable = $('#example').dataTable();\n\t\t *\n\t\t * oTable.$('tr').click( function () {\n\t\t * var data = oTable.fnGetData( this );\n\t\t * // ... do something with the array / object of data for the row\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Individual cell data\n\t\t * $(document).ready(function() {\n\t\t * oTable = $('#example').dataTable();\n\t\t *\n\t\t * oTable.$('td').click( function () {\n\t\t * var sData = oTable.fnGetData( this );\n\t\t * alert( 'The cell clicked on had the value of '+sData );\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\tthis.fnGetData = function( src, col )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\n\t\t\tif ( src !== undefined ) {\n\t\t\t\tvar type = src.nodeName ? src.nodeName.toLowerCase() : '';\n\t\t\n\t\t\t\treturn col !== undefined || type == 'td' || type == 'th' ?\n\t\t\t\t\tapi.cell( src, col ).data() :\n\t\t\t\t\tapi.row( src ).data() || null;\n\t\t\t}\n\t\t\n\t\t\treturn api.data().toArray();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Get an array of the TR nodes that are used in the table's body. Note that you will\n\t\t * typically want to use the '$' API method in preference to this as it is more\n\t\t * flexible.\n\t\t * @param {int} [iRow] Optional row index for the TR element you want\n\t\t * @returns {array|node} If iRow is undefined, returns an array of all TR elements\n\t\t * in the table's body, or iRow is defined, just the TR element requested.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Get the nodes from the table\n\t\t * var nNodes = oTable.fnGetNodes( );\n\t\t * } );\n\t\t */\n\t\tthis.fnGetNodes = function( iRow )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\n\t\t\treturn iRow !== undefined ?\n\t\t\t\tapi.row( iRow ).node() :\n\t\t\t\tapi.rows().nodes().flatten().toArray();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Get the array indexes of a particular cell from it's DOM element\n\t\t * and column index including hidden columns\n\t\t * @param {node} node this can either be a TR, TD or TH in the table's body\n\t\t * @returns {int} If nNode is given as a TR, then a single index is returned, or\n\t\t * if given as a cell, an array of [row index, column index (visible),\n\t\t * column index (all)] is given.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * $('#example tbody td').click( function () {\n\t\t * // Get the position of the current data from the node\n\t\t * var aPos = oTable.fnGetPosition( this );\n\t\t *\n\t\t * // Get the data array for this row\n\t\t * var aData = oTable.fnGetData( aPos[0] );\n\t\t *\n\t\t * // Update the data array and return the value\n\t\t * aData[ aPos[1] ] = 'clicked';\n\t\t * this.innerHTML = 'clicked';\n\t\t * } );\n\t\t *\n\t\t * // Init DataTables\n\t\t * oTable = $('#example').dataTable();\n\t\t * } );\n\t\t */\n\t\tthis.fnGetPosition = function( node )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\tvar nodeName = node.nodeName.toUpperCase();\n\t\t\n\t\t\tif ( nodeName == 'TR' ) {\n\t\t\t\treturn api.row( node ).index();\n\t\t\t}\n\t\t\telse if ( nodeName == 'TD' || nodeName == 'TH' ) {\n\t\t\t\tvar cell = api.cell( node ).index();\n\t\t\n\t\t\t\treturn [\n\t\t\t\t\tcell.row,\n\t\t\t\t\tcell.columnVisible,\n\t\t\t\t\tcell.column\n\t\t\t\t];\n\t\t\t}\n\t\t\treturn null;\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Check to see if a row is 'open' or not.\n\t\t * @param {node} nTr the table row to check\n\t\t * @returns {boolean} true if the row is currently open, false otherwise\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable;\n\t\t *\n\t\t * // 'open' an information row when a row is clicked on\n\t\t * $('#example tbody tr').click( function () {\n\t\t * if ( oTable.fnIsOpen(this) ) {\n\t\t * oTable.fnClose( this );\n\t\t * } else {\n\t\t * oTable.fnOpen( this, \"Temporary row opened\", \"info_row\" );\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * oTable = $('#example').dataTable();\n\t\t * } );\n\t\t */\n\t\tthis.fnIsOpen = function( nTr )\n\t\t{\n\t\t\treturn this.api( true ).row( nTr ).child.isShown();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * This function will place a new row directly after a row which is currently\n\t\t * on display on the page, with the HTML contents that is passed into the\n\t\t * function. This can be used, for example, to ask for confirmation that a\n\t\t * particular record should be deleted.\n\t\t * @param {node} nTr The table row to 'open'\n\t\t * @param {string|node|jQuery} mHtml The HTML to put into the row\n\t\t * @param {string} sClass Class to give the new TD cell\n\t\t * @returns {node} The row opened. Note that if the table row passed in as the\n\t\t * first parameter, is not found in the table, this method will silently\n\t\t * return.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable;\n\t\t *\n\t\t * // 'open' an information row when a row is clicked on\n\t\t * $('#example tbody tr').click( function () {\n\t\t * if ( oTable.fnIsOpen(this) ) {\n\t\t * oTable.fnClose( this );\n\t\t * } else {\n\t\t * oTable.fnOpen( this, \"Temporary row opened\", \"info_row\" );\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * oTable = $('#example').dataTable();\n\t\t * } );\n\t\t */\n\t\tthis.fnOpen = function( nTr, mHtml, sClass )\n\t\t{\n\t\t\treturn this.api( true )\n\t\t\t\t.row( nTr )\n\t\t\t\t.child( mHtml, sClass )\n\t\t\t\t.show()\n\t\t\t\t.child()[0];\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Change the pagination - provides the internal logic for pagination in a simple API\n\t\t * function. With this function you can have a DataTables table go to the next,\n\t\t * previous, first or last pages.\n\t\t * @param {string|int} mAction Paging action to take: \"first\", \"previous\", \"next\" or \"last\"\n\t\t * or page number to jump to (integer), note that page 0 is the first page.\n\t\t * @param {bool} [bRedraw=true] Redraw the table or not\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t * oTable.fnPageChange( 'next' );\n\t\t * } );\n\t\t */\n\t\tthis.fnPageChange = function ( mAction, bRedraw )\n\t\t{\n\t\t\tvar api = this.api( true ).page( mAction );\n\t\t\n\t\t\tif ( bRedraw === undefined || bRedraw ) {\n\t\t\t\tapi.draw(false);\n\t\t\t}\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Show a particular column\n\t\t * @param {int} iCol The column whose display should be changed\n\t\t * @param {bool} bShow Show (true) or hide (false) the column\n\t\t * @param {bool} [bRedraw=true] Redraw the table or not\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Hide the second column after initialisation\n\t\t * oTable.fnSetColumnVis( 1, false );\n\t\t * } );\n\t\t */\n\t\tthis.fnSetColumnVis = function ( iCol, bShow, bRedraw )\n\t\t{\n\t\t\tvar api = this.api( true ).column( iCol ).visible( bShow );\n\t\t\n\t\t\tif ( bRedraw === undefined || bRedraw ) {\n\t\t\t\tapi.columns.adjust().draw();\n\t\t\t}\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Get the settings for a particular table for external manipulation\n\t\t * @returns {object} DataTables settings object. See\n\t\t * {@link DataTable.models.oSettings}\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t * var oSettings = oTable.fnSettings();\n\t\t *\n\t\t * // Show an example parameter from the settings\n\t\t * alert( oSettings._iDisplayStart );\n\t\t * } );\n\t\t */\n\t\tthis.fnSettings = function()\n\t\t{\n\t\t\treturn _fnSettingsFromNode( this[_ext.iApiIndex] );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Sort the table by a particular column\n\t\t * @param {int} iCol the data index to sort on. Note that this will not match the\n\t\t * 'display index' if you have hidden data entries\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Sort immediately with columns 0 and 1\n\t\t * oTable.fnSort( [ [0,'asc'], [1,'asc'] ] );\n\t\t * } );\n\t\t */\n\t\tthis.fnSort = function( aaSort )\n\t\t{\n\t\t\tthis.api( true ).order( aaSort ).draw();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Attach a sort listener to an element for a given column\n\t\t * @param {node} nNode the element to attach the sort listener to\n\t\t * @param {int} iColumn the column that a click on this node will sort on\n\t\t * @param {function} [fnCallback] callback function when sort is run\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Sort on column 1, when 'sorter' is clicked on\n\t\t * oTable.fnSortListener( document.getElementById('sorter'), 1 );\n\t\t * } );\n\t\t */\n\t\tthis.fnSortListener = function( nNode, iColumn, fnCallback )\n\t\t{\n\t\t\tthis.api( true ).order.listener( nNode, iColumn, fnCallback );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Update a table cell or row - this method will accept either a single value to\n\t\t * update the cell with, an array of values with one element for each column or\n\t\t * an object in the same format as the original data source. The function is\n\t\t * self-referencing in order to make the multi column updates easier.\n\t\t * @param {object|array|string} mData Data to update the cell/row with\n\t\t * @param {node|int} mRow TR element you want to update or the aoData index\n\t\t * @param {int} [iColumn] The column to update, give as null or undefined to\n\t\t * update a whole row.\n\t\t * @param {bool} [bRedraw=true] Redraw the table or not\n\t\t * @param {bool} [bAction=true] Perform pre-draw actions or not\n\t\t * @returns {int} 0 on success, 1 on error\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t * oTable.fnUpdate( 'Example update', 0, 0 ); // Single cell\n\t\t * oTable.fnUpdate( ['a', 'b', 'c', 'd', 'e'], $('tbody tr')[0] ); // Row\n\t\t * } );\n\t\t */\n\t\tthis.fnUpdate = function( mData, mRow, iColumn, bRedraw, bAction )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\n\t\t\tif ( iColumn === undefined || iColumn === null ) {\n\t\t\t\tapi.row( mRow ).data( mData );\n\t\t\t}\n\t\t\telse {\n\t\t\t\tapi.cell( mRow, iColumn ).data( mData );\n\t\t\t}\n\t\t\n\t\t\tif ( bAction === undefined || bAction ) {\n\t\t\t\tapi.columns.adjust();\n\t\t\t}\n\t\t\n\t\t\tif ( bRedraw === undefined || bRedraw ) {\n\t\t\t\tapi.draw();\n\t\t\t}\n\t\t\treturn 0;\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Provide a common method for plug-ins to check the version of DataTables being used, in order\n\t\t * to ensure compatibility.\n\t\t * @param {string} sVersion Version string to check for, in the format \"X.Y.Z\". Note that the\n\t\t * formats \"X\" and \"X.Y\" are also acceptable.\n\t\t * @returns {boolean} true if this version of DataTables is greater or equal to the required\n\t\t * version, or false if this version of DataTales is not suitable\n\t\t * @method\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t * alert( oTable.fnVersionCheck( '1.9.0' ) );\n\t\t * } );\n\t\t */\n\t\tthis.fnVersionCheck = _ext.fnVersionCheck;\n\t\t\n\n\t\tvar _that = this;\n\t\tvar emptyInit = options === undefined;\n\t\tvar len = this.length;\n\n\t\tif ( emptyInit ) {\n\t\t\toptions = {};\n\t\t}\n\n\t\tthis.oApi = this.internal = _ext.internal;\n\n\t\t// Extend with old style plug-in API methods\n\t\tfor ( var fn in DataTable.ext.internal ) {\n\t\t\tif ( fn ) {\n\t\t\t\tthis[fn] = _fnExternApiFunc(fn);\n\t\t\t}\n\t\t}\n\n\t\tthis.each(function() {\n\t\t\t// For each initialisation we want to give it a clean initialisation\n\t\t\t// object that can be bashed around\n\t\t\tvar o = {};\n\t\t\tvar oInit = len > 1 ? // optimisation for single table case\n\t\t\t\t_fnExtend( o, options, true ) :\n\t\t\t\toptions;\n\n\t\t\t/*global oInit,_that,emptyInit*/\n\t\t\tvar i=0, iLen, j, jLen, k, kLen;\n\t\t\tvar sId = this.getAttribute( 'id' );\n\t\t\tvar bInitHandedOff = false;\n\t\t\tvar defaults = DataTable.defaults;\n\t\t\tvar $this = $(this);\n\t\t\t\n\t\t\t\n\t\t\t/* Sanity check */\n\t\t\tif ( this.nodeName.toLowerCase() != 'table' )\n\t\t\t{\n\t\t\t\t_fnLog( null, 0, 'Non-table node initialisation ('+this.nodeName+')', 2 );\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t\n\t\t\t/* Backwards compatibility for the defaults */\n\t\t\t_fnCompatOpts( defaults );\n\t\t\t_fnCompatCols( defaults.column );\n\t\t\t\n\t\t\t/* Convert the camel-case defaults to Hungarian */\n\t\t\t_fnCamelToHungarian( defaults, defaults, true );\n\t\t\t_fnCamelToHungarian( defaults.column, defaults.column, true );\n\t\t\t\n\t\t\t/* Setting up the initialisation object */\n\t\t\t_fnCamelToHungarian( defaults, $.extend( oInit, $this.data() ) );\n\t\t\t\n\t\t\t\n\t\t\t\n\t\t\t/* Check to see if we are re-initialising a table */\n\t\t\tvar allSettings = DataTable.settings;\n\t\t\tfor ( i=0, iLen=allSettings.length ; i<iLen ; i++ )\n\t\t\t{\n\t\t\t\tvar s = allSettings[i];\n\t\t\t\n\t\t\t\t/* Base check on table node */\n\t\t\t\tif ( s.nTable == this || s.nTHead.parentNode == this || (s.nTFoot && s.nTFoot.parentNode == this) )\n\t\t\t\t{\n\t\t\t\t\tvar bRetrieve = oInit.bRetrieve !== undefined ? oInit.bRetrieve : defaults.bRetrieve;\n\t\t\t\t\tvar bDestroy = oInit.bDestroy !== undefined ? oInit.bDestroy : defaults.bDestroy;\n\t\t\t\n\t\t\t\t\tif ( emptyInit || bRetrieve )\n\t\t\t\t\t{\n\t\t\t\t\t\treturn s.oInstance;\n\t\t\t\t\t}\n\t\t\t\t\telse if ( bDestroy )\n\t\t\t\t\t{\n\t\t\t\t\t\ts.oInstance.fnDestroy();\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\t_fnLog( s, 0, 'Cannot reinitialise DataTable', 3 );\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\n\t\t\t\t/* If the element we are initialising has the same ID as a table which was previously\n\t\t\t\t * initialised, but the table nodes don't match (from before) then we destroy the old\n\t\t\t\t * instance by simply deleting it. This is under the assumption that the table has been\n\t\t\t\t * destroyed by other methods. Anyone using non-id selectors will need to do this manually\n\t\t\t\t */\n\t\t\t\tif ( s.sTableId == this.id )\n\t\t\t\t{\n\t\t\t\t\tallSettings.splice( i, 1 );\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\t/* Ensure the table has an ID - required for accessibility */\n\t\t\tif ( sId === null || sId === \"\" )\n\t\t\t{\n\t\t\t\tsId = \"DataTables_Table_\"+(DataTable.ext._unique++);\n\t\t\t\tthis.id = sId;\n\t\t\t}\n\t\t\t\n\t\t\t/* Create the settings object for this table and set some of the default parameters */\n\t\t\tvar oSettings = $.extend( true, {}, DataTable.models.oSettings, {\n\t\t\t\t\"sDestroyWidth\": $this[0].style.width,\n\t\t\t\t\"sInstance\": sId,\n\t\t\t\t\"sTableId\": sId\n\t\t\t} );\n\t\t\toSettings.nTable = this;\n\t\t\toSettings.oApi = _that.internal;\n\t\t\toSettings.oInit = oInit;\n\t\t\t\n\t\t\tallSettings.push( oSettings );\n\t\t\t\n\t\t\t// Need to add the instance after the instance after the settings object has been added\n\t\t\t// to the settings array, so we can self reference the table instance if more than one\n\t\t\toSettings.oInstance = (_that.length===1) ? _that : $this.dataTable();\n\t\t\t\n\t\t\t// Backwards compatibility, before we apply all the defaults\n\t\t\t_fnCompatOpts( oInit );\n\t\t\t\n\t\t\tif ( oInit.oLanguage )\n\t\t\t{\n\t\t\t\t_fnLanguageCompat( oInit.oLanguage );\n\t\t\t}\n\t\t\t\n\t\t\t// If the length menu is given, but the init display length is not, use the length menu\n\t\t\tif ( oInit.aLengthMenu && ! oInit.iDisplayLength )\n\t\t\t{\n\t\t\t\toInit.iDisplayLength = $.isArray( oInit.aLengthMenu[0] ) ?\n\t\t\t\t\toInit.aLengthMenu[0][0] : oInit.aLengthMenu[0];\n\t\t\t}\n\t\t\t\n\t\t\t// Apply the defaults and init options to make a single init object will all\n\t\t\t// options defined from defaults and instance options.\n\t\t\toInit = _fnExtend( $.extend( true, {}, defaults ), oInit );\n\t\t\t\n\t\t\t\n\t\t\t// Map the initialisation options onto the settings object\n\t\t\t_fnMap( oSettings.oFeatures, oInit, [\n\t\t\t\t\"bPaginate\",\n\t\t\t\t\"bLengthChange\",\n\t\t\t\t\"bFilter\",\n\t\t\t\t\"bSort\",\n\t\t\t\t\"bSortMulti\",\n\t\t\t\t\"bInfo\",\n\t\t\t\t\"bProcessing\",\n\t\t\t\t\"bAutoWidth\",\n\t\t\t\t\"bSortClasses\",\n\t\t\t\t\"bServerSide\",\n\t\t\t\t\"bDeferRender\"\n\t\t\t] );\n\t\t\t_fnMap( oSettings, oInit, [\n\t\t\t\t\"asStripeClasses\",\n\t\t\t\t\"ajax\",\n\t\t\t\t\"fnServerData\",\n\t\t\t\t\"fnFormatNumber\",\n\t\t\t\t\"sServerMethod\",\n\t\t\t\t\"aaSorting\",\n\t\t\t\t\"aaSortingFixed\",\n\t\t\t\t\"aLengthMenu\",\n\t\t\t\t\"sPaginationType\",\n\t\t\t\t\"sAjaxSource\",\n\t\t\t\t\"sAjaxDataProp\",\n\t\t\t\t\"iStateDuration\",\n\t\t\t\t\"sDom\",\n\t\t\t\t\"bSortCellsTop\",\n\t\t\t\t\"iTabIndex\",\n\t\t\t\t\"fnStateLoadCallback\",\n\t\t\t\t\"fnStateSaveCallback\",\n\t\t\t\t\"renderer\",\n\t\t\t\t\"searchDelay\",\n\t\t\t\t\"rowId\",\n\t\t\t\t[ \"iCookieDuration\", \"iStateDuration\" ], // backwards compat\n\t\t\t\t[ \"oSearch\", \"oPreviousSearch\" ],\n\t\t\t\t[ \"aoSearchCols\", \"aoPreSearchCols\" ],\n\t\t\t\t[ \"iDisplayLength\", \"_iDisplayLength\" ],\n\t\t\t\t[ \"bJQueryUI\", \"bJUI\" ]\n\t\t\t] );\n\t\t\t_fnMap( oSettings.oScroll, oInit, [\n\t\t\t\t[ \"sScrollX\", \"sX\" ],\n\t\t\t\t[ \"sScrollXInner\", \"sXInner\" ],\n\t\t\t\t[ \"sScrollY\", \"sY\" ],\n\t\t\t\t[ \"bScrollCollapse\", \"bCollapse\" ]\n\t\t\t] );\n\t\t\t_fnMap( oSettings.oLanguage, oInit, \"fnInfoCallback\" );\n\t\t\t\n\t\t\t/* Callback functions which are array driven */\n\t\t\t_fnCallbackReg( oSettings, 'aoDrawCallback', oInit.fnDrawCallback, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoServerParams', oInit.fnServerParams, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoStateSaveParams', oInit.fnStateSaveParams, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoStateLoadParams', oInit.fnStateLoadParams, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoStateLoaded', oInit.fnStateLoaded, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoRowCallback', oInit.fnRowCallback, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoRowCreatedCallback', oInit.fnCreatedRow, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoHeaderCallback', oInit.fnHeaderCallback, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoFooterCallback', oInit.fnFooterCallback, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoInitComplete', oInit.fnInitComplete, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoPreDrawCallback', oInit.fnPreDrawCallback, 'user' );\n\t\t\t\n\t\t\toSettings.rowIdFn = _fnGetObjectDataFn( oInit.rowId );\n\t\t\t\n\t\t\t/* Browser support detection */\n\t\t\t_fnBrowserDetect( oSettings );\n\t\t\t\n\t\t\tvar oClasses = oSettings.oClasses;\n\t\t\t\n\t\t\t// @todo Remove in 1.11\n\t\t\tif ( oInit.bJQueryUI )\n\t\t\t{\n\t\t\t\t/* Use the JUI classes object for display. You could clone the oStdClasses object if\n\t\t\t\t * you want to have multiple tables with multiple independent classes\n\t\t\t\t */\n\t\t\t\t$.extend( oClasses, DataTable.ext.oJUIClasses, oInit.oClasses );\n\t\t\t\n\t\t\t\tif ( oInit.sDom === defaults.sDom && defaults.sDom === \"lfrtip\" )\n\t\t\t\t{\n\t\t\t\t\t/* Set the DOM to use a layout suitable for jQuery UI's theming */\n\t\t\t\t\toSettings.sDom = '<\"H\"lfr>t<\"F\"ip>';\n\t\t\t\t}\n\t\t\t\n\t\t\t\tif ( ! oSettings.renderer ) {\n\t\t\t\t\toSettings.renderer = 'jqueryui';\n\t\t\t\t}\n\t\t\t\telse if ( $.isPlainObject( oSettings.renderer ) && ! oSettings.renderer.header ) {\n\t\t\t\t\toSettings.renderer.header = 'jqueryui';\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t$.extend( oClasses, DataTable.ext.classes, oInit.oClasses );\n\t\t\t}\n\t\t\t$this.addClass( oClasses.sTable );\n\t\t\t\n\t\t\t\n\t\t\tif ( oSettings.iInitDisplayStart === undefined )\n\t\t\t{\n\t\t\t\t/* Display start point, taking into account the save saving */\n\t\t\t\toSettings.iInitDisplayStart = oInit.iDisplayStart;\n\t\t\t\toSettings._iDisplayStart = oInit.iDisplayStart;\n\t\t\t}\n\t\t\t\n\t\t\tif ( oInit.iDeferLoading !== null )\n\t\t\t{\n\t\t\t\toSettings.bDeferLoading = true;\n\t\t\t\tvar tmp = $.isArray( oInit.iDeferLoading );\n\t\t\t\toSettings._iRecordsDisplay = tmp ? oInit.iDeferLoading[0] : oInit.iDeferLoading;\n\t\t\t\toSettings._iRecordsTotal = tmp ? oInit.iDeferLoading[1] : oInit.iDeferLoading;\n\t\t\t}\n\t\t\t\n\t\t\t/* Language definitions */\n\t\t\tvar oLanguage = oSettings.oLanguage;\n\t\t\t$.extend( true, oLanguage, oInit.oLanguage );\n\t\t\t\n\t\t\tif ( oLanguage.sUrl !== \"\" )\n\t\t\t{\n\t\t\t\t/* Get the language definitions from a file - because this Ajax call makes the language\n\t\t\t\t * get async to the remainder of this function we use bInitHandedOff to indicate that\n\t\t\t\t * _fnInitialise will be fired by the returned Ajax handler, rather than the constructor\n\t\t\t\t */\n\t\t\t\t$.ajax( {\n\t\t\t\t\tdataType: 'json',\n\t\t\t\t\turl: oLanguage.sUrl,\n\t\t\t\t\tsuccess: function ( json ) {\n\t\t\t\t\t\t_fnLanguageCompat( json );\n\t\t\t\t\t\t_fnCamelToHungarian( defaults.oLanguage, json );\n\t\t\t\t\t\t$.extend( true, oLanguage, json );\n\t\t\t\t\t\t_fnInitialise( oSettings );\n\t\t\t\t\t},\n\t\t\t\t\terror: function () {\n\t\t\t\t\t\t// Error occurred loading language file, continue on as best we can\n\t\t\t\t\t\t_fnInitialise( oSettings );\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t\tbInitHandedOff = true;\n\t\t\t}\n\t\t\t\n\t\t\t/*\n\t\t\t * Stripes\n\t\t\t */\n\t\t\tif ( oInit.asStripeClasses === null )\n\t\t\t{\n\t\t\t\toSettings.asStripeClasses =[\n\t\t\t\t\toClasses.sStripeOdd,\n\t\t\t\t\toClasses.sStripeEven\n\t\t\t\t];\n\t\t\t}\n\t\t\t\n\t\t\t/* Remove row stripe classes if they are already on the table row */\n\t\t\tvar stripeClasses = oSettings.asStripeClasses;\n\t\t\tvar rowOne = $this.children('tbody').find('tr').eq(0);\n\t\t\tif ( $.inArray( true, $.map( stripeClasses, function(el, i) {\n\t\t\t\treturn rowOne.hasClass(el);\n\t\t\t} ) ) !== -1 ) {\n\t\t\t\t$('tbody tr', this).removeClass( stripeClasses.join(' ') );\n\t\t\t\toSettings.asDestroyStripes = stripeClasses.slice();\n\t\t\t}\n\t\t\t\n\t\t\t/*\n\t\t\t * Columns\n\t\t\t * See if we should load columns automatically or use defined ones\n\t\t\t */\n\t\t\tvar anThs = [];\n\t\t\tvar aoColumnsInit;\n\t\t\tvar nThead = this.getElementsByTagName('thead');\n\t\t\tif ( nThead.length !== 0 )\n\t\t\t{\n\t\t\t\t_fnDetectHeader( oSettings.aoHeader, nThead[0] );\n\t\t\t\tanThs = _fnGetUniqueThs( oSettings );\n\t\t\t}\n\t\t\t\n\t\t\t/* If not given a column array, generate one with nulls */\n\t\t\tif ( oInit.aoColumns === null )\n\t\t\t{\n\t\t\t\taoColumnsInit = [];\n\t\t\t\tfor ( i=0, iLen=anThs.length ; i<iLen ; i++ )\n\t\t\t\t{\n\t\t\t\t\taoColumnsInit.push( null );\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\taoColumnsInit = oInit.aoColumns;\n\t\t\t}\n\t\t\t\n\t\t\t/* Add the columns */\n\t\t\tfor ( i=0, iLen=aoColumnsInit.length ; i<iLen ; i++ )\n\t\t\t{\n\t\t\t\t_fnAddColumn( oSettings, anThs ? anThs[i] : null );\n\t\t\t}\n\t\t\t\n\t\t\t/* Apply the column definitions */\n\t\t\t_fnApplyColumnDefs( oSettings, oInit.aoColumnDefs, aoColumnsInit, function (iCol, oDef) {\n\t\t\t\t_fnColumnOptions( oSettings, iCol, oDef );\n\t\t\t} );\n\t\t\t\n\t\t\t/* HTML5 attribute detection - build an mData object automatically if the\n\t\t\t * attributes are found\n\t\t\t */\n\t\t\tif ( rowOne.length ) {\n\t\t\t\tvar a = function ( cell, name ) {\n\t\t\t\t\treturn cell.getAttribute( 'data-'+name ) !== null ? name : null;\n\t\t\t\t};\n\t\t\t\n\t\t\t\t$( rowOne[0] ).children('th, td').each( function (i, cell) {\n\t\t\t\t\tvar col = oSettings.aoColumns[i];\n\t\t\t\n\t\t\t\t\tif ( col.mData === i ) {\n\t\t\t\t\t\tvar sort = a( cell, 'sort' ) || a( cell, 'order' );\n\t\t\t\t\t\tvar filter = a( cell, 'filter' ) || a( cell, 'search' );\n\t\t\t\n\t\t\t\t\t\tif ( sort !== null || filter !== null ) {\n\t\t\t\t\t\t\tcol.mData = {\n\t\t\t\t\t\t\t\t_: i+'.display',\n\t\t\t\t\t\t\t\tsort: sort !== null ? i+'.@data-'+sort : undefined,\n\t\t\t\t\t\t\t\ttype: sort !== null ? i+'.@data-'+sort : undefined,\n\t\t\t\t\t\t\t\tfilter: filter !== null ? i+'.@data-'+filter : undefined\n\t\t\t\t\t\t\t};\n\t\t\t\n\t\t\t\t\t\t\t_fnColumnOptions( oSettings, i );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t}\n\t\t\t\n\t\t\tvar features = oSettings.oFeatures;\n\t\t\t\n\t\t\t/* Must be done after everything which can be overridden by the state saving! */\n\t\t\tif ( oInit.bStateSave )\n\t\t\t{\n\t\t\t\tfeatures.bStateSave = true;\n\t\t\t\t_fnLoadState( oSettings, oInit );\n\t\t\t\t_fnCallbackReg( oSettings, 'aoDrawCallback', _fnSaveState, 'state_save' );\n\t\t\t}\n\t\t\t\n\t\t\t\n\t\t\t/*\n\t\t\t * Sorting\n\t\t\t * @todo For modularisation (1.11) this needs to do into a sort start up handler\n\t\t\t */\n\t\t\t\n\t\t\t// If aaSorting is not defined, then we use the first indicator in asSorting\n\t\t\t// in case that has been altered, so the default sort reflects that option\n\t\t\tif ( oInit.aaSorting === undefined )\n\t\t\t{\n\t\t\t\tvar sorting = oSettings.aaSorting;\n\t\t\t\tfor ( i=0, iLen=sorting.length ; i<iLen ; i++ )\n\t\t\t\t{\n\t\t\t\t\tsorting[i][1] = oSettings.aoColumns[ i ].asSorting[0];\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\t/* Do a first pass on the sorting classes (allows any size changes to be taken into\n\t\t\t * account, and also will apply sorting disabled classes if disabled\n\t\t\t */\n\t\t\t_fnSortingClasses( oSettings );\n\t\t\t\n\t\t\tif ( features.bSort )\n\t\t\t{\n\t\t\t\t_fnCallbackReg( oSettings, 'aoDrawCallback', function () {\n\t\t\t\t\tif ( oSettings.bSorted ) {\n\t\t\t\t\t\tvar aSort = _fnSortFlatten( oSettings );\n\t\t\t\t\t\tvar sortedColumns = {};\n\t\t\t\n\t\t\t\t\t\t$.each( aSort, function (i, val) {\n\t\t\t\t\t\t\tsortedColumns[ val.src ] = val.dir;\n\t\t\t\t\t\t} );\n\t\t\t\n\t\t\t\t\t\t_fnCallbackFire( oSettings, null, 'order', [oSettings, aSort, sortedColumns] );\n\t\t\t\t\t\t_fnSortAria( oSettings );\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t}\n\t\t\t\n\t\t\t_fnCallbackReg( oSettings, 'aoDrawCallback', function () {\n\t\t\t\tif ( oSettings.bSorted || _fnDataSource( oSettings ) === 'ssp' || features.bDeferRender ) {\n\t\t\t\t\t_fnSortingClasses( oSettings );\n\t\t\t\t}\n\t\t\t}, 'sc' );\n\t\t\t\n\t\t\t\n\t\t\t/*\n\t\t\t * Final init\n\t\t\t * Cache the header, body and footer as required, creating them if needed\n\t\t\t */\n\t\t\t\n\t\t\t// Work around for Webkit bug 83867 - store the caption-side before removing from doc\n\t\t\tvar captions = $this.children('caption').each( function () {\n\t\t\t\tthis._captionSide = $this.css('caption-side');\n\t\t\t} );\n\t\t\t\n\t\t\tvar thead = $this.children('thead');\n\t\t\tif ( thead.length === 0 )\n\t\t\t{\n\t\t\t\tthead = $('<thead/>').appendTo(this);\n\t\t\t}\n\t\t\toSettings.nTHead = thead[0];\n\t\t\t\n\t\t\tvar tbody = $this.children('tbody');\n\t\t\tif ( tbody.length === 0 )\n\t\t\t{\n\t\t\t\ttbody = $('<tbody/>').appendTo(this);\n\t\t\t}\n\t\t\toSettings.nTBody = tbody[0];\n\t\t\t\n\t\t\tvar tfoot = $this.children('tfoot');\n\t\t\tif ( tfoot.length === 0 && captions.length > 0 && (oSettings.oScroll.sX !== \"\" || oSettings.oScroll.sY !== \"\") )\n\t\t\t{\n\t\t\t\t// If we are a scrolling table, and no footer has been given, then we need to create\n\t\t\t\t// a tfoot element for the caption element to be appended to\n\t\t\t\ttfoot = $('<tfoot/>').appendTo(this);\n\t\t\t}\n\t\t\t\n\t\t\tif ( tfoot.length === 0 || tfoot.children().length === 0 ) {\n\t\t\t\t$this.addClass( oClasses.sNoFooter );\n\t\t\t}\n\t\t\telse if ( tfoot.length > 0 ) {\n\t\t\t\toSettings.nTFoot = tfoot[0];\n\t\t\t\t_fnDetectHeader( oSettings.aoFooter, oSettings.nTFoot );\n\t\t\t}\n\t\t\t\n\t\t\t/* Check if there is data passing into the constructor */\n\t\t\tif ( oInit.aaData )\n\t\t\t{\n\t\t\t\tfor ( i=0 ; i<oInit.aaData.length ; i++ )\n\t\t\t\t{\n\t\t\t\t\t_fnAddData( oSettings, oInit.aaData[ i ] );\n\t\t\t\t}\n\t\t\t}\n\t\t\telse if ( oSettings.bDeferLoading || _fnDataSource( oSettings ) == 'dom' )\n\t\t\t{\n\t\t\t\t/* Grab the data from the page - only do this when deferred loading or no Ajax\n\t\t\t\t * source since there is no point in reading the DOM data if we are then going\n\t\t\t\t * to replace it with Ajax data\n\t\t\t\t */\n\t\t\t\t_fnAddTr( oSettings, $(oSettings.nTBody).children('tr') );\n\t\t\t}\n\t\t\t\n\t\t\t/* Copy the data index array */\n\t\t\toSettings.aiDisplay = oSettings.aiDisplayMaster.slice();\n\t\t\t\n\t\t\t/* Initialisation complete - table can be drawn */\n\t\t\toSettings.bInitialised = true;\n\t\t\t\n\t\t\t/* Check if we need to initialise the table (it might not have been handed off to the\n\t\t\t * language processor)\n\t\t\t */\n\t\t\tif ( bInitHandedOff === false )\n\t\t\t{\n\t\t\t\t_fnInitialise( oSettings );\n\t\t\t}\n\t\t} );\n\t\t_that = null;\n\t\treturn this;\n\t};\n\n\t\n\t/*\n\t * It is useful to have variables which are scoped locally so only the\n\t * DataTables functions can access them and they don't leak into global space.\n\t * At the same time these functions are often useful over multiple files in the\n\t * core and API, so we list, or at least document, all variables which are used\n\t * by DataTables as private variables here. This also ensures that there is no\n\t * clashing of variable names and that they can easily referenced for reuse.\n\t */\n\t\n\t\n\t// Defined else where\n\t// _selector_run\n\t// _selector_opts\n\t// _selector_first\n\t// _selector_row_indexes\n\t\n\tvar _ext; // DataTable.ext\n\tvar _Api; // DataTable.Api\n\tvar _api_register; // DataTable.Api.register\n\tvar _api_registerPlural; // DataTable.Api.registerPlural\n\t\n\tvar _re_dic = {};\n\tvar _re_new_lines = /[\\r\\n]/g;\n\tvar _re_html = /<.*?>/g;\n\tvar _re_date_start = /^[\\w\\+\\-]/;\n\tvar _re_date_end = /[\\w\\+\\-]$/;\n\t\n\t// Escape regular expression special characters\n\tvar _re_escape_regex = new RegExp( '(\\\\' + [ '/', '.', '*', '+', '?', '|', '(', ')', '[', ']', '{', '}', '\\\\', '$', '^', '-' ].join('|\\\\') + ')', 'g' );\n\t\n\t// http://en.wikipedia.org/wiki/Foreign_exchange_market\n\t// - \\u20BD - Russian ruble.\n\t// - \\u20a9 - South Korean Won\n\t// - \\u20BA - Turkish Lira\n\t// - \\u20B9 - Indian Rupee\n\t// - R - Brazil (R$) and South Africa\n\t// - fr - Swiss Franc\n\t// - kr - Swedish krona, Norwegian krone and Danish krone\n\t// - \\u2009 is thin space and \\u202F is narrow no-break space, both used in many\n\t// standards as thousands separators.\n\tvar _re_formatted_numeric = /[',$£€¥%\\u2009\\u202F\\u20BD\\u20a9\\u20BArfk]/gi;\n\t\n\t\n\tvar _empty = function ( d ) {\n\t\treturn !d || d === true || d === '-' ? true : false;\n\t};\n\t\n\t\n\tvar _intVal = function ( s ) {\n\t\tvar integer = parseInt( s, 10 );\n\t\treturn !isNaN(integer) && isFinite(s) ? integer : null;\n\t};\n\t\n\t// Convert from a formatted number with characters other than `.` as the\n\t// decimal place, to a Javascript number\n\tvar _numToDecimal = function ( num, decimalPoint ) {\n\t\t// Cache created regular expressions for speed as this function is called often\n\t\tif ( ! _re_dic[ decimalPoint ] ) {\n\t\t\t_re_dic[ decimalPoint ] = new RegExp( _fnEscapeRegex( decimalPoint ), 'g' );\n\t\t}\n\t\treturn typeof num === 'string' && decimalPoint !== '.' ?\n\t\t\tnum.replace( /\\./g, '' ).replace( _re_dic[ decimalPoint ], '.' ) :\n\t\t\tnum;\n\t};\n\t\n\t\n\tvar _isNumber = function ( d, decimalPoint, formatted ) {\n\t\tvar strType = typeof d === 'string';\n\t\n\t\t// If empty return immediately so there must be a number if it is a\n\t\t// formatted string (this stops the string \"k\", or \"kr\", etc being detected\n\t\t// as a formatted number for currency\n\t\tif ( _empty( d ) ) {\n\t\t\treturn true;\n\t\t}\n\t\n\t\tif ( decimalPoint && strType ) {\n\t\t\td = _numToDecimal( d, decimalPoint );\n\t\t}\n\t\n\t\tif ( formatted && strType ) {\n\t\t\td = d.replace( _re_formatted_numeric, '' );\n\t\t}\n\t\n\t\treturn !isNaN( parseFloat(d) ) && isFinite( d );\n\t};\n\t\n\t\n\t// A string without HTML in it can be considered to be HTML still\n\tvar _isHtml = function ( d ) {\n\t\treturn _empty( d ) || typeof d === 'string';\n\t};\n\t\n\t\n\tvar _htmlNumeric = function ( d, decimalPoint, formatted ) {\n\t\tif ( _empty( d ) ) {\n\t\t\treturn true;\n\t\t}\n\t\n\t\tvar html = _isHtml( d );\n\t\treturn ! html ?\n\t\t\tnull :\n\t\t\t_isNumber( _stripHtml( d ), decimalPoint, formatted ) ?\n\t\t\t\ttrue :\n\t\t\t\tnull;\n\t};\n\t\n\t\n\tvar _pluck = function ( a, prop, prop2 ) {\n\t\tvar out = [];\n\t\tvar i=0, ien=a.length;\n\t\n\t\t// Could have the test in the loop for slightly smaller code, but speed\n\t\t// is essential here\n\t\tif ( prop2 !== undefined ) {\n\t\t\tfor ( ; i<ien ; i++ ) {\n\t\t\t\tif ( a[i] && a[i][ prop ] ) {\n\t\t\t\t\tout.push( a[i][ prop ][ prop2 ] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tfor ( ; i<ien ; i++ ) {\n\t\t\t\tif ( a[i] ) {\n\t\t\t\t\tout.push( a[i][ prop ] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\treturn out;\n\t};\n\t\n\t\n\t// Basically the same as _pluck, but rather than looping over `a` we use `order`\n\t// as the indexes to pick from `a`\n\tvar _pluck_order = function ( a, order, prop, prop2 )\n\t{\n\t\tvar out = [];\n\t\tvar i=0, ien=order.length;\n\t\n\t\t// Could have the test in the loop for slightly smaller code, but speed\n\t\t// is essential here\n\t\tif ( prop2 !== undefined ) {\n\t\t\tfor ( ; i<ien ; i++ ) {\n\t\t\t\tif ( a[ order[i] ][ prop ] ) {\n\t\t\t\t\tout.push( a[ order[i] ][ prop ][ prop2 ] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tfor ( ; i<ien ; i++ ) {\n\t\t\t\tout.push( a[ order[i] ][ prop ] );\n\t\t\t}\n\t\t}\n\t\n\t\treturn out;\n\t};\n\t\n\t\n\tvar _range = function ( len, start )\n\t{\n\t\tvar out = [];\n\t\tvar end;\n\t\n\t\tif ( start === undefined ) {\n\t\t\tstart = 0;\n\t\t\tend = len;\n\t\t}\n\t\telse {\n\t\t\tend = start;\n\t\t\tstart = len;\n\t\t}\n\t\n\t\tfor ( var i=start ; i<end ; i++ ) {\n\t\t\tout.push( i );\n\t\t}\n\t\n\t\treturn out;\n\t};\n\t\n\t\n\tvar _removeEmpty = function ( a )\n\t{\n\t\tvar out = [];\n\t\n\t\tfor ( var i=0, ien=a.length ; i<ien ; i++ ) {\n\t\t\tif ( a[i] ) { // careful - will remove all falsy values!\n\t\t\t\tout.push( a[i] );\n\t\t\t}\n\t\t}\n\t\n\t\treturn out;\n\t};\n\t\n\t\n\tvar _stripHtml = function ( d ) {\n\t\treturn d.replace( _re_html, '' );\n\t};\n\t\n\t\n\t/**\n\t * Find the unique elements in a source array.\n\t *\n\t * @param {array} src Source array\n\t * @return {array} Array of unique items\n\t * @ignore\n\t */\n\tvar _unique = function ( src )\n\t{\n\t\t// A faster unique method is to use object keys to identify used values,\n\t\t// but this doesn't work with arrays or objects, which we must also\n\t\t// consider. See jsperf.com/compare-array-unique-versions/4 for more\n\t\t// information.\n\t\tvar\n\t\t\tout = [],\n\t\t\tval,\n\t\t\ti, ien=src.length,\n\t\t\tj, k=0;\n\t\n\t\tagain: for ( i=0 ; i<ien ; i++ ) {\n\t\t\tval = src[i];\n\t\n\t\t\tfor ( j=0 ; j<k ; j++ ) {\n\t\t\t\tif ( out[j] === val ) {\n\t\t\t\t\tcontinue again;\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\tout.push( val );\n\t\t\tk++;\n\t\t}\n\t\n\t\treturn out;\n\t};\n\t\n\t\n\t/**\n\t * DataTables utility methods\n\t * \n\t * This namespace provides helper methods that DataTables uses internally to\n\t * create a DataTable, but which are not exclusively used only for DataTables.\n\t * These methods can be used by extension authors to save the duplication of\n\t * code.\n\t *\n\t * @namespace\n\t */\n\tDataTable.util = {\n\t\t/**\n\t\t * Throttle the calls to a function. Arguments and context are maintained\n\t\t * for the throttled function.\n\t\t *\n\t\t * @param {function} fn Function to be called\n\t\t * @param {integer} freq Call frequency in mS\n\t\t * @return {function} Wrapped function\n\t\t */\n\t\tthrottle: function ( fn, freq ) {\n\t\t\tvar\n\t\t\t\tfrequency = freq !== undefined ? freq : 200,\n\t\t\t\tlast,\n\t\t\t\ttimer;\n\t\n\t\t\treturn function () {\n\t\t\t\tvar\n\t\t\t\t\tthat = this,\n\t\t\t\t\tnow = +new Date(),\n\t\t\t\t\targs = arguments;\n\t\n\t\t\t\tif ( last && now < last + frequency ) {\n\t\t\t\t\tclearTimeout( timer );\n\t\n\t\t\t\t\ttimer = setTimeout( function () {\n\t\t\t\t\t\tlast = undefined;\n\t\t\t\t\t\tfn.apply( that, args );\n\t\t\t\t\t}, frequency );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tlast = now;\n\t\t\t\t\tfn.apply( that, args );\n\t\t\t\t}\n\t\t\t};\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Escape a string such that it can be used in a regular expression\n\t\t *\n\t\t * @param {string} val string to escape\n\t\t * @returns {string} escaped string\n\t\t */\n\t\tescapeRegex: function ( val ) {\n\t\t\treturn val.replace( _re_escape_regex, '\\\\$1' );\n\t\t}\n\t};\n\t\n\t\n\t\n\t/**\n\t * Create a mapping object that allows camel case parameters to be looked up\n\t * for their Hungarian counterparts. The mapping is stored in a private\n\t * parameter called `_hungarianMap` which can be accessed on the source object.\n\t * @param {object} o\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnHungarianMap ( o )\n\t{\n\t\tvar\n\t\t\thungarian = 'a aa ai ao as b fn i m o s ',\n\t\t\tmatch,\n\t\t\tnewKey,\n\t\t\tmap = {};\n\t\n\t\t$.each( o, function (key, val) {\n\t\t\tmatch = key.match(/^([^A-Z]+?)([A-Z])/);\n\t\n\t\t\tif ( match && hungarian.indexOf(match[1]+' ') !== -1 )\n\t\t\t{\n\t\t\t\tnewKey = key.replace( match[0], match[2].toLowerCase() );\n\t\t\t\tmap[ newKey ] = key;\n\t\n\t\t\t\tif ( match[1] === 'o' )\n\t\t\t\t{\n\t\t\t\t\t_fnHungarianMap( o[key] );\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t\n\t\to._hungarianMap = map;\n\t}\n\t\n\t\n\t/**\n\t * Convert from camel case parameters to Hungarian, based on a Hungarian map\n\t * created by _fnHungarianMap.\n\t * @param {object} src The model object which holds all parameters that can be\n\t * mapped.\n\t * @param {object} user The object to convert from camel case to Hungarian.\n\t * @param {boolean} force When set to `true`, properties which already have a\n\t * Hungarian value in the `user` object will be overwritten. Otherwise they\n\t * won't be.\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnCamelToHungarian ( src, user, force )\n\t{\n\t\tif ( ! src._hungarianMap ) {\n\t\t\t_fnHungarianMap( src );\n\t\t}\n\t\n\t\tvar hungarianKey;\n\t\n\t\t$.each( user, function (key, val) {\n\t\t\thungarianKey = src._hungarianMap[ key ];\n\t\n\t\t\tif ( hungarianKey !== undefined && (force || user[hungarianKey] === undefined) )\n\t\t\t{\n\t\t\t\t// For objects, we need to buzz down into the object to copy parameters\n\t\t\t\tif ( hungarianKey.charAt(0) === 'o' )\n\t\t\t\t{\n\t\t\t\t\t// Copy the camelCase options over to the hungarian\n\t\t\t\t\tif ( ! user[ hungarianKey ] ) {\n\t\t\t\t\t\tuser[ hungarianKey ] = {};\n\t\t\t\t\t}\n\t\t\t\t\t$.extend( true, user[hungarianKey], user[key] );\n\t\n\t\t\t\t\t_fnCamelToHungarian( src[hungarianKey], user[hungarianKey], force );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tuser[hungarianKey] = user[ key ];\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t}\n\t\n\t\n\t/**\n\t * Language compatibility - when certain options are given, and others aren't, we\n\t * need to duplicate the values over, in order to provide backwards compatibility\n\t * with older language files.\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnLanguageCompat( lang )\n\t{\n\t\tvar defaults = DataTable.defaults.oLanguage;\n\t\tvar zeroRecords = lang.sZeroRecords;\n\t\n\t\t/* Backwards compatibility - if there is no sEmptyTable given, then use the same as\n\t\t * sZeroRecords - assuming that is given.\n\t\t */\n\t\tif ( ! lang.sEmptyTable && zeroRecords &&\n\t\t\tdefaults.sEmptyTable === \"No data available in table\" )\n\t\t{\n\t\t\t_fnMap( lang, lang, 'sZeroRecords', 'sEmptyTable' );\n\t\t}\n\t\n\t\t/* Likewise with loading records */\n\t\tif ( ! lang.sLoadingRecords && zeroRecords &&\n\t\t\tdefaults.sLoadingRecords === \"Loading...\" )\n\t\t{\n\t\t\t_fnMap( lang, lang, 'sZeroRecords', 'sLoadingRecords' );\n\t\t}\n\t\n\t\t// Old parameter name of the thousands separator mapped onto the new\n\t\tif ( lang.sInfoThousands ) {\n\t\t\tlang.sThousands = lang.sInfoThousands;\n\t\t}\n\t\n\t\tvar decimal = lang.sDecimal;\n\t\tif ( decimal ) {\n\t\t\t_addNumericSort( decimal );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Map one parameter onto another\n\t * @param {object} o Object to map\n\t * @param {*} knew The new parameter name\n\t * @param {*} old The old parameter name\n\t */\n\tvar _fnCompatMap = function ( o, knew, old ) {\n\t\tif ( o[ knew ] !== undefined ) {\n\t\t\to[ old ] = o[ knew ];\n\t\t}\n\t};\n\t\n\t\n\t/**\n\t * Provide backwards compatibility for the main DT options. Note that the new\n\t * options are mapped onto the old parameters, so this is an external interface\n\t * change only.\n\t * @param {object} init Object to map\n\t */\n\tfunction _fnCompatOpts ( init )\n\t{\n\t\t_fnCompatMap( init, 'ordering', 'bSort' );\n\t\t_fnCompatMap( init, 'orderMulti', 'bSortMulti' );\n\t\t_fnCompatMap( init, 'orderClasses', 'bSortClasses' );\n\t\t_fnCompatMap( init, 'orderCellsTop', 'bSortCellsTop' );\n\t\t_fnCompatMap( init, 'order', 'aaSorting' );\n\t\t_fnCompatMap( init, 'orderFixed', 'aaSortingFixed' );\n\t\t_fnCompatMap( init, 'paging', 'bPaginate' );\n\t\t_fnCompatMap( init, 'pagingType', 'sPaginationType' );\n\t\t_fnCompatMap( init, 'pageLength', 'iDisplayLength' );\n\t\t_fnCompatMap( init, 'searching', 'bFilter' );\n\t\n\t\t// Boolean initialisation of x-scrolling\n\t\tif ( typeof init.sScrollX === 'boolean' ) {\n\t\t\tinit.sScrollX = init.sScrollX ? '100%' : '';\n\t\t}\n\t\tif ( typeof init.scrollX === 'boolean' ) {\n\t\t\tinit.scrollX = init.scrollX ? '100%' : '';\n\t\t}\n\t\n\t\t// Column search objects are in an array, so it needs to be converted\n\t\t// element by element\n\t\tvar searchCols = init.aoSearchCols;\n\t\n\t\tif ( searchCols ) {\n\t\t\tfor ( var i=0, ien=searchCols.length ; i<ien ; i++ ) {\n\t\t\t\tif ( searchCols[i] ) {\n\t\t\t\t\t_fnCamelToHungarian( DataTable.models.oSearch, searchCols[i] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Provide backwards compatibility for column options. Note that the new options\n\t * are mapped onto the old parameters, so this is an external interface change\n\t * only.\n\t * @param {object} init Object to map\n\t */\n\tfunction _fnCompatCols ( init )\n\t{\n\t\t_fnCompatMap( init, 'orderable', 'bSortable' );\n\t\t_fnCompatMap( init, 'orderData', 'aDataSort' );\n\t\t_fnCompatMap( init, 'orderSequence', 'asSorting' );\n\t\t_fnCompatMap( init, 'orderDataType', 'sortDataType' );\n\t\n\t\t// orderData can be given as an integer\n\t\tvar dataSort = init.aDataSort;\n\t\tif ( dataSort && ! $.isArray( dataSort ) ) {\n\t\t\tinit.aDataSort = [ dataSort ];\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Browser feature detection for capabilities, quirks\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnBrowserDetect( settings )\n\t{\n\t\t// We don't need to do this every time DataTables is constructed, the values\n\t\t// calculated are specific to the browser and OS configuration which we\n\t\t// don't expect to change between initialisations\n\t\tif ( ! DataTable.__browser ) {\n\t\t\tvar browser = {};\n\t\t\tDataTable.__browser = browser;\n\t\n\t\t\t// Scrolling feature / quirks detection\n\t\t\tvar n = $('<div/>')\n\t\t\t\t.css( {\n\t\t\t\t\tposition: 'fixed',\n\t\t\t\t\ttop: 0,\n\t\t\t\t\tleft: 0,\n\t\t\t\t\theight: 1,\n\t\t\t\t\twidth: 1,\n\t\t\t\t\toverflow: 'hidden'\n\t\t\t\t} )\n\t\t\t\t.append(\n\t\t\t\t\t$('<div/>')\n\t\t\t\t\t\t.css( {\n\t\t\t\t\t\t\tposition: 'absolute',\n\t\t\t\t\t\t\ttop: 1,\n\t\t\t\t\t\t\tleft: 1,\n\t\t\t\t\t\t\twidth: 100,\n\t\t\t\t\t\t\toverflow: 'scroll'\n\t\t\t\t\t\t} )\n\t\t\t\t\t\t.append(\n\t\t\t\t\t\t\t$('<div/>')\n\t\t\t\t\t\t\t\t.css( {\n\t\t\t\t\t\t\t\t\twidth: '100%',\n\t\t\t\t\t\t\t\t\theight: 10\n\t\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t)\n\t\t\t\t)\n\t\t\t\t.appendTo( 'body' );\n\t\n\t\t\tvar outer = n.children();\n\t\t\tvar inner = outer.children();\n\t\n\t\t\t// Numbers below, in order, are:\n\t\t\t// inner.offsetWidth, inner.clientWidth, outer.offsetWidth, outer.clientWidth\n\t\t\t//\n\t\t\t// IE6 XP: 100 100 100 83\n\t\t\t// IE7 Vista: 100 100 100 83\n\t\t\t// IE 8+ Windows: 83 83 100 83\n\t\t\t// Evergreen Windows: 83 83 100 83\n\t\t\t// Evergreen Mac with scrollbars: 85 85 100 85\n\t\t\t// Evergreen Mac without scrollbars: 100 100 100 100\n\t\n\t\t\t// Get scrollbar width\n\t\t\tbrowser.barWidth = outer[0].offsetWidth - outer[0].clientWidth;\n\t\n\t\t\t// IE6/7 will oversize a width 100% element inside a scrolling element, to\n\t\t\t// include the width of the scrollbar, while other browsers ensure the inner\n\t\t\t// element is contained without forcing scrolling\n\t\t\tbrowser.bScrollOversize = inner[0].offsetWidth === 100 && outer[0].clientWidth !== 100;\n\t\n\t\t\t// In rtl text layout, some browsers (most, but not all) will place the\n\t\t\t// scrollbar on the left, rather than the right.\n\t\t\tbrowser.bScrollbarLeft = Math.round( inner.offset().left ) !== 1;\n\t\n\t\t\t// IE8- don't provide height and width for getBoundingClientRect\n\t\t\tbrowser.bBounding = n[0].getBoundingClientRect().width ? true : false;\n\t\n\t\t\tn.remove();\n\t\t}\n\t\n\t\t$.extend( settings.oBrowser, DataTable.__browser );\n\t\tsettings.oScroll.iBarWidth = DataTable.__browser.barWidth;\n\t}\n\t\n\t\n\t/**\n\t * Array.prototype reduce[Right] method, used for browsers which don't support\n\t * JS 1.6. Done this way to reduce code size, since we iterate either way\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnReduce ( that, fn, init, start, end, inc )\n\t{\n\t\tvar\n\t\t\ti = start,\n\t\t\tvalue,\n\t\t\tisSet = false;\n\t\n\t\tif ( init !== undefined ) {\n\t\t\tvalue = init;\n\t\t\tisSet = true;\n\t\t}\n\t\n\t\twhile ( i !== end ) {\n\t\t\tif ( ! that.hasOwnProperty(i) ) {\n\t\t\t\tcontinue;\n\t\t\t}\n\t\n\t\t\tvalue = isSet ?\n\t\t\t\tfn( value, that[i], i, that ) :\n\t\t\t\tthat[i];\n\t\n\t\t\tisSet = true;\n\t\t\ti += inc;\n\t\t}\n\t\n\t\treturn value;\n\t}\n\t\n\t/**\n\t * Add a column to the list used for the table with default values\n\t * @param {object} oSettings dataTables settings object\n\t * @param {node} nTh The th element for this column\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAddColumn( oSettings, nTh )\n\t{\n\t\t// Add column to aoColumns array\n\t\tvar oDefaults = DataTable.defaults.column;\n\t\tvar iCol = oSettings.aoColumns.length;\n\t\tvar oCol = $.extend( {}, DataTable.models.oColumn, oDefaults, {\n\t\t\t\"nTh\": nTh ? nTh : document.createElement('th'),\n\t\t\t\"sTitle\": oDefaults.sTitle ? oDefaults.sTitle : nTh ? nTh.innerHTML : '',\n\t\t\t\"aDataSort\": oDefaults.aDataSort ? oDefaults.aDataSort : [iCol],\n\t\t\t\"mData\": oDefaults.mData ? oDefaults.mData : iCol,\n\t\t\tidx: iCol\n\t\t} );\n\t\toSettings.aoColumns.push( oCol );\n\t\n\t\t// Add search object for column specific search. Note that the `searchCols[ iCol ]`\n\t\t// passed into extend can be undefined. This allows the user to give a default\n\t\t// with only some of the parameters defined, and also not give a default\n\t\tvar searchCols = oSettings.aoPreSearchCols;\n\t\tsearchCols[ iCol ] = $.extend( {}, DataTable.models.oSearch, searchCols[ iCol ] );\n\t\n\t\t// Use the default column options function to initialise classes etc\n\t\t_fnColumnOptions( oSettings, iCol, $(nTh).data() );\n\t}\n\t\n\t\n\t/**\n\t * Apply options for a column\n\t * @param {object} oSettings dataTables settings object\n\t * @param {int} iCol column index to consider\n\t * @param {object} oOptions object with sType, bVisible and bSearchable etc\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnColumnOptions( oSettings, iCol, oOptions )\n\t{\n\t\tvar oCol = oSettings.aoColumns[ iCol ];\n\t\tvar oClasses = oSettings.oClasses;\n\t\tvar th = $(oCol.nTh);\n\t\n\t\t// Try to get width information from the DOM. We can't get it from CSS\n\t\t// as we'd need to parse the CSS stylesheet. `width` option can override\n\t\tif ( ! oCol.sWidthOrig ) {\n\t\t\t// Width attribute\n\t\t\toCol.sWidthOrig = th.attr('width') || null;\n\t\n\t\t\t// Style attribute\n\t\t\tvar t = (th.attr('style') || '').match(/width:\\s*(\\d+[pxem%]+)/);\n\t\t\tif ( t ) {\n\t\t\t\toCol.sWidthOrig = t[1];\n\t\t\t}\n\t\t}\n\t\n\t\t/* User specified column options */\n\t\tif ( oOptions !== undefined && oOptions !== null )\n\t\t{\n\t\t\t// Backwards compatibility\n\t\t\t_fnCompatCols( oOptions );\n\t\n\t\t\t// Map camel case parameters to their Hungarian counterparts\n\t\t\t_fnCamelToHungarian( DataTable.defaults.column, oOptions );\n\t\n\t\t\t/* Backwards compatibility for mDataProp */\n\t\t\tif ( oOptions.mDataProp !== undefined && !oOptions.mData )\n\t\t\t{\n\t\t\t\toOptions.mData = oOptions.mDataProp;\n\t\t\t}\n\t\n\t\t\tif ( oOptions.sType )\n\t\t\t{\n\t\t\t\toCol._sManualType = oOptions.sType;\n\t\t\t}\n\t\n\t\t\t// `class` is a reserved word in Javascript, so we need to provide\n\t\t\t// the ability to use a valid name for the camel case input\n\t\t\tif ( oOptions.className && ! oOptions.sClass )\n\t\t\t{\n\t\t\t\toOptions.sClass = oOptions.className;\n\t\t\t}\n\t\n\t\t\t$.extend( oCol, oOptions );\n\t\t\t_fnMap( oCol, oOptions, \"sWidth\", \"sWidthOrig\" );\n\t\n\t\t\t/* iDataSort to be applied (backwards compatibility), but aDataSort will take\n\t\t\t * priority if defined\n\t\t\t */\n\t\t\tif ( oOptions.iDataSort !== undefined )\n\t\t\t{\n\t\t\t\toCol.aDataSort = [ oOptions.iDataSort ];\n\t\t\t}\n\t\t\t_fnMap( oCol, oOptions, \"aDataSort\" );\n\t\t}\n\t\n\t\t/* Cache the data get and set functions for speed */\n\t\tvar mDataSrc = oCol.mData;\n\t\tvar mData = _fnGetObjectDataFn( mDataSrc );\n\t\tvar mRender = oCol.mRender ? _fnGetObjectDataFn( oCol.mRender ) : null;\n\t\n\t\tvar attrTest = function( src ) {\n\t\t\treturn typeof src === 'string' && src.indexOf('@') !== -1;\n\t\t};\n\t\toCol._bAttrSrc = $.isPlainObject( mDataSrc ) && (\n\t\t\tattrTest(mDataSrc.sort) || attrTest(mDataSrc.type) || attrTest(mDataSrc.filter)\n\t\t);\n\t\toCol._setter = null;\n\t\n\t\toCol.fnGetData = function (rowData, type, meta) {\n\t\t\tvar innerData = mData( rowData, type, undefined, meta );\n\t\n\t\t\treturn mRender && type ?\n\t\t\t\tmRender( innerData, type, rowData, meta ) :\n\t\t\t\tinnerData;\n\t\t};\n\t\toCol.fnSetData = function ( rowData, val, meta ) {\n\t\t\treturn _fnSetObjectDataFn( mDataSrc )( rowData, val, meta );\n\t\t};\n\t\n\t\t// Indicate if DataTables should read DOM data as an object or array\n\t\t// Used in _fnGetRowElements\n\t\tif ( typeof mDataSrc !== 'number' ) {\n\t\t\toSettings._rowReadObject = true;\n\t\t}\n\t\n\t\t/* Feature sorting overrides column specific when off */\n\t\tif ( !oSettings.oFeatures.bSort )\n\t\t{\n\t\t\toCol.bSortable = false;\n\t\t\tth.addClass( oClasses.sSortableNone ); // Have to add class here as order event isn't called\n\t\t}\n\t\n\t\t/* Check that the class assignment is correct for sorting */\n\t\tvar bAsc = $.inArray('asc', oCol.asSorting) !== -1;\n\t\tvar bDesc = $.inArray('desc', oCol.asSorting) !== -1;\n\t\tif ( !oCol.bSortable || (!bAsc && !bDesc) )\n\t\t{\n\t\t\toCol.sSortingClass = oClasses.sSortableNone;\n\t\t\toCol.sSortingClassJUI = \"\";\n\t\t}\n\t\telse if ( bAsc && !bDesc )\n\t\t{\n\t\t\toCol.sSortingClass = oClasses.sSortableAsc;\n\t\t\toCol.sSortingClassJUI = oClasses.sSortJUIAscAllowed;\n\t\t}\n\t\telse if ( !bAsc && bDesc )\n\t\t{\n\t\t\toCol.sSortingClass = oClasses.sSortableDesc;\n\t\t\toCol.sSortingClassJUI = oClasses.sSortJUIDescAllowed;\n\t\t}\n\t\telse\n\t\t{\n\t\t\toCol.sSortingClass = oClasses.sSortable;\n\t\t\toCol.sSortingClassJUI = oClasses.sSortJUI;\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Adjust the table column widths for new data. Note: you would probably want to\n\t * do a redraw after calling this function!\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAdjustColumnSizing ( settings )\n\t{\n\t\t/* Not interested in doing column width calculation if auto-width is disabled */\n\t\tif ( settings.oFeatures.bAutoWidth !== false )\n\t\t{\n\t\t\tvar columns = settings.aoColumns;\n\t\n\t\t\t_fnCalculateColumnWidths( settings );\n\t\t\tfor ( var i=0 , iLen=columns.length ; i<iLen ; i++ )\n\t\t\t{\n\t\t\t\tcolumns[i].nTh.style.width = columns[i].sWidth;\n\t\t\t}\n\t\t}\n\t\n\t\tvar scroll = settings.oScroll;\n\t\tif ( scroll.sY !== '' || scroll.sX !== '')\n\t\t{\n\t\t\t_fnScrollDraw( settings );\n\t\t}\n\t\n\t\t_fnCallbackFire( settings, null, 'column-sizing', [settings] );\n\t}\n\t\n\t\n\t/**\n\t * Covert the index of a visible column to the index in the data array (take account\n\t * of hidden columns)\n\t * @param {object} oSettings dataTables settings object\n\t * @param {int} iMatch Visible column index to lookup\n\t * @returns {int} i the data index\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnVisibleToColumnIndex( oSettings, iMatch )\n\t{\n\t\tvar aiVis = _fnGetColumns( oSettings, 'bVisible' );\n\t\n\t\treturn typeof aiVis[iMatch] === 'number' ?\n\t\t\taiVis[iMatch] :\n\t\t\tnull;\n\t}\n\t\n\t\n\t/**\n\t * Covert the index of an index in the data array and convert it to the visible\n\t * column index (take account of hidden columns)\n\t * @param {int} iMatch Column index to lookup\n\t * @param {object} oSettings dataTables settings object\n\t * @returns {int} i the data index\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnColumnIndexToVisible( oSettings, iMatch )\n\t{\n\t\tvar aiVis = _fnGetColumns( oSettings, 'bVisible' );\n\t\tvar iPos = $.inArray( iMatch, aiVis );\n\t\n\t\treturn iPos !== -1 ? iPos : null;\n\t}\n\t\n\t\n\t/**\n\t * Get the number of visible columns\n\t * @param {object} oSettings dataTables settings object\n\t * @returns {int} i the number of visible columns\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnVisbleColumns( oSettings )\n\t{\n\t\tvar vis = 0;\n\t\n\t\t// No reduce in IE8, use a loop for now\n\t\t$.each( oSettings.aoColumns, function ( i, col ) {\n\t\t\tif ( col.bVisible && $(col.nTh).css('display') !== 'none' ) {\n\t\t\t\tvis++;\n\t\t\t}\n\t\t} );\n\t\n\t\treturn vis;\n\t}\n\t\n\t\n\t/**\n\t * Get an array of column indexes that match a given property\n\t * @param {object} oSettings dataTables settings object\n\t * @param {string} sParam Parameter in aoColumns to look for - typically\n\t * bVisible or bSearchable\n\t * @returns {array} Array of indexes with matched properties\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetColumns( oSettings, sParam )\n\t{\n\t\tvar a = [];\n\t\n\t\t$.map( oSettings.aoColumns, function(val, i) {\n\t\t\tif ( val[sParam] ) {\n\t\t\t\ta.push( i );\n\t\t\t}\n\t\t} );\n\t\n\t\treturn a;\n\t}\n\t\n\t\n\t/**\n\t * Calculate the 'type' of a column\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnColumnTypes ( settings )\n\t{\n\t\tvar columns = settings.aoColumns;\n\t\tvar data = settings.aoData;\n\t\tvar types = DataTable.ext.type.detect;\n\t\tvar i, ien, j, jen, k, ken;\n\t\tvar col, cell, detectedType, cache;\n\t\n\t\t// For each column, spin over the \n\t\tfor ( i=0, ien=columns.length ; i<ien ; i++ ) {\n\t\t\tcol = columns[i];\n\t\t\tcache = [];\n\t\n\t\t\tif ( ! col.sType && col._sManualType ) {\n\t\t\t\tcol.sType = col._sManualType;\n\t\t\t}\n\t\t\telse if ( ! col.sType ) {\n\t\t\t\tfor ( j=0, jen=types.length ; j<jen ; j++ ) {\n\t\t\t\t\tfor ( k=0, ken=data.length ; k<ken ; k++ ) {\n\t\t\t\t\t\t// Use a cache array so we only need to get the type data\n\t\t\t\t\t\t// from the formatter once (when using multiple detectors)\n\t\t\t\t\t\tif ( cache[k] === undefined ) {\n\t\t\t\t\t\t\tcache[k] = _fnGetCellData( settings, k, i, 'type' );\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\tdetectedType = types[j]( cache[k], settings );\n\t\n\t\t\t\t\t\t// If null, then this type can't apply to this column, so\n\t\t\t\t\t\t// rather than testing all cells, break out. There is an\n\t\t\t\t\t\t// exception for the last type which is `html`. We need to\n\t\t\t\t\t\t// scan all rows since it is possible to mix string and HTML\n\t\t\t\t\t\t// types\n\t\t\t\t\t\tif ( ! detectedType && j !== types.length-1 ) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t// Only a single match is needed for html type since it is\n\t\t\t\t\t\t// bottom of the pile and very similar to string\n\t\t\t\t\t\tif ( detectedType === 'html' ) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\n\t\t\t\t\t// Type is valid for all data points in the column - use this\n\t\t\t\t\t// type\n\t\t\t\t\tif ( detectedType ) {\n\t\t\t\t\t\tcol.sType = detectedType;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\t// Fall back - if no type was detected, always use string\n\t\t\t\tif ( ! col.sType ) {\n\t\t\t\t\tcol.sType = 'string';\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Take the column definitions and static columns arrays and calculate how\n\t * they relate to column indexes. The callback function will then apply the\n\t * definition found for a column to a suitable configuration object.\n\t * @param {object} oSettings dataTables settings object\n\t * @param {array} aoColDefs The aoColumnDefs array that is to be applied\n\t * @param {array} aoCols The aoColumns array that defines columns individually\n\t * @param {function} fn Callback function - takes two parameters, the calculated\n\t * column index and the definition for that column.\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnApplyColumnDefs( oSettings, aoColDefs, aoCols, fn )\n\t{\n\t\tvar i, iLen, j, jLen, k, kLen, def;\n\t\tvar columns = oSettings.aoColumns;\n\t\n\t\t// Column definitions with aTargets\n\t\tif ( aoColDefs )\n\t\t{\n\t\t\t/* Loop over the definitions array - loop in reverse so first instance has priority */\n\t\t\tfor ( i=aoColDefs.length-1 ; i>=0 ; i-- )\n\t\t\t{\n\t\t\t\tdef = aoColDefs[i];\n\t\n\t\t\t\t/* Each definition can target multiple columns, as it is an array */\n\t\t\t\tvar aTargets = def.targets !== undefined ?\n\t\t\t\t\tdef.targets :\n\t\t\t\t\tdef.aTargets;\n\t\n\t\t\t\tif ( ! $.isArray( aTargets ) )\n\t\t\t\t{\n\t\t\t\t\taTargets = [ aTargets ];\n\t\t\t\t}\n\t\n\t\t\t\tfor ( j=0, jLen=aTargets.length ; j<jLen ; j++ )\n\t\t\t\t{\n\t\t\t\t\tif ( typeof aTargets[j] === 'number' && aTargets[j] >= 0 )\n\t\t\t\t\t{\n\t\t\t\t\t\t/* Add columns that we don't yet know about */\n\t\t\t\t\t\twhile( columns.length <= aTargets[j] )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t_fnAddColumn( oSettings );\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t/* Integer, basic index */\n\t\t\t\t\t\tfn( aTargets[j], def );\n\t\t\t\t\t}\n\t\t\t\t\telse if ( typeof aTargets[j] === 'number' && aTargets[j] < 0 )\n\t\t\t\t\t{\n\t\t\t\t\t\t/* Negative integer, right to left column counting */\n\t\t\t\t\t\tfn( columns.length+aTargets[j], def );\n\t\t\t\t\t}\n\t\t\t\t\telse if ( typeof aTargets[j] === 'string' )\n\t\t\t\t\t{\n\t\t\t\t\t\t/* Class name matching on TH element */\n\t\t\t\t\t\tfor ( k=0, kLen=columns.length ; k<kLen ; k++ )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif ( aTargets[j] == \"_all\" ||\n\t\t\t\t\t\t\t $(columns[k].nTh).hasClass( aTargets[j] ) )\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfn( k, def );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\t// Statically defined columns array\n\t\tif ( aoCols )\n\t\t{\n\t\t\tfor ( i=0, iLen=aoCols.length ; i<iLen ; i++ )\n\t\t\t{\n\t\t\t\tfn( i, aoCols[i] );\n\t\t\t}\n\t\t}\n\t}\n\t\n\t/**\n\t * Add a data array to the table, creating DOM node etc. This is the parallel to\n\t * _fnGatherData, but for adding rows from a Javascript source, rather than a\n\t * DOM source.\n\t * @param {object} oSettings dataTables settings object\n\t * @param {array} aData data array to be added\n\t * @param {node} [nTr] TR element to add to the table - optional. If not given,\n\t * DataTables will create a row automatically\n\t * @param {array} [anTds] Array of TD|TH elements for the row - must be given\n\t * if nTr is.\n\t * @returns {int} >=0 if successful (index of new aoData entry), -1 if failed\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAddData ( oSettings, aDataIn, nTr, anTds )\n\t{\n\t\t/* Create the object for storing information about this new row */\n\t\tvar iRow = oSettings.aoData.length;\n\t\tvar oData = $.extend( true, {}, DataTable.models.oRow, {\n\t\t\tsrc: nTr ? 'dom' : 'data',\n\t\t\tidx: iRow\n\t\t} );\n\t\n\t\toData._aData = aDataIn;\n\t\toSettings.aoData.push( oData );\n\t\n\t\t/* Create the cells */\n\t\tvar nTd, sThisType;\n\t\tvar columns = oSettings.aoColumns;\n\t\n\t\t// Invalidate the column types as the new data needs to be revalidated\n\t\tfor ( var i=0, iLen=columns.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tcolumns[i].sType = null;\n\t\t}\n\t\n\t\t/* Add to the display array */\n\t\toSettings.aiDisplayMaster.push( iRow );\n\t\n\t\tvar id = oSettings.rowIdFn( aDataIn );\n\t\tif ( id !== undefined ) {\n\t\t\toSettings.aIds[ id ] = oData;\n\t\t}\n\t\n\t\t/* Create the DOM information, or register it if already present */\n\t\tif ( nTr || ! oSettings.oFeatures.bDeferRender )\n\t\t{\n\t\t\t_fnCreateTr( oSettings, iRow, nTr, anTds );\n\t\t}\n\t\n\t\treturn iRow;\n\t}\n\t\n\t\n\t/**\n\t * Add one or more TR elements to the table. Generally we'd expect to\n\t * use this for reading data from a DOM sourced table, but it could be\n\t * used for an TR element. Note that if a TR is given, it is used (i.e.\n\t * it is not cloned).\n\t * @param {object} settings dataTables settings object\n\t * @param {array|node|jQuery} trs The TR element(s) to add to the table\n\t * @returns {array} Array of indexes for the added rows\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAddTr( settings, trs )\n\t{\n\t\tvar row;\n\t\n\t\t// Allow an individual node to be passed in\n\t\tif ( ! (trs instanceof $) ) {\n\t\t\ttrs = $(trs);\n\t\t}\n\t\n\t\treturn trs.map( function (i, el) {\n\t\t\trow = _fnGetRowElements( settings, el );\n\t\t\treturn _fnAddData( settings, row.data, el, row.cells );\n\t\t} );\n\t}\n\t\n\t\n\t/**\n\t * Take a TR element and convert it to an index in aoData\n\t * @param {object} oSettings dataTables settings object\n\t * @param {node} n the TR element to find\n\t * @returns {int} index if the node is found, null if not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnNodeToDataIndex( oSettings, n )\n\t{\n\t\treturn (n._DT_RowIndex!==undefined) ? n._DT_RowIndex : null;\n\t}\n\t\n\t\n\t/**\n\t * Take a TD element and convert it into a column data index (not the visible index)\n\t * @param {object} oSettings dataTables settings object\n\t * @param {int} iRow The row number the TD/TH can be found in\n\t * @param {node} n The TD/TH element to find\n\t * @returns {int} index if the node is found, -1 if not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnNodeToColumnIndex( oSettings, iRow, n )\n\t{\n\t\treturn $.inArray( n, oSettings.aoData[ iRow ].anCells );\n\t}\n\t\n\t\n\t/**\n\t * Get the data for a given cell from the internal cache, taking into account data mapping\n\t * @param {object} settings dataTables settings object\n\t * @param {int} rowIdx aoData row id\n\t * @param {int} colIdx Column index\n\t * @param {string} type data get type ('display', 'type' 'filter' 'sort')\n\t * @returns {*} Cell data\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetCellData( settings, rowIdx, colIdx, type )\n\t{\n\t\tvar draw = settings.iDraw;\n\t\tvar col = settings.aoColumns[colIdx];\n\t\tvar rowData = settings.aoData[rowIdx]._aData;\n\t\tvar defaultContent = col.sDefaultContent;\n\t\tvar cellData = col.fnGetData( rowData, type, {\n\t\t\tsettings: settings,\n\t\t\trow: rowIdx,\n\t\t\tcol: colIdx\n\t\t} );\n\t\n\t\tif ( cellData === undefined ) {\n\t\t\tif ( settings.iDrawError != draw && defaultContent === null ) {\n\t\t\t\t_fnLog( settings, 0, \"Requested unknown parameter \"+\n\t\t\t\t\t(typeof col.mData=='function' ? '{function}' : \"'\"+col.mData+\"'\")+\n\t\t\t\t\t\" for row \"+rowIdx+\", column \"+colIdx, 4 );\n\t\t\t\tsettings.iDrawError = draw;\n\t\t\t}\n\t\t\treturn defaultContent;\n\t\t}\n\t\n\t\t// When the data source is null and a specific data type is requested (i.e.\n\t\t// not the original data), we can use default column data\n\t\tif ( (cellData === rowData || cellData === null) && defaultContent !== null && type !== undefined ) {\n\t\t\tcellData = defaultContent;\n\t\t}\n\t\telse if ( typeof cellData === 'function' ) {\n\t\t\t// If the data source is a function, then we run it and use the return,\n\t\t\t// executing in the scope of the data object (for instances)\n\t\t\treturn cellData.call( rowData );\n\t\t}\n\t\n\t\tif ( cellData === null && type == 'display' ) {\n\t\t\treturn '';\n\t\t}\n\t\treturn cellData;\n\t}\n\t\n\t\n\t/**\n\t * Set the value for a specific cell, into the internal data cache\n\t * @param {object} settings dataTables settings object\n\t * @param {int} rowIdx aoData row id\n\t * @param {int} colIdx Column index\n\t * @param {*} val Value to set\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSetCellData( settings, rowIdx, colIdx, val )\n\t{\n\t\tvar col = settings.aoColumns[colIdx];\n\t\tvar rowData = settings.aoData[rowIdx]._aData;\n\t\n\t\tcol.fnSetData( rowData, val, {\n\t\t\tsettings: settings,\n\t\t\trow: rowIdx,\n\t\t\tcol: colIdx\n\t\t} );\n\t}\n\t\n\t\n\t// Private variable that is used to match action syntax in the data property object\n\tvar __reArray = /\\[.*?\\]$/;\n\tvar __reFn = /\\(\\)$/;\n\t\n\t/**\n\t * Split string on periods, taking into account escaped periods\n\t * @param {string} str String to split\n\t * @return {array} Split string\n\t */\n\tfunction _fnSplitObjNotation( str )\n\t{\n\t\treturn $.map( str.match(/(\\\\.|[^\\.])+/g) || [''], function ( s ) {\n\t\t\treturn s.replace(/\\\\./g, '.');\n\t\t} );\n\t}\n\t\n\t\n\t/**\n\t * Return a function that can be used to get data from a source object, taking\n\t * into account the ability to use nested objects as a source\n\t * @param {string|int|function} mSource The data source for the object\n\t * @returns {function} Data get function\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetObjectDataFn( mSource )\n\t{\n\t\tif ( $.isPlainObject( mSource ) )\n\t\t{\n\t\t\t/* Build an object of get functions, and wrap them in a single call */\n\t\t\tvar o = {};\n\t\t\t$.each( mSource, function (key, val) {\n\t\t\t\tif ( val ) {\n\t\t\t\t\to[key] = _fnGetObjectDataFn( val );\n\t\t\t\t}\n\t\t\t} );\n\t\n\t\t\treturn function (data, type, row, meta) {\n\t\t\t\tvar t = o[type] || o._;\n\t\t\t\treturn t !== undefined ?\n\t\t\t\t\tt(data, type, row, meta) :\n\t\t\t\t\tdata;\n\t\t\t};\n\t\t}\n\t\telse if ( mSource === null )\n\t\t{\n\t\t\t/* Give an empty string for rendering / sorting etc */\n\t\t\treturn function (data) { // type, row and meta also passed, but not used\n\t\t\t\treturn data;\n\t\t\t};\n\t\t}\n\t\telse if ( typeof mSource === 'function' )\n\t\t{\n\t\t\treturn function (data, type, row, meta) {\n\t\t\t\treturn mSource( data, type, row, meta );\n\t\t\t};\n\t\t}\n\t\telse if ( typeof mSource === 'string' && (mSource.indexOf('.') !== -1 ||\n\t\t\t mSource.indexOf('[') !== -1 || mSource.indexOf('(') !== -1) )\n\t\t{\n\t\t\t/* If there is a . in the source string then the data source is in a\n\t\t\t * nested object so we loop over the data for each level to get the next\n\t\t\t * level down. On each loop we test for undefined, and if found immediately\n\t\t\t * return. This allows entire objects to be missing and sDefaultContent to\n\t\t\t * be used if defined, rather than throwing an error\n\t\t\t */\n\t\t\tvar fetchData = function (data, type, src) {\n\t\t\t\tvar arrayNotation, funcNotation, out, innerSrc;\n\t\n\t\t\t\tif ( src !== \"\" )\n\t\t\t\t{\n\t\t\t\t\tvar a = _fnSplitObjNotation( src );\n\t\n\t\t\t\t\tfor ( var i=0, iLen=a.length ; i<iLen ; i++ )\n\t\t\t\t\t{\n\t\t\t\t\t\t// Check if we are dealing with special notation\n\t\t\t\t\t\tarrayNotation = a[i].match(__reArray);\n\t\t\t\t\t\tfuncNotation = a[i].match(__reFn);\n\t\n\t\t\t\t\t\tif ( arrayNotation )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// Array notation\n\t\t\t\t\t\t\ta[i] = a[i].replace(__reArray, '');\n\t\n\t\t\t\t\t\t\t// Condition allows simply [] to be passed in\n\t\t\t\t\t\t\tif ( a[i] !== \"\" ) {\n\t\t\t\t\t\t\t\tdata = data[ a[i] ];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tout = [];\n\t\n\t\t\t\t\t\t\t// Get the remainder of the nested object to get\n\t\t\t\t\t\t\ta.splice( 0, i+1 );\n\t\t\t\t\t\t\tinnerSrc = a.join('.');\n\t\n\t\t\t\t\t\t\t// Traverse each entry in the array getting the properties requested\n\t\t\t\t\t\t\tif ( $.isArray( data ) ) {\n\t\t\t\t\t\t\t\tfor ( var j=0, jLen=data.length ; j<jLen ; j++ ) {\n\t\t\t\t\t\t\t\t\tout.push( fetchData( data[j], type, innerSrc ) );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t\t// If a string is given in between the array notation indicators, that\n\t\t\t\t\t\t\t// is used to join the strings together, otherwise an array is returned\n\t\t\t\t\t\t\tvar join = arrayNotation[0].substring(1, arrayNotation[0].length-1);\n\t\t\t\t\t\t\tdata = (join===\"\") ? out : out.join(join);\n\t\n\t\t\t\t\t\t\t// The inner call to fetchData has already traversed through the remainder\n\t\t\t\t\t\t\t// of the source requested, so we exit from the loop\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse if ( funcNotation )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// Function call\n\t\t\t\t\t\t\ta[i] = a[i].replace(__reFn, '');\n\t\t\t\t\t\t\tdata = data[ a[i] ]();\n\t\t\t\t\t\t\tcontinue;\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\tif ( data === null || data[ a[i] ] === undefined )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\treturn undefined;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tdata = data[ a[i] ];\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\treturn data;\n\t\t\t};\n\t\n\t\t\treturn function (data, type) { // row and meta also passed, but not used\n\t\t\t\treturn fetchData( data, type, mSource );\n\t\t\t};\n\t\t}\n\t\telse\n\t\t{\n\t\t\t/* Array or flat object mapping */\n\t\t\treturn function (data, type) { // row and meta also passed, but not used\n\t\t\t\treturn data[mSource];\n\t\t\t};\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Return a function that can be used to set data from a source object, taking\n\t * into account the ability to use nested objects as a source\n\t * @param {string|int|function} mSource The data source for the object\n\t * @returns {function} Data set function\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSetObjectDataFn( mSource )\n\t{\n\t\tif ( $.isPlainObject( mSource ) )\n\t\t{\n\t\t\t/* Unlike get, only the underscore (global) option is used for for\n\t\t\t * setting data since we don't know the type here. This is why an object\n\t\t\t * option is not documented for `mData` (which is read/write), but it is\n\t\t\t * for `mRender` which is read only.\n\t\t\t */\n\t\t\treturn _fnSetObjectDataFn( mSource._ );\n\t\t}\n\t\telse if ( mSource === null )\n\t\t{\n\t\t\t/* Nothing to do when the data source is null */\n\t\t\treturn function () {};\n\t\t}\n\t\telse if ( typeof mSource === 'function' )\n\t\t{\n\t\t\treturn function (data, val, meta) {\n\t\t\t\tmSource( data, 'set', val, meta );\n\t\t\t};\n\t\t}\n\t\telse if ( typeof mSource === 'string' && (mSource.indexOf('.') !== -1 ||\n\t\t\t mSource.indexOf('[') !== -1 || mSource.indexOf('(') !== -1) )\n\t\t{\n\t\t\t/* Like the get, we need to get data from a nested object */\n\t\t\tvar setData = function (data, val, src) {\n\t\t\t\tvar a = _fnSplitObjNotation( src ), b;\n\t\t\t\tvar aLast = a[a.length-1];\n\t\t\t\tvar arrayNotation, funcNotation, o, innerSrc;\n\t\n\t\t\t\tfor ( var i=0, iLen=a.length-1 ; i<iLen ; i++ )\n\t\t\t\t{\n\t\t\t\t\t// Check if we are dealing with an array notation request\n\t\t\t\t\tarrayNotation = a[i].match(__reArray);\n\t\t\t\t\tfuncNotation = a[i].match(__reFn);\n\t\n\t\t\t\t\tif ( arrayNotation )\n\t\t\t\t\t{\n\t\t\t\t\t\ta[i] = a[i].replace(__reArray, '');\n\t\t\t\t\t\tdata[ a[i] ] = [];\n\t\n\t\t\t\t\t\t// Get the remainder of the nested object to set so we can recurse\n\t\t\t\t\t\tb = a.slice();\n\t\t\t\t\t\tb.splice( 0, i+1 );\n\t\t\t\t\t\tinnerSrc = b.join('.');\n\t\n\t\t\t\t\t\t// Traverse each entry in the array setting the properties requested\n\t\t\t\t\t\tif ( $.isArray( val ) )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tfor ( var j=0, jLen=val.length ; j<jLen ; j++ )\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\to = {};\n\t\t\t\t\t\t\t\tsetData( o, val[j], innerSrc );\n\t\t\t\t\t\t\t\tdata[ a[i] ].push( o );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// We've been asked to save data to an array, but it\n\t\t\t\t\t\t\t// isn't array data to be saved. Best that can be done\n\t\t\t\t\t\t\t// is to just save the value.\n\t\t\t\t\t\t\tdata[ a[i] ] = val;\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t// The inner call to setData has already traversed through the remainder\n\t\t\t\t\t\t// of the source and has set the data, thus we can exit here\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t\telse if ( funcNotation )\n\t\t\t\t\t{\n\t\t\t\t\t\t// Function call\n\t\t\t\t\t\ta[i] = a[i].replace(__reFn, '');\n\t\t\t\t\t\tdata = data[ a[i] ]( val );\n\t\t\t\t\t}\n\t\n\t\t\t\t\t// If the nested object doesn't currently exist - since we are\n\t\t\t\t\t// trying to set the value - create it\n\t\t\t\t\tif ( data[ a[i] ] === null || data[ a[i] ] === undefined )\n\t\t\t\t\t{\n\t\t\t\t\t\tdata[ a[i] ] = {};\n\t\t\t\t\t}\n\t\t\t\t\tdata = data[ a[i] ];\n\t\t\t\t}\n\t\n\t\t\t\t// Last item in the input - i.e, the actual set\n\t\t\t\tif ( aLast.match(__reFn ) )\n\t\t\t\t{\n\t\t\t\t\t// Function call\n\t\t\t\t\tdata = data[ aLast.replace(__reFn, '') ]( val );\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t// If array notation is used, we just want to strip it and use the property name\n\t\t\t\t\t// and assign the value. If it isn't used, then we get the result we want anyway\n\t\t\t\t\tdata[ aLast.replace(__reArray, '') ] = val;\n\t\t\t\t}\n\t\t\t};\n\t\n\t\t\treturn function (data, val) { // meta is also passed in, but not used\n\t\t\t\treturn setData( data, val, mSource );\n\t\t\t};\n\t\t}\n\t\telse\n\t\t{\n\t\t\t/* Array or flat object mapping */\n\t\t\treturn function (data, val) { // meta is also passed in, but not used\n\t\t\t\tdata[mSource] = val;\n\t\t\t};\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Return an array with the full table data\n\t * @param {object} oSettings dataTables settings object\n\t * @returns array {array} aData Master data array\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetDataMaster ( settings )\n\t{\n\t\treturn _pluck( settings.aoData, '_aData' );\n\t}\n\t\n\t\n\t/**\n\t * Nuke the table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnClearTable( settings )\n\t{\n\t\tsettings.aoData.length = 0;\n\t\tsettings.aiDisplayMaster.length = 0;\n\t\tsettings.aiDisplay.length = 0;\n\t\tsettings.aIds = {};\n\t}\n\t\n\t\n\t /**\n\t * Take an array of integers (index array) and remove a target integer (value - not\n\t * the key!)\n\t * @param {array} a Index array to target\n\t * @param {int} iTarget value to find\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnDeleteIndex( a, iTarget, splice )\n\t{\n\t\tvar iTargetIndex = -1;\n\t\n\t\tfor ( var i=0, iLen=a.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tif ( a[i] == iTarget )\n\t\t\t{\n\t\t\t\tiTargetIndex = i;\n\t\t\t}\n\t\t\telse if ( a[i] > iTarget )\n\t\t\t{\n\t\t\t\ta[i]--;\n\t\t\t}\n\t\t}\n\t\n\t\tif ( iTargetIndex != -1 && splice === undefined )\n\t\t{\n\t\t\ta.splice( iTargetIndex, 1 );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Mark cached data as invalid such that a re-read of the data will occur when\n\t * the cached data is next requested. Also update from the data source object.\n\t *\n\t * @param {object} settings DataTables settings object\n\t * @param {int} rowIdx Row index to invalidate\n\t * @param {string} [src] Source to invalidate from: undefined, 'auto', 'dom'\n\t * or 'data'\n\t * @param {int} [colIdx] Column index to invalidate. If undefined the whole\n\t * row will be invalidated\n\t * @memberof DataTable#oApi\n\t *\n\t * @todo For the modularisation of v1.11 this will need to become a callback, so\n\t * the sort and filter methods can subscribe to it. That will required\n\t * initialisation options for sorting, which is why it is not already baked in\n\t */\n\tfunction _fnInvalidate( settings, rowIdx, src, colIdx )\n\t{\n\t\tvar row = settings.aoData[ rowIdx ];\n\t\tvar i, ien;\n\t\tvar cellWrite = function ( cell, col ) {\n\t\t\t// This is very frustrating, but in IE if you just write directly\n\t\t\t// to innerHTML, and elements that are overwritten are GC'ed,\n\t\t\t// even if there is a reference to them elsewhere\n\t\t\twhile ( cell.childNodes.length ) {\n\t\t\t\tcell.removeChild( cell.firstChild );\n\t\t\t}\n\t\n\t\t\tcell.innerHTML = _fnGetCellData( settings, rowIdx, col, 'display' );\n\t\t};\n\t\n\t\t// Are we reading last data from DOM or the data object?\n\t\tif ( src === 'dom' || ((! src || src === 'auto') && row.src === 'dom') ) {\n\t\t\t// Read the data from the DOM\n\t\t\trow._aData = _fnGetRowElements(\n\t\t\t\t\tsettings, row, colIdx, colIdx === undefined ? undefined : row._aData\n\t\t\t\t)\n\t\t\t\t.data;\n\t\t}\n\t\telse {\n\t\t\t// Reading from data object, update the DOM\n\t\t\tvar cells = row.anCells;\n\t\n\t\t\tif ( cells ) {\n\t\t\t\tif ( colIdx !== undefined ) {\n\t\t\t\t\tcellWrite( cells[colIdx], colIdx );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tfor ( i=0, ien=cells.length ; i<ien ; i++ ) {\n\t\t\t\t\t\tcellWrite( cells[i], i );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\t// For both row and cell invalidation, the cached data for sorting and\n\t\t// filtering is nulled out\n\t\trow._aSortData = null;\n\t\trow._aFilterData = null;\n\t\n\t\t// Invalidate the type for a specific column (if given) or all columns since\n\t\t// the data might have changed\n\t\tvar cols = settings.aoColumns;\n\t\tif ( colIdx !== undefined ) {\n\t\t\tcols[ colIdx ].sType = null;\n\t\t}\n\t\telse {\n\t\t\tfor ( i=0, ien=cols.length ; i<ien ; i++ ) {\n\t\t\t\tcols[i].sType = null;\n\t\t\t}\n\t\n\t\t\t// Update DataTables special `DT_*` attributes for the row\n\t\t\t_fnRowAttributes( settings, row );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Build a data source object from an HTML row, reading the contents of the\n\t * cells that are in the row.\n\t *\n\t * @param {object} settings DataTables settings object\n\t * @param {node|object} TR element from which to read data or existing row\n\t * object from which to re-read the data from the cells\n\t * @param {int} [colIdx] Optional column index\n\t * @param {array|object} [d] Data source object. If `colIdx` is given then this\n\t * parameter should also be given and will be used to write the data into.\n\t * Only the column in question will be written\n\t * @returns {object} Object with two parameters: `data` the data read, in\n\t * document order, and `cells` and array of nodes (they can be useful to the\n\t * caller, so rather than needing a second traversal to get them, just return\n\t * them from here).\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetRowElements( settings, row, colIdx, d )\n\t{\n\t\tvar\n\t\t\ttds = [],\n\t\t\ttd = row.firstChild,\n\t\t\tname, col, o, i=0, contents,\n\t\t\tcolumns = settings.aoColumns,\n\t\t\tobjectRead = settings._rowReadObject;\n\t\n\t\t// Allow the data object to be passed in, or construct\n\t\td = d !== undefined ?\n\t\t\td :\n\t\t\tobjectRead ?\n\t\t\t\t{} :\n\t\t\t\t[];\n\t\n\t\tvar attr = function ( str, td ) {\n\t\t\tif ( typeof str === 'string' ) {\n\t\t\t\tvar idx = str.indexOf('@');\n\t\n\t\t\t\tif ( idx !== -1 ) {\n\t\t\t\t\tvar attr = str.substring( idx+1 );\n\t\t\t\t\tvar setter = _fnSetObjectDataFn( str );\n\t\t\t\t\tsetter( d, td.getAttribute( attr ) );\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\n\t\t// Read data from a cell and store into the data object\n\t\tvar cellProcess = function ( cell ) {\n\t\t\tif ( colIdx === undefined || colIdx === i ) {\n\t\t\t\tcol = columns[i];\n\t\t\t\tcontents = $.trim(cell.innerHTML);\n\t\n\t\t\t\tif ( col && col._bAttrSrc ) {\n\t\t\t\t\tvar setter = _fnSetObjectDataFn( col.mData._ );\n\t\t\t\t\tsetter( d, contents );\n\t\n\t\t\t\t\tattr( col.mData.sort, cell );\n\t\t\t\t\tattr( col.mData.type, cell );\n\t\t\t\t\tattr( col.mData.filter, cell );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\t// Depending on the `data` option for the columns the data can\n\t\t\t\t\t// be read to either an object or an array.\n\t\t\t\t\tif ( objectRead ) {\n\t\t\t\t\t\tif ( ! col._setter ) {\n\t\t\t\t\t\t\t// Cache the setter function\n\t\t\t\t\t\t\tcol._setter = _fnSetObjectDataFn( col.mData );\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcol._setter( d, contents );\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\td[i] = contents;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\ti++;\n\t\t};\n\t\n\t\tif ( td ) {\n\t\t\t// `tr` element was passed in\n\t\t\twhile ( td ) {\n\t\t\t\tname = td.nodeName.toUpperCase();\n\t\n\t\t\t\tif ( name == \"TD\" || name == \"TH\" ) {\n\t\t\t\t\tcellProcess( td );\n\t\t\t\t\ttds.push( td );\n\t\t\t\t}\n\t\n\t\t\t\ttd = td.nextSibling;\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\t// Existing row object passed in\n\t\t\ttds = row.anCells;\n\t\n\t\t\tfor ( var j=0, jen=tds.length ; j<jen ; j++ ) {\n\t\t\t\tcellProcess( tds[j] );\n\t\t\t}\n\t\t}\n\t\n\t\t// Read the ID from the DOM if present\n\t\tvar rowNode = row.firstChild ? row : row.nTr;\n\t\n\t\tif ( rowNode ) {\n\t\t\tvar id = rowNode.getAttribute( 'id' );\n\t\n\t\t\tif ( id ) {\n\t\t\t\t_fnSetObjectDataFn( settings.rowId )( d, id );\n\t\t\t}\n\t\t}\n\t\n\t\treturn {\n\t\t\tdata: d,\n\t\t\tcells: tds\n\t\t};\n\t}\n\t/**\n\t * Create a new TR element (and it's TD children) for a row\n\t * @param {object} oSettings dataTables settings object\n\t * @param {int} iRow Row to consider\n\t * @param {node} [nTrIn] TR element to add to the table - optional. If not given,\n\t * DataTables will create a row automatically\n\t * @param {array} [anTds] Array of TD|TH elements for the row - must be given\n\t * if nTr is.\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnCreateTr ( oSettings, iRow, nTrIn, anTds )\n\t{\n\t\tvar\n\t\t\trow = oSettings.aoData[iRow],\n\t\t\trowData = row._aData,\n\t\t\tcells = [],\n\t\t\tnTr, nTd, oCol,\n\t\t\ti, iLen;\n\t\n\t\tif ( row.nTr === null )\n\t\t{\n\t\t\tnTr = nTrIn || document.createElement('tr');\n\t\n\t\t\trow.nTr = nTr;\n\t\t\trow.anCells = cells;\n\t\n\t\t\t/* Use a private property on the node to allow reserve mapping from the node\n\t\t\t * to the aoData array for fast look up\n\t\t\t */\n\t\t\tnTr._DT_RowIndex = iRow;\n\t\n\t\t\t/* Special parameters can be given by the data source to be used on the row */\n\t\t\t_fnRowAttributes( oSettings, row );\n\t\n\t\t\t/* Process each column */\n\t\t\tfor ( i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )\n\t\t\t{\n\t\t\t\toCol = oSettings.aoColumns[i];\n\t\n\t\t\t\tnTd = nTrIn ? anTds[i] : document.createElement( oCol.sCellType );\n\t\t\t\tnTd._DT_CellIndex = {\n\t\t\t\t\trow: iRow,\n\t\t\t\t\tcolumn: i\n\t\t\t\t};\n\t\t\t\t\n\t\t\t\tcells.push( nTd );\n\t\n\t\t\t\t// Need to create the HTML if new, or if a rendering function is defined\n\t\t\t\tif ( (!nTrIn || oCol.mRender || oCol.mData !== i) &&\n\t\t\t\t\t (!$.isPlainObject(oCol.mData) || oCol.mData._ !== i+'.display')\n\t\t\t\t) {\n\t\t\t\t\tnTd.innerHTML = _fnGetCellData( oSettings, iRow, i, 'display' );\n\t\t\t\t}\n\t\n\t\t\t\t/* Add user defined class */\n\t\t\t\tif ( oCol.sClass )\n\t\t\t\t{\n\t\t\t\t\tnTd.className += ' '+oCol.sClass;\n\t\t\t\t}\n\t\n\t\t\t\t// Visibility - add or remove as required\n\t\t\t\tif ( oCol.bVisible && ! nTrIn )\n\t\t\t\t{\n\t\t\t\t\tnTr.appendChild( nTd );\n\t\t\t\t}\n\t\t\t\telse if ( ! oCol.bVisible && nTrIn )\n\t\t\t\t{\n\t\t\t\t\tnTd.parentNode.removeChild( nTd );\n\t\t\t\t}\n\t\n\t\t\t\tif ( oCol.fnCreatedCell )\n\t\t\t\t{\n\t\t\t\t\toCol.fnCreatedCell.call( oSettings.oInstance,\n\t\t\t\t\t\tnTd, _fnGetCellData( oSettings, iRow, i ), rowData, iRow, i\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t_fnCallbackFire( oSettings, 'aoRowCreatedCallback', null, [nTr, rowData, iRow] );\n\t\t}\n\t\n\t\t// Remove once webkit bug 131819 and Chromium bug 365619 have been resolved\n\t\t// and deployed\n\t\trow.nTr.setAttribute( 'role', 'row' );\n\t}\n\t\n\t\n\t/**\n\t * Add attributes to a row based on the special `DT_*` parameters in a data\n\t * source object.\n\t * @param {object} settings DataTables settings object\n\t * @param {object} DataTables row object for the row to be modified\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnRowAttributes( settings, row )\n\t{\n\t\tvar tr = row.nTr;\n\t\tvar data = row._aData;\n\t\n\t\tif ( tr ) {\n\t\t\tvar id = settings.rowIdFn( data );\n\t\n\t\t\tif ( id ) {\n\t\t\t\ttr.id = id;\n\t\t\t}\n\t\n\t\t\tif ( data.DT_RowClass ) {\n\t\t\t\t// Remove any classes added by DT_RowClass before\n\t\t\t\tvar a = data.DT_RowClass.split(' ');\n\t\t\t\trow.__rowc = row.__rowc ?\n\t\t\t\t\t_unique( row.__rowc.concat( a ) ) :\n\t\t\t\t\ta;\n\t\n\t\t\t\t$(tr)\n\t\t\t\t\t.removeClass( row.__rowc.join(' ') )\n\t\t\t\t\t.addClass( data.DT_RowClass );\n\t\t\t}\n\t\n\t\t\tif ( data.DT_RowAttr ) {\n\t\t\t\t$(tr).attr( data.DT_RowAttr );\n\t\t\t}\n\t\n\t\t\tif ( data.DT_RowData ) {\n\t\t\t\t$(tr).data( data.DT_RowData );\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Create the HTML header for the table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnBuildHead( oSettings )\n\t{\n\t\tvar i, ien, cell, row, column;\n\t\tvar thead = oSettings.nTHead;\n\t\tvar tfoot = oSettings.nTFoot;\n\t\tvar createHeader = $('th, td', thead).length === 0;\n\t\tvar classes = oSettings.oClasses;\n\t\tvar columns = oSettings.aoColumns;\n\t\n\t\tif ( createHeader ) {\n\t\t\trow = $('<tr/>').appendTo( thead );\n\t\t}\n\t\n\t\tfor ( i=0, ien=columns.length ; i<ien ; i++ ) {\n\t\t\tcolumn = columns[i];\n\t\t\tcell = $( column.nTh ).addClass( column.sClass );\n\t\n\t\t\tif ( createHeader ) {\n\t\t\t\tcell.appendTo( row );\n\t\t\t}\n\t\n\t\t\t// 1.11 move into sorting\n\t\t\tif ( oSettings.oFeatures.bSort ) {\n\t\t\t\tcell.addClass( column.sSortingClass );\n\t\n\t\t\t\tif ( column.bSortable !== false ) {\n\t\t\t\t\tcell\n\t\t\t\t\t\t.attr( 'tabindex', oSettings.iTabIndex )\n\t\t\t\t\t\t.attr( 'aria-controls', oSettings.sTableId );\n\t\n\t\t\t\t\t_fnSortAttachListener( oSettings, column.nTh, i );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\tif ( column.sTitle != cell[0].innerHTML ) {\n\t\t\t\tcell.html( column.sTitle );\n\t\t\t}\n\t\n\t\t\t_fnRenderer( oSettings, 'header' )(\n\t\t\t\toSettings, cell, column, classes\n\t\t\t);\n\t\t}\n\t\n\t\tif ( createHeader ) {\n\t\t\t_fnDetectHeader( oSettings.aoHeader, thead );\n\t\t}\n\t\t\n\t\t/* ARIA role for the rows */\n\t \t$(thead).find('>tr').attr('role', 'row');\n\t\n\t\t/* Deal with the footer - add classes if required */\n\t\t$(thead).find('>tr>th, >tr>td').addClass( classes.sHeaderTH );\n\t\t$(tfoot).find('>tr>th, >tr>td').addClass( classes.sFooterTH );\n\t\n\t\t// Cache the footer cells. Note that we only take the cells from the first\n\t\t// row in the footer. If there is more than one row the user wants to\n\t\t// interact with, they need to use the table().foot() method. Note also this\n\t\t// allows cells to be used for multiple columns using colspan\n\t\tif ( tfoot !== null ) {\n\t\t\tvar cells = oSettings.aoFooter[0];\n\t\n\t\t\tfor ( i=0, ien=cells.length ; i<ien ; i++ ) {\n\t\t\t\tcolumn = columns[i];\n\t\t\t\tcolumn.nTf = cells[i].cell;\n\t\n\t\t\t\tif ( column.sClass ) {\n\t\t\t\t\t$(column.nTf).addClass( column.sClass );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Draw the header (or footer) element based on the column visibility states. The\n\t * methodology here is to use the layout array from _fnDetectHeader, modified for\n\t * the instantaneous column visibility, to construct the new layout. The grid is\n\t * traversed over cell at a time in a rows x columns grid fashion, although each\n\t * cell insert can cover multiple elements in the grid - which is tracks using the\n\t * aApplied array. Cell inserts in the grid will only occur where there isn't\n\t * already a cell in that position.\n\t * @param {object} oSettings dataTables settings object\n\t * @param array {objects} aoSource Layout array from _fnDetectHeader\n\t * @param {boolean} [bIncludeHidden=false] If true then include the hidden columns in the calc,\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnDrawHead( oSettings, aoSource, bIncludeHidden )\n\t{\n\t\tvar i, iLen, j, jLen, k, kLen, n, nLocalTr;\n\t\tvar aoLocal = [];\n\t\tvar aApplied = [];\n\t\tvar iColumns = oSettings.aoColumns.length;\n\t\tvar iRowspan, iColspan;\n\t\n\t\tif ( ! aoSource )\n\t\t{\n\t\t\treturn;\n\t\t}\n\t\n\t\tif ( bIncludeHidden === undefined )\n\t\t{\n\t\t\tbIncludeHidden = false;\n\t\t}\n\t\n\t\t/* Make a copy of the master layout array, but without the visible columns in it */\n\t\tfor ( i=0, iLen=aoSource.length ; i<iLen ; i++ )\n\t\t{\n\t\t\taoLocal[i] = aoSource[i].slice();\n\t\t\taoLocal[i].nTr = aoSource[i].nTr;\n\t\n\t\t\t/* Remove any columns which are currently hidden */\n\t\t\tfor ( j=iColumns-1 ; j>=0 ; j-- )\n\t\t\t{\n\t\t\t\tif ( !oSettings.aoColumns[j].bVisible && !bIncludeHidden )\n\t\t\t\t{\n\t\t\t\t\taoLocal[i].splice( j, 1 );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t/* Prep the applied array - it needs an element for each row */\n\t\t\taApplied.push( [] );\n\t\t}\n\t\n\t\tfor ( i=0, iLen=aoLocal.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tnLocalTr = aoLocal[i].nTr;\n\t\n\t\t\t/* All cells are going to be replaced, so empty out the row */\n\t\t\tif ( nLocalTr )\n\t\t\t{\n\t\t\t\twhile( (n = nLocalTr.firstChild) )\n\t\t\t\t{\n\t\t\t\t\tnLocalTr.removeChild( n );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\tfor ( j=0, jLen=aoLocal[i].length ; j<jLen ; j++ )\n\t\t\t{\n\t\t\t\tiRowspan = 1;\n\t\t\t\tiColspan = 1;\n\t\n\t\t\t\t/* Check to see if there is already a cell (row/colspan) covering our target\n\t\t\t\t * insert point. If there is, then there is nothing to do.\n\t\t\t\t */\n\t\t\t\tif ( aApplied[i][j] === undefined )\n\t\t\t\t{\n\t\t\t\t\tnLocalTr.appendChild( aoLocal[i][j].cell );\n\t\t\t\t\taApplied[i][j] = 1;\n\t\n\t\t\t\t\t/* Expand the cell to cover as many rows as needed */\n\t\t\t\t\twhile ( aoLocal[i+iRowspan] !== undefined &&\n\t\t\t\t\t aoLocal[i][j].cell == aoLocal[i+iRowspan][j].cell )\n\t\t\t\t\t{\n\t\t\t\t\t\taApplied[i+iRowspan][j] = 1;\n\t\t\t\t\t\tiRowspan++;\n\t\t\t\t\t}\n\t\n\t\t\t\t\t/* Expand the cell to cover as many columns as needed */\n\t\t\t\t\twhile ( aoLocal[i][j+iColspan] !== undefined &&\n\t\t\t\t\t aoLocal[i][j].cell == aoLocal[i][j+iColspan].cell )\n\t\t\t\t\t{\n\t\t\t\t\t\t/* Must update the applied array over the rows for the columns */\n\t\t\t\t\t\tfor ( k=0 ; k<iRowspan ; k++ )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\taApplied[i+k][j+iColspan] = 1;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tiColspan++;\n\t\t\t\t\t}\n\t\n\t\t\t\t\t/* Do the actual expansion in the DOM */\n\t\t\t\t\t$(aoLocal[i][j].cell)\n\t\t\t\t\t\t.attr('rowspan', iRowspan)\n\t\t\t\t\t\t.attr('colspan', iColspan);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Insert the required TR nodes into the table for display\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnDraw( oSettings )\n\t{\n\t\t/* Provide a pre-callback function which can be used to cancel the draw is false is returned */\n\t\tvar aPreDraw = _fnCallbackFire( oSettings, 'aoPreDrawCallback', 'preDraw', [oSettings] );\n\t\tif ( $.inArray( false, aPreDraw ) !== -1 )\n\t\t{\n\t\t\t_fnProcessingDisplay( oSettings, false );\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar i, iLen, n;\n\t\tvar anRows = [];\n\t\tvar iRowCount = 0;\n\t\tvar asStripeClasses = oSettings.asStripeClasses;\n\t\tvar iStripes = asStripeClasses.length;\n\t\tvar iOpenRows = oSettings.aoOpenRows.length;\n\t\tvar oLang = oSettings.oLanguage;\n\t\tvar iInitDisplayStart = oSettings.iInitDisplayStart;\n\t\tvar bServerSide = _fnDataSource( oSettings ) == 'ssp';\n\t\tvar aiDisplay = oSettings.aiDisplay;\n\t\n\t\toSettings.bDrawing = true;\n\t\n\t\t/* Check and see if we have an initial draw position from state saving */\n\t\tif ( iInitDisplayStart !== undefined && iInitDisplayStart !== -1 )\n\t\t{\n\t\t\toSettings._iDisplayStart = bServerSide ?\n\t\t\t\tiInitDisplayStart :\n\t\t\t\tiInitDisplayStart >= oSettings.fnRecordsDisplay() ?\n\t\t\t\t\t0 :\n\t\t\t\t\tiInitDisplayStart;\n\t\n\t\t\toSettings.iInitDisplayStart = -1;\n\t\t}\n\t\n\t\tvar iDisplayStart = oSettings._iDisplayStart;\n\t\tvar iDisplayEnd = oSettings.fnDisplayEnd();\n\t\n\t\t/* Server-side processing draw intercept */\n\t\tif ( oSettings.bDeferLoading )\n\t\t{\n\t\t\toSettings.bDeferLoading = false;\n\t\t\toSettings.iDraw++;\n\t\t\t_fnProcessingDisplay( oSettings, false );\n\t\t}\n\t\telse if ( !bServerSide )\n\t\t{\n\t\t\toSettings.iDraw++;\n\t\t}\n\t\telse if ( !oSettings.bDestroying && !_fnAjaxUpdate( oSettings ) )\n\t\t{\n\t\t\treturn;\n\t\t}\n\t\n\t\tif ( aiDisplay.length !== 0 )\n\t\t{\n\t\t\tvar iStart = bServerSide ? 0 : iDisplayStart;\n\t\t\tvar iEnd = bServerSide ? oSettings.aoData.length : iDisplayEnd;\n\t\n\t\t\tfor ( var j=iStart ; j<iEnd ; j++ )\n\t\t\t{\n\t\t\t\tvar iDataIndex = aiDisplay[j];\n\t\t\t\tvar aoData = oSettings.aoData[ iDataIndex ];\n\t\t\t\tif ( aoData.nTr === null )\n\t\t\t\t{\n\t\t\t\t\t_fnCreateTr( oSettings, iDataIndex );\n\t\t\t\t}\n\t\n\t\t\t\tvar nRow = aoData.nTr;\n\t\n\t\t\t\t/* Remove the old striping classes and then add the new one */\n\t\t\t\tif ( iStripes !== 0 )\n\t\t\t\t{\n\t\t\t\t\tvar sStripe = asStripeClasses[ iRowCount % iStripes ];\n\t\t\t\t\tif ( aoData._sRowStripe != sStripe )\n\t\t\t\t\t{\n\t\t\t\t\t\t$(nRow).removeClass( aoData._sRowStripe ).addClass( sStripe );\n\t\t\t\t\t\taoData._sRowStripe = sStripe;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\t// Row callback functions - might want to manipulate the row\n\t\t\t\t// iRowCount and j are not currently documented. Are they at all\n\t\t\t\t// useful?\n\t\t\t\t_fnCallbackFire( oSettings, 'aoRowCallback', null,\n\t\t\t\t\t[nRow, aoData._aData, iRowCount, j] );\n\t\n\t\t\t\tanRows.push( nRow );\n\t\t\t\tiRowCount++;\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\t/* Table is empty - create a row with an empty message in it */\n\t\t\tvar sZero = oLang.sZeroRecords;\n\t\t\tif ( oSettings.iDraw == 1 && _fnDataSource( oSettings ) == 'ajax' )\n\t\t\t{\n\t\t\t\tsZero = oLang.sLoadingRecords;\n\t\t\t}\n\t\t\telse if ( oLang.sEmptyTable && oSettings.fnRecordsTotal() === 0 )\n\t\t\t{\n\t\t\t\tsZero = oLang.sEmptyTable;\n\t\t\t}\n\t\n\t\t\tanRows[ 0 ] = $( '<tr/>', { 'class': iStripes ? asStripeClasses[0] : '' } )\n\t\t\t\t.append( $('<td />', {\n\t\t\t\t\t'valign': 'top',\n\t\t\t\t\t'colSpan': _fnVisbleColumns( oSettings ),\n\t\t\t\t\t'class': oSettings.oClasses.sRowEmpty\n\t\t\t\t} ).html( sZero ) )[0];\n\t\t}\n\t\n\t\t/* Header and footer callbacks */\n\t\t_fnCallbackFire( oSettings, 'aoHeaderCallback', 'header', [ $(oSettings.nTHead).children('tr')[0],\n\t\t\t_fnGetDataMaster( oSettings ), iDisplayStart, iDisplayEnd, aiDisplay ] );\n\t\n\t\t_fnCallbackFire( oSettings, 'aoFooterCallback', 'footer', [ $(oSettings.nTFoot).children('tr')[0],\n\t\t\t_fnGetDataMaster( oSettings ), iDisplayStart, iDisplayEnd, aiDisplay ] );\n\t\n\t\tvar body = $(oSettings.nTBody);\n\t\n\t\tbody.children().detach();\n\t\tbody.append( $(anRows) );\n\t\n\t\t/* Call all required callback functions for the end of a draw */\n\t\t_fnCallbackFire( oSettings, 'aoDrawCallback', 'draw', [oSettings] );\n\t\n\t\t/* Draw is complete, sorting and filtering must be as well */\n\t\toSettings.bSorted = false;\n\t\toSettings.bFiltered = false;\n\t\toSettings.bDrawing = false;\n\t}\n\t\n\t\n\t/**\n\t * Redraw the table - taking account of the various features which are enabled\n\t * @param {object} oSettings dataTables settings object\n\t * @param {boolean} [holdPosition] Keep the current paging position. By default\n\t * the paging is reset to the first page\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnReDraw( settings, holdPosition )\n\t{\n\t\tvar\n\t\t\tfeatures = settings.oFeatures,\n\t\t\tsort = features.bSort,\n\t\t\tfilter = features.bFilter;\n\t\n\t\tif ( sort ) {\n\t\t\t_fnSort( settings );\n\t\t}\n\t\n\t\tif ( filter ) {\n\t\t\t_fnFilterComplete( settings, settings.oPreviousSearch );\n\t\t}\n\t\telse {\n\t\t\t// No filtering, so we want to just use the display master\n\t\t\tsettings.aiDisplay = settings.aiDisplayMaster.slice();\n\t\t}\n\t\n\t\tif ( holdPosition !== true ) {\n\t\t\tsettings._iDisplayStart = 0;\n\t\t}\n\t\n\t\t// Let any modules know about the draw hold position state (used by\n\t\t// scrolling internally)\n\t\tsettings._drawHold = holdPosition;\n\t\n\t\t_fnDraw( settings );\n\t\n\t\tsettings._drawHold = false;\n\t}\n\t\n\t\n\t/**\n\t * Add the options to the page HTML for the table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAddOptionsHtml ( oSettings )\n\t{\n\t\tvar classes = oSettings.oClasses;\n\t\tvar table = $(oSettings.nTable);\n\t\tvar holding = $('<div/>').insertBefore( table ); // Holding element for speed\n\t\tvar features = oSettings.oFeatures;\n\t\n\t\t// All DataTables are wrapped in a div\n\t\tvar insert = $('<div/>', {\n\t\t\tid: oSettings.sTableId+'_wrapper',\n\t\t\t'class': classes.sWrapper + (oSettings.nTFoot ? '' : ' '+classes.sNoFooter)\n\t\t} );\n\t\n\t\toSettings.nHolding = holding[0];\n\t\toSettings.nTableWrapper = insert[0];\n\t\toSettings.nTableReinsertBefore = oSettings.nTable.nextSibling;\n\t\n\t\t/* Loop over the user set positioning and place the elements as needed */\n\t\tvar aDom = oSettings.sDom.split('');\n\t\tvar featureNode, cOption, nNewNode, cNext, sAttr, j;\n\t\tfor ( var i=0 ; i<aDom.length ; i++ )\n\t\t{\n\t\t\tfeatureNode = null;\n\t\t\tcOption = aDom[i];\n\t\n\t\t\tif ( cOption == '<' )\n\t\t\t{\n\t\t\t\t/* New container div */\n\t\t\t\tnNewNode = $('<div/>')[0];\n\t\n\t\t\t\t/* Check to see if we should append an id and/or a class name to the container */\n\t\t\t\tcNext = aDom[i+1];\n\t\t\t\tif ( cNext == \"'\" || cNext == '\"' )\n\t\t\t\t{\n\t\t\t\t\tsAttr = \"\";\n\t\t\t\t\tj = 2;\n\t\t\t\t\twhile ( aDom[i+j] != cNext )\n\t\t\t\t\t{\n\t\t\t\t\t\tsAttr += aDom[i+j];\n\t\t\t\t\t\tj++;\n\t\t\t\t\t}\n\t\n\t\t\t\t\t/* Replace jQuery UI constants @todo depreciated */\n\t\t\t\t\tif ( sAttr == \"H\" )\n\t\t\t\t\t{\n\t\t\t\t\t\tsAttr = classes.sJUIHeader;\n\t\t\t\t\t}\n\t\t\t\t\telse if ( sAttr == \"F\" )\n\t\t\t\t\t{\n\t\t\t\t\t\tsAttr = classes.sJUIFooter;\n\t\t\t\t\t}\n\t\n\t\t\t\t\t/* The attribute can be in the format of \"#id.class\", \"#id\" or \"class\" This logic\n\t\t\t\t\t * breaks the string into parts and applies them as needed\n\t\t\t\t\t */\n\t\t\t\t\tif ( sAttr.indexOf('.') != -1 )\n\t\t\t\t\t{\n\t\t\t\t\t\tvar aSplit = sAttr.split('.');\n\t\t\t\t\t\tnNewNode.id = aSplit[0].substr(1, aSplit[0].length-1);\n\t\t\t\t\t\tnNewNode.className = aSplit[1];\n\t\t\t\t\t}\n\t\t\t\t\telse if ( sAttr.charAt(0) == \"#\" )\n\t\t\t\t\t{\n\t\t\t\t\t\tnNewNode.id = sAttr.substr(1, sAttr.length-1);\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\tnNewNode.className = sAttr;\n\t\t\t\t\t}\n\t\n\t\t\t\t\ti += j; /* Move along the position array */\n\t\t\t\t}\n\t\n\t\t\t\tinsert.append( nNewNode );\n\t\t\t\tinsert = $(nNewNode);\n\t\t\t}\n\t\t\telse if ( cOption == '>' )\n\t\t\t{\n\t\t\t\t/* End container div */\n\t\t\t\tinsert = insert.parent();\n\t\t\t}\n\t\t\t// @todo Move options into their own plugins?\n\t\t\telse if ( cOption == 'l' && features.bPaginate && features.bLengthChange )\n\t\t\t{\n\t\t\t\t/* Length */\n\t\t\t\tfeatureNode = _fnFeatureHtmlLength( oSettings );\n\t\t\t}\n\t\t\telse if ( cOption == 'f' && features.bFilter )\n\t\t\t{\n\t\t\t\t/* Filter */\n\t\t\t\tfeatureNode = _fnFeatureHtmlFilter( oSettings );\n\t\t\t}\n\t\t\telse if ( cOption == 'r' && features.bProcessing )\n\t\t\t{\n\t\t\t\t/* pRocessing */\n\t\t\t\tfeatureNode = _fnFeatureHtmlProcessing( oSettings );\n\t\t\t}\n\t\t\telse if ( cOption == 't' )\n\t\t\t{\n\t\t\t\t/* Table */\n\t\t\t\tfeatureNode = _fnFeatureHtmlTable( oSettings );\n\t\t\t}\n\t\t\telse if ( cOption == 'i' && features.bInfo )\n\t\t\t{\n\t\t\t\t/* Info */\n\t\t\t\tfeatureNode = _fnFeatureHtmlInfo( oSettings );\n\t\t\t}\n\t\t\telse if ( cOption == 'p' && features.bPaginate )\n\t\t\t{\n\t\t\t\t/* Pagination */\n\t\t\t\tfeatureNode = _fnFeatureHtmlPaginate( oSettings );\n\t\t\t}\n\t\t\telse if ( DataTable.ext.feature.length !== 0 )\n\t\t\t{\n\t\t\t\t/* Plug-in features */\n\t\t\t\tvar aoFeatures = DataTable.ext.feature;\n\t\t\t\tfor ( var k=0, kLen=aoFeatures.length ; k<kLen ; k++ )\n\t\t\t\t{\n\t\t\t\t\tif ( cOption == aoFeatures[k].cFeature )\n\t\t\t\t\t{\n\t\t\t\t\t\tfeatureNode = aoFeatures[k].fnInit( oSettings );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t/* Add to the 2D features array */\n\t\t\tif ( featureNode )\n\t\t\t{\n\t\t\t\tvar aanFeatures = oSettings.aanFeatures;\n\t\n\t\t\t\tif ( ! aanFeatures[cOption] )\n\t\t\t\t{\n\t\t\t\t\taanFeatures[cOption] = [];\n\t\t\t\t}\n\t\n\t\t\t\taanFeatures[cOption].push( featureNode );\n\t\t\t\tinsert.append( featureNode );\n\t\t\t}\n\t\t}\n\t\n\t\t/* Built our DOM structure - replace the holding div with what we want */\n\t\tholding.replaceWith( insert );\n\t\toSettings.nHolding = null;\n\t}\n\t\n\t\n\t/**\n\t * Use the DOM source to create up an array of header cells. The idea here is to\n\t * create a layout grid (array) of rows x columns, which contains a reference\n\t * to the cell that that point in the grid (regardless of col/rowspan), such that\n\t * any column / row could be removed and the new grid constructed\n\t * @param array {object} aLayout Array to store the calculated layout in\n\t * @param {node} nThead The header/footer element for the table\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnDetectHeader ( aLayout, nThead )\n\t{\n\t\tvar nTrs = $(nThead).children('tr');\n\t\tvar nTr, nCell;\n\t\tvar i, k, l, iLen, jLen, iColShifted, iColumn, iColspan, iRowspan;\n\t\tvar bUnique;\n\t\tvar fnShiftCol = function ( a, i, j ) {\n\t\t\tvar k = a[i];\n\t while ( k[j] ) {\n\t\t\t\tj++;\n\t\t\t}\n\t\t\treturn j;\n\t\t};\n\t\n\t\taLayout.splice( 0, aLayout.length );\n\t\n\t\t/* We know how many rows there are in the layout - so prep it */\n\t\tfor ( i=0, iLen=nTrs.length ; i<iLen ; i++ )\n\t\t{\n\t\t\taLayout.push( [] );\n\t\t}\n\t\n\t\t/* Calculate a layout array */\n\t\tfor ( i=0, iLen=nTrs.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tnTr = nTrs[i];\n\t\t\tiColumn = 0;\n\t\n\t\t\t/* For every cell in the row... */\n\t\t\tnCell = nTr.firstChild;\n\t\t\twhile ( nCell ) {\n\t\t\t\tif ( nCell.nodeName.toUpperCase() == \"TD\" ||\n\t\t\t\t nCell.nodeName.toUpperCase() == \"TH\" )\n\t\t\t\t{\n\t\t\t\t\t/* Get the col and rowspan attributes from the DOM and sanitise them */\n\t\t\t\t\tiColspan = nCell.getAttribute('colspan') * 1;\n\t\t\t\t\tiRowspan = nCell.getAttribute('rowspan') * 1;\n\t\t\t\t\tiColspan = (!iColspan || iColspan===0 || iColspan===1) ? 1 : iColspan;\n\t\t\t\t\tiRowspan = (!iRowspan || iRowspan===0 || iRowspan===1) ? 1 : iRowspan;\n\t\n\t\t\t\t\t/* There might be colspan cells already in this row, so shift our target\n\t\t\t\t\t * accordingly\n\t\t\t\t\t */\n\t\t\t\t\tiColShifted = fnShiftCol( aLayout, i, iColumn );\n\t\n\t\t\t\t\t/* Cache calculation for unique columns */\n\t\t\t\t\tbUnique = iColspan === 1 ? true : false;\n\t\n\t\t\t\t\t/* If there is col / rowspan, copy the information into the layout grid */\n\t\t\t\t\tfor ( l=0 ; l<iColspan ; l++ )\n\t\t\t\t\t{\n\t\t\t\t\t\tfor ( k=0 ; k<iRowspan ; k++ )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\taLayout[i+k][iColShifted+l] = {\n\t\t\t\t\t\t\t\t\"cell\": nCell,\n\t\t\t\t\t\t\t\t\"unique\": bUnique\n\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\taLayout[i+k].nTr = nTr;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tnCell = nCell.nextSibling;\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Get an array of unique th elements, one for each column\n\t * @param {object} oSettings dataTables settings object\n\t * @param {node} nHeader automatically detect the layout from this node - optional\n\t * @param {array} aLayout thead/tfoot layout from _fnDetectHeader - optional\n\t * @returns array {node} aReturn list of unique th's\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetUniqueThs ( oSettings, nHeader, aLayout )\n\t{\n\t\tvar aReturn = [];\n\t\tif ( !aLayout )\n\t\t{\n\t\t\taLayout = oSettings.aoHeader;\n\t\t\tif ( nHeader )\n\t\t\t{\n\t\t\t\taLayout = [];\n\t\t\t\t_fnDetectHeader( aLayout, nHeader );\n\t\t\t}\n\t\t}\n\t\n\t\tfor ( var i=0, iLen=aLayout.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tfor ( var j=0, jLen=aLayout[i].length ; j<jLen ; j++ )\n\t\t\t{\n\t\t\t\tif ( aLayout[i][j].unique &&\n\t\t\t\t\t (!aReturn[j] || !oSettings.bSortCellsTop) )\n\t\t\t\t{\n\t\t\t\t\taReturn[j] = aLayout[i][j].cell;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\treturn aReturn;\n\t}\n\t\n\t/**\n\t * Create an Ajax call based on the table's settings, taking into account that\n\t * parameters can have multiple forms, and backwards compatibility.\n\t *\n\t * @param {object} oSettings dataTables settings object\n\t * @param {array} data Data to send to the server, required by\n\t * DataTables - may be augmented by developer callbacks\n\t * @param {function} fn Callback function to run when data is obtained\n\t */\n\tfunction _fnBuildAjax( oSettings, data, fn )\n\t{\n\t\t// Compatibility with 1.9-, allow fnServerData and event to manipulate\n\t\t_fnCallbackFire( oSettings, 'aoServerParams', 'serverParams', [data] );\n\t\n\t\t// Convert to object based for 1.10+ if using the old array scheme which can\n\t\t// come from server-side processing or serverParams\n\t\tif ( data && $.isArray(data) ) {\n\t\t\tvar tmp = {};\n\t\t\tvar rbracket = /(.*?)\\[\\]$/;\n\t\n\t\t\t$.each( data, function (key, val) {\n\t\t\t\tvar match = val.name.match(rbracket);\n\t\n\t\t\t\tif ( match ) {\n\t\t\t\t\t// Support for arrays\n\t\t\t\t\tvar name = match[0];\n\t\n\t\t\t\t\tif ( ! tmp[ name ] ) {\n\t\t\t\t\t\ttmp[ name ] = [];\n\t\t\t\t\t}\n\t\t\t\t\ttmp[ name ].push( val.value );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\ttmp[val.name] = val.value;\n\t\t\t\t}\n\t\t\t} );\n\t\t\tdata = tmp;\n\t\t}\n\t\n\t\tvar ajaxData;\n\t\tvar ajax = oSettings.ajax;\n\t\tvar instance = oSettings.oInstance;\n\t\tvar callback = function ( json ) {\n\t\t\t_fnCallbackFire( oSettings, null, 'xhr', [oSettings, json, oSettings.jqXHR] );\n\t\t\tfn( json );\n\t\t};\n\t\n\t\tif ( $.isPlainObject( ajax ) && ajax.data )\n\t\t{\n\t\t\tajaxData = ajax.data;\n\t\n\t\t\tvar newData = $.isFunction( ajaxData ) ?\n\t\t\t\tajaxData( data, oSettings ) : // fn can manipulate data or return\n\t\t\t\tajaxData; // an object object or array to merge\n\t\n\t\t\t// If the function returned something, use that alone\n\t\t\tdata = $.isFunction( ajaxData ) && newData ?\n\t\t\t\tnewData :\n\t\t\t\t$.extend( true, data, newData );\n\t\n\t\t\t// Remove the data property as we've resolved it already and don't want\n\t\t\t// jQuery to do it again (it is restored at the end of the function)\n\t\t\tdelete ajax.data;\n\t\t}\n\t\n\t\tvar baseAjax = {\n\t\t\t\"data\": data,\n\t\t\t\"success\": function (json) {\n\t\t\t\tvar error = json.error || json.sError;\n\t\t\t\tif ( error ) {\n\t\t\t\t\t_fnLog( oSettings, 0, error );\n\t\t\t\t}\n\t\n\t\t\t\toSettings.json = json;\n\t\t\t\tcallback( json );\n\t\t\t},\n\t\t\t\"dataType\": \"json\",\n\t\t\t\"cache\": false,\n\t\t\t\"type\": oSettings.sServerMethod,\n\t\t\t\"error\": function (xhr, error, thrown) {\n\t\t\t\tvar ret = _fnCallbackFire( oSettings, null, 'xhr', [oSettings, null, oSettings.jqXHR] );\n\t\n\t\t\t\tif ( $.inArray( true, ret ) === -1 ) {\n\t\t\t\t\tif ( error == \"parsererror\" ) {\n\t\t\t\t\t\t_fnLog( oSettings, 0, 'Invalid JSON response', 1 );\n\t\t\t\t\t}\n\t\t\t\t\telse if ( xhr.readyState === 4 ) {\n\t\t\t\t\t\t_fnLog( oSettings, 0, 'Ajax error', 7 );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\t_fnProcessingDisplay( oSettings, false );\n\t\t\t}\n\t\t};\n\t\n\t\t// Store the data submitted for the API\n\t\toSettings.oAjaxData = data;\n\t\n\t\t// Allow plug-ins and external processes to modify the data\n\t\t_fnCallbackFire( oSettings, null, 'preXhr', [oSettings, data] );\n\t\n\t\tif ( oSettings.fnServerData )\n\t\t{\n\t\t\t// DataTables 1.9- compatibility\n\t\t\toSettings.fnServerData.call( instance,\n\t\t\t\toSettings.sAjaxSource,\n\t\t\t\t$.map( data, function (val, key) { // Need to convert back to 1.9 trad format\n\t\t\t\t\treturn { name: key, value: val };\n\t\t\t\t} ),\n\t\t\t\tcallback,\n\t\t\t\toSettings\n\t\t\t);\n\t\t}\n\t\telse if ( oSettings.sAjaxSource || typeof ajax === 'string' )\n\t\t{\n\t\t\t// DataTables 1.9- compatibility\n\t\t\toSettings.jqXHR = $.ajax( $.extend( baseAjax, {\n\t\t\t\turl: ajax || oSettings.sAjaxSource\n\t\t\t} ) );\n\t\t}\n\t\telse if ( $.isFunction( ajax ) )\n\t\t{\n\t\t\t// Is a function - let the caller define what needs to be done\n\t\t\toSettings.jqXHR = ajax.call( instance, data, callback, oSettings );\n\t\t}\n\t\telse\n\t\t{\n\t\t\t// Object to extend the base settings\n\t\t\toSettings.jqXHR = $.ajax( $.extend( baseAjax, ajax ) );\n\t\n\t\t\t// Restore for next time around\n\t\t\tajax.data = ajaxData;\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Update the table using an Ajax call\n\t * @param {object} settings dataTables settings object\n\t * @returns {boolean} Block the table drawing or not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAjaxUpdate( settings )\n\t{\n\t\tif ( settings.bAjaxDataGet ) {\n\t\t\tsettings.iDraw++;\n\t\t\t_fnProcessingDisplay( settings, true );\n\t\n\t\t\t_fnBuildAjax(\n\t\t\t\tsettings,\n\t\t\t\t_fnAjaxParameters( settings ),\n\t\t\t\tfunction(json) {\n\t\t\t\t\t_fnAjaxUpdateDraw( settings, json );\n\t\t\t\t}\n\t\t\t);\n\t\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t}\n\t\n\t\n\t/**\n\t * Build up the parameters in an object needed for a server-side processing\n\t * request. Note that this is basically done twice, is different ways - a modern\n\t * method which is used by default in DataTables 1.10 which uses objects and\n\t * arrays, or the 1.9- method with is name / value pairs. 1.9 method is used if\n\t * the sAjaxSource option is used in the initialisation, or the legacyAjax\n\t * option is set.\n\t * @param {object} oSettings dataTables settings object\n\t * @returns {bool} block the table drawing or not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAjaxParameters( settings )\n\t{\n\t\tvar\n\t\t\tcolumns = settings.aoColumns,\n\t\t\tcolumnCount = columns.length,\n\t\t\tfeatures = settings.oFeatures,\n\t\t\tpreSearch = settings.oPreviousSearch,\n\t\t\tpreColSearch = settings.aoPreSearchCols,\n\t\t\ti, data = [], dataProp, column, columnSearch,\n\t\t\tsort = _fnSortFlatten( settings ),\n\t\t\tdisplayStart = settings._iDisplayStart,\n\t\t\tdisplayLength = features.bPaginate !== false ?\n\t\t\t\tsettings._iDisplayLength :\n\t\t\t\t-1;\n\t\n\t\tvar param = function ( name, value ) {\n\t\t\tdata.push( { 'name': name, 'value': value } );\n\t\t};\n\t\n\t\t// DataTables 1.9- compatible method\n\t\tparam( 'sEcho', settings.iDraw );\n\t\tparam( 'iColumns', columnCount );\n\t\tparam( 'sColumns', _pluck( columns, 'sName' ).join(',') );\n\t\tparam( 'iDisplayStart', displayStart );\n\t\tparam( 'iDisplayLength', displayLength );\n\t\n\t\t// DataTables 1.10+ method\n\t\tvar d = {\n\t\t\tdraw: settings.iDraw,\n\t\t\tcolumns: [],\n\t\t\torder: [],\n\t\t\tstart: displayStart,\n\t\t\tlength: displayLength,\n\t\t\tsearch: {\n\t\t\t\tvalue: preSearch.sSearch,\n\t\t\t\tregex: preSearch.bRegex\n\t\t\t}\n\t\t};\n\t\n\t\tfor ( i=0 ; i<columnCount ; i++ ) {\n\t\t\tcolumn = columns[i];\n\t\t\tcolumnSearch = preColSearch[i];\n\t\t\tdataProp = typeof column.mData==\"function\" ? 'function' : column.mData ;\n\t\n\t\t\td.columns.push( {\n\t\t\t\tdata: dataProp,\n\t\t\t\tname: column.sName,\n\t\t\t\tsearchable: column.bSearchable,\n\t\t\t\torderable: column.bSortable,\n\t\t\t\tsearch: {\n\t\t\t\t\tvalue: columnSearch.sSearch,\n\t\t\t\t\tregex: columnSearch.bRegex\n\t\t\t\t}\n\t\t\t} );\n\t\n\t\t\tparam( \"mDataProp_\"+i, dataProp );\n\t\n\t\t\tif ( features.bFilter ) {\n\t\t\t\tparam( 'sSearch_'+i, columnSearch.sSearch );\n\t\t\t\tparam( 'bRegex_'+i, columnSearch.bRegex );\n\t\t\t\tparam( 'bSearchable_'+i, column.bSearchable );\n\t\t\t}\n\t\n\t\t\tif ( features.bSort ) {\n\t\t\t\tparam( 'bSortable_'+i, column.bSortable );\n\t\t\t}\n\t\t}\n\t\n\t\tif ( features.bFilter ) {\n\t\t\tparam( 'sSearch', preSearch.sSearch );\n\t\t\tparam( 'bRegex', preSearch.bRegex );\n\t\t}\n\t\n\t\tif ( features.bSort ) {\n\t\t\t$.each( sort, function ( i, val ) {\n\t\t\t\td.order.push( { column: val.col, dir: val.dir } );\n\t\n\t\t\t\tparam( 'iSortCol_'+i, val.col );\n\t\t\t\tparam( 'sSortDir_'+i, val.dir );\n\t\t\t} );\n\t\n\t\t\tparam( 'iSortingCols', sort.length );\n\t\t}\n\t\n\t\t// If the legacy.ajax parameter is null, then we automatically decide which\n\t\t// form to use, based on sAjaxSource\n\t\tvar legacy = DataTable.ext.legacy.ajax;\n\t\tif ( legacy === null ) {\n\t\t\treturn settings.sAjaxSource ? data : d;\n\t\t}\n\t\n\t\t// Otherwise, if legacy has been specified then we use that to decide on the\n\t\t// form\n\t\treturn legacy ? data : d;\n\t}\n\t\n\t\n\t/**\n\t * Data the data from the server (nuking the old) and redraw the table\n\t * @param {object} oSettings dataTables settings object\n\t * @param {object} json json data return from the server.\n\t * @param {string} json.sEcho Tracking flag for DataTables to match requests\n\t * @param {int} json.iTotalRecords Number of records in the data set, not accounting for filtering\n\t * @param {int} json.iTotalDisplayRecords Number of records in the data set, accounting for filtering\n\t * @param {array} json.aaData The data to display on this page\n\t * @param {string} [json.sColumns] Column ordering (sName, comma separated)\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAjaxUpdateDraw ( settings, json )\n\t{\n\t\t// v1.10 uses camelCase variables, while 1.9 uses Hungarian notation.\n\t\t// Support both\n\t\tvar compat = function ( old, modern ) {\n\t\t\treturn json[old] !== undefined ? json[old] : json[modern];\n\t\t};\n\t\n\t\tvar data = _fnAjaxDataSrc( settings, json );\n\t\tvar draw = compat( 'sEcho', 'draw' );\n\t\tvar recordsTotal = compat( 'iTotalRecords', 'recordsTotal' );\n\t\tvar recordsFiltered = compat( 'iTotalDisplayRecords', 'recordsFiltered' );\n\t\n\t\tif ( draw ) {\n\t\t\t// Protect against out of sequence returns\n\t\t\tif ( draw*1 < settings.iDraw ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tsettings.iDraw = draw * 1;\n\t\t}\n\t\n\t\t_fnClearTable( settings );\n\t\tsettings._iRecordsTotal = parseInt(recordsTotal, 10);\n\t\tsettings._iRecordsDisplay = parseInt(recordsFiltered, 10);\n\t\n\t\tfor ( var i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t_fnAddData( settings, data[i] );\n\t\t}\n\t\tsettings.aiDisplay = settings.aiDisplayMaster.slice();\n\t\n\t\tsettings.bAjaxDataGet = false;\n\t\t_fnDraw( settings );\n\t\n\t\tif ( ! settings._bInitComplete ) {\n\t\t\t_fnInitComplete( settings, json );\n\t\t}\n\t\n\t\tsettings.bAjaxDataGet = true;\n\t\t_fnProcessingDisplay( settings, false );\n\t}\n\t\n\t\n\t/**\n\t * Get the data from the JSON data source to use for drawing a table. Using\n\t * `_fnGetObjectDataFn` allows the data to be sourced from a property of the\n\t * source object, or from a processing function.\n\t * @param {object} oSettings dataTables settings object\n\t * @param {object} json Data source object / array from the server\n\t * @return {array} Array of data to use\n\t */\n\tfunction _fnAjaxDataSrc ( oSettings, json )\n\t{\n\t\tvar dataSrc = $.isPlainObject( oSettings.ajax ) && oSettings.ajax.dataSrc !== undefined ?\n\t\t\toSettings.ajax.dataSrc :\n\t\t\toSettings.sAjaxDataProp; // Compatibility with 1.9-.\n\t\n\t\t// Compatibility with 1.9-. In order to read from aaData, check if the\n\t\t// default has been changed, if not, check for aaData\n\t\tif ( dataSrc === 'data' ) {\n\t\t\treturn json.aaData || json[dataSrc];\n\t\t}\n\t\n\t\treturn dataSrc !== \"\" ?\n\t\t\t_fnGetObjectDataFn( dataSrc )( json ) :\n\t\t\tjson;\n\t}\n\t\n\t/**\n\t * Generate the node required for filtering text\n\t * @returns {node} Filter control element\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlFilter ( settings )\n\t{\n\t\tvar classes = settings.oClasses;\n\t\tvar tableId = settings.sTableId;\n\t\tvar language = settings.oLanguage;\n\t\tvar previousSearch = settings.oPreviousSearch;\n\t\tvar features = settings.aanFeatures;\n\t\tvar input = '<input type=\"search\" class=\"'+classes.sFilterInput+'\"/>';\n\t\n\t\tvar str = language.sSearch;\n\t\tstr = str.match(/_INPUT_/) ?\n\t\t\tstr.replace('_INPUT_', input) :\n\t\t\tstr+input;\n\t\n\t\tvar filter = $('<div/>', {\n\t\t\t\t'id': ! features.f ? tableId+'_filter' : null,\n\t\t\t\t'class': classes.sFilter\n\t\t\t} )\n\t\t\t.append( $('<label/>' ).append( str ) );\n\t\n\t\tvar searchFn = function() {\n\t\t\t/* Update all other filter input elements for the new display */\n\t\t\tvar n = features.f;\n\t\t\tvar val = !this.value ? \"\" : this.value; // mental IE8 fix :-(\n\t\n\t\t\t/* Now do the filter */\n\t\t\tif ( val != previousSearch.sSearch ) {\n\t\t\t\t_fnFilterComplete( settings, {\n\t\t\t\t\t\"sSearch\": val,\n\t\t\t\t\t\"bRegex\": previousSearch.bRegex,\n\t\t\t\t\t\"bSmart\": previousSearch.bSmart ,\n\t\t\t\t\t\"bCaseInsensitive\": previousSearch.bCaseInsensitive\n\t\t\t\t} );\n\t\n\t\t\t\t// Need to redraw, without resorting\n\t\t\t\tsettings._iDisplayStart = 0;\n\t\t\t\t_fnDraw( settings );\n\t\t\t}\n\t\t};\n\t\n\t\tvar searchDelay = settings.searchDelay !== null ?\n\t\t\tsettings.searchDelay :\n\t\t\t_fnDataSource( settings ) === 'ssp' ?\n\t\t\t\t400 :\n\t\t\t\t0;\n\t\n\t\tvar jqFilter = $('input', filter)\n\t\t\t.val( previousSearch.sSearch )\n\t\t\t.attr( 'placeholder', language.sSearchPlaceholder )\n\t\t\t.bind(\n\t\t\t\t'keyup.DT search.DT input.DT paste.DT cut.DT',\n\t\t\t\tsearchDelay ?\n\t\t\t\t\t_fnThrottle( searchFn, searchDelay ) :\n\t\t\t\t\tsearchFn\n\t\t\t)\n\t\t\t.bind( 'keypress.DT', function(e) {\n\t\t\t\t/* Prevent form submission */\n\t\t\t\tif ( e.keyCode == 13 ) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t} )\n\t\t\t.attr('aria-controls', tableId);\n\t\n\t\t// Update the input elements whenever the table is filtered\n\t\t$(settings.nTable).on( 'search.dt.DT', function ( ev, s ) {\n\t\t\tif ( settings === s ) {\n\t\t\t\t// IE9 throws an 'unknown error' if document.activeElement is used\n\t\t\t\t// inside an iframe or frame...\n\t\t\t\ttry {\n\t\t\t\t\tif ( jqFilter[0] !== document.activeElement ) {\n\t\t\t\t\t\tjqFilter.val( previousSearch.sSearch );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tcatch ( e ) {}\n\t\t\t}\n\t\t} );\n\t\n\t\treturn filter[0];\n\t}\n\t\n\t\n\t/**\n\t * Filter the table using both the global filter and column based filtering\n\t * @param {object} oSettings dataTables settings object\n\t * @param {object} oSearch search information\n\t * @param {int} [iForce] force a research of the master array (1) or not (undefined or 0)\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFilterComplete ( oSettings, oInput, iForce )\n\t{\n\t\tvar oPrevSearch = oSettings.oPreviousSearch;\n\t\tvar aoPrevSearch = oSettings.aoPreSearchCols;\n\t\tvar fnSaveFilter = function ( oFilter ) {\n\t\t\t/* Save the filtering values */\n\t\t\toPrevSearch.sSearch = oFilter.sSearch;\n\t\t\toPrevSearch.bRegex = oFilter.bRegex;\n\t\t\toPrevSearch.bSmart = oFilter.bSmart;\n\t\t\toPrevSearch.bCaseInsensitive = oFilter.bCaseInsensitive;\n\t\t};\n\t\tvar fnRegex = function ( o ) {\n\t\t\t// Backwards compatibility with the bEscapeRegex option\n\t\t\treturn o.bEscapeRegex !== undefined ? !o.bEscapeRegex : o.bRegex;\n\t\t};\n\t\n\t\t// Resolve any column types that are unknown due to addition or invalidation\n\t\t// @todo As per sort - can this be moved into an event handler?\n\t\t_fnColumnTypes( oSettings );\n\t\n\t\t/* In server-side processing all filtering is done by the server, so no point hanging around here */\n\t\tif ( _fnDataSource( oSettings ) != 'ssp' )\n\t\t{\n\t\t\t/* Global filter */\n\t\t\t_fnFilter( oSettings, oInput.sSearch, iForce, fnRegex(oInput), oInput.bSmart, oInput.bCaseInsensitive );\n\t\t\tfnSaveFilter( oInput );\n\t\n\t\t\t/* Now do the individual column filter */\n\t\t\tfor ( var i=0 ; i<aoPrevSearch.length ; i++ )\n\t\t\t{\n\t\t\t\t_fnFilterColumn( oSettings, aoPrevSearch[i].sSearch, i, fnRegex(aoPrevSearch[i]),\n\t\t\t\t\taoPrevSearch[i].bSmart, aoPrevSearch[i].bCaseInsensitive );\n\t\t\t}\n\t\n\t\t\t/* Custom filtering */\n\t\t\t_fnFilterCustom( oSettings );\n\t\t}\n\t\telse\n\t\t{\n\t\t\tfnSaveFilter( oInput );\n\t\t}\n\t\n\t\t/* Tell the draw function we have been filtering */\n\t\toSettings.bFiltered = true;\n\t\t_fnCallbackFire( oSettings, null, 'search', [oSettings] );\n\t}\n\t\n\t\n\t/**\n\t * Apply custom filtering functions\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFilterCustom( settings )\n\t{\n\t\tvar filters = DataTable.ext.search;\n\t\tvar displayRows = settings.aiDisplay;\n\t\tvar row, rowIdx;\n\t\n\t\tfor ( var i=0, ien=filters.length ; i<ien ; i++ ) {\n\t\t\tvar rows = [];\n\t\n\t\t\t// Loop over each row and see if it should be included\n\t\t\tfor ( var j=0, jen=displayRows.length ; j<jen ; j++ ) {\n\t\t\t\trowIdx = displayRows[ j ];\n\t\t\t\trow = settings.aoData[ rowIdx ];\n\t\n\t\t\t\tif ( filters[i]( settings, row._aFilterData, rowIdx, row._aData, j ) ) {\n\t\t\t\t\trows.push( rowIdx );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// So the array reference doesn't break set the results into the\n\t\t\t// existing array\n\t\t\tdisplayRows.length = 0;\n\t\t\t$.merge( displayRows, rows );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Filter the table on a per-column basis\n\t * @param {object} oSettings dataTables settings object\n\t * @param {string} sInput string to filter on\n\t * @param {int} iColumn column to filter\n\t * @param {bool} bRegex treat search string as a regular expression or not\n\t * @param {bool} bSmart use smart filtering or not\n\t * @param {bool} bCaseInsensitive Do case insenstive matching or not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFilterColumn ( settings, searchStr, colIdx, regex, smart, caseInsensitive )\n\t{\n\t\tif ( searchStr === '' ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar data;\n\t\tvar display = settings.aiDisplay;\n\t\tvar rpSearch = _fnFilterCreateSearch( searchStr, regex, smart, caseInsensitive );\n\t\n\t\tfor ( var i=display.length-1 ; i>=0 ; i-- ) {\n\t\t\tdata = settings.aoData[ display[i] ]._aFilterData[ colIdx ];\n\t\n\t\t\tif ( ! rpSearch.test( data ) ) {\n\t\t\t\tdisplay.splice( i, 1 );\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Filter the data table based on user input and draw the table\n\t * @param {object} settings dataTables settings object\n\t * @param {string} input string to filter on\n\t * @param {int} force optional - force a research of the master array (1) or not (undefined or 0)\n\t * @param {bool} regex treat as a regular expression or not\n\t * @param {bool} smart perform smart filtering or not\n\t * @param {bool} caseInsensitive Do case insenstive matching or not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFilter( settings, input, force, regex, smart, caseInsensitive )\n\t{\n\t\tvar rpSearch = _fnFilterCreateSearch( input, regex, smart, caseInsensitive );\n\t\tvar prevSearch = settings.oPreviousSearch.sSearch;\n\t\tvar displayMaster = settings.aiDisplayMaster;\n\t\tvar display, invalidated, i;\n\t\n\t\t// Need to take account of custom filtering functions - always filter\n\t\tif ( DataTable.ext.search.length !== 0 ) {\n\t\t\tforce = true;\n\t\t}\n\t\n\t\t// Check if any of the rows were invalidated\n\t\tinvalidated = _fnFilterData( settings );\n\t\n\t\t// If the input is blank - we just want the full data set\n\t\tif ( input.length <= 0 ) {\n\t\t\tsettings.aiDisplay = displayMaster.slice();\n\t\t}\n\t\telse {\n\t\t\t// New search - start from the master array\n\t\t\tif ( invalidated ||\n\t\t\t\t force ||\n\t\t\t\t prevSearch.length > input.length ||\n\t\t\t\t input.indexOf(prevSearch) !== 0 ||\n\t\t\t\t settings.bSorted // On resort, the display master needs to be\n\t\t\t\t // re-filtered since indexes will have changed\n\t\t\t) {\n\t\t\t\tsettings.aiDisplay = displayMaster.slice();\n\t\t\t}\n\t\n\t\t\t// Search the display array\n\t\t\tdisplay = settings.aiDisplay;\n\t\n\t\t\tfor ( i=display.length-1 ; i>=0 ; i-- ) {\n\t\t\t\tif ( ! rpSearch.test( settings.aoData[ display[i] ]._sFilterRow ) ) {\n\t\t\t\t\tdisplay.splice( i, 1 );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Build a regular expression object suitable for searching a table\n\t * @param {string} sSearch string to search for\n\t * @param {bool} bRegex treat as a regular expression or not\n\t * @param {bool} bSmart perform smart filtering or not\n\t * @param {bool} bCaseInsensitive Do case insensitive matching or not\n\t * @returns {RegExp} constructed object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFilterCreateSearch( search, regex, smart, caseInsensitive )\n\t{\n\t\tsearch = regex ?\n\t\t\tsearch :\n\t\t\t_fnEscapeRegex( search );\n\t\t\n\t\tif ( smart ) {\n\t\t\t/* For smart filtering we want to allow the search to work regardless of\n\t\t\t * word order. We also want double quoted text to be preserved, so word\n\t\t\t * order is important - a la google. So this is what we want to\n\t\t\t * generate:\n\t\t\t * \n\t\t\t * ^(?=.*?\\bone\\b)(?=.*?\\btwo three\\b)(?=.*?\\bfour\\b).*$\n\t\t\t */\n\t\t\tvar a = $.map( search.match( /\"[^\"]+\"|[^ ]+/g ) || [''], function ( word ) {\n\t\t\t\tif ( word.charAt(0) === '\"' ) {\n\t\t\t\t\tvar m = word.match( /^\"(.*)\"$/ );\n\t\t\t\t\tword = m ? m[1] : word;\n\t\t\t\t}\n\t\n\t\t\t\treturn word.replace('\"', '');\n\t\t\t} );\n\t\n\t\t\tsearch = '^(?=.*?'+a.join( ')(?=.*?' )+').*$';\n\t\t}\n\t\n\t\treturn new RegExp( search, caseInsensitive ? 'i' : '' );\n\t}\n\t\n\t\n\t/**\n\t * Escape a string such that it can be used in a regular expression\n\t * @param {string} sVal string to escape\n\t * @returns {string} escaped string\n\t * @memberof DataTable#oApi\n\t */\n\tvar _fnEscapeRegex = DataTable.util.escapeRegex;\n\t\n\tvar __filter_div = $('<div>')[0];\n\tvar __filter_div_textContent = __filter_div.textContent !== undefined;\n\t\n\t// Update the filtering data for each row if needed (by invalidation or first run)\n\tfunction _fnFilterData ( settings )\n\t{\n\t\tvar columns = settings.aoColumns;\n\t\tvar column;\n\t\tvar i, j, ien, jen, filterData, cellData, row;\n\t\tvar fomatters = DataTable.ext.type.search;\n\t\tvar wasInvalidated = false;\n\t\n\t\tfor ( i=0, ien=settings.aoData.length ; i<ien ; i++ ) {\n\t\t\trow = settings.aoData[i];\n\t\n\t\t\tif ( ! row._aFilterData ) {\n\t\t\t\tfilterData = [];\n\t\n\t\t\t\tfor ( j=0, jen=columns.length ; j<jen ; j++ ) {\n\t\t\t\t\tcolumn = columns[j];\n\t\n\t\t\t\t\tif ( column.bSearchable ) {\n\t\t\t\t\t\tcellData = _fnGetCellData( settings, i, j, 'filter' );\n\t\n\t\t\t\t\t\tif ( fomatters[ column.sType ] ) {\n\t\t\t\t\t\t\tcellData = fomatters[ column.sType ]( cellData );\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t// Search in DataTables 1.10 is string based. In 1.11 this\n\t\t\t\t\t\t// should be altered to also allow strict type checking.\n\t\t\t\t\t\tif ( cellData === null ) {\n\t\t\t\t\t\t\tcellData = '';\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\tif ( typeof cellData !== 'string' && cellData.toString ) {\n\t\t\t\t\t\t\tcellData = cellData.toString();\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tcellData = '';\n\t\t\t\t\t}\n\t\n\t\t\t\t\t// If it looks like there is an HTML entity in the string,\n\t\t\t\t\t// attempt to decode it so sorting works as expected. Note that\n\t\t\t\t\t// we could use a single line of jQuery to do this, but the DOM\n\t\t\t\t\t// method used here is much faster http://jsperf.com/html-decode\n\t\t\t\t\tif ( cellData.indexOf && cellData.indexOf('&') !== -1 ) {\n\t\t\t\t\t\t__filter_div.innerHTML = cellData;\n\t\t\t\t\t\tcellData = __filter_div_textContent ?\n\t\t\t\t\t\t\t__filter_div.textContent :\n\t\t\t\t\t\t\t__filter_div.innerText;\n\t\t\t\t\t}\n\t\n\t\t\t\t\tif ( cellData.replace ) {\n\t\t\t\t\t\tcellData = cellData.replace(/[\\r\\n]/g, '');\n\t\t\t\t\t}\n\t\n\t\t\t\t\tfilterData.push( cellData );\n\t\t\t\t}\n\t\n\t\t\t\trow._aFilterData = filterData;\n\t\t\t\trow._sFilterRow = filterData.join(' ');\n\t\t\t\twasInvalidated = true;\n\t\t\t}\n\t\t}\n\t\n\t\treturn wasInvalidated;\n\t}\n\t\n\t\n\t/**\n\t * Convert from the internal Hungarian notation to camelCase for external\n\t * interaction\n\t * @param {object} obj Object to convert\n\t * @returns {object} Inverted object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSearchToCamel ( obj )\n\t{\n\t\treturn {\n\t\t\tsearch: obj.sSearch,\n\t\t\tsmart: obj.bSmart,\n\t\t\tregex: obj.bRegex,\n\t\t\tcaseInsensitive: obj.bCaseInsensitive\n\t\t};\n\t}\n\t\n\t\n\t\n\t/**\n\t * Convert from camelCase notation to the internal Hungarian. We could use the\n\t * Hungarian convert function here, but this is cleaner\n\t * @param {object} obj Object to convert\n\t * @returns {object} Inverted object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSearchToHung ( obj )\n\t{\n\t\treturn {\n\t\t\tsSearch: obj.search,\n\t\t\tbSmart: obj.smart,\n\t\t\tbRegex: obj.regex,\n\t\t\tbCaseInsensitive: obj.caseInsensitive\n\t\t};\n\t}\n\t\n\t/**\n\t * Generate the node required for the info display\n\t * @param {object} oSettings dataTables settings object\n\t * @returns {node} Information element\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlInfo ( settings )\n\t{\n\t\tvar\n\t\t\ttid = settings.sTableId,\n\t\t\tnodes = settings.aanFeatures.i,\n\t\t\tn = $('<div/>', {\n\t\t\t\t'class': settings.oClasses.sInfo,\n\t\t\t\t'id': ! nodes ? tid+'_info' : null\n\t\t\t} );\n\t\n\t\tif ( ! nodes ) {\n\t\t\t// Update display on each draw\n\t\t\tsettings.aoDrawCallback.push( {\n\t\t\t\t\"fn\": _fnUpdateInfo,\n\t\t\t\t\"sName\": \"information\"\n\t\t\t} );\n\t\n\t\t\tn\n\t\t\t\t.attr( 'role', 'status' )\n\t\t\t\t.attr( 'aria-live', 'polite' );\n\t\n\t\t\t// Table is described by our info div\n\t\t\t$(settings.nTable).attr( 'aria-describedby', tid+'_info' );\n\t\t}\n\t\n\t\treturn n[0];\n\t}\n\t\n\t\n\t/**\n\t * Update the information elements in the display\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnUpdateInfo ( settings )\n\t{\n\t\t/* Show information about the table */\n\t\tvar nodes = settings.aanFeatures.i;\n\t\tif ( nodes.length === 0 ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar\n\t\t\tlang = settings.oLanguage,\n\t\t\tstart = settings._iDisplayStart+1,\n\t\t\tend = settings.fnDisplayEnd(),\n\t\t\tmax = settings.fnRecordsTotal(),\n\t\t\ttotal = settings.fnRecordsDisplay(),\n\t\t\tout = total ?\n\t\t\t\tlang.sInfo :\n\t\t\t\tlang.sInfoEmpty;\n\t\n\t\tif ( total !== max ) {\n\t\t\t/* Record set after filtering */\n\t\t\tout += ' ' + lang.sInfoFiltered;\n\t\t}\n\t\n\t\t// Convert the macros\n\t\tout += lang.sInfoPostFix;\n\t\tout = _fnInfoMacros( settings, out );\n\t\n\t\tvar callback = lang.fnInfoCallback;\n\t\tif ( callback !== null ) {\n\t\t\tout = callback.call( settings.oInstance,\n\t\t\t\tsettings, start, end, max, total, out\n\t\t\t);\n\t\t}\n\t\n\t\t$(nodes).html( out );\n\t}\n\t\n\t\n\tfunction _fnInfoMacros ( settings, str )\n\t{\n\t\t// When infinite scrolling, we are always starting at 1. _iDisplayStart is used only\n\t\t// internally\n\t\tvar\n\t\t\tformatter = settings.fnFormatNumber,\n\t\t\tstart = settings._iDisplayStart+1,\n\t\t\tlen = settings._iDisplayLength,\n\t\t\tvis = settings.fnRecordsDisplay(),\n\t\t\tall = len === -1;\n\t\n\t\treturn str.\n\t\t\treplace(/_START_/g, formatter.call( settings, start ) ).\n\t\t\treplace(/_END_/g, formatter.call( settings, settings.fnDisplayEnd() ) ).\n\t\t\treplace(/_MAX_/g, formatter.call( settings, settings.fnRecordsTotal() ) ).\n\t\t\treplace(/_TOTAL_/g, formatter.call( settings, vis ) ).\n\t\t\treplace(/_PAGE_/g, formatter.call( settings, all ? 1 : Math.ceil( start / len ) ) ).\n\t\t\treplace(/_PAGES_/g, formatter.call( settings, all ? 1 : Math.ceil( vis / len ) ) );\n\t}\n\t\n\t\n\t\n\t/**\n\t * Draw the table for the first time, adding all required features\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnInitialise ( settings )\n\t{\n\t\tvar i, iLen, iAjaxStart=settings.iInitDisplayStart;\n\t\tvar columns = settings.aoColumns, column;\n\t\tvar features = settings.oFeatures;\n\t\tvar deferLoading = settings.bDeferLoading; // value modified by the draw\n\t\n\t\t/* Ensure that the table data is fully initialised */\n\t\tif ( ! settings.bInitialised ) {\n\t\t\tsetTimeout( function(){ _fnInitialise( settings ); }, 200 );\n\t\t\treturn;\n\t\t}\n\t\n\t\t/* Show the display HTML options */\n\t\t_fnAddOptionsHtml( settings );\n\t\n\t\t/* Build and draw the header / footer for the table */\n\t\t_fnBuildHead( settings );\n\t\t_fnDrawHead( settings, settings.aoHeader );\n\t\t_fnDrawHead( settings, settings.aoFooter );\n\t\n\t\t/* Okay to show that something is going on now */\n\t\t_fnProcessingDisplay( settings, true );\n\t\n\t\t/* Calculate sizes for columns */\n\t\tif ( features.bAutoWidth ) {\n\t\t\t_fnCalculateColumnWidths( settings );\n\t\t}\n\t\n\t\tfor ( i=0, iLen=columns.length ; i<iLen ; i++ ) {\n\t\t\tcolumn = columns[i];\n\t\n\t\t\tif ( column.sWidth ) {\n\t\t\t\tcolumn.nTh.style.width = _fnStringToCss( column.sWidth );\n\t\t\t}\n\t\t}\n\t\n\t\t_fnCallbackFire( settings, null, 'preInit', [settings] );\n\t\n\t\t// If there is default sorting required - let's do it. The sort function\n\t\t// will do the drawing for us. Otherwise we draw the table regardless of the\n\t\t// Ajax source - this allows the table to look initialised for Ajax sourcing\n\t\t// data (show 'loading' message possibly)\n\t\t_fnReDraw( settings );\n\t\n\t\t// Server-side processing init complete is done by _fnAjaxUpdateDraw\n\t\tvar dataSrc = _fnDataSource( settings );\n\t\tif ( dataSrc != 'ssp' || deferLoading ) {\n\t\t\t// if there is an ajax source load the data\n\t\t\tif ( dataSrc == 'ajax' ) {\n\t\t\t\t_fnBuildAjax( settings, [], function(json) {\n\t\t\t\t\tvar aData = _fnAjaxDataSrc( settings, json );\n\t\n\t\t\t\t\t// Got the data - add it to the table\n\t\t\t\t\tfor ( i=0 ; i<aData.length ; i++ ) {\n\t\t\t\t\t\t_fnAddData( settings, aData[i] );\n\t\t\t\t\t}\n\t\n\t\t\t\t\t// Reset the init display for cookie saving. We've already done\n\t\t\t\t\t// a filter, and therefore cleared it before. So we need to make\n\t\t\t\t\t// it appear 'fresh'\n\t\t\t\t\tsettings.iInitDisplayStart = iAjaxStart;\n\t\n\t\t\t\t\t_fnReDraw( settings );\n\t\n\t\t\t\t\t_fnProcessingDisplay( settings, false );\n\t\t\t\t\t_fnInitComplete( settings, json );\n\t\t\t\t}, settings );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t_fnProcessingDisplay( settings, false );\n\t\t\t\t_fnInitComplete( settings );\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Draw the table for the first time, adding all required features\n\t * @param {object} oSettings dataTables settings object\n\t * @param {object} [json] JSON from the server that completed the table, if using Ajax source\n\t * with client-side processing (optional)\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnInitComplete ( settings, json )\n\t{\n\t\tsettings._bInitComplete = true;\n\t\n\t\t// When data was added after the initialisation (data or Ajax) we need to\n\t\t// calculate the column sizing\n\t\tif ( json || settings.oInit.aaData ) {\n\t\t\t_fnAdjustColumnSizing( settings );\n\t\t}\n\t\n\t\t_fnCallbackFire( settings, null, 'plugin-init', [settings, json] );\n\t\t_fnCallbackFire( settings, 'aoInitComplete', 'init', [settings, json] );\n\t}\n\t\n\t\n\tfunction _fnLengthChange ( settings, val )\n\t{\n\t\tvar len = parseInt( val, 10 );\n\t\tsettings._iDisplayLength = len;\n\t\n\t\t_fnLengthOverflow( settings );\n\t\n\t\t// Fire length change event\n\t\t_fnCallbackFire( settings, null, 'length', [settings, len] );\n\t}\n\t\n\t\n\t/**\n\t * Generate the node required for user display length changing\n\t * @param {object} settings dataTables settings object\n\t * @returns {node} Display length feature node\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlLength ( settings )\n\t{\n\t\tvar\n\t\t\tclasses = settings.oClasses,\n\t\t\ttableId = settings.sTableId,\n\t\t\tmenu = settings.aLengthMenu,\n\t\t\td2 = $.isArray( menu[0] ),\n\t\t\tlengths = d2 ? menu[0] : menu,\n\t\t\tlanguage = d2 ? menu[1] : menu;\n\t\n\t\tvar select = $('<select/>', {\n\t\t\t'name': tableId+'_length',\n\t\t\t'aria-controls': tableId,\n\t\t\t'class': classes.sLengthSelect\n\t\t} );\n\t\n\t\tfor ( var i=0, ien=lengths.length ; i<ien ; i++ ) {\n\t\t\tselect[0][ i ] = new Option( language[i], lengths[i] );\n\t\t}\n\t\n\t\tvar div = $('<div><label/></div>').addClass( classes.sLength );\n\t\tif ( ! settings.aanFeatures.l ) {\n\t\t\tdiv[0].id = tableId+'_length';\n\t\t}\n\t\n\t\tdiv.children().append(\n\t\t\tsettings.oLanguage.sLengthMenu.replace( '_MENU_', select[0].outerHTML )\n\t\t);\n\t\n\t\t// Can't use `select` variable as user might provide their own and the\n\t\t// reference is broken by the use of outerHTML\n\t\t$('select', div)\n\t\t\t.val( settings._iDisplayLength )\n\t\t\t.bind( 'change.DT', function(e) {\n\t\t\t\t_fnLengthChange( settings, $(this).val() );\n\t\t\t\t_fnDraw( settings );\n\t\t\t} );\n\t\n\t\t// Update node value whenever anything changes the table's length\n\t\t$(settings.nTable).bind( 'length.dt.DT', function (e, s, len) {\n\t\t\tif ( settings === s ) {\n\t\t\t\t$('select', div).val( len );\n\t\t\t}\n\t\t} );\n\t\n\t\treturn div[0];\n\t}\n\t\n\t\n\t\n\t/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *\n\t * Note that most of the paging logic is done in\n\t * DataTable.ext.pager\n\t */\n\t\n\t/**\n\t * Generate the node required for default pagination\n\t * @param {object} oSettings dataTables settings object\n\t * @returns {node} Pagination feature node\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlPaginate ( settings )\n\t{\n\t\tvar\n\t\t\ttype = settings.sPaginationType,\n\t\t\tplugin = DataTable.ext.pager[ type ],\n\t\t\tmodern = typeof plugin === 'function',\n\t\t\tredraw = function( settings ) {\n\t\t\t\t_fnDraw( settings );\n\t\t\t},\n\t\t\tnode = $('<div/>').addClass( settings.oClasses.sPaging + type )[0],\n\t\t\tfeatures = settings.aanFeatures;\n\t\n\t\tif ( ! modern ) {\n\t\t\tplugin.fnInit( settings, node, redraw );\n\t\t}\n\t\n\t\t/* Add a draw callback for the pagination on first instance, to update the paging display */\n\t\tif ( ! features.p )\n\t\t{\n\t\t\tnode.id = settings.sTableId+'_paginate';\n\t\n\t\t\tsettings.aoDrawCallback.push( {\n\t\t\t\t\"fn\": function( settings ) {\n\t\t\t\t\tif ( modern ) {\n\t\t\t\t\t\tvar\n\t\t\t\t\t\t\tstart = settings._iDisplayStart,\n\t\t\t\t\t\t\tlen = settings._iDisplayLength,\n\t\t\t\t\t\t\tvisRecords = settings.fnRecordsDisplay(),\n\t\t\t\t\t\t\tall = len === -1,\n\t\t\t\t\t\t\tpage = all ? 0 : Math.ceil( start / len ),\n\t\t\t\t\t\t\tpages = all ? 1 : Math.ceil( visRecords / len ),\n\t\t\t\t\t\t\tbuttons = plugin(page, pages),\n\t\t\t\t\t\t\ti, ien;\n\t\n\t\t\t\t\t\tfor ( i=0, ien=features.p.length ; i<ien ; i++ ) {\n\t\t\t\t\t\t\t_fnRenderer( settings, 'pageButton' )(\n\t\t\t\t\t\t\t\tsettings, features.p[i], i, buttons, page, pages\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tplugin.fnUpdate( settings, redraw );\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\t\"sName\": \"pagination\"\n\t\t\t} );\n\t\t}\n\t\n\t\treturn node;\n\t}\n\t\n\t\n\t/**\n\t * Alter the display settings to change the page\n\t * @param {object} settings DataTables settings object\n\t * @param {string|int} action Paging action to take: \"first\", \"previous\",\n\t * \"next\" or \"last\" or page number to jump to (integer)\n\t * @param [bool] redraw Automatically draw the update or not\n\t * @returns {bool} true page has changed, false - no change\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnPageChange ( settings, action, redraw )\n\t{\n\t\tvar\n\t\t\tstart = settings._iDisplayStart,\n\t\t\tlen = settings._iDisplayLength,\n\t\t\trecords = settings.fnRecordsDisplay();\n\t\n\t\tif ( records === 0 || len === -1 )\n\t\t{\n\t\t\tstart = 0;\n\t\t}\n\t\telse if ( typeof action === \"number\" )\n\t\t{\n\t\t\tstart = action * len;\n\t\n\t\t\tif ( start > records )\n\t\t\t{\n\t\t\t\tstart = 0;\n\t\t\t}\n\t\t}\n\t\telse if ( action == \"first\" )\n\t\t{\n\t\t\tstart = 0;\n\t\t}\n\t\telse if ( action == \"previous\" )\n\t\t{\n\t\t\tstart = len >= 0 ?\n\t\t\t\tstart - len :\n\t\t\t\t0;\n\t\n\t\t\tif ( start < 0 )\n\t\t\t{\n\t\t\t start = 0;\n\t\t\t}\n\t\t}\n\t\telse if ( action == \"next\" )\n\t\t{\n\t\t\tif ( start + len < records )\n\t\t\t{\n\t\t\t\tstart += len;\n\t\t\t}\n\t\t}\n\t\telse if ( action == \"last\" )\n\t\t{\n\t\t\tstart = Math.floor( (records-1) / len) * len;\n\t\t}\n\t\telse\n\t\t{\n\t\t\t_fnLog( settings, 0, \"Unknown paging action: \"+action, 5 );\n\t\t}\n\t\n\t\tvar changed = settings._iDisplayStart !== start;\n\t\tsettings._iDisplayStart = start;\n\t\n\t\tif ( changed ) {\n\t\t\t_fnCallbackFire( settings, null, 'page', [settings] );\n\t\n\t\t\tif ( redraw ) {\n\t\t\t\t_fnDraw( settings );\n\t\t\t}\n\t\t}\n\t\n\t\treturn changed;\n\t}\n\t\n\t\n\t\n\t/**\n\t * Generate the node required for the processing node\n\t * @param {object} settings dataTables settings object\n\t * @returns {node} Processing element\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlProcessing ( settings )\n\t{\n\t\treturn $('<div/>', {\n\t\t\t\t'id': ! settings.aanFeatures.r ? settings.sTableId+'_processing' : null,\n\t\t\t\t'class': settings.oClasses.sProcessing\n\t\t\t} )\n\t\t\t.html( settings.oLanguage.sProcessing )\n\t\t\t.insertBefore( settings.nTable )[0];\n\t}\n\t\n\t\n\t/**\n\t * Display or hide the processing indicator\n\t * @param {object} settings dataTables settings object\n\t * @param {bool} show Show the processing indicator (true) or not (false)\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnProcessingDisplay ( settings, show )\n\t{\n\t\tif ( settings.oFeatures.bProcessing ) {\n\t\t\t$(settings.aanFeatures.r).css( 'display', show ? 'block' : 'none' );\n\t\t}\n\t\n\t\t_fnCallbackFire( settings, null, 'processing', [settings, show] );\n\t}\n\t\n\t/**\n\t * Add any control elements for the table - specifically scrolling\n\t * @param {object} settings dataTables settings object\n\t * @returns {node} Node to add to the DOM\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlTable ( settings )\n\t{\n\t\tvar table = $(settings.nTable);\n\t\n\t\t// Add the ARIA grid role to the table\n\t\ttable.attr( 'role', 'grid' );\n\t\n\t\t// Scrolling from here on in\n\t\tvar scroll = settings.oScroll;\n\t\n\t\tif ( scroll.sX === '' && scroll.sY === '' ) {\n\t\t\treturn settings.nTable;\n\t\t}\n\t\n\t\tvar scrollX = scroll.sX;\n\t\tvar scrollY = scroll.sY;\n\t\tvar classes = settings.oClasses;\n\t\tvar caption = table.children('caption');\n\t\tvar captionSide = caption.length ? caption[0]._captionSide : null;\n\t\tvar headerClone = $( table[0].cloneNode(false) );\n\t\tvar footerClone = $( table[0].cloneNode(false) );\n\t\tvar footer = table.children('tfoot');\n\t\tvar _div = '<div/>';\n\t\tvar size = function ( s ) {\n\t\t\treturn !s ? null : _fnStringToCss( s );\n\t\t};\n\t\n\t\tif ( ! footer.length ) {\n\t\t\tfooter = null;\n\t\t}\n\t\n\t\t/*\n\t\t * The HTML structure that we want to generate in this function is:\n\t\t * div - scroller\n\t\t * div - scroll head\n\t\t * div - scroll head inner\n\t\t * table - scroll head table\n\t\t * thead - thead\n\t\t * div - scroll body\n\t\t * table - table (master table)\n\t\t * thead - thead clone for sizing\n\t\t * tbody - tbody\n\t\t * div - scroll foot\n\t\t * div - scroll foot inner\n\t\t * table - scroll foot table\n\t\t * tfoot - tfoot\n\t\t */\n\t\tvar scroller = $( _div, { 'class': classes.sScrollWrapper } )\n\t\t\t.append(\n\t\t\t\t$(_div, { 'class': classes.sScrollHead } )\n\t\t\t\t\t.css( {\n\t\t\t\t\t\toverflow: 'hidden',\n\t\t\t\t\t\tposition: 'relative',\n\t\t\t\t\t\tborder: 0,\n\t\t\t\t\t\twidth: scrollX ? size(scrollX) : '100%'\n\t\t\t\t\t} )\n\t\t\t\t\t.append(\n\t\t\t\t\t\t$(_div, { 'class': classes.sScrollHeadInner } )\n\t\t\t\t\t\t\t.css( {\n\t\t\t\t\t\t\t\t'box-sizing': 'content-box',\n\t\t\t\t\t\t\t\twidth: scroll.sXInner || '100%'\n\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t\t.append(\n\t\t\t\t\t\t\t\theaderClone\n\t\t\t\t\t\t\t\t\t.removeAttr('id')\n\t\t\t\t\t\t\t\t\t.css( 'margin-left', 0 )\n\t\t\t\t\t\t\t\t\t.append( captionSide === 'top' ? caption : null )\n\t\t\t\t\t\t\t\t\t.append(\n\t\t\t\t\t\t\t\t\t\ttable.children('thead')\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t)\n\t\t\t\t\t)\n\t\t\t)\n\t\t\t.append(\n\t\t\t\t$(_div, { 'class': classes.sScrollBody } )\n\t\t\t\t\t.css( {\n\t\t\t\t\t\tposition: 'relative',\n\t\t\t\t\t\toverflow: 'auto',\n\t\t\t\t\t\twidth: size( scrollX )\n\t\t\t\t\t} )\n\t\t\t\t\t.append( table )\n\t\t\t);\n\t\n\t\tif ( footer ) {\n\t\t\tscroller.append(\n\t\t\t\t$(_div, { 'class': classes.sScrollFoot } )\n\t\t\t\t\t.css( {\n\t\t\t\t\t\toverflow: 'hidden',\n\t\t\t\t\t\tborder: 0,\n\t\t\t\t\t\twidth: scrollX ? size(scrollX) : '100%'\n\t\t\t\t\t} )\n\t\t\t\t\t.append(\n\t\t\t\t\t\t$(_div, { 'class': classes.sScrollFootInner } )\n\t\t\t\t\t\t\t.append(\n\t\t\t\t\t\t\t\tfooterClone\n\t\t\t\t\t\t\t\t\t.removeAttr('id')\n\t\t\t\t\t\t\t\t\t.css( 'margin-left', 0 )\n\t\t\t\t\t\t\t\t\t.append( captionSide === 'bottom' ? caption : null )\n\t\t\t\t\t\t\t\t\t.append(\n\t\t\t\t\t\t\t\t\t\ttable.children('tfoot')\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t)\n\t\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\n\t\tvar children = scroller.children();\n\t\tvar scrollHead = children[0];\n\t\tvar scrollBody = children[1];\n\t\tvar scrollFoot = footer ? children[2] : null;\n\t\n\t\t// When the body is scrolled, then we also want to scroll the headers\n\t\tif ( scrollX ) {\n\t\t\t$(scrollBody).on( 'scroll.DT', function (e) {\n\t\t\t\tvar scrollLeft = this.scrollLeft;\n\t\n\t\t\t\tscrollHead.scrollLeft = scrollLeft;\n\t\n\t\t\t\tif ( footer ) {\n\t\t\t\t\tscrollFoot.scrollLeft = scrollLeft;\n\t\t\t\t}\n\t\t\t} );\n\t\t}\n\t\n\t\t$(scrollBody).css(\n\t\t\tscrollY && scroll.bCollapse ? 'max-height' : 'height', \n\t\t\tscrollY\n\t\t);\n\t\n\t\tsettings.nScrollHead = scrollHead;\n\t\tsettings.nScrollBody = scrollBody;\n\t\tsettings.nScrollFoot = scrollFoot;\n\t\n\t\t// On redraw - align columns\n\t\tsettings.aoDrawCallback.push( {\n\t\t\t\"fn\": _fnScrollDraw,\n\t\t\t\"sName\": \"scrolling\"\n\t\t} );\n\t\n\t\treturn scroller[0];\n\t}\n\t\n\t\n\t\n\t/**\n\t * Update the header, footer and body tables for resizing - i.e. column\n\t * alignment.\n\t *\n\t * Welcome to the most horrible function DataTables. The process that this\n\t * function follows is basically:\n\t * 1. Re-create the table inside the scrolling div\n\t * 2. Take live measurements from the DOM\n\t * 3. Apply the measurements to align the columns\n\t * 4. Clean up\n\t *\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnScrollDraw ( settings )\n\t{\n\t\t// Given that this is such a monster function, a lot of variables are use\n\t\t// to try and keep the minimised size as small as possible\n\t\tvar\n\t\t\tscroll = settings.oScroll,\n\t\t\tscrollX = scroll.sX,\n\t\t\tscrollXInner = scroll.sXInner,\n\t\t\tscrollY = scroll.sY,\n\t\t\tbarWidth = scroll.iBarWidth,\n\t\t\tdivHeader = $(settings.nScrollHead),\n\t\t\tdivHeaderStyle = divHeader[0].style,\n\t\t\tdivHeaderInner = divHeader.children('div'),\n\t\t\tdivHeaderInnerStyle = divHeaderInner[0].style,\n\t\t\tdivHeaderTable = divHeaderInner.children('table'),\n\t\t\tdivBodyEl = settings.nScrollBody,\n\t\t\tdivBody = $(divBodyEl),\n\t\t\tdivBodyStyle = divBodyEl.style,\n\t\t\tdivFooter = $(settings.nScrollFoot),\n\t\t\tdivFooterInner = divFooter.children('div'),\n\t\t\tdivFooterTable = divFooterInner.children('table'),\n\t\t\theader = $(settings.nTHead),\n\t\t\ttable = $(settings.nTable),\n\t\t\ttableEl = table[0],\n\t\t\ttableStyle = tableEl.style,\n\t\t\tfooter = settings.nTFoot ? $(settings.nTFoot) : null,\n\t\t\tbrowser = settings.oBrowser,\n\t\t\tie67 = browser.bScrollOversize,\n\t\t\tdtHeaderCells = _pluck( settings.aoColumns, 'nTh' ),\n\t\t\theaderTrgEls, footerTrgEls,\n\t\t\theaderSrcEls, footerSrcEls,\n\t\t\theaderCopy, footerCopy,\n\t\t\theaderWidths=[], footerWidths=[],\n\t\t\theaderContent=[], footerContent=[],\n\t\t\tidx, correction, sanityWidth,\n\t\t\tzeroOut = function(nSizer) {\n\t\t\t\tvar style = nSizer.style;\n\t\t\t\tstyle.paddingTop = \"0\";\n\t\t\t\tstyle.paddingBottom = \"0\";\n\t\t\t\tstyle.borderTopWidth = \"0\";\n\t\t\t\tstyle.borderBottomWidth = \"0\";\n\t\t\t\tstyle.height = 0;\n\t\t\t};\n\t\n\t\t// If the scrollbar visibility has changed from the last draw, we need to\n\t\t// adjust the column sizes as the table width will have changed to account\n\t\t// for the scrollbar\n\t\tvar scrollBarVis = divBodyEl.scrollHeight > divBodyEl.clientHeight;\n\t\t\n\t\tif ( settings.scrollBarVis !== scrollBarVis && settings.scrollBarVis !== undefined ) {\n\t\t\tsettings.scrollBarVis = scrollBarVis;\n\t\t\t_fnAdjustColumnSizing( settings );\n\t\t\treturn; // adjust column sizing will call this function again\n\t\t}\n\t\telse {\n\t\t\tsettings.scrollBarVis = scrollBarVis;\n\t\t}\n\t\n\t\t/*\n\t\t * 1. Re-create the table inside the scrolling div\n\t\t */\n\t\n\t\t// Remove the old minimised thead and tfoot elements in the inner table\n\t\ttable.children('thead, tfoot').remove();\n\t\n\t\tif ( footer ) {\n\t\t\tfooterCopy = footer.clone().prependTo( table );\n\t\t\tfooterTrgEls = footer.find('tr'); // the original tfoot is in its own table and must be sized\n\t\t\tfooterSrcEls = footerCopy.find('tr');\n\t\t}\n\t\n\t\t// Clone the current header and footer elements and then place it into the inner table\n\t\theaderCopy = header.clone().prependTo( table );\n\t\theaderTrgEls = header.find('tr'); // original header is in its own table\n\t\theaderSrcEls = headerCopy.find('tr');\n\t\theaderCopy.find('th, td').removeAttr('tabindex');\n\t\n\t\n\t\t/*\n\t\t * 2. Take live measurements from the DOM - do not alter the DOM itself!\n\t\t */\n\t\n\t\t// Remove old sizing and apply the calculated column widths\n\t\t// Get the unique column headers in the newly created (cloned) header. We want to apply the\n\t\t// calculated sizes to this header\n\t\tif ( ! scrollX )\n\t\t{\n\t\t\tdivBodyStyle.width = '100%';\n\t\t\tdivHeader[0].style.width = '100%';\n\t\t}\n\t\n\t\t$.each( _fnGetUniqueThs( settings, headerCopy ), function ( i, el ) {\n\t\t\tidx = _fnVisibleToColumnIndex( settings, i );\n\t\t\tel.style.width = settings.aoColumns[idx].sWidth;\n\t\t} );\n\t\n\t\tif ( footer ) {\n\t\t\t_fnApplyToChildren( function(n) {\n\t\t\t\tn.style.width = \"\";\n\t\t\t}, footerSrcEls );\n\t\t}\n\t\n\t\t// Size the table as a whole\n\t\tsanityWidth = table.outerWidth();\n\t\tif ( scrollX === \"\" ) {\n\t\t\t// No x scrolling\n\t\t\ttableStyle.width = \"100%\";\n\t\n\t\t\t// IE7 will make the width of the table when 100% include the scrollbar\n\t\t\t// - which is shouldn't. When there is a scrollbar we need to take this\n\t\t\t// into account.\n\t\t\tif ( ie67 && (table.find('tbody').height() > divBodyEl.offsetHeight ||\n\t\t\t\tdivBody.css('overflow-y') == \"scroll\")\n\t\t\t) {\n\t\t\t\ttableStyle.width = _fnStringToCss( table.outerWidth() - barWidth);\n\t\t\t}\n\t\n\t\t\t// Recalculate the sanity width\n\t\t\tsanityWidth = table.outerWidth();\n\t\t}\n\t\telse if ( scrollXInner !== \"\" ) {\n\t\t\t// legacy x scroll inner has been given - use it\n\t\t\ttableStyle.width = _fnStringToCss(scrollXInner);\n\t\n\t\t\t// Recalculate the sanity width\n\t\t\tsanityWidth = table.outerWidth();\n\t\t}\n\t\n\t\t// Hidden header should have zero height, so remove padding and borders. Then\n\t\t// set the width based on the real headers\n\t\n\t\t// Apply all styles in one pass\n\t\t_fnApplyToChildren( zeroOut, headerSrcEls );\n\t\n\t\t// Read all widths in next pass\n\t\t_fnApplyToChildren( function(nSizer) {\n\t\t\theaderContent.push( nSizer.innerHTML );\n\t\t\theaderWidths.push( _fnStringToCss( $(nSizer).css('width') ) );\n\t\t}, headerSrcEls );\n\t\n\t\t// Apply all widths in final pass\n\t\t_fnApplyToChildren( function(nToSize, i) {\n\t\t\t// Only apply widths to the DataTables detected header cells - this\n\t\t\t// prevents complex headers from having contradictory sizes applied\n\t\t\tif ( $.inArray( nToSize, dtHeaderCells ) !== -1 ) {\n\t\t\t\tnToSize.style.width = headerWidths[i];\n\t\t\t}\n\t\t}, headerTrgEls );\n\t\n\t\t$(headerSrcEls).height(0);\n\t\n\t\t/* Same again with the footer if we have one */\n\t\tif ( footer )\n\t\t{\n\t\t\t_fnApplyToChildren( zeroOut, footerSrcEls );\n\t\n\t\t\t_fnApplyToChildren( function(nSizer) {\n\t\t\t\tfooterContent.push( nSizer.innerHTML );\n\t\t\t\tfooterWidths.push( _fnStringToCss( $(nSizer).css('width') ) );\n\t\t\t}, footerSrcEls );\n\t\n\t\t\t_fnApplyToChildren( function(nToSize, i) {\n\t\t\t\tnToSize.style.width = footerWidths[i];\n\t\t\t}, footerTrgEls );\n\t\n\t\t\t$(footerSrcEls).height(0);\n\t\t}\n\t\n\t\n\t\t/*\n\t\t * 3. Apply the measurements\n\t\t */\n\t\n\t\t// \"Hide\" the header and footer that we used for the sizing. We need to keep\n\t\t// the content of the cell so that the width applied to the header and body\n\t\t// both match, but we want to hide it completely. We want to also fix their\n\t\t// width to what they currently are\n\t\t_fnApplyToChildren( function(nSizer, i) {\n\t\t\tnSizer.innerHTML = '<div class=\"dataTables_sizing\" style=\"height:0;overflow:hidden;\">'+headerContent[i]+'</div>';\n\t\t\tnSizer.style.width = headerWidths[i];\n\t\t}, headerSrcEls );\n\t\n\t\tif ( footer )\n\t\t{\n\t\t\t_fnApplyToChildren( function(nSizer, i) {\n\t\t\t\tnSizer.innerHTML = '<div class=\"dataTables_sizing\" style=\"height:0;overflow:hidden;\">'+footerContent[i]+'</div>';\n\t\t\t\tnSizer.style.width = footerWidths[i];\n\t\t\t}, footerSrcEls );\n\t\t}\n\t\n\t\t// Sanity check that the table is of a sensible width. If not then we are going to get\n\t\t// misalignment - try to prevent this by not allowing the table to shrink below its min width\n\t\tif ( table.outerWidth() < sanityWidth )\n\t\t{\n\t\t\t// The min width depends upon if we have a vertical scrollbar visible or not */\n\t\t\tcorrection = ((divBodyEl.scrollHeight > divBodyEl.offsetHeight ||\n\t\t\t\tdivBody.css('overflow-y') == \"scroll\")) ?\n\t\t\t\t\tsanityWidth+barWidth :\n\t\t\t\t\tsanityWidth;\n\t\n\t\t\t// IE6/7 are a law unto themselves...\n\t\t\tif ( ie67 && (divBodyEl.scrollHeight >\n\t\t\t\tdivBodyEl.offsetHeight || divBody.css('overflow-y') == \"scroll\")\n\t\t\t) {\n\t\t\t\ttableStyle.width = _fnStringToCss( correction-barWidth );\n\t\t\t}\n\t\n\t\t\t// And give the user a warning that we've stopped the table getting too small\n\t\t\tif ( scrollX === \"\" || scrollXInner !== \"\" ) {\n\t\t\t\t_fnLog( settings, 1, 'Possible column misalignment', 6 );\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tcorrection = '100%';\n\t\t}\n\t\n\t\t// Apply to the container elements\n\t\tdivBodyStyle.width = _fnStringToCss( correction );\n\t\tdivHeaderStyle.width = _fnStringToCss( correction );\n\t\n\t\tif ( footer ) {\n\t\t\tsettings.nScrollFoot.style.width = _fnStringToCss( correction );\n\t\t}\n\t\n\t\n\t\t/*\n\t\t * 4. Clean up\n\t\t */\n\t\tif ( ! scrollY ) {\n\t\t\t/* IE7< puts a vertical scrollbar in place (when it shouldn't be) due to subtracting\n\t\t\t * the scrollbar height from the visible display, rather than adding it on. We need to\n\t\t\t * set the height in order to sort this. Don't want to do it in any other browsers.\n\t\t\t */\n\t\t\tif ( ie67 ) {\n\t\t\t\tdivBodyStyle.height = _fnStringToCss( tableEl.offsetHeight+barWidth );\n\t\t\t}\n\t\t}\n\t\n\t\t/* Finally set the width's of the header and footer tables */\n\t\tvar iOuterWidth = table.outerWidth();\n\t\tdivHeaderTable[0].style.width = _fnStringToCss( iOuterWidth );\n\t\tdivHeaderInnerStyle.width = _fnStringToCss( iOuterWidth );\n\t\n\t\t// Figure out if there are scrollbar present - if so then we need a the header and footer to\n\t\t// provide a bit more space to allow \"overflow\" scrolling (i.e. past the scrollbar)\n\t\tvar bScrolling = table.height() > divBodyEl.clientHeight || divBody.css('overflow-y') == \"scroll\";\n\t\tvar padding = 'padding' + (browser.bScrollbarLeft ? 'Left' : 'Right' );\n\t\tdivHeaderInnerStyle[ padding ] = bScrolling ? barWidth+\"px\" : \"0px\";\n\t\n\t\tif ( footer ) {\n\t\t\tdivFooterTable[0].style.width = _fnStringToCss( iOuterWidth );\n\t\t\tdivFooterInner[0].style.width = _fnStringToCss( iOuterWidth );\n\t\t\tdivFooterInner[0].style[padding] = bScrolling ? barWidth+\"px\" : \"0px\";\n\t\t}\n\t\n\t\t// Correct DOM ordering for colgroup - comes before the thead\n\t\ttable.children('colgroup').insertBefore( table.children('thead') );\n\t\n\t\t/* Adjust the position of the header in case we loose the y-scrollbar */\n\t\tdivBody.scroll();\n\t\n\t\t// If sorting or filtering has occurred, jump the scrolling back to the top\n\t\t// only if we aren't holding the position\n\t\tif ( (settings.bSorted || settings.bFiltered) && ! settings._drawHold ) {\n\t\t\tdivBodyEl.scrollTop = 0;\n\t\t}\n\t}\n\t\n\t\n\t\n\t/**\n\t * Apply a given function to the display child nodes of an element array (typically\n\t * TD children of TR rows\n\t * @param {function} fn Method to apply to the objects\n\t * @param array {nodes} an1 List of elements to look through for display children\n\t * @param array {nodes} an2 Another list (identical structure to the first) - optional\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnApplyToChildren( fn, an1, an2 )\n\t{\n\t\tvar index=0, i=0, iLen=an1.length;\n\t\tvar nNode1, nNode2;\n\t\n\t\twhile ( i < iLen ) {\n\t\t\tnNode1 = an1[i].firstChild;\n\t\t\tnNode2 = an2 ? an2[i].firstChild : null;\n\t\n\t\t\twhile ( nNode1 ) {\n\t\t\t\tif ( nNode1.nodeType === 1 ) {\n\t\t\t\t\tif ( an2 ) {\n\t\t\t\t\t\tfn( nNode1, nNode2, index );\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tfn( nNode1, index );\n\t\t\t\t\t}\n\t\n\t\t\t\t\tindex++;\n\t\t\t\t}\n\t\n\t\t\t\tnNode1 = nNode1.nextSibling;\n\t\t\t\tnNode2 = an2 ? nNode2.nextSibling : null;\n\t\t\t}\n\t\n\t\t\ti++;\n\t\t}\n\t}\n\t\n\t\n\t\n\tvar __re_html_remove = /<.*?>/g;\n\t\n\t\n\t/**\n\t * Calculate the width of columns for the table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnCalculateColumnWidths ( oSettings )\n\t{\n\t\tvar\n\t\t\ttable = oSettings.nTable,\n\t\t\tcolumns = oSettings.aoColumns,\n\t\t\tscroll = oSettings.oScroll,\n\t\t\tscrollY = scroll.sY,\n\t\t\tscrollX = scroll.sX,\n\t\t\tscrollXInner = scroll.sXInner,\n\t\t\tcolumnCount = columns.length,\n\t\t\tvisibleColumns = _fnGetColumns( oSettings, 'bVisible' ),\n\t\t\theaderCells = $('th', oSettings.nTHead),\n\t\t\ttableWidthAttr = table.getAttribute('width'), // from DOM element\n\t\t\ttableContainer = table.parentNode,\n\t\t\tuserInputs = false,\n\t\t\ti, column, columnIdx, width, outerWidth,\n\t\t\tbrowser = oSettings.oBrowser,\n\t\t\tie67 = browser.bScrollOversize;\n\t\n\t\tvar styleWidth = table.style.width;\n\t\tif ( styleWidth && styleWidth.indexOf('%') !== -1 ) {\n\t\t\ttableWidthAttr = styleWidth;\n\t\t}\n\t\n\t\t/* Convert any user input sizes into pixel sizes */\n\t\tfor ( i=0 ; i<visibleColumns.length ; i++ ) {\n\t\t\tcolumn = columns[ visibleColumns[i] ];\n\t\n\t\t\tif ( column.sWidth !== null ) {\n\t\t\t\tcolumn.sWidth = _fnConvertToWidth( column.sWidthOrig, tableContainer );\n\t\n\t\t\t\tuserInputs = true;\n\t\t\t}\n\t\t}\n\t\n\t\t/* If the number of columns in the DOM equals the number that we have to\n\t\t * process in DataTables, then we can use the offsets that are created by\n\t\t * the web- browser. No custom sizes can be set in order for this to happen,\n\t\t * nor scrolling used\n\t\t */\n\t\tif ( ie67 || ! userInputs && ! scrollX && ! scrollY &&\n\t\t columnCount == _fnVisbleColumns( oSettings ) &&\n\t\t columnCount == headerCells.length\n\t\t) {\n\t\t\tfor ( i=0 ; i<columnCount ; i++ ) {\n\t\t\t\tvar colIdx = _fnVisibleToColumnIndex( oSettings, i );\n\t\n\t\t\t\tif ( colIdx !== null ) {\n\t\t\t\t\tcolumns[ colIdx ].sWidth = _fnStringToCss( headerCells.eq(i).width() );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\t// Otherwise construct a single row, worst case, table with the widest\n\t\t\t// node in the data, assign any user defined widths, then insert it into\n\t\t\t// the DOM and allow the browser to do all the hard work of calculating\n\t\t\t// table widths\n\t\t\tvar tmpTable = $(table).clone() // don't use cloneNode - IE8 will remove events on the main table\n\t\t\t\t.css( 'visibility', 'hidden' )\n\t\t\t\t.removeAttr( 'id' );\n\t\n\t\t\t// Clean up the table body\n\t\t\ttmpTable.find('tbody tr').remove();\n\t\t\tvar tr = $('<tr/>').appendTo( tmpTable.find('tbody') );\n\t\n\t\t\t// Clone the table header and footer - we can't use the header / footer\n\t\t\t// from the cloned table, since if scrolling is active, the table's\n\t\t\t// real header and footer are contained in different table tags\n\t\t\ttmpTable.find('thead, tfoot').remove();\n\t\t\ttmpTable\n\t\t\t\t.append( $(oSettings.nTHead).clone() )\n\t\t\t\t.append( $(oSettings.nTFoot).clone() );\n\t\n\t\t\t// Remove any assigned widths from the footer (from scrolling)\n\t\t\ttmpTable.find('tfoot th, tfoot td').css('width', '');\n\t\n\t\t\t// Apply custom sizing to the cloned header\n\t\t\theaderCells = _fnGetUniqueThs( oSettings, tmpTable.find('thead')[0] );\n\t\n\t\t\tfor ( i=0 ; i<visibleColumns.length ; i++ ) {\n\t\t\t\tcolumn = columns[ visibleColumns[i] ];\n\t\n\t\t\t\theaderCells[i].style.width = column.sWidthOrig !== null && column.sWidthOrig !== '' ?\n\t\t\t\t\t_fnStringToCss( column.sWidthOrig ) :\n\t\t\t\t\t'';\n\t\n\t\t\t\t// For scrollX we need to force the column width otherwise the\n\t\t\t\t// browser will collapse it. If this width is smaller than the\n\t\t\t\t// width the column requires, then it will have no effect\n\t\t\t\tif ( column.sWidthOrig && scrollX ) {\n\t\t\t\t\t$( headerCells[i] ).append( $('<div/>').css( {\n\t\t\t\t\t\twidth: column.sWidthOrig,\n\t\t\t\t\t\tmargin: 0,\n\t\t\t\t\t\tpadding: 0,\n\t\t\t\t\t\tborder: 0,\n\t\t\t\t\t\theight: 1\n\t\t\t\t\t} ) );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// Find the widest cell for each column and put it into the table\n\t\t\tif ( oSettings.aoData.length ) {\n\t\t\t\tfor ( i=0 ; i<visibleColumns.length ; i++ ) {\n\t\t\t\t\tcolumnIdx = visibleColumns[i];\n\t\t\t\t\tcolumn = columns[ columnIdx ];\n\t\n\t\t\t\t\t$( _fnGetWidestNode( oSettings, columnIdx ) )\n\t\t\t\t\t\t.clone( false )\n\t\t\t\t\t\t.append( column.sContentPadding )\n\t\t\t\t\t\t.appendTo( tr );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// Tidy the temporary table - remove name attributes so there aren't\n\t\t\t// duplicated in the dom (radio elements for example)\n\t\t\t$('[name]', tmpTable).removeAttr('name');\n\t\n\t\t\t// Table has been built, attach to the document so we can work with it.\n\t\t\t// A holding element is used, positioned at the top of the container\n\t\t\t// with minimal height, so it has no effect on if the container scrolls\n\t\t\t// or not. Otherwise it might trigger scrolling when it actually isn't\n\t\t\t// needed\n\t\t\tvar holder = $('<div/>').css( scrollX || scrollY ?\n\t\t\t\t\t{\n\t\t\t\t\t\tposition: 'absolute',\n\t\t\t\t\t\ttop: 0,\n\t\t\t\t\t\tleft: 0,\n\t\t\t\t\t\theight: 1,\n\t\t\t\t\t\tright: 0,\n\t\t\t\t\t\toverflow: 'hidden'\n\t\t\t\t\t} :\n\t\t\t\t\t{}\n\t\t\t\t)\n\t\t\t\t.append( tmpTable )\n\t\t\t\t.appendTo( tableContainer );\n\t\n\t\t\t// When scrolling (X or Y) we want to set the width of the table as \n\t\t\t// appropriate. However, when not scrolling leave the table width as it\n\t\t\t// is. This results in slightly different, but I think correct behaviour\n\t\t\tif ( scrollX && scrollXInner ) {\n\t\t\t\ttmpTable.width( scrollXInner );\n\t\t\t}\n\t\t\telse if ( scrollX ) {\n\t\t\t\ttmpTable.css( 'width', 'auto' );\n\t\t\t\ttmpTable.removeAttr('width');\n\t\n\t\t\t\t// If there is no width attribute or style, then allow the table to\n\t\t\t\t// collapse\n\t\t\t\tif ( tmpTable.width() < tableContainer.clientWidth && tableWidthAttr ) {\n\t\t\t\t\ttmpTable.width( tableContainer.clientWidth );\n\t\t\t\t}\n\t\t\t}\n\t\t\telse if ( scrollY ) {\n\t\t\t\ttmpTable.width( tableContainer.clientWidth );\n\t\t\t}\n\t\t\telse if ( tableWidthAttr ) {\n\t\t\t\ttmpTable.width( tableWidthAttr );\n\t\t\t}\n\t\n\t\t\t// Get the width of each column in the constructed table - we need to\n\t\t\t// know the inner width (so it can be assigned to the other table's\n\t\t\t// cells) and the outer width so we can calculate the full width of the\n\t\t\t// table. This is safe since DataTables requires a unique cell for each\n\t\t\t// column, but if ever a header can span multiple columns, this will\n\t\t\t// need to be modified.\n\t\t\tvar total = 0;\n\t\t\tfor ( i=0 ; i<visibleColumns.length ; i++ ) {\n\t\t\t\tvar cell = $(headerCells[i]);\n\t\t\t\tvar border = cell.outerWidth() - cell.width();\n\t\n\t\t\t\t// Use getBounding... where possible (not IE8-) because it can give\n\t\t\t\t// sub-pixel accuracy, which we then want to round up!\n\t\t\t\tvar bounding = browser.bBounding ?\n\t\t\t\t\tMath.ceil( headerCells[i].getBoundingClientRect().width ) :\n\t\t\t\t\tcell.outerWidth();\n\t\n\t\t\t\t// Total is tracked to remove any sub-pixel errors as the outerWidth\n\t\t\t\t// of the table might not equal the total given here (IE!).\n\t\t\t\ttotal += bounding;\n\t\n\t\t\t\t// Width for each column to use\n\t\t\t\tcolumns[ visibleColumns[i] ].sWidth = _fnStringToCss( bounding - border );\n\t\t\t}\n\t\n\t\t\ttable.style.width = _fnStringToCss( total );\n\t\n\t\t\t// Finished with the table - ditch it\n\t\t\tholder.remove();\n\t\t}\n\t\n\t\t// If there is a width attr, we want to attach an event listener which\n\t\t// allows the table sizing to automatically adjust when the window is\n\t\t// resized. Use the width attr rather than CSS, since we can't know if the\n\t\t// CSS is a relative value or absolute - DOM read is always px.\n\t\tif ( tableWidthAttr ) {\n\t\t\ttable.style.width = _fnStringToCss( tableWidthAttr );\n\t\t}\n\t\n\t\tif ( (tableWidthAttr || scrollX) && ! oSettings._reszEvt ) {\n\t\t\tvar bindResize = function () {\n\t\t\t\t$(window).bind('resize.DT-'+oSettings.sInstance, _fnThrottle( function () {\n\t\t\t\t\t_fnAdjustColumnSizing( oSettings );\n\t\t\t\t} ) );\n\t\t\t};\n\t\n\t\t\t// IE6/7 will crash if we bind a resize event handler on page load.\n\t\t\t// To be removed in 1.11 which drops IE6/7 support\n\t\t\tif ( ie67 ) {\n\t\t\t\tsetTimeout( bindResize, 1000 );\n\t\t\t}\n\t\t\telse {\n\t\t\t\tbindResize();\n\t\t\t}\n\t\n\t\t\toSettings._reszEvt = true;\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Throttle the calls to a function. Arguments and context are maintained for\n\t * the throttled function\n\t * @param {function} fn Function to be called\n\t * @param {int} [freq=200] call frequency in mS\n\t * @returns {function} wrapped function\n\t * @memberof DataTable#oApi\n\t */\n\tvar _fnThrottle = DataTable.util.throttle;\n\t\n\t\n\t/**\n\t * Convert a CSS unit width to pixels (e.g. 2em)\n\t * @param {string} width width to be converted\n\t * @param {node} parent parent to get the with for (required for relative widths) - optional\n\t * @returns {int} width in pixels\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnConvertToWidth ( width, parent )\n\t{\n\t\tif ( ! width ) {\n\t\t\treturn 0;\n\t\t}\n\t\n\t\tvar n = $('<div/>')\n\t\t\t.css( 'width', _fnStringToCss( width ) )\n\t\t\t.appendTo( parent || document.body );\n\t\n\t\tvar val = n[0].offsetWidth;\n\t\tn.remove();\n\t\n\t\treturn val;\n\t}\n\t\n\t\n\t/**\n\t * Get the widest node\n\t * @param {object} settings dataTables settings object\n\t * @param {int} colIdx column of interest\n\t * @returns {node} widest table node\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetWidestNode( settings, colIdx )\n\t{\n\t\tvar idx = _fnGetMaxLenString( settings, colIdx );\n\t\tif ( idx < 0 ) {\n\t\t\treturn null;\n\t\t}\n\t\n\t\tvar data = settings.aoData[ idx ];\n\t\treturn ! data.nTr ? // Might not have been created when deferred rendering\n\t\t\t$('<td/>').html( _fnGetCellData( settings, idx, colIdx, 'display' ) )[0] :\n\t\t\tdata.anCells[ colIdx ];\n\t}\n\t\n\t\n\t/**\n\t * Get the maximum strlen for each data column\n\t * @param {object} settings dataTables settings object\n\t * @param {int} colIdx column of interest\n\t * @returns {string} max string length for each column\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetMaxLenString( settings, colIdx )\n\t{\n\t\tvar s, max=-1, maxIdx = -1;\n\t\n\t\tfor ( var i=0, ien=settings.aoData.length ; i<ien ; i++ ) {\n\t\t\ts = _fnGetCellData( settings, i, colIdx, 'display' )+'';\n\t\t\ts = s.replace( __re_html_remove, '' );\n\t\t\ts = s.replace( / /g, ' ' );\n\t\n\t\t\tif ( s.length > max ) {\n\t\t\t\tmax = s.length;\n\t\t\t\tmaxIdx = i;\n\t\t\t}\n\t\t}\n\t\n\t\treturn maxIdx;\n\t}\n\t\n\t\n\t/**\n\t * Append a CSS unit (only if required) to a string\n\t * @param {string} value to css-ify\n\t * @returns {string} value with css unit\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnStringToCss( s )\n\t{\n\t\tif ( s === null ) {\n\t\t\treturn '0px';\n\t\t}\n\t\n\t\tif ( typeof s == 'number' ) {\n\t\t\treturn s < 0 ?\n\t\t\t\t'0px' :\n\t\t\t\ts+'px';\n\t\t}\n\t\n\t\t// Check it has a unit character already\n\t\treturn s.match(/\\d$/) ?\n\t\t\ts+'px' :\n\t\t\ts;\n\t}\n\t\n\t\n\t\n\tfunction _fnSortFlatten ( settings )\n\t{\n\t\tvar\n\t\t\ti, iLen, k, kLen,\n\t\t\taSort = [],\n\t\t\taiOrig = [],\n\t\t\taoColumns = settings.aoColumns,\n\t\t\taDataSort, iCol, sType, srcCol,\n\t\t\tfixed = settings.aaSortingFixed,\n\t\t\tfixedObj = $.isPlainObject( fixed ),\n\t\t\tnestedSort = [],\n\t\t\tadd = function ( a ) {\n\t\t\t\tif ( a.length && ! $.isArray( a[0] ) ) {\n\t\t\t\t\t// 1D array\n\t\t\t\t\tnestedSort.push( a );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\t// 2D array\n\t\t\t\t\t$.merge( nestedSort, a );\n\t\t\t\t}\n\t\t\t};\n\t\n\t\t// Build the sort array, with pre-fix and post-fix options if they have been\n\t\t// specified\n\t\tif ( $.isArray( fixed ) ) {\n\t\t\tadd( fixed );\n\t\t}\n\t\n\t\tif ( fixedObj && fixed.pre ) {\n\t\t\tadd( fixed.pre );\n\t\t}\n\t\n\t\tadd( settings.aaSorting );\n\t\n\t\tif (fixedObj && fixed.post ) {\n\t\t\tadd( fixed.post );\n\t\t}\n\t\n\t\tfor ( i=0 ; i<nestedSort.length ; i++ )\n\t\t{\n\t\t\tsrcCol = nestedSort[i][0];\n\t\t\taDataSort = aoColumns[ srcCol ].aDataSort;\n\t\n\t\t\tfor ( k=0, kLen=aDataSort.length ; k<kLen ; k++ )\n\t\t\t{\n\t\t\t\tiCol = aDataSort[k];\n\t\t\t\tsType = aoColumns[ iCol ].sType || 'string';\n\t\n\t\t\t\tif ( nestedSort[i]._idx === undefined ) {\n\t\t\t\t\tnestedSort[i]._idx = $.inArray( nestedSort[i][1], aoColumns[iCol].asSorting );\n\t\t\t\t}\n\t\n\t\t\t\taSort.push( {\n\t\t\t\t\tsrc: srcCol,\n\t\t\t\t\tcol: iCol,\n\t\t\t\t\tdir: nestedSort[i][1],\n\t\t\t\t\tindex: nestedSort[i]._idx,\n\t\t\t\t\ttype: sType,\n\t\t\t\t\tformatter: DataTable.ext.type.order[ sType+\"-pre\" ]\n\t\t\t\t} );\n\t\t\t}\n\t\t}\n\t\n\t\treturn aSort;\n\t}\n\t\n\t/**\n\t * Change the order of the table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t * @todo This really needs split up!\n\t */\n\tfunction _fnSort ( oSettings )\n\t{\n\t\tvar\n\t\t\ti, ien, iLen, j, jLen, k, kLen,\n\t\t\tsDataType, nTh,\n\t\t\taiOrig = [],\n\t\t\toExtSort = DataTable.ext.type.order,\n\t\t\taoData = oSettings.aoData,\n\t\t\taoColumns = oSettings.aoColumns,\n\t\t\taDataSort, data, iCol, sType, oSort,\n\t\t\tformatters = 0,\n\t\t\tsortCol,\n\t\t\tdisplayMaster = oSettings.aiDisplayMaster,\n\t\t\taSort;\n\t\n\t\t// Resolve any column types that are unknown due to addition or invalidation\n\t\t// @todo Can this be moved into a 'data-ready' handler which is called when\n\t\t// data is going to be used in the table?\n\t\t_fnColumnTypes( oSettings );\n\t\n\t\taSort = _fnSortFlatten( oSettings );\n\t\n\t\tfor ( i=0, ien=aSort.length ; i<ien ; i++ ) {\n\t\t\tsortCol = aSort[i];\n\t\n\t\t\t// Track if we can use the fast sort algorithm\n\t\t\tif ( sortCol.formatter ) {\n\t\t\t\tformatters++;\n\t\t\t}\n\t\n\t\t\t// Load the data needed for the sort, for each cell\n\t\t\t_fnSortData( oSettings, sortCol.col );\n\t\t}\n\t\n\t\t/* No sorting required if server-side or no sorting array */\n\t\tif ( _fnDataSource( oSettings ) != 'ssp' && aSort.length !== 0 )\n\t\t{\n\t\t\t// Create a value - key array of the current row positions such that we can use their\n\t\t\t// current position during the sort, if values match, in order to perform stable sorting\n\t\t\tfor ( i=0, iLen=displayMaster.length ; i<iLen ; i++ ) {\n\t\t\t\taiOrig[ displayMaster[i] ] = i;\n\t\t\t}\n\t\n\t\t\t/* Do the sort - here we want multi-column sorting based on a given data source (column)\n\t\t\t * and sorting function (from oSort) in a certain direction. It's reasonably complex to\n\t\t\t * follow on it's own, but this is what we want (example two column sorting):\n\t\t\t * fnLocalSorting = function(a,b){\n\t\t\t * var iTest;\n\t\t\t * iTest = oSort['string-asc']('data11', 'data12');\n\t\t\t * if (iTest !== 0)\n\t\t\t * return iTest;\n\t\t\t * iTest = oSort['numeric-desc']('data21', 'data22');\n\t\t\t * if (iTest !== 0)\n\t\t\t * return iTest;\n\t\t\t * return oSort['numeric-asc']( aiOrig[a], aiOrig[b] );\n\t\t\t * }\n\t\t\t * Basically we have a test for each sorting column, if the data in that column is equal,\n\t\t\t * test the next column. If all columns match, then we use a numeric sort on the row\n\t\t\t * positions in the original data array to provide a stable sort.\n\t\t\t *\n\t\t\t * Note - I know it seems excessive to have two sorting methods, but the first is around\n\t\t\t * 15% faster, so the second is only maintained for backwards compatibility with sorting\n\t\t\t * methods which do not have a pre-sort formatting function.\n\t\t\t */\n\t\t\tif ( formatters === aSort.length ) {\n\t\t\t\t// All sort types have formatting functions\n\t\t\t\tdisplayMaster.sort( function ( a, b ) {\n\t\t\t\t\tvar\n\t\t\t\t\t\tx, y, k, test, sort,\n\t\t\t\t\t\tlen=aSort.length,\n\t\t\t\t\t\tdataA = aoData[a]._aSortData,\n\t\t\t\t\t\tdataB = aoData[b]._aSortData;\n\t\n\t\t\t\t\tfor ( k=0 ; k<len ; k++ ) {\n\t\t\t\t\t\tsort = aSort[k];\n\t\n\t\t\t\t\t\tx = dataA[ sort.col ];\n\t\t\t\t\t\ty = dataB[ sort.col ];\n\t\n\t\t\t\t\t\ttest = x<y ? -1 : x>y ? 1 : 0;\n\t\t\t\t\t\tif ( test !== 0 ) {\n\t\t\t\t\t\t\treturn sort.dir === 'asc' ? test : -test;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\n\t\t\t\t\tx = aiOrig[a];\n\t\t\t\t\ty = aiOrig[b];\n\t\t\t\t\treturn x<y ? -1 : x>y ? 1 : 0;\n\t\t\t\t} );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Depreciated - remove in 1.11 (providing a plug-in option)\n\t\t\t\t// Not all sort types have formatting methods, so we have to call their sorting\n\t\t\t\t// methods.\n\t\t\t\tdisplayMaster.sort( function ( a, b ) {\n\t\t\t\t\tvar\n\t\t\t\t\t\tx, y, k, l, test, sort, fn,\n\t\t\t\t\t\tlen=aSort.length,\n\t\t\t\t\t\tdataA = aoData[a]._aSortData,\n\t\t\t\t\t\tdataB = aoData[b]._aSortData;\n\t\n\t\t\t\t\tfor ( k=0 ; k<len ; k++ ) {\n\t\t\t\t\t\tsort = aSort[k];\n\t\n\t\t\t\t\t\tx = dataA[ sort.col ];\n\t\t\t\t\t\ty = dataB[ sort.col ];\n\t\n\t\t\t\t\t\tfn = oExtSort[ sort.type+\"-\"+sort.dir ] || oExtSort[ \"string-\"+sort.dir ];\n\t\t\t\t\t\ttest = fn( x, y );\n\t\t\t\t\t\tif ( test !== 0 ) {\n\t\t\t\t\t\t\treturn test;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\n\t\t\t\t\tx = aiOrig[a];\n\t\t\t\t\ty = aiOrig[b];\n\t\t\t\t\treturn x<y ? -1 : x>y ? 1 : 0;\n\t\t\t\t} );\n\t\t\t}\n\t\t}\n\t\n\t\t/* Tell the draw function that we have sorted the data */\n\t\toSettings.bSorted = true;\n\t}\n\t\n\t\n\tfunction _fnSortAria ( settings )\n\t{\n\t\tvar label;\n\t\tvar nextSort;\n\t\tvar columns = settings.aoColumns;\n\t\tvar aSort = _fnSortFlatten( settings );\n\t\tvar oAria = settings.oLanguage.oAria;\n\t\n\t\t// ARIA attributes - need to loop all columns, to update all (removing old\n\t\t// attributes as needed)\n\t\tfor ( var i=0, iLen=columns.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tvar col = columns[i];\n\t\t\tvar asSorting = col.asSorting;\n\t\t\tvar sTitle = col.sTitle.replace( /<.*?>/g, \"\" );\n\t\t\tvar th = col.nTh;\n\t\n\t\t\t// IE7 is throwing an error when setting these properties with jQuery's\n\t\t\t// attr() and removeAttr() methods...\n\t\t\tth.removeAttribute('aria-sort');\n\t\n\t\t\t/* In ARIA only the first sorting column can be marked as sorting - no multi-sort option */\n\t\t\tif ( col.bSortable ) {\n\t\t\t\tif ( aSort.length > 0 && aSort[0].col == i ) {\n\t\t\t\t\tth.setAttribute('aria-sort', aSort[0].dir==\"asc\" ? \"ascending\" : \"descending\" );\n\t\t\t\t\tnextSort = asSorting[ aSort[0].index+1 ] || asSorting[0];\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tnextSort = asSorting[0];\n\t\t\t\t}\n\t\n\t\t\t\tlabel = sTitle + ( nextSort === \"asc\" ?\n\t\t\t\t\toAria.sSortAscending :\n\t\t\t\t\toAria.sSortDescending\n\t\t\t\t);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tlabel = sTitle;\n\t\t\t}\n\t\n\t\t\tth.setAttribute('aria-label', label);\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Function to run on user sort request\n\t * @param {object} settings dataTables settings object\n\t * @param {node} attachTo node to attach the handler to\n\t * @param {int} colIdx column sorting index\n\t * @param {boolean} [append=false] Append the requested sort to the existing\n\t * sort if true (i.e. multi-column sort)\n\t * @param {function} [callback] callback function\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSortListener ( settings, colIdx, append, callback )\n\t{\n\t\tvar col = settings.aoColumns[ colIdx ];\n\t\tvar sorting = settings.aaSorting;\n\t\tvar asSorting = col.asSorting;\n\t\tvar nextSortIdx;\n\t\tvar next = function ( a, overflow ) {\n\t\t\tvar idx = a._idx;\n\t\t\tif ( idx === undefined ) {\n\t\t\t\tidx = $.inArray( a[1], asSorting );\n\t\t\t}\n\t\n\t\t\treturn idx+1 < asSorting.length ?\n\t\t\t\tidx+1 :\n\t\t\t\toverflow ?\n\t\t\t\t\tnull :\n\t\t\t\t\t0;\n\t\t};\n\t\n\t\t// Convert to 2D array if needed\n\t\tif ( typeof sorting[0] === 'number' ) {\n\t\t\tsorting = settings.aaSorting = [ sorting ];\n\t\t}\n\t\n\t\t// If appending the sort then we are multi-column sorting\n\t\tif ( append && settings.oFeatures.bSortMulti ) {\n\t\t\t// Are we already doing some kind of sort on this column?\n\t\t\tvar sortIdx = $.inArray( colIdx, _pluck(sorting, '0') );\n\t\n\t\t\tif ( sortIdx !== -1 ) {\n\t\t\t\t// Yes, modify the sort\n\t\t\t\tnextSortIdx = next( sorting[sortIdx], true );\n\t\n\t\t\t\tif ( nextSortIdx === null && sorting.length === 1 ) {\n\t\t\t\t\tnextSortIdx = 0; // can't remove sorting completely\n\t\t\t\t}\n\t\n\t\t\t\tif ( nextSortIdx === null ) {\n\t\t\t\t\tsorting.splice( sortIdx, 1 );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tsorting[sortIdx][1] = asSorting[ nextSortIdx ];\n\t\t\t\t\tsorting[sortIdx]._idx = nextSortIdx;\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// No sort on this column yet\n\t\t\t\tsorting.push( [ colIdx, asSorting[0], 0 ] );\n\t\t\t\tsorting[sorting.length-1]._idx = 0;\n\t\t\t}\n\t\t}\n\t\telse if ( sorting.length && sorting[0][0] == colIdx ) {\n\t\t\t// Single column - already sorting on this column, modify the sort\n\t\t\tnextSortIdx = next( sorting[0] );\n\t\n\t\t\tsorting.length = 1;\n\t\t\tsorting[0][1] = asSorting[ nextSortIdx ];\n\t\t\tsorting[0]._idx = nextSortIdx;\n\t\t}\n\t\telse {\n\t\t\t// Single column - sort only on this column\n\t\t\tsorting.length = 0;\n\t\t\tsorting.push( [ colIdx, asSorting[0] ] );\n\t\t\tsorting[0]._idx = 0;\n\t\t}\n\t\n\t\t// Run the sort by calling a full redraw\n\t\t_fnReDraw( settings );\n\t\n\t\t// callback used for async user interaction\n\t\tif ( typeof callback == 'function' ) {\n\t\t\tcallback( settings );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Attach a sort handler (click) to a node\n\t * @param {object} settings dataTables settings object\n\t * @param {node} attachTo node to attach the handler to\n\t * @param {int} colIdx column sorting index\n\t * @param {function} [callback] callback function\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSortAttachListener ( settings, attachTo, colIdx, callback )\n\t{\n\t\tvar col = settings.aoColumns[ colIdx ];\n\t\n\t\t_fnBindAction( attachTo, {}, function (e) {\n\t\t\t/* If the column is not sortable - don't to anything */\n\t\t\tif ( col.bSortable === false ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\n\t\t\t// If processing is enabled use a timeout to allow the processing\n\t\t\t// display to be shown - otherwise to it synchronously\n\t\t\tif ( settings.oFeatures.bProcessing ) {\n\t\t\t\t_fnProcessingDisplay( settings, true );\n\t\n\t\t\t\tsetTimeout( function() {\n\t\t\t\t\t_fnSortListener( settings, colIdx, e.shiftKey, callback );\n\t\n\t\t\t\t\t// In server-side processing, the draw callback will remove the\n\t\t\t\t\t// processing display\n\t\t\t\t\tif ( _fnDataSource( settings ) !== 'ssp' ) {\n\t\t\t\t\t\t_fnProcessingDisplay( settings, false );\n\t\t\t\t\t}\n\t\t\t\t}, 0 );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t_fnSortListener( settings, colIdx, e.shiftKey, callback );\n\t\t\t}\n\t\t} );\n\t}\n\t\n\t\n\t/**\n\t * Set the sorting classes on table's body, Note: it is safe to call this function\n\t * when bSort and bSortClasses are false\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSortingClasses( settings )\n\t{\n\t\tvar oldSort = settings.aLastSort;\n\t\tvar sortClass = settings.oClasses.sSortColumn;\n\t\tvar sort = _fnSortFlatten( settings );\n\t\tvar features = settings.oFeatures;\n\t\tvar i, ien, colIdx;\n\t\n\t\tif ( features.bSort && features.bSortClasses ) {\n\t\t\t// Remove old sorting classes\n\t\t\tfor ( i=0, ien=oldSort.length ; i<ien ; i++ ) {\n\t\t\t\tcolIdx = oldSort[i].src;\n\t\n\t\t\t\t// Remove column sorting\n\t\t\t\t$( _pluck( settings.aoData, 'anCells', colIdx ) )\n\t\t\t\t\t.removeClass( sortClass + (i<2 ? i+1 : 3) );\n\t\t\t}\n\t\n\t\t\t// Add new column sorting\n\t\t\tfor ( i=0, ien=sort.length ; i<ien ; i++ ) {\n\t\t\t\tcolIdx = sort[i].src;\n\t\n\t\t\t\t$( _pluck( settings.aoData, 'anCells', colIdx ) )\n\t\t\t\t\t.addClass( sortClass + (i<2 ? i+1 : 3) );\n\t\t\t}\n\t\t}\n\t\n\t\tsettings.aLastSort = sort;\n\t}\n\t\n\t\n\t// Get the data to sort a column, be it from cache, fresh (populating the\n\t// cache), or from a sort formatter\n\tfunction _fnSortData( settings, idx )\n\t{\n\t\t// Custom sorting function - provided by the sort data type\n\t\tvar column = settings.aoColumns[ idx ];\n\t\tvar customSort = DataTable.ext.order[ column.sSortDataType ];\n\t\tvar customData;\n\t\n\t\tif ( customSort ) {\n\t\t\tcustomData = customSort.call( settings.oInstance, settings, idx,\n\t\t\t\t_fnColumnIndexToVisible( settings, idx )\n\t\t\t);\n\t\t}\n\t\n\t\t// Use / populate cache\n\t\tvar row, cellData;\n\t\tvar formatter = DataTable.ext.type.order[ column.sType+\"-pre\" ];\n\t\n\t\tfor ( var i=0, ien=settings.aoData.length ; i<ien ; i++ ) {\n\t\t\trow = settings.aoData[i];\n\t\n\t\t\tif ( ! row._aSortData ) {\n\t\t\t\trow._aSortData = [];\n\t\t\t}\n\t\n\t\t\tif ( ! row._aSortData[idx] || customSort ) {\n\t\t\t\tcellData = customSort ?\n\t\t\t\t\tcustomData[i] : // If there was a custom sort function, use data from there\n\t\t\t\t\t_fnGetCellData( settings, i, idx, 'sort' );\n\t\n\t\t\t\trow._aSortData[ idx ] = formatter ?\n\t\t\t\t\tformatter( cellData ) :\n\t\t\t\t\tcellData;\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t\n\t/**\n\t * Save the state of a table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSaveState ( settings )\n\t{\n\t\tif ( !settings.oFeatures.bStateSave || settings.bDestroying )\n\t\t{\n\t\t\treturn;\n\t\t}\n\t\n\t\t/* Store the interesting variables */\n\t\tvar state = {\n\t\t\ttime: +new Date(),\n\t\t\tstart: settings._iDisplayStart,\n\t\t\tlength: settings._iDisplayLength,\n\t\t\torder: $.extend( true, [], settings.aaSorting ),\n\t\t\tsearch: _fnSearchToCamel( settings.oPreviousSearch ),\n\t\t\tcolumns: $.map( settings.aoColumns, function ( col, i ) {\n\t\t\t\treturn {\n\t\t\t\t\tvisible: col.bVisible,\n\t\t\t\t\tsearch: _fnSearchToCamel( settings.aoPreSearchCols[i] )\n\t\t\t\t};\n\t\t\t} )\n\t\t};\n\t\n\t\t_fnCallbackFire( settings, \"aoStateSaveParams\", 'stateSaveParams', [settings, state] );\n\t\n\t\tsettings.oSavedState = state;\n\t\tsettings.fnStateSaveCallback.call( settings.oInstance, settings, state );\n\t}\n\t\n\t\n\t/**\n\t * Attempt to load a saved table state\n\t * @param {object} oSettings dataTables settings object\n\t * @param {object} oInit DataTables init object so we can override settings\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnLoadState ( settings, oInit )\n\t{\n\t\tvar i, ien;\n\t\tvar columns = settings.aoColumns;\n\t\n\t\tif ( ! settings.oFeatures.bStateSave ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar state = settings.fnStateLoadCallback.call( settings.oInstance, settings );\n\t\tif ( ! state || ! state.time ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\t/* Allow custom and plug-in manipulation functions to alter the saved data set and\n\t\t * cancelling of loading by returning false\n\t\t */\n\t\tvar abStateLoad = _fnCallbackFire( settings, 'aoStateLoadParams', 'stateLoadParams', [settings, state] );\n\t\tif ( $.inArray( false, abStateLoad ) !== -1 ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\t/* Reject old data */\n\t\tvar duration = settings.iStateDuration;\n\t\tif ( duration > 0 && state.time < +new Date() - (duration*1000) ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\t// Number of columns have changed - all bets are off, no restore of settings\n\t\tif ( columns.length !== state.columns.length ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\t// Store the saved state so it might be accessed at any time\n\t\tsettings.oLoadedState = $.extend( true, {}, state );\n\t\n\t\t// Restore key features - todo - for 1.11 this needs to be done by\n\t\t// subscribed events\n\t\tif ( state.start !== undefined ) {\n\t\t\tsettings._iDisplayStart = state.start;\n\t\t\tsettings.iInitDisplayStart = state.start;\n\t\t}\n\t\tif ( state.length !== undefined ) {\n\t\t\tsettings._iDisplayLength = state.length;\n\t\t}\n\t\n\t\t// Order\n\t\tif ( state.order !== undefined ) {\n\t\t\tsettings.aaSorting = [];\n\t\t\t$.each( state.order, function ( i, col ) {\n\t\t\t\tsettings.aaSorting.push( col[0] >= columns.length ?\n\t\t\t\t\t[ 0, col[1] ] :\n\t\t\t\t\tcol\n\t\t\t\t);\n\t\t\t} );\n\t\t}\n\t\n\t\t// Search\n\t\tif ( state.search !== undefined ) {\n\t\t\t$.extend( settings.oPreviousSearch, _fnSearchToHung( state.search ) );\n\t\t}\n\t\n\t\t// Columns\n\t\tfor ( i=0, ien=state.columns.length ; i<ien ; i++ ) {\n\t\t\tvar col = state.columns[i];\n\t\n\t\t\t// Visibility\n\t\t\tif ( col.visible !== undefined ) {\n\t\t\t\tcolumns[i].bVisible = col.visible;\n\t\t\t}\n\t\n\t\t\t// Search\n\t\t\tif ( col.search !== undefined ) {\n\t\t\t\t$.extend( settings.aoPreSearchCols[i], _fnSearchToHung( col.search ) );\n\t\t\t}\n\t\t}\n\t\n\t\t_fnCallbackFire( settings, 'aoStateLoaded', 'stateLoaded', [settings, state] );\n\t}\n\t\n\t\n\t/**\n\t * Return the settings object for a particular table\n\t * @param {node} table table we are using as a dataTable\n\t * @returns {object} Settings object - or null if not found\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSettingsFromNode ( table )\n\t{\n\t\tvar settings = DataTable.settings;\n\t\tvar idx = $.inArray( table, _pluck( settings, 'nTable' ) );\n\t\n\t\treturn idx !== -1 ?\n\t\t\tsettings[ idx ] :\n\t\t\tnull;\n\t}\n\t\n\t\n\t/**\n\t * Log an error message\n\t * @param {object} settings dataTables settings object\n\t * @param {int} level log error messages, or display them to the user\n\t * @param {string} msg error message\n\t * @param {int} tn Technical note id to get more information about the error.\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnLog( settings, level, msg, tn )\n\t{\n\t\tmsg = 'DataTables warning: '+\n\t\t\t(settings ? 'table id='+settings.sTableId+' - ' : '')+msg;\n\t\n\t\tif ( tn ) {\n\t\t\tmsg += '. For more information about this error, please see '+\n\t\t\t'http://datatables.net/tn/'+tn;\n\t\t}\n\t\n\t\tif ( ! level ) {\n\t\t\t// Backwards compatibility pre 1.10\n\t\t\tvar ext = DataTable.ext;\n\t\t\tvar type = ext.sErrMode || ext.errMode;\n\t\n\t\t\tif ( settings ) {\n\t\t\t\t_fnCallbackFire( settings, null, 'error', [ settings, tn, msg ] );\n\t\t\t}\n\t\n\t\t\tif ( type == 'alert' ) {\n\t\t\t\talert( msg );\n\t\t\t}\n\t\t\telse if ( type == 'throw' ) {\n\t\t\t\tthrow new Error(msg);\n\t\t\t}\n\t\t\telse if ( typeof type == 'function' ) {\n\t\t\t\ttype( settings, tn, msg );\n\t\t\t}\n\t\t}\n\t\telse if ( window.console && console.log ) {\n\t\t\tconsole.log( msg );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * See if a property is defined on one object, if so assign it to the other object\n\t * @param {object} ret target object\n\t * @param {object} src source object\n\t * @param {string} name property\n\t * @param {string} [mappedName] name to map too - optional, name used if not given\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnMap( ret, src, name, mappedName )\n\t{\n\t\tif ( $.isArray( name ) ) {\n\t\t\t$.each( name, function (i, val) {\n\t\t\t\tif ( $.isArray( val ) ) {\n\t\t\t\t\t_fnMap( ret, src, val[0], val[1] );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\t_fnMap( ret, src, val );\n\t\t\t\t}\n\t\t\t} );\n\t\n\t\t\treturn;\n\t\t}\n\t\n\t\tif ( mappedName === undefined ) {\n\t\t\tmappedName = name;\n\t\t}\n\t\n\t\tif ( src[name] !== undefined ) {\n\t\t\tret[mappedName] = src[name];\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Extend objects - very similar to jQuery.extend, but deep copy objects, and\n\t * shallow copy arrays. The reason we need to do this, is that we don't want to\n\t * deep copy array init values (such as aaSorting) since the dev wouldn't be\n\t * able to override them, but we do want to deep copy arrays.\n\t * @param {object} out Object to extend\n\t * @param {object} extender Object from which the properties will be applied to\n\t * out\n\t * @param {boolean} breakRefs If true, then arrays will be sliced to take an\n\t * independent copy with the exception of the `data` or `aaData` parameters\n\t * if they are present. This is so you can pass in a collection to\n\t * DataTables and have that used as your data source without breaking the\n\t * references\n\t * @returns {object} out Reference, just for convenience - out === the return.\n\t * @memberof DataTable#oApi\n\t * @todo This doesn't take account of arrays inside the deep copied objects.\n\t */\n\tfunction _fnExtend( out, extender, breakRefs )\n\t{\n\t\tvar val;\n\t\n\t\tfor ( var prop in extender ) {\n\t\t\tif ( extender.hasOwnProperty(prop) ) {\n\t\t\t\tval = extender[prop];\n\t\n\t\t\t\tif ( $.isPlainObject( val ) ) {\n\t\t\t\t\tif ( ! $.isPlainObject( out[prop] ) ) {\n\t\t\t\t\t\tout[prop] = {};\n\t\t\t\t\t}\n\t\t\t\t\t$.extend( true, out[prop], val );\n\t\t\t\t}\n\t\t\t\telse if ( breakRefs && prop !== 'data' && prop !== 'aaData' && $.isArray(val) ) {\n\t\t\t\t\tout[prop] = val.slice();\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tout[prop] = val;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\treturn out;\n\t}\n\t\n\t\n\t/**\n\t * Bind an event handers to allow a click or return key to activate the callback.\n\t * This is good for accessibility since a return on the keyboard will have the\n\t * same effect as a click, if the element has focus.\n\t * @param {element} n Element to bind the action to\n\t * @param {object} oData Data object to pass to the triggered function\n\t * @param {function} fn Callback function for when the event is triggered\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnBindAction( n, oData, fn )\n\t{\n\t\t$(n)\n\t\t\t.bind( 'click.DT', oData, function (e) {\n\t\t\t\t\tn.blur(); // Remove focus outline for mouse users\n\t\t\t\t\tfn(e);\n\t\t\t\t} )\n\t\t\t.bind( 'keypress.DT', oData, function (e){\n\t\t\t\t\tif ( e.which === 13 ) {\n\t\t\t\t\t\te.preventDefault();\n\t\t\t\t\t\tfn(e);\n\t\t\t\t\t}\n\t\t\t\t} )\n\t\t\t.bind( 'selectstart.DT', function () {\n\t\t\t\t\t/* Take the brutal approach to cancelling text selection */\n\t\t\t\t\treturn false;\n\t\t\t\t} );\n\t}\n\t\n\t\n\t/**\n\t * Register a callback function. Easily allows a callback function to be added to\n\t * an array store of callback functions that can then all be called together.\n\t * @param {object} oSettings dataTables settings object\n\t * @param {string} sStore Name of the array storage for the callbacks in oSettings\n\t * @param {function} fn Function to be called back\n\t * @param {string} sName Identifying name for the callback (i.e. a label)\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnCallbackReg( oSettings, sStore, fn, sName )\n\t{\n\t\tif ( fn )\n\t\t{\n\t\t\toSettings[sStore].push( {\n\t\t\t\t\"fn\": fn,\n\t\t\t\t\"sName\": sName\n\t\t\t} );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Fire callback functions and trigger events. Note that the loop over the\n\t * callback array store is done backwards! Further note that you do not want to\n\t * fire off triggers in time sensitive applications (for example cell creation)\n\t * as its slow.\n\t * @param {object} settings dataTables settings object\n\t * @param {string} callbackArr Name of the array storage for the callbacks in\n\t * oSettings\n\t * @param {string} eventName Name of the jQuery custom event to trigger. If\n\t * null no trigger is fired\n\t * @param {array} args Array of arguments to pass to the callback function /\n\t * trigger\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnCallbackFire( settings, callbackArr, eventName, args )\n\t{\n\t\tvar ret = [];\n\t\n\t\tif ( callbackArr ) {\n\t\t\tret = $.map( settings[callbackArr].slice().reverse(), function (val, i) {\n\t\t\t\treturn val.fn.apply( settings.oInstance, args );\n\t\t\t} );\n\t\t}\n\t\n\t\tif ( eventName !== null ) {\n\t\t\tvar e = $.Event( eventName+'.dt' );\n\t\n\t\t\t$(settings.nTable).trigger( e, args );\n\t\n\t\t\tret.push( e.result );\n\t\t}\n\t\n\t\treturn ret;\n\t}\n\t\n\t\n\tfunction _fnLengthOverflow ( settings )\n\t{\n\t\tvar\n\t\t\tstart = settings._iDisplayStart,\n\t\t\tend = settings.fnDisplayEnd(),\n\t\t\tlen = settings._iDisplayLength;\n\t\n\t\t/* If we have space to show extra rows (backing up from the end point - then do so */\n\t\tif ( start >= end )\n\t\t{\n\t\t\tstart = end - len;\n\t\t}\n\t\n\t\t// Keep the start record on the current page\n\t\tstart -= (start % len);\n\t\n\t\tif ( len === -1 || start < 0 )\n\t\t{\n\t\t\tstart = 0;\n\t\t}\n\t\n\t\tsettings._iDisplayStart = start;\n\t}\n\t\n\t\n\tfunction _fnRenderer( settings, type )\n\t{\n\t\tvar renderer = settings.renderer;\n\t\tvar host = DataTable.ext.renderer[type];\n\t\n\t\tif ( $.isPlainObject( renderer ) && renderer[type] ) {\n\t\t\t// Specific renderer for this type. If available use it, otherwise use\n\t\t\t// the default.\n\t\t\treturn host[renderer[type]] || host._;\n\t\t}\n\t\telse if ( typeof renderer === 'string' ) {\n\t\t\t// Common renderer - if there is one available for this type use it,\n\t\t\t// otherwise use the default\n\t\t\treturn host[renderer] || host._;\n\t\t}\n\t\n\t\t// Use the default\n\t\treturn host._;\n\t}\n\t\n\t\n\t/**\n\t * Detect the data source being used for the table. Used to simplify the code\n\t * a little (ajax) and to make it compress a little smaller.\n\t *\n\t * @param {object} settings dataTables settings object\n\t * @returns {string} Data source\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnDataSource ( settings )\n\t{\n\t\tif ( settings.oFeatures.bServerSide ) {\n\t\t\treturn 'ssp';\n\t\t}\n\t\telse if ( settings.ajax || settings.sAjaxSource ) {\n\t\t\treturn 'ajax';\n\t\t}\n\t\treturn 'dom';\n\t}\n\t\n\n\t\n\t\n\t/**\n\t * Computed structure of the DataTables API, defined by the options passed to\n\t * `DataTable.Api.register()` when building the API.\n\t *\n\t * The structure is built in order to speed creation and extension of the Api\n\t * objects since the extensions are effectively pre-parsed.\n\t *\n\t * The array is an array of objects with the following structure, where this\n\t * base array represents the Api prototype base:\n\t *\n\t * [\n\t * {\n\t * name: 'data' -- string - Property name\n\t * val: function () {}, -- function - Api method (or undefined if just an object\n\t * methodExt: [ ... ], -- array - Array of Api object definitions to extend the method result\n\t * propExt: [ ... ] -- array - Array of Api object definitions to extend the property\n\t * },\n\t * {\n\t * name: 'row'\n\t * val: {},\n\t * methodExt: [ ... ],\n\t * propExt: [\n\t * {\n\t * name: 'data'\n\t * val: function () {},\n\t * methodExt: [ ... ],\n\t * propExt: [ ... ]\n\t * },\n\t * ...\n\t * ]\n\t * }\n\t * ]\n\t *\n\t * @type {Array}\n\t * @ignore\n\t */\n\tvar __apiStruct = [];\n\t\n\t\n\t/**\n\t * `Array.prototype` reference.\n\t *\n\t * @type object\n\t * @ignore\n\t */\n\tvar __arrayProto = Array.prototype;\n\t\n\t\n\t/**\n\t * Abstraction for `context` parameter of the `Api` constructor to allow it to\n\t * take several different forms for ease of use.\n\t *\n\t * Each of the input parameter types will be converted to a DataTables settings\n\t * object where possible.\n\t *\n\t * @param {string|node|jQuery|object} mixed DataTable identifier. Can be one\n\t * of:\n\t *\n\t * * `string` - jQuery selector. Any DataTables' matching the given selector\n\t * with be found and used.\n\t * * `node` - `TABLE` node which has already been formed into a DataTable.\n\t * * `jQuery` - A jQuery object of `TABLE` nodes.\n\t * * `object` - DataTables settings object\n\t * * `DataTables.Api` - API instance\n\t * @return {array|null} Matching DataTables settings objects. `null` or\n\t * `undefined` is returned if no matching DataTable is found.\n\t * @ignore\n\t */\n\tvar _toSettings = function ( mixed )\n\t{\n\t\tvar idx, jq;\n\t\tvar settings = DataTable.settings;\n\t\tvar tables = $.map( settings, function (el, i) {\n\t\t\treturn el.nTable;\n\t\t} );\n\t\n\t\tif ( ! mixed ) {\n\t\t\treturn [];\n\t\t}\n\t\telse if ( mixed.nTable && mixed.oApi ) {\n\t\t\t// DataTables settings object\n\t\t\treturn [ mixed ];\n\t\t}\n\t\telse if ( mixed.nodeName && mixed.nodeName.toLowerCase() === 'table' ) {\n\t\t\t// Table node\n\t\t\tidx = $.inArray( mixed, tables );\n\t\t\treturn idx !== -1 ? [ settings[idx] ] : null;\n\t\t}\n\t\telse if ( mixed && typeof mixed.settings === 'function' ) {\n\t\t\treturn mixed.settings().toArray();\n\t\t}\n\t\telse if ( typeof mixed === 'string' ) {\n\t\t\t// jQuery selector\n\t\t\tjq = $(mixed);\n\t\t}\n\t\telse if ( mixed instanceof $ ) {\n\t\t\t// jQuery object (also DataTables instance)\n\t\t\tjq = mixed;\n\t\t}\n\t\n\t\tif ( jq ) {\n\t\t\treturn jq.map( function(i) {\n\t\t\t\tidx = $.inArray( this, tables );\n\t\t\t\treturn idx !== -1 ? settings[idx] : null;\n\t\t\t} ).toArray();\n\t\t}\n\t};\n\t\n\t\n\t/**\n\t * DataTables API class - used to control and interface with one or more\n\t * DataTables enhanced tables.\n\t *\n\t * The API class is heavily based on jQuery, presenting a chainable interface\n\t * that you can use to interact with tables. Each instance of the API class has\n\t * a \"context\" - i.e. the tables that it will operate on. This could be a single\n\t * table, all tables on a page or a sub-set thereof.\n\t *\n\t * Additionally the API is designed to allow you to easily work with the data in\n\t * the tables, retrieving and manipulating it as required. This is done by\n\t * presenting the API class as an array like interface. The contents of the\n\t * array depend upon the actions requested by each method (for example\n\t * `rows().nodes()` will return an array of nodes, while `rows().data()` will\n\t * return an array of objects or arrays depending upon your table's\n\t * configuration). The API object has a number of array like methods (`push`,\n\t * `pop`, `reverse` etc) as well as additional helper methods (`each`, `pluck`,\n\t * `unique` etc) to assist your working with the data held in a table.\n\t *\n\t * Most methods (those which return an Api instance) are chainable, which means\n\t * the return from a method call also has all of the methods available that the\n\t * top level object had. For example, these two calls are equivalent:\n\t *\n\t * // Not chained\n\t * api.row.add( {...} );\n\t * api.draw();\n\t *\n\t * // Chained\n\t * api.row.add( {...} ).draw();\n\t *\n\t * @class DataTable.Api\n\t * @param {array|object|string|jQuery} context DataTable identifier. This is\n\t * used to define which DataTables enhanced tables this API will operate on.\n\t * Can be one of:\n\t *\n\t * * `string` - jQuery selector. Any DataTables' matching the given selector\n\t * with be found and used.\n\t * * `node` - `TABLE` node which has already been formed into a DataTable.\n\t * * `jQuery` - A jQuery object of `TABLE` nodes.\n\t * * `object` - DataTables settings object\n\t * @param {array} [data] Data to initialise the Api instance with.\n\t *\n\t * @example\n\t * // Direct initialisation during DataTables construction\n\t * var api = $('#example').DataTable();\n\t *\n\t * @example\n\t * // Initialisation using a DataTables jQuery object\n\t * var api = $('#example').dataTable().api();\n\t *\n\t * @example\n\t * // Initialisation as a constructor\n\t * var api = new $.fn.DataTable.Api( 'table.dataTable' );\n\t */\n\t_Api = function ( context, data )\n\t{\n\t\tif ( ! (this instanceof _Api) ) {\n\t\t\treturn new _Api( context, data );\n\t\t}\n\t\n\t\tvar settings = [];\n\t\tvar ctxSettings = function ( o ) {\n\t\t\tvar a = _toSettings( o );\n\t\t\tif ( a ) {\n\t\t\t\tsettings = settings.concat( a );\n\t\t\t}\n\t\t};\n\t\n\t\tif ( $.isArray( context ) ) {\n\t\t\tfor ( var i=0, ien=context.length ; i<ien ; i++ ) {\n\t\t\t\tctxSettings( context[i] );\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tctxSettings( context );\n\t\t}\n\t\n\t\t// Remove duplicates\n\t\tthis.context = _unique( settings );\n\t\n\t\t// Initial data\n\t\tif ( data ) {\n\t\t\t$.merge( this, data );\n\t\t}\n\t\n\t\t// selector\n\t\tthis.selector = {\n\t\t\trows: null,\n\t\t\tcols: null,\n\t\t\topts: null\n\t\t};\n\t\n\t\t_Api.extend( this, this, __apiStruct );\n\t};\n\t\n\tDataTable.Api = _Api;\n\t\n\t// Don't destroy the existing prototype, just extend it. Required for jQuery 2's\n\t// isPlainObject.\n\t$.extend( _Api.prototype, {\n\t\tany: function ()\n\t\t{\n\t\t\treturn this.count() !== 0;\n\t\t},\n\t\n\t\n\t\tconcat: __arrayProto.concat,\n\t\n\t\n\t\tcontext: [], // array of table settings objects\n\t\n\t\n\t\tcount: function ()\n\t\t{\n\t\t\treturn this.flatten().length;\n\t\t},\n\t\n\t\n\t\teach: function ( fn )\n\t\t{\n\t\t\tfor ( var i=0, ien=this.length ; i<ien; i++ ) {\n\t\t\t\tfn.call( this, this[i], i, this );\n\t\t\t}\n\t\n\t\t\treturn this;\n\t\t},\n\t\n\t\n\t\teq: function ( idx )\n\t\t{\n\t\t\tvar ctx = this.context;\n\t\n\t\t\treturn ctx.length > idx ?\n\t\t\t\tnew _Api( ctx[idx], this[idx] ) :\n\t\t\t\tnull;\n\t\t},\n\t\n\t\n\t\tfilter: function ( fn )\n\t\t{\n\t\t\tvar a = [];\n\t\n\t\t\tif ( __arrayProto.filter ) {\n\t\t\t\ta = __arrayProto.filter.call( this, fn, this );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Compatibility for browsers without EMCA-252-5 (JS 1.6)\n\t\t\t\tfor ( var i=0, ien=this.length ; i<ien ; i++ ) {\n\t\t\t\t\tif ( fn.call( this, this[i], i, this ) ) {\n\t\t\t\t\t\ta.push( this[i] );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\treturn new _Api( this.context, a );\n\t\t},\n\t\n\t\n\t\tflatten: function ()\n\t\t{\n\t\t\tvar a = [];\n\t\t\treturn new _Api( this.context, a.concat.apply( a, this.toArray() ) );\n\t\t},\n\t\n\t\n\t\tjoin: __arrayProto.join,\n\t\n\t\n\t\tindexOf: __arrayProto.indexOf || function (obj, start)\n\t\t{\n\t\t\tfor ( var i=(start || 0), ien=this.length ; i<ien ; i++ ) {\n\t\t\t\tif ( this[i] === obj ) {\n\t\t\t\t\treturn i;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn -1;\n\t\t},\n\t\n\t\titerator: function ( flatten, type, fn, alwaysNew ) {\n\t\t\tvar\n\t\t\t\ta = [], ret,\n\t\t\t\ti, ien, j, jen,\n\t\t\t\tcontext = this.context,\n\t\t\t\trows, items, item,\n\t\t\t\tselector = this.selector;\n\t\n\t\t\t// Argument shifting\n\t\t\tif ( typeof flatten === 'string' ) {\n\t\t\t\talwaysNew = fn;\n\t\t\t\tfn = type;\n\t\t\t\ttype = flatten;\n\t\t\t\tflatten = false;\n\t\t\t}\n\t\n\t\t\tfor ( i=0, ien=context.length ; i<ien ; i++ ) {\n\t\t\t\tvar apiInst = new _Api( context[i] );\n\t\n\t\t\t\tif ( type === 'table' ) {\n\t\t\t\t\tret = fn.call( apiInst, context[i], i );\n\t\n\t\t\t\t\tif ( ret !== undefined ) {\n\t\t\t\t\t\ta.push( ret );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse if ( type === 'columns' || type === 'rows' ) {\n\t\t\t\t\t// this has same length as context - one entry for each table\n\t\t\t\t\tret = fn.call( apiInst, context[i], this[i], i );\n\t\n\t\t\t\t\tif ( ret !== undefined ) {\n\t\t\t\t\t\ta.push( ret );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse if ( type === 'column' || type === 'column-rows' || type === 'row' || type === 'cell' ) {\n\t\t\t\t\t// columns and rows share the same structure.\n\t\t\t\t\t// 'this' is an array of column indexes for each context\n\t\t\t\t\titems = this[i];\n\t\n\t\t\t\t\tif ( type === 'column-rows' ) {\n\t\t\t\t\t\trows = _selector_row_indexes( context[i], selector.opts );\n\t\t\t\t\t}\n\t\n\t\t\t\t\tfor ( j=0, jen=items.length ; j<jen ; j++ ) {\n\t\t\t\t\t\titem = items[j];\n\t\n\t\t\t\t\t\tif ( type === 'cell' ) {\n\t\t\t\t\t\t\tret = fn.call( apiInst, context[i], item.row, item.column, i, j );\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tret = fn.call( apiInst, context[i], item, i, j, rows );\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\tif ( ret !== undefined ) {\n\t\t\t\t\t\t\ta.push( ret );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\tif ( a.length || alwaysNew ) {\n\t\t\t\tvar api = new _Api( context, flatten ? a.concat.apply( [], a ) : a );\n\t\t\t\tvar apiSelector = api.selector;\n\t\t\t\tapiSelector.rows = selector.rows;\n\t\t\t\tapiSelector.cols = selector.cols;\n\t\t\t\tapiSelector.opts = selector.opts;\n\t\t\t\treturn api;\n\t\t\t}\n\t\t\treturn this;\n\t\t},\n\t\n\t\n\t\tlastIndexOf: __arrayProto.lastIndexOf || function (obj, start)\n\t\t{\n\t\t\t// Bit cheeky...\n\t\t\treturn this.indexOf.apply( this.toArray.reverse(), arguments );\n\t\t},\n\t\n\t\n\t\tlength: 0,\n\t\n\t\n\t\tmap: function ( fn )\n\t\t{\n\t\t\tvar a = [];\n\t\n\t\t\tif ( __arrayProto.map ) {\n\t\t\t\ta = __arrayProto.map.call( this, fn, this );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Compatibility for browsers without EMCA-252-5 (JS 1.6)\n\t\t\t\tfor ( var i=0, ien=this.length ; i<ien ; i++ ) {\n\t\t\t\t\ta.push( fn.call( this, this[i], i ) );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\treturn new _Api( this.context, a );\n\t\t},\n\t\n\t\n\t\tpluck: function ( prop )\n\t\t{\n\t\t\treturn this.map( function ( el ) {\n\t\t\t\treturn el[ prop ];\n\t\t\t} );\n\t\t},\n\t\n\t\tpop: __arrayProto.pop,\n\t\n\t\n\t\tpush: __arrayProto.push,\n\t\n\t\n\t\t// Does not return an API instance\n\t\treduce: __arrayProto.reduce || function ( fn, init )\n\t\t{\n\t\t\treturn _fnReduce( this, fn, init, 0, this.length, 1 );\n\t\t},\n\t\n\t\n\t\treduceRight: __arrayProto.reduceRight || function ( fn, init )\n\t\t{\n\t\t\treturn _fnReduce( this, fn, init, this.length-1, -1, -1 );\n\t\t},\n\t\n\t\n\t\treverse: __arrayProto.reverse,\n\t\n\t\n\t\t// Object with rows, columns and opts\n\t\tselector: null,\n\t\n\t\n\t\tshift: __arrayProto.shift,\n\t\n\t\n\t\tsort: __arrayProto.sort, // ? name - order?\n\t\n\t\n\t\tsplice: __arrayProto.splice,\n\t\n\t\n\t\ttoArray: function ()\n\t\t{\n\t\t\treturn __arrayProto.slice.call( this );\n\t\t},\n\t\n\t\n\t\tto$: function ()\n\t\t{\n\t\t\treturn $( this );\n\t\t},\n\t\n\t\n\t\ttoJQuery: function ()\n\t\t{\n\t\t\treturn $( this );\n\t\t},\n\t\n\t\n\t\tunique: function ()\n\t\t{\n\t\t\treturn new _Api( this.context, _unique(this) );\n\t\t},\n\t\n\t\n\t\tunshift: __arrayProto.unshift\n\t} );\n\t\n\t\n\t_Api.extend = function ( scope, obj, ext )\n\t{\n\t\t// Only extend API instances and static properties of the API\n\t\tif ( ! ext.length || ! obj || ( ! (obj instanceof _Api) && ! obj.__dt_wrapper ) ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar\n\t\t\ti, ien,\n\t\t\tj, jen,\n\t\t\tstruct, inner,\n\t\t\tmethodScoping = function ( scope, fn, struc ) {\n\t\t\t\treturn function () {\n\t\t\t\t\tvar ret = fn.apply( scope, arguments );\n\t\n\t\t\t\t\t// Method extension\n\t\t\t\t\t_Api.extend( ret, ret, struc.methodExt );\n\t\t\t\t\treturn ret;\n\t\t\t\t};\n\t\t\t};\n\t\n\t\tfor ( i=0, ien=ext.length ; i<ien ; i++ ) {\n\t\t\tstruct = ext[i];\n\t\n\t\t\t// Value\n\t\t\tobj[ struct.name ] = typeof struct.val === 'function' ?\n\t\t\t\tmethodScoping( scope, struct.val, struct ) :\n\t\t\t\t$.isPlainObject( struct.val ) ?\n\t\t\t\t\t{} :\n\t\t\t\t\tstruct.val;\n\t\n\t\t\tobj[ struct.name ].__dt_wrapper = true;\n\t\n\t\t\t// Property extension\n\t\t\t_Api.extend( scope, obj[ struct.name ], struct.propExt );\n\t\t}\n\t};\n\t\n\t\n\t// @todo - Is there need for an augment function?\n\t// _Api.augment = function ( inst, name )\n\t// {\n\t// \t// Find src object in the structure from the name\n\t// \tvar parts = name.split('.');\n\t\n\t// \t_Api.extend( inst, obj );\n\t// };\n\t\n\t\n\t// [\n\t// {\n\t// name: 'data' -- string - Property name\n\t// val: function () {}, -- function - Api method (or undefined if just an object\n\t// methodExt: [ ... ], -- array - Array of Api object definitions to extend the method result\n\t// propExt: [ ... ] -- array - Array of Api object definitions to extend the property\n\t// },\n\t// {\n\t// name: 'row'\n\t// val: {},\n\t// methodExt: [ ... ],\n\t// propExt: [\n\t// {\n\t// name: 'data'\n\t// val: function () {},\n\t// methodExt: [ ... ],\n\t// propExt: [ ... ]\n\t// },\n\t// ...\n\t// ]\n\t// }\n\t// ]\n\t\n\t_Api.register = _api_register = function ( name, val )\n\t{\n\t\tif ( $.isArray( name ) ) {\n\t\t\tfor ( var j=0, jen=name.length ; j<jen ; j++ ) {\n\t\t\t\t_Api.register( name[j], val );\n\t\t\t}\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar\n\t\t\ti, ien,\n\t\t\their = name.split('.'),\n\t\t\tstruct = __apiStruct,\n\t\t\tkey, method;\n\t\n\t\tvar find = function ( src, name ) {\n\t\t\tfor ( var i=0, ien=src.length ; i<ien ; i++ ) {\n\t\t\t\tif ( src[i].name === name ) {\n\t\t\t\t\treturn src[i];\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn null;\n\t\t};\n\t\n\t\tfor ( i=0, ien=heir.length ; i<ien ; i++ ) {\n\t\t\tmethod = heir[i].indexOf('()') !== -1;\n\t\t\tkey = method ?\n\t\t\t\their[i].replace('()', '') :\n\t\t\t\their[i];\n\t\n\t\t\tvar src = find( struct, key );\n\t\t\tif ( ! src ) {\n\t\t\t\tsrc = {\n\t\t\t\t\tname: key,\n\t\t\t\t\tval: {},\n\t\t\t\t\tmethodExt: [],\n\t\t\t\t\tpropExt: []\n\t\t\t\t};\n\t\t\t\tstruct.push( src );\n\t\t\t}\n\t\n\t\t\tif ( i === ien-1 ) {\n\t\t\t\tsrc.val = val;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tstruct = method ?\n\t\t\t\t\tsrc.methodExt :\n\t\t\t\t\tsrc.propExt;\n\t\t\t}\n\t\t}\n\t};\n\t\n\t\n\t_Api.registerPlural = _api_registerPlural = function ( pluralName, singularName, val ) {\n\t\t_Api.register( pluralName, val );\n\t\n\t\t_Api.register( singularName, function () {\n\t\t\tvar ret = val.apply( this, arguments );\n\t\n\t\t\tif ( ret === this ) {\n\t\t\t\t// Returned item is the API instance that was passed in, return it\n\t\t\t\treturn this;\n\t\t\t}\n\t\t\telse if ( ret instanceof _Api ) {\n\t\t\t\t// New API instance returned, want the value from the first item\n\t\t\t\t// in the returned array for the singular result.\n\t\t\t\treturn ret.length ?\n\t\t\t\t\t$.isArray( ret[0] ) ?\n\t\t\t\t\t\tnew _Api( ret.context, ret[0] ) : // Array results are 'enhanced'\n\t\t\t\t\t\tret[0] :\n\t\t\t\t\tundefined;\n\t\t\t}\n\t\n\t\t\t// Non-API return - just fire it back\n\t\t\treturn ret;\n\t\t} );\n\t};\n\t\n\t\n\t/**\n\t * Selector for HTML tables. Apply the given selector to the give array of\n\t * DataTables settings objects.\n\t *\n\t * @param {string|integer} [selector] jQuery selector string or integer\n\t * @param {array} Array of DataTables settings objects to be filtered\n\t * @return {array}\n\t * @ignore\n\t */\n\tvar __table_selector = function ( selector, a )\n\t{\n\t\t// Integer is used to pick out a table by index\n\t\tif ( typeof selector === 'number' ) {\n\t\t\treturn [ a[ selector ] ];\n\t\t}\n\t\n\t\t// Perform a jQuery selector on the table nodes\n\t\tvar nodes = $.map( a, function (el, i) {\n\t\t\treturn el.nTable;\n\t\t} );\n\t\n\t\treturn $(nodes)\n\t\t\t.filter( selector )\n\t\t\t.map( function (i) {\n\t\t\t\t// Need to translate back from the table node to the settings\n\t\t\t\tvar idx = $.inArray( this, nodes );\n\t\t\t\treturn a[ idx ];\n\t\t\t} )\n\t\t\t.toArray();\n\t};\n\t\n\t\n\t\n\t/**\n\t * Context selector for the API's context (i.e. the tables the API instance\n\t * refers to.\n\t *\n\t * @name DataTable.Api#tables\n\t * @param {string|integer} [selector] Selector to pick which tables the iterator\n\t * should operate on. If not given, all tables in the current context are\n\t * used. This can be given as a jQuery selector (for example `':gt(0)'`) to\n\t * select multiple tables or as an integer to select a single table.\n\t * @returns {DataTable.Api} Returns a new API instance if a selector is given.\n\t */\n\t_api_register( 'tables()', function ( selector ) {\n\t\t// A new instance is created if there was a selector specified\n\t\treturn selector ?\n\t\t\tnew _Api( __table_selector( selector, this.context ) ) :\n\t\t\tthis;\n\t} );\n\t\n\t\n\t_api_register( 'table()', function ( selector ) {\n\t\tvar tables = this.tables( selector );\n\t\tvar ctx = tables.context;\n\t\n\t\t// Truncate to the first matched table\n\t\treturn ctx.length ?\n\t\t\tnew _Api( ctx[0] ) :\n\t\t\ttables;\n\t} );\n\t\n\t\n\t_api_registerPlural( 'tables().nodes()', 'table().node()' , function () {\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\treturn ctx.nTable;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'tables().body()', 'table().body()' , function () {\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\treturn ctx.nTBody;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'tables().header()', 'table().header()' , function () {\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\treturn ctx.nTHead;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'tables().footer()', 'table().footer()' , function () {\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\treturn ctx.nTFoot;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'tables().containers()', 'table().container()' , function () {\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\treturn ctx.nTableWrapper;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t\n\t/**\n\t * Redraw the tables in the current context.\n\t */\n\t_api_register( 'draw()', function ( paging ) {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tif ( paging === 'page' ) {\n\t\t\t\t_fnDraw( settings );\n\t\t\t}\n\t\t\telse {\n\t\t\t\tif ( typeof paging === 'string' ) {\n\t\t\t\t\tpaging = paging === 'full-hold' ?\n\t\t\t\t\t\tfalse :\n\t\t\t\t\t\ttrue;\n\t\t\t\t}\n\t\n\t\t\t\t_fnReDraw( settings, paging===false );\n\t\t\t}\n\t\t} );\n\t} );\n\t\n\t\n\t\n\t/**\n\t * Get the current page index.\n\t *\n\t * @return {integer} Current page index (zero based)\n\t *//**\n\t * Set the current page.\n\t *\n\t * Note that if you attempt to show a page which does not exist, DataTables will\n\t * not throw an error, but rather reset the paging.\n\t *\n\t * @param {integer|string} action The paging action to take. This can be one of:\n\t * * `integer` - The page index to jump to\n\t * * `string` - An action to take:\n\t * * `first` - Jump to first page.\n\t * * `next` - Jump to the next page\n\t * * `previous` - Jump to previous page\n\t * * `last` - Jump to the last page.\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'page()', function ( action ) {\n\t\tif ( action === undefined ) {\n\t\t\treturn this.page.info().page; // not an expensive call\n\t\t}\n\t\n\t\t// else, have an action to take on all tables\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnPageChange( settings, action );\n\t\t} );\n\t} );\n\t\n\t\n\t/**\n\t * Paging information for the first table in the current context.\n\t *\n\t * If you require paging information for another table, use the `table()` method\n\t * with a suitable selector.\n\t *\n\t * @return {object} Object with the following properties set:\n\t * * `page` - Current page index (zero based - i.e. the first page is `0`)\n\t * * `pages` - Total number of pages\n\t * * `start` - Display index for the first record shown on the current page\n\t * * `end` - Display index for the last record shown on the current page\n\t * * `length` - Display length (number of records). Note that generally `start\n\t * + length = end`, but this is not always true, for example if there are\n\t * only 2 records to show on the final page, with a length of 10.\n\t * * `recordsTotal` - Full data set length\n\t * * `recordsDisplay` - Data set length once the current filtering criterion\n\t * are applied.\n\t */\n\t_api_register( 'page.info()', function ( action ) {\n\t\tif ( this.context.length === 0 ) {\n\t\t\treturn undefined;\n\t\t}\n\t\n\t\tvar\n\t\t\tsettings = this.context[0],\n\t\t\tstart = settings._iDisplayStart,\n\t\t\tlen = settings.oFeatures.bPaginate ? settings._iDisplayLength : -1,\n\t\t\tvisRecords = settings.fnRecordsDisplay(),\n\t\t\tall = len === -1;\n\t\n\t\treturn {\n\t\t\t\"page\": all ? 0 : Math.floor( start / len ),\n\t\t\t\"pages\": all ? 1 : Math.ceil( visRecords / len ),\n\t\t\t\"start\": start,\n\t\t\t\"end\": settings.fnDisplayEnd(),\n\t\t\t\"length\": len,\n\t\t\t\"recordsTotal\": settings.fnRecordsTotal(),\n\t\t\t\"recordsDisplay\": visRecords,\n\t\t\t\"serverSide\": _fnDataSource( settings ) === 'ssp'\n\t\t};\n\t} );\n\t\n\t\n\t/**\n\t * Get the current page length.\n\t *\n\t * @return {integer} Current page length. Note `-1` indicates that all records\n\t * are to be shown.\n\t *//**\n\t * Set the current page length.\n\t *\n\t * @param {integer} Page length to set. Use `-1` to show all records.\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'page.len()', function ( len ) {\n\t\t// Note that we can't call this function 'length()' because `length`\n\t\t// is a Javascript property of functions which defines how many arguments\n\t\t// the function expects.\n\t\tif ( len === undefined ) {\n\t\t\treturn this.context.length !== 0 ?\n\t\t\t\tthis.context[0]._iDisplayLength :\n\t\t\t\tundefined;\n\t\t}\n\t\n\t\t// else, set the page length\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnLengthChange( settings, len );\n\t\t} );\n\t} );\n\t\n\t\n\t\n\tvar __reload = function ( settings, holdPosition, callback ) {\n\t\t// Use the draw event to trigger a callback\n\t\tif ( callback ) {\n\t\t\tvar api = new _Api( settings );\n\t\n\t\t\tapi.one( 'draw', function () {\n\t\t\t\tcallback( api.ajax.json() );\n\t\t\t} );\n\t\t}\n\t\n\t\tif ( _fnDataSource( settings ) == 'ssp' ) {\n\t\t\t_fnReDraw( settings, holdPosition );\n\t\t}\n\t\telse {\n\t\t\t_fnProcessingDisplay( settings, true );\n\t\n\t\t\t// Cancel an existing request\n\t\t\tvar xhr = settings.jqXHR;\n\t\t\tif ( xhr && xhr.readyState !== 4 ) {\n\t\t\t\txhr.abort();\n\t\t\t}\n\t\n\t\t\t// Trigger xhr\n\t\t\t_fnBuildAjax( settings, [], function( json ) {\n\t\t\t\t_fnClearTable( settings );\n\t\n\t\t\t\tvar data = _fnAjaxDataSrc( settings, json );\n\t\t\t\tfor ( var i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t\t\t_fnAddData( settings, data[i] );\n\t\t\t\t}\n\t\n\t\t\t\t_fnReDraw( settings, holdPosition );\n\t\t\t\t_fnProcessingDisplay( settings, false );\n\t\t\t} );\n\t\t}\n\t};\n\t\n\t\n\t/**\n\t * Get the JSON response from the last Ajax request that DataTables made to the\n\t * server. Note that this returns the JSON from the first table in the current\n\t * context.\n\t *\n\t * @return {object} JSON received from the server.\n\t */\n\t_api_register( 'ajax.json()', function () {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( ctx.length > 0 ) {\n\t\t\treturn ctx[0].json;\n\t\t}\n\t\n\t\t// else return undefined;\n\t} );\n\t\n\t\n\t/**\n\t * Get the data submitted in the last Ajax request\n\t */\n\t_api_register( 'ajax.params()', function () {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( ctx.length > 0 ) {\n\t\t\treturn ctx[0].oAjaxData;\n\t\t}\n\t\n\t\t// else return undefined;\n\t} );\n\t\n\t\n\t/**\n\t * Reload tables from the Ajax data source. Note that this function will\n\t * automatically re-draw the table when the remote data has been loaded.\n\t *\n\t * @param {boolean} [reset=true] Reset (default) or hold the current paging\n\t * position. A full re-sort and re-filter is performed when this method is\n\t * called, which is why the pagination reset is the default action.\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'ajax.reload()', function ( callback, resetPaging ) {\n\t\treturn this.iterator( 'table', function (settings) {\n\t\t\t__reload( settings, resetPaging===false, callback );\n\t\t} );\n\t} );\n\t\n\t\n\t/**\n\t * Get the current Ajax URL. Note that this returns the URL from the first\n\t * table in the current context.\n\t *\n\t * @return {string} Current Ajax source URL\n\t *//**\n\t * Set the Ajax URL. Note that this will set the URL for all tables in the\n\t * current context.\n\t *\n\t * @param {string} url URL to set.\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'ajax.url()', function ( url ) {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( url === undefined ) {\n\t\t\t// get\n\t\t\tif ( ctx.length === 0 ) {\n\t\t\t\treturn undefined;\n\t\t\t}\n\t\t\tctx = ctx[0];\n\t\n\t\t\treturn ctx.ajax ?\n\t\t\t\t$.isPlainObject( ctx.ajax ) ?\n\t\t\t\t\tctx.ajax.url :\n\t\t\t\t\tctx.ajax :\n\t\t\t\tctx.sAjaxSource;\n\t\t}\n\t\n\t\t// set\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tif ( $.isPlainObject( settings.ajax ) ) {\n\t\t\t\tsettings.ajax.url = url;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tsettings.ajax = url;\n\t\t\t}\n\t\t\t// No need to consider sAjaxSource here since DataTables gives priority\n\t\t\t// to `ajax` over `sAjaxSource`. So setting `ajax` here, renders any\n\t\t\t// value of `sAjaxSource` redundant.\n\t\t} );\n\t} );\n\t\n\t\n\t/**\n\t * Load data from the newly set Ajax URL. Note that this method is only\n\t * available when `ajax.url()` is used to set a URL. Additionally, this method\n\t * has the same effect as calling `ajax.reload()` but is provided for\n\t * convenience when setting a new URL. Like `ajax.reload()` it will\n\t * automatically redraw the table once the remote data has been loaded.\n\t *\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'ajax.url().load()', function ( callback, resetPaging ) {\n\t\t// Same as a reload, but makes sense to present it for easy access after a\n\t\t// url change\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\t__reload( ctx, resetPaging===false, callback );\n\t\t} );\n\t} );\n\t\n\t\n\t\n\t\n\tvar _selector_run = function ( type, selector, selectFn, settings, opts )\n\t{\n\t\tvar\n\t\t\tout = [], res,\n\t\t\ta, i, ien, j, jen,\n\t\t\tselectorType = typeof selector;\n\t\n\t\t// Can't just check for isArray here, as an API or jQuery instance might be\n\t\t// given with their array like look\n\t\tif ( ! selector || selectorType === 'string' || selectorType === 'function' || selector.length === undefined ) {\n\t\t\tselector = [ selector ];\n\t\t}\n\t\n\t\tfor ( i=0, ien=selector.length ; i<ien ; i++ ) {\n\t\t\ta = selector[i] && selector[i].split ?\n\t\t\t\tselector[i].split(',') :\n\t\t\t\t[ selector[i] ];\n\t\n\t\t\tfor ( j=0, jen=a.length ; j<jen ; j++ ) {\n\t\t\t\tres = selectFn( typeof a[j] === 'string' ? $.trim(a[j]) : a[j] );\n\t\n\t\t\t\tif ( res && res.length ) {\n\t\t\t\t\tout = out.concat( res );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\t// selector extensions\n\t\tvar ext = _ext.selector[ type ];\n\t\tif ( ext.length ) {\n\t\t\tfor ( i=0, ien=ext.length ; i<ien ; i++ ) {\n\t\t\t\tout = ext[i]( settings, opts, out );\n\t\t\t}\n\t\t}\n\t\n\t\treturn _unique( out );\n\t};\n\t\n\t\n\tvar _selector_opts = function ( opts )\n\t{\n\t\tif ( ! opts ) {\n\t\t\topts = {};\n\t\t}\n\t\n\t\t// Backwards compatibility for 1.9- which used the terminology filter rather\n\t\t// than search\n\t\tif ( opts.filter && opts.search === undefined ) {\n\t\t\topts.search = opts.filter;\n\t\t}\n\t\n\t\treturn $.extend( {\n\t\t\tsearch: 'none',\n\t\t\torder: 'current',\n\t\t\tpage: 'all'\n\t\t}, opts );\n\t};\n\t\n\t\n\tvar _selector_first = function ( inst )\n\t{\n\t\t// Reduce the API instance to the first item found\n\t\tfor ( var i=0, ien=inst.length ; i<ien ; i++ ) {\n\t\t\tif ( inst[i].length > 0 ) {\n\t\t\t\t// Assign the first element to the first item in the instance\n\t\t\t\t// and truncate the instance and context\n\t\t\t\tinst[0] = inst[i];\n\t\t\t\tinst[0].length = 1;\n\t\t\t\tinst.length = 1;\n\t\t\t\tinst.context = [ inst.context[i] ];\n\t\n\t\t\t\treturn inst;\n\t\t\t}\n\t\t}\n\t\n\t\t// Not found - return an empty instance\n\t\tinst.length = 0;\n\t\treturn inst;\n\t};\n\t\n\t\n\tvar _selector_row_indexes = function ( settings, opts )\n\t{\n\t\tvar\n\t\t\ti, ien, tmp, a=[],\n\t\t\tdisplayFiltered = settings.aiDisplay,\n\t\t\tdisplayMaster = settings.aiDisplayMaster;\n\t\n\t\tvar\n\t\t\tsearch = opts.search, // none, applied, removed\n\t\t\torder = opts.order, // applied, current, index (original - compatibility with 1.9)\n\t\t\tpage = opts.page; // all, current\n\t\n\t\tif ( _fnDataSource( settings ) == 'ssp' ) {\n\t\t\t// In server-side processing mode, most options are irrelevant since\n\t\t\t// rows not shown don't exist and the index order is the applied order\n\t\t\t// Removed is a special case - for consistency just return an empty\n\t\t\t// array\n\t\t\treturn search === 'removed' ?\n\t\t\t\t[] :\n\t\t\t\t_range( 0, displayMaster.length );\n\t\t}\n\t\telse if ( page == 'current' ) {\n\t\t\t// Current page implies that order=current and fitler=applied, since it is\n\t\t\t// fairly senseless otherwise, regardless of what order and search actually\n\t\t\t// are\n\t\t\tfor ( i=settings._iDisplayStart, ien=settings.fnDisplayEnd() ; i<ien ; i++ ) {\n\t\t\t\ta.push( displayFiltered[i] );\n\t\t\t}\n\t\t}\n\t\telse if ( order == 'current' || order == 'applied' ) {\n\t\t\ta = search == 'none' ?\n\t\t\t\tdisplayMaster.slice() : // no search\n\t\t\t\tsearch == 'applied' ?\n\t\t\t\t\tdisplayFiltered.slice() : // applied search\n\t\t\t\t\t$.map( displayMaster, function (el, i) { // removed search\n\t\t\t\t\t\treturn $.inArray( el, displayFiltered ) === -1 ? el : null;\n\t\t\t\t\t} );\n\t\t}\n\t\telse if ( order == 'index' || order == 'original' ) {\n\t\t\tfor ( i=0, ien=settings.aoData.length ; i<ien ; i++ ) {\n\t\t\t\tif ( search == 'none' ) {\n\t\t\t\t\ta.push( i );\n\t\t\t\t}\n\t\t\t\telse { // applied | removed\n\t\t\t\t\ttmp = $.inArray( i, displayFiltered );\n\t\n\t\t\t\t\tif ((tmp === -1 && search == 'removed') ||\n\t\t\t\t\t\t(tmp >= 0 && search == 'applied') )\n\t\t\t\t\t{\n\t\t\t\t\t\ta.push( i );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\treturn a;\n\t};\n\t\n\t\n\t/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *\n\t * Rows\n\t *\n\t * {} - no selector - use all available rows\n\t * {integer} - row aoData index\n\t * {node} - TR node\n\t * {string} - jQuery selector to apply to the TR elements\n\t * {array} - jQuery array of nodes, or simply an array of TR nodes\n\t *\n\t */\n\t\n\t\n\tvar __row_selector = function ( settings, selector, opts )\n\t{\n\t\tvar run = function ( sel ) {\n\t\t\tvar selInt = _intVal( sel );\n\t\t\tvar i, ien;\n\t\n\t\t\t// Short cut - selector is a number and no options provided (default is\n\t\t\t// all records, so no need to check if the index is in there, since it\n\t\t\t// must be - dev error if the index doesn't exist).\n\t\t\tif ( selInt !== null && ! opts ) {\n\t\t\t\treturn [ selInt ];\n\t\t\t}\n\t\n\t\t\tvar rows = _selector_row_indexes( settings, opts );\n\t\n\t\t\tif ( selInt !== null && $.inArray( selInt, rows ) !== -1 ) {\n\t\t\t\t// Selector - integer\n\t\t\t\treturn [ selInt ];\n\t\t\t}\n\t\t\telse if ( ! sel ) {\n\t\t\t\t// Selector - none\n\t\t\t\treturn rows;\n\t\t\t}\n\t\n\t\t\t// Selector - function\n\t\t\tif ( typeof sel === 'function' ) {\n\t\t\t\treturn $.map( rows, function (idx) {\n\t\t\t\t\tvar row = settings.aoData[ idx ];\n\t\t\t\t\treturn sel( idx, row._aData, row.nTr ) ? idx : null;\n\t\t\t\t} );\n\t\t\t}\n\t\n\t\t\t// Get nodes in the order from the `rows` array with null values removed\n\t\t\tvar nodes = _removeEmpty(\n\t\t\t\t_pluck_order( settings.aoData, rows, 'nTr' )\n\t\t\t);\n\t\n\t\t\t// Selector - node\n\t\t\tif ( sel.nodeName ) {\n\t\t\t\tif ( sel._DT_RowIndex !== undefined ) {\n\t\t\t\t\treturn [ sel._DT_RowIndex ]; // Property added by DT for fast lookup\n\t\t\t\t}\n\t\t\t\telse if ( sel._DT_CellIndex ) {\n\t\t\t\t\treturn [ sel._DT_CellIndex.row ];\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tvar host = $(sel).closest('*[data-dt-row]');\n\t\t\t\t\treturn host.length ?\n\t\t\t\t\t\t[ host.data('dt-row') ] :\n\t\t\t\t\t\t[];\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// ID selector. Want to always be able to select rows by id, regardless\n\t\t\t// of if the tr element has been created or not, so can't rely upon\n\t\t\t// jQuery here - hence a custom implementation. This does not match\n\t\t\t// Sizzle's fast selector or HTML4 - in HTML5 the ID can be anything,\n\t\t\t// but to select it using a CSS selector engine (like Sizzle or\n\t\t\t// querySelect) it would need to need to be escaped for some characters.\n\t\t\t// DataTables simplifies this for row selectors since you can select\n\t\t\t// only a row. A # indicates an id any anything that follows is the id -\n\t\t\t// unescaped.\n\t\t\tif ( typeof sel === 'string' && sel.charAt(0) === '#' ) {\n\t\t\t\t// get row index from id\n\t\t\t\tvar rowObj = settings.aIds[ sel.replace( /^#/, '' ) ];\n\t\t\t\tif ( rowObj !== undefined ) {\n\t\t\t\t\treturn [ rowObj.idx ];\n\t\t\t\t}\n\t\n\t\t\t\t// need to fall through to jQuery in case there is DOM id that\n\t\t\t\t// matches\n\t\t\t}\n\t\n\t\t\t// Selector - jQuery selector string, array of nodes or jQuery object/\n\t\t\t// As jQuery's .filter() allows jQuery objects to be passed in filter,\n\t\t\t// it also allows arrays, so this will cope with all three options\n\t\t\treturn $(nodes)\n\t\t\t\t.filter( sel )\n\t\t\t\t.map( function () {\n\t\t\t\t\treturn this._DT_RowIndex;\n\t\t\t\t} )\n\t\t\t\t.toArray();\n\t\t};\n\t\n\t\treturn _selector_run( 'row', selector, run, settings, opts );\n\t};\n\t\n\t\n\t_api_register( 'rows()', function ( selector, opts ) {\n\t\t// argument shifting\n\t\tif ( selector === undefined ) {\n\t\t\tselector = '';\n\t\t}\n\t\telse if ( $.isPlainObject( selector ) ) {\n\t\t\topts = selector;\n\t\t\tselector = '';\n\t\t}\n\t\n\t\topts = _selector_opts( opts );\n\t\n\t\tvar inst = this.iterator( 'table', function ( settings ) {\n\t\t\treturn __row_selector( settings, selector, opts );\n\t\t}, 1 );\n\t\n\t\t// Want argument shifting here and in __row_selector?\n\t\tinst.selector.rows = selector;\n\t\tinst.selector.opts = opts;\n\t\n\t\treturn inst;\n\t} );\n\t\n\t_api_register( 'rows().nodes()', function () {\n\t\treturn this.iterator( 'row', function ( settings, row ) {\n\t\t\treturn settings.aoData[ row ].nTr || undefined;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_register( 'rows().data()', function () {\n\t\treturn this.iterator( true, 'rows', function ( settings, rows ) {\n\t\t\treturn _pluck_order( settings.aoData, rows, '_aData' );\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'rows().cache()', 'row().cache()', function ( type ) {\n\t\treturn this.iterator( 'row', function ( settings, row ) {\n\t\t\tvar r = settings.aoData[ row ];\n\t\t\treturn type === 'search' ? r._aFilterData : r._aSortData;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'rows().invalidate()', 'row().invalidate()', function ( src ) {\n\t\treturn this.iterator( 'row', function ( settings, row ) {\n\t\t\t_fnInvalidate( settings, row, src );\n\t\t} );\n\t} );\n\t\n\t_api_registerPlural( 'rows().indexes()', 'row().index()', function () {\n\t\treturn this.iterator( 'row', function ( settings, row ) {\n\t\t\treturn row;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'rows().ids()', 'row().id()', function ( hash ) {\n\t\tvar a = [];\n\t\tvar context = this.context;\n\t\n\t\t// `iterator` will drop undefined values, but in this case we want them\n\t\tfor ( var i=0, ien=context.length ; i<ien ; i++ ) {\n\t\t\tfor ( var j=0, jen=this[i].length ; j<jen ; j++ ) {\n\t\t\t\tvar id = context[i].rowIdFn( context[i].aoData[ this[i][j] ]._aData );\n\t\t\t\ta.push( (hash === true ? '#' : '' )+ id );\n\t\t\t}\n\t\t}\n\t\n\t\treturn new _Api( context, a );\n\t} );\n\t\n\t_api_registerPlural( 'rows().remove()', 'row().remove()', function () {\n\t\tvar that = this;\n\t\n\t\tthis.iterator( 'row', function ( settings, row, thatIdx ) {\n\t\t\tvar data = settings.aoData;\n\t\t\tvar rowData = data[ row ];\n\t\t\tvar i, ien, j, jen;\n\t\t\tvar loopRow, loopCells;\n\t\n\t\t\tdata.splice( row, 1 );\n\t\n\t\t\t// Update the cached indexes\n\t\t\tfor ( i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t\tloopRow = data[i];\n\t\t\t\tloopCells = loopRow.anCells;\n\t\n\t\t\t\t// Rows\n\t\t\t\tif ( loopRow.nTr !== null ) {\n\t\t\t\t\tloopRow.nTr._DT_RowIndex = i;\n\t\t\t\t}\n\t\n\t\t\t\t// Cells\n\t\t\t\tif ( loopCells !== null ) {\n\t\t\t\t\tfor ( j=0, jen=loopCells.length ; j<jen ; j++ ) {\n\t\t\t\t\t\tloopCells[j]._DT_CellIndex.row = i;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// Delete from the display arrays\n\t\t\t_fnDeleteIndex( settings.aiDisplayMaster, row );\n\t\t\t_fnDeleteIndex( settings.aiDisplay, row );\n\t\t\t_fnDeleteIndex( that[ thatIdx ], row, false ); // maintain local indexes\n\t\n\t\t\t// Check for an 'overflow' they case for displaying the table\n\t\t\t_fnLengthOverflow( settings );\n\t\n\t\t\t// Remove the row's ID reference if there is one\n\t\t\tvar id = settings.rowIdFn( rowData._aData );\n\t\t\tif ( id !== undefined ) {\n\t\t\t\tdelete settings.aIds[ id ];\n\t\t\t}\n\t\t} );\n\t\n\t\tthis.iterator( 'table', function ( settings ) {\n\t\t\tfor ( var i=0, ien=settings.aoData.length ; i<ien ; i++ ) {\n\t\t\t\tsettings.aoData[i].idx = i;\n\t\t\t}\n\t\t} );\n\t\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( 'rows.add()', function ( rows ) {\n\t\tvar newRows = this.iterator( 'table', function ( settings ) {\n\t\t\t\tvar row, i, ien;\n\t\t\t\tvar out = [];\n\t\n\t\t\t\tfor ( i=0, ien=rows.length ; i<ien ; i++ ) {\n\t\t\t\t\trow = rows[i];\n\t\n\t\t\t\t\tif ( row.nodeName && row.nodeName.toUpperCase() === 'TR' ) {\n\t\t\t\t\t\tout.push( _fnAddTr( settings, row )[0] );\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tout.push( _fnAddData( settings, row ) );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\treturn out;\n\t\t\t}, 1 );\n\t\n\t\t// Return an Api.rows() extended instance, so rows().nodes() etc can be used\n\t\tvar modRows = this.rows( -1 );\n\t\tmodRows.pop();\n\t\t$.merge( modRows, newRows );\n\t\n\t\treturn modRows;\n\t} );\n\t\n\t\n\t\n\t\n\t\n\t/**\n\t *\n\t */\n\t_api_register( 'row()', function ( selector, opts ) {\n\t\treturn _selector_first( this.rows( selector, opts ) );\n\t} );\n\t\n\t\n\t_api_register( 'row().data()', function ( data ) {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( data === undefined ) {\n\t\t\t// Get\n\t\t\treturn ctx.length && this.length ?\n\t\t\t\tctx[0].aoData[ this[0] ]._aData :\n\t\t\t\tundefined;\n\t\t}\n\t\n\t\t// Set\n\t\tctx[0].aoData[ this[0] ]._aData = data;\n\t\n\t\t// Automatically invalidate\n\t\t_fnInvalidate( ctx[0], this[0], 'data' );\n\t\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( 'row().node()', function () {\n\t\tvar ctx = this.context;\n\t\n\t\treturn ctx.length && this.length ?\n\t\t\tctx[0].aoData[ this[0] ].nTr || null :\n\t\t\tnull;\n\t} );\n\t\n\t\n\t_api_register( 'row.add()', function ( row ) {\n\t\t// Allow a jQuery object to be passed in - only a single row is added from\n\t\t// it though - the first element in the set\n\t\tif ( row instanceof $ && row.length ) {\n\t\t\trow = row[0];\n\t\t}\n\t\n\t\tvar rows = this.iterator( 'table', function ( settings ) {\n\t\t\tif ( row.nodeName && row.nodeName.toUpperCase() === 'TR' ) {\n\t\t\t\treturn _fnAddTr( settings, row )[0];\n\t\t\t}\n\t\t\treturn _fnAddData( settings, row );\n\t\t} );\n\t\n\t\t// Return an Api.rows() extended instance, with the newly added row selected\n\t\treturn this.row( rows[0] );\n\t} );\n\t\n\t\n\t\n\tvar __details_add = function ( ctx, row, data, klass )\n\t{\n\t\t// Convert to array of TR elements\n\t\tvar rows = [];\n\t\tvar addRow = function ( r, k ) {\n\t\t\t// Recursion to allow for arrays of jQuery objects\n\t\t\tif ( $.isArray( r ) || r instanceof $ ) {\n\t\t\t\tfor ( var i=0, ien=r.length ; i<ien ; i++ ) {\n\t\t\t\t\taddRow( r[i], k );\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\t\n\t\t\t// If we get a TR element, then just add it directly - up to the dev\n\t\t\t// to add the correct number of columns etc\n\t\t\tif ( r.nodeName && r.nodeName.toLowerCase() === 'tr' ) {\n\t\t\t\trows.push( r );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Otherwise create a row with a wrapper\n\t\t\t\tvar created = $('<tr><td/></tr>').addClass( k );\n\t\t\t\t$('td', created)\n\t\t\t\t\t.addClass( k )\n\t\t\t\t\t.html( r )\n\t\t\t\t\t[0].colSpan = _fnVisbleColumns( ctx );\n\t\n\t\t\t\trows.push( created[0] );\n\t\t\t}\n\t\t};\n\t\n\t\taddRow( data, klass );\n\t\n\t\tif ( row._details ) {\n\t\t\trow._details.remove();\n\t\t}\n\t\n\t\trow._details = $(rows);\n\t\n\t\t// If the children were already shown, that state should be retained\n\t\tif ( row._detailsShow ) {\n\t\t\trow._details.insertAfter( row.nTr );\n\t\t}\n\t};\n\t\n\t\n\tvar __details_remove = function ( api, idx )\n\t{\n\t\tvar ctx = api.context;\n\t\n\t\tif ( ctx.length ) {\n\t\t\tvar row = ctx[0].aoData[ idx !== undefined ? idx : api[0] ];\n\t\n\t\t\tif ( row && row._details ) {\n\t\t\t\trow._details.remove();\n\t\n\t\t\t\trow._detailsShow = undefined;\n\t\t\t\trow._details = undefined;\n\t\t\t}\n\t\t}\n\t};\n\t\n\t\n\tvar __details_display = function ( api, show ) {\n\t\tvar ctx = api.context;\n\t\n\t\tif ( ctx.length && api.length ) {\n\t\t\tvar row = ctx[0].aoData[ api[0] ];\n\t\n\t\t\tif ( row._details ) {\n\t\t\t\trow._detailsShow = show;\n\t\n\t\t\t\tif ( show ) {\n\t\t\t\t\trow._details.insertAfter( row.nTr );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\trow._details.detach();\n\t\t\t\t}\n\t\n\t\t\t\t__details_events( ctx[0] );\n\t\t\t}\n\t\t}\n\t};\n\t\n\t\n\tvar __details_events = function ( settings )\n\t{\n\t\tvar api = new _Api( settings );\n\t\tvar namespace = '.dt.DT_details';\n\t\tvar drawEvent = 'draw'+namespace;\n\t\tvar colvisEvent = 'column-visibility'+namespace;\n\t\tvar destroyEvent = 'destroy'+namespace;\n\t\tvar data = settings.aoData;\n\t\n\t\tapi.off( drawEvent +' '+ colvisEvent +' '+ destroyEvent );\n\t\n\t\tif ( _pluck( data, '_details' ).length > 0 ) {\n\t\t\t// On each draw, insert the required elements into the document\n\t\t\tapi.on( drawEvent, function ( e, ctx ) {\n\t\t\t\tif ( settings !== ctx ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\n\t\t\t\tapi.rows( {page:'current'} ).eq(0).each( function (idx) {\n\t\t\t\t\t// Internal data grab\n\t\t\t\t\tvar row = data[ idx ];\n\t\n\t\t\t\t\tif ( row._detailsShow ) {\n\t\t\t\t\t\trow._details.insertAfter( row.nTr );\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t} );\n\t\n\t\t\t// Column visibility change - update the colspan\n\t\t\tapi.on( colvisEvent, function ( e, ctx, idx, vis ) {\n\t\t\t\tif ( settings !== ctx ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\n\t\t\t\t// Update the colspan for the details rows (note, only if it already has\n\t\t\t\t// a colspan)\n\t\t\t\tvar row, visible = _fnVisbleColumns( ctx );\n\t\n\t\t\t\tfor ( var i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t\t\trow = data[i];\n\t\n\t\t\t\t\tif ( row._details ) {\n\t\t\t\t\t\trow._details.children('td[colspan]').attr('colspan', visible );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} );\n\t\n\t\t\t// Table destroyed - nuke any child rows\n\t\t\tapi.on( destroyEvent, function ( e, ctx ) {\n\t\t\t\tif ( settings !== ctx ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\n\t\t\t\tfor ( var i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t\t\tif ( data[i]._details ) {\n\t\t\t\t\t\t__details_remove( api, i );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} );\n\t\t}\n\t};\n\t\n\t// Strings for the method names to help minification\n\tvar _emp = '';\n\tvar _child_obj = _emp+'row().child';\n\tvar _child_mth = _child_obj+'()';\n\t\n\t// data can be:\n\t// tr\n\t// string\n\t// jQuery or array of any of the above\n\t_api_register( _child_mth, function ( data, klass ) {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( data === undefined ) {\n\t\t\t// get\n\t\t\treturn ctx.length && this.length ?\n\t\t\t\tctx[0].aoData[ this[0] ]._details :\n\t\t\t\tundefined;\n\t\t}\n\t\telse if ( data === true ) {\n\t\t\t// show\n\t\t\tthis.child.show();\n\t\t}\n\t\telse if ( data === false ) {\n\t\t\t// remove\n\t\t\t__details_remove( this );\n\t\t}\n\t\telse if ( ctx.length && this.length ) {\n\t\t\t// set\n\t\t\t__details_add( ctx[0], ctx[0].aoData[ this[0] ], data, klass );\n\t\t}\n\t\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( [\n\t\t_child_obj+'.show()',\n\t\t_child_mth+'.show()' // only when `child()` was called with parameters (without\n\t], function ( show ) { // it returns an object and this method is not executed)\n\t\t__details_display( this, true );\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( [\n\t\t_child_obj+'.hide()',\n\t\t_child_mth+'.hide()' // only when `child()` was called with parameters (without\n\t], function () { // it returns an object and this method is not executed)\n\t\t__details_display( this, false );\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( [\n\t\t_child_obj+'.remove()',\n\t\t_child_mth+'.remove()' // only when `child()` was called with parameters (without\n\t], function () { // it returns an object and this method is not executed)\n\t\t__details_remove( this );\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( _child_obj+'.isShown()', function () {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( ctx.length && this.length ) {\n\t\t\t// _detailsShown as false or undefined will fall through to return false\n\t\t\treturn ctx[0].aoData[ this[0] ]._detailsShow || false;\n\t\t}\n\t\treturn false;\n\t} );\n\t\n\t\n\t\n\t/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *\n\t * Columns\n\t *\n\t * {integer} - column index (>=0 count from left, <0 count from right)\n\t * \"{integer}:visIdx\" - visible column index (i.e. translate to column index) (>=0 count from left, <0 count from right)\n\t * \"{integer}:visible\" - alias for {integer}:visIdx (>=0 count from left, <0 count from right)\n\t * \"{string}:name\" - column name\n\t * \"{string}\" - jQuery selector on column header nodes\n\t *\n\t */\n\t\n\t// can be an array of these items, comma separated list, or an array of comma\n\t// separated lists\n\t\n\tvar __re_column_selector = /^(.+):(name|visIdx|visible)$/;\n\t\n\t\n\t// r1 and r2 are redundant - but it means that the parameters match for the\n\t// iterator callback in columns().data()\n\tvar __columnData = function ( settings, column, r1, r2, rows ) {\n\t\tvar a = [];\n\t\tfor ( var row=0, ien=rows.length ; row<ien ; row++ ) {\n\t\t\ta.push( _fnGetCellData( settings, rows[row], column ) );\n\t\t}\n\t\treturn a;\n\t};\n\t\n\t\n\tvar __column_selector = function ( settings, selector, opts )\n\t{\n\t\tvar\n\t\t\tcolumns = settings.aoColumns,\n\t\t\tnames = _pluck( columns, 'sName' ),\n\t\t\tnodes = _pluck( columns, 'nTh' );\n\t\n\t\tvar run = function ( s ) {\n\t\t\tvar selInt = _intVal( s );\n\t\n\t\t\t// Selector - all\n\t\t\tif ( s === '' ) {\n\t\t\t\treturn _range( columns.length );\n\t\t\t}\n\t\n\t\t\t// Selector - index\n\t\t\tif ( selInt !== null ) {\n\t\t\t\treturn [ selInt >= 0 ?\n\t\t\t\t\tselInt : // Count from left\n\t\t\t\t\tcolumns.length + selInt // Count from right (+ because its a negative value)\n\t\t\t\t];\n\t\t\t}\n\t\n\t\t\t// Selector = function\n\t\t\tif ( typeof s === 'function' ) {\n\t\t\t\tvar rows = _selector_row_indexes( settings, opts );\n\t\n\t\t\t\treturn $.map( columns, function (col, idx) {\n\t\t\t\t\treturn s(\n\t\t\t\t\t\t\tidx,\n\t\t\t\t\t\t\t__columnData( settings, idx, 0, 0, rows ),\n\t\t\t\t\t\t\tnodes[ idx ]\n\t\t\t\t\t\t) ? idx : null;\n\t\t\t\t} );\n\t\t\t}\n\t\n\t\t\t// jQuery or string selector\n\t\t\tvar match = typeof s === 'string' ?\n\t\t\t\ts.match( __re_column_selector ) :\n\t\t\t\t'';\n\t\n\t\t\tif ( match ) {\n\t\t\t\tswitch( match[2] ) {\n\t\t\t\t\tcase 'visIdx':\n\t\t\t\t\tcase 'visible':\n\t\t\t\t\t\tvar idx = parseInt( match[1], 10 );\n\t\t\t\t\t\t// Visible index given, convert to column index\n\t\t\t\t\t\tif ( idx < 0 ) {\n\t\t\t\t\t\t\t// Counting from the right\n\t\t\t\t\t\t\tvar visColumns = $.map( columns, function (col,i) {\n\t\t\t\t\t\t\t\treturn col.bVisible ? i : null;\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t\treturn [ visColumns[ visColumns.length + idx ] ];\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// Counting from the left\n\t\t\t\t\t\treturn [ _fnVisibleToColumnIndex( settings, idx ) ];\n\t\n\t\t\t\t\tcase 'name':\n\t\t\t\t\t\t// match by name. `names` is column index complete and in order\n\t\t\t\t\t\treturn $.map( names, function (name, i) {\n\t\t\t\t\t\t\treturn name === match[1] ? i : null;\n\t\t\t\t\t\t} );\n\t\n\t\t\t\t\tdefault:\n\t\t\t\t\t\treturn [];\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// Cell in the table body\n\t\t\tif ( s.nodeName && s._DT_CellIndex ) {\n\t\t\t\treturn [ s._DT_CellIndex.column ];\n\t\t\t}\n\t\n\t\t\t// jQuery selector on the TH elements for the columns\n\t\t\tvar jqResult = $( nodes )\n\t\t\t\t.filter( s )\n\t\t\t\t.map( function () {\n\t\t\t\t\treturn $.inArray( this, nodes ); // `nodes` is column index complete and in order\n\t\t\t\t} )\n\t\t\t\t.toArray();\n\t\n\t\t\tif ( jqResult.length || ! s.nodeName ) {\n\t\t\t\treturn jqResult;\n\t\t\t}\n\t\n\t\t\t// Otherwise a node which might have a `dt-column` data attribute, or be\n\t\t\t// a child or such an element\n\t\t\tvar host = $(s).closest('*[data-dt-column]');\n\t\t\treturn host.length ?\n\t\t\t\t[ host.data('dt-column') ] :\n\t\t\t\t[];\n\t\t};\n\t\n\t\treturn _selector_run( 'column', selector, run, settings, opts );\n\t};\n\t\n\t\n\tvar __setColumnVis = function ( settings, column, vis ) {\n\t\tvar\n\t\t\tcols = settings.aoColumns,\n\t\t\tcol = cols[ column ],\n\t\t\tdata = settings.aoData,\n\t\t\trow, cells, i, ien, tr;\n\t\n\t\t// Get\n\t\tif ( vis === undefined ) {\n\t\t\treturn col.bVisible;\n\t\t}\n\t\n\t\t// Set\n\t\t// No change\n\t\tif ( col.bVisible === vis ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tif ( vis ) {\n\t\t\t// Insert column\n\t\t\t// Need to decide if we should use appendChild or insertBefore\n\t\t\tvar insertBefore = $.inArray( true, _pluck(cols, 'bVisible'), column+1 );\n\t\n\t\t\tfor ( i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t\ttr = data[i].nTr;\n\t\t\t\tcells = data[i].anCells;\n\t\n\t\t\t\tif ( tr ) {\n\t\t\t\t\t// insertBefore can act like appendChild if 2nd arg is null\n\t\t\t\t\ttr.insertBefore( cells[ column ], cells[ insertBefore ] || null );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\t// Remove column\n\t\t\t$( _pluck( settings.aoData, 'anCells', column ) ).detach();\n\t\t}\n\t\n\t\t// Common actions\n\t\tcol.bVisible = vis;\n\t\t_fnDrawHead( settings, settings.aoHeader );\n\t\t_fnDrawHead( settings, settings.aoFooter );\n\t\n\t\t_fnSaveState( settings );\n\t};\n\t\n\t\n\t_api_register( 'columns()', function ( selector, opts ) {\n\t\t// argument shifting\n\t\tif ( selector === undefined ) {\n\t\t\tselector = '';\n\t\t}\n\t\telse if ( $.isPlainObject( selector ) ) {\n\t\t\topts = selector;\n\t\t\tselector = '';\n\t\t}\n\t\n\t\topts = _selector_opts( opts );\n\t\n\t\tvar inst = this.iterator( 'table', function ( settings ) {\n\t\t\treturn __column_selector( settings, selector, opts );\n\t\t}, 1 );\n\t\n\t\t// Want argument shifting here and in _row_selector?\n\t\tinst.selector.cols = selector;\n\t\tinst.selector.opts = opts;\n\t\n\t\treturn inst;\n\t} );\n\t\n\t_api_registerPlural( 'columns().header()', 'column().header()', function ( selector, opts ) {\n\t\treturn this.iterator( 'column', function ( settings, column ) {\n\t\t\treturn settings.aoColumns[column].nTh;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().footer()', 'column().footer()', function ( selector, opts ) {\n\t\treturn this.iterator( 'column', function ( settings, column ) {\n\t\t\treturn settings.aoColumns[column].nTf;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().data()', 'column().data()', function () {\n\t\treturn this.iterator( 'column-rows', __columnData, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().dataSrc()', 'column().dataSrc()', function () {\n\t\treturn this.iterator( 'column', function ( settings, column ) {\n\t\t\treturn settings.aoColumns[column].mData;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().cache()', 'column().cache()', function ( type ) {\n\t\treturn this.iterator( 'column-rows', function ( settings, column, i, j, rows ) {\n\t\t\treturn _pluck_order( settings.aoData, rows,\n\t\t\t\ttype === 'search' ? '_aFilterData' : '_aSortData', column\n\t\t\t);\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().nodes()', 'column().nodes()', function () {\n\t\treturn this.iterator( 'column-rows', function ( settings, column, i, j, rows ) {\n\t\t\treturn _pluck_order( settings.aoData, rows, 'anCells', column ) ;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().visible()', 'column().visible()', function ( vis, calc ) {\n\t\tvar ret = this.iterator( 'column', function ( settings, column ) {\n\t\t\tif ( vis === undefined ) {\n\t\t\t\treturn settings.aoColumns[ column ].bVisible;\n\t\t\t} // else\n\t\t\t__setColumnVis( settings, column, vis );\n\t\t} );\n\t\n\t\t// Group the column visibility changes\n\t\tif ( vis !== undefined ) {\n\t\t\t// Second loop once the first is done for events\n\t\t\tthis.iterator( 'column', function ( settings, column ) {\n\t\t\t\t_fnCallbackFire( settings, null, 'column-visibility', [settings, column, vis, calc] );\n\t\t\t} );\n\t\n\t\t\tif ( calc === undefined || calc ) {\n\t\t\t\tthis.columns.adjust();\n\t\t\t}\n\t\t}\n\t\n\t\treturn ret;\n\t} );\n\t\n\t_api_registerPlural( 'columns().indexes()', 'column().index()', function ( type ) {\n\t\treturn this.iterator( 'column', function ( settings, column ) {\n\t\t\treturn type === 'visible' ?\n\t\t\t\t_fnColumnIndexToVisible( settings, column ) :\n\t\t\t\tcolumn;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_register( 'columns.adjust()', function () {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnAdjustColumnSizing( settings );\n\t\t}, 1 );\n\t} );\n\t\n\t_api_register( 'column.index()', function ( type, idx ) {\n\t\tif ( this.context.length !== 0 ) {\n\t\t\tvar ctx = this.context[0];\n\t\n\t\t\tif ( type === 'fromVisible' || type === 'toData' ) {\n\t\t\t\treturn _fnVisibleToColumnIndex( ctx, idx );\n\t\t\t}\n\t\t\telse if ( type === 'fromData' || type === 'toVisible' ) {\n\t\t\t\treturn _fnColumnIndexToVisible( ctx, idx );\n\t\t\t}\n\t\t}\n\t} );\n\t\n\t_api_register( 'column()', function ( selector, opts ) {\n\t\treturn _selector_first( this.columns( selector, opts ) );\n\t} );\n\t\n\t\n\t\n\tvar __cell_selector = function ( settings, selector, opts )\n\t{\n\t\tvar data = settings.aoData;\n\t\tvar rows = _selector_row_indexes( settings, opts );\n\t\tvar cells = _removeEmpty( _pluck_order( data, rows, 'anCells' ) );\n\t\tvar allCells = $( [].concat.apply([], cells) );\n\t\tvar row;\n\t\tvar columns = settings.aoColumns.length;\n\t\tvar a, i, ien, j, o, host;\n\t\n\t\tvar run = function ( s ) {\n\t\t\tvar fnSelector = typeof s === 'function';\n\t\n\t\t\tif ( s === null || s === undefined || fnSelector ) {\n\t\t\t\t// All cells and function selectors\n\t\t\t\ta = [];\n\t\n\t\t\t\tfor ( i=0, ien=rows.length ; i<ien ; i++ ) {\n\t\t\t\t\trow = rows[i];\n\t\n\t\t\t\t\tfor ( j=0 ; j<columns ; j++ ) {\n\t\t\t\t\t\to = {\n\t\t\t\t\t\t\trow: row,\n\t\t\t\t\t\t\tcolumn: j\n\t\t\t\t\t\t};\n\t\n\t\t\t\t\t\tif ( fnSelector ) {\n\t\t\t\t\t\t\t// Selector - function\n\t\t\t\t\t\t\thost = data[ row ];\n\t\n\t\t\t\t\t\t\tif ( s( o, _fnGetCellData(settings, row, j), host.anCells ? host.anCells[j] : null ) ) {\n\t\t\t\t\t\t\t\ta.push( o );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t// Selector - all\n\t\t\t\t\t\t\ta.push( o );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\treturn a;\n\t\t\t}\n\t\t\t\n\t\t\t// Selector - index\n\t\t\tif ( $.isPlainObject( s ) ) {\n\t\t\t\treturn [s];\n\t\t\t}\n\t\n\t\t\t// Selector - jQuery filtered cells\n\t\t\tvar jqResult = allCells\n\t\t\t\t.filter( s )\n\t\t\t\t.map( function (i, el) {\n\t\t\t\t\treturn { // use a new object, in case someone changes the values\n\t\t\t\t\t\trow: el._DT_CellIndex.row,\n\t\t\t\t\t\tcolumn: el._DT_CellIndex.column\n\t \t\t\t\t};\n\t\t\t\t} )\n\t\t\t\t.toArray();\n\t\n\t\t\tif ( jqResult.length || ! s.nodeName ) {\n\t\t\t\treturn jqResult;\n\t\t\t}\n\t\n\t\t\t// Otherwise the selector is a node, and there is one last option - the\n\t\t\t// element might be a child of an element which has dt-row and dt-column\n\t\t\t// data attributes\n\t\t\thost = $(s).closest('*[data-dt-row]');\n\t\t\treturn host.length ?\n\t\t\t\t[ {\n\t\t\t\t\trow: host.data('dt-row'),\n\t\t\t\t\tcolumn: host.data('dt-column')\n\t\t\t\t} ] :\n\t\t\t\t[];\n\t\t};\n\t\n\t\treturn _selector_run( 'cell', selector, run, settings, opts );\n\t};\n\t\n\t\n\t\n\t\n\t_api_register( 'cells()', function ( rowSelector, columnSelector, opts ) {\n\t\t// Argument shifting\n\t\tif ( $.isPlainObject( rowSelector ) ) {\n\t\t\t// Indexes\n\t\t\tif ( rowSelector.row === undefined ) {\n\t\t\t\t// Selector options in first parameter\n\t\t\t\topts = rowSelector;\n\t\t\t\trowSelector = null;\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Cell index objects in first parameter\n\t\t\t\topts = columnSelector;\n\t\t\t\tcolumnSelector = null;\n\t\t\t}\n\t\t}\n\t\tif ( $.isPlainObject( columnSelector ) ) {\n\t\t\topts = columnSelector;\n\t\t\tcolumnSelector = null;\n\t\t}\n\t\n\t\t// Cell selector\n\t\tif ( columnSelector === null || columnSelector === undefined ) {\n\t\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t\treturn __cell_selector( settings, rowSelector, _selector_opts( opts ) );\n\t\t\t} );\n\t\t}\n\t\n\t\t// Row + column selector\n\t\tvar columns = this.columns( columnSelector, opts );\n\t\tvar rows = this.rows( rowSelector, opts );\n\t\tvar a, i, ien, j, jen;\n\t\n\t\tvar cells = this.iterator( 'table', function ( settings, idx ) {\n\t\t\ta = [];\n\t\n\t\t\tfor ( i=0, ien=rows[idx].length ; i<ien ; i++ ) {\n\t\t\t\tfor ( j=0, jen=columns[idx].length ; j<jen ; j++ ) {\n\t\t\t\t\ta.push( {\n\t\t\t\t\t\trow: rows[idx][i],\n\t\t\t\t\t\tcolumn: columns[idx][j]\n\t\t\t\t\t} );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\treturn a;\n\t\t}, 1 );\n\t\n\t\t$.extend( cells.selector, {\n\t\t\tcols: columnSelector,\n\t\t\trows: rowSelector,\n\t\t\topts: opts\n\t\t} );\n\t\n\t\treturn cells;\n\t} );\n\t\n\t\n\t_api_registerPlural( 'cells().nodes()', 'cell().node()', function () {\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\tvar data = settings.aoData[ row ];\n\t\n\t\t\treturn data && data.anCells ?\n\t\t\t\tdata.anCells[ column ] :\n\t\t\t\tundefined;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_register( 'cells().data()', function () {\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\treturn _fnGetCellData( settings, row, column );\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'cells().cache()', 'cell().cache()', function ( type ) {\n\t\ttype = type === 'search' ? '_aFilterData' : '_aSortData';\n\t\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\treturn settings.aoData[ row ][ type ][ column ];\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'cells().render()', 'cell().render()', function ( type ) {\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\treturn _fnGetCellData( settings, row, column, type );\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'cells().indexes()', 'cell().index()', function () {\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\treturn {\n\t\t\t\trow: row,\n\t\t\t\tcolumn: column,\n\t\t\t\tcolumnVisible: _fnColumnIndexToVisible( settings, column )\n\t\t\t};\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'cells().invalidate()', 'cell().invalidate()', function ( src ) {\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\t_fnInvalidate( settings, row, src, column );\n\t\t} );\n\t} );\n\t\n\t\n\t\n\t_api_register( 'cell()', function ( rowSelector, columnSelector, opts ) {\n\t\treturn _selector_first( this.cells( rowSelector, columnSelector, opts ) );\n\t} );\n\t\n\t\n\t_api_register( 'cell().data()', function ( data ) {\n\t\tvar ctx = this.context;\n\t\tvar cell = this[0];\n\t\n\t\tif ( data === undefined ) {\n\t\t\t// Get\n\t\t\treturn ctx.length && cell.length ?\n\t\t\t\t_fnGetCellData( ctx[0], cell[0].row, cell[0].column ) :\n\t\t\t\tundefined;\n\t\t}\n\t\n\t\t// Set\n\t\t_fnSetCellData( ctx[0], cell[0].row, cell[0].column, data );\n\t\t_fnInvalidate( ctx[0], cell[0].row, 'data', cell[0].column );\n\t\n\t\treturn this;\n\t} );\n\t\n\t\n\t\n\t/**\n\t * Get current ordering (sorting) that has been applied to the table.\n\t *\n\t * @returns {array} 2D array containing the sorting information for the first\n\t * table in the current context. Each element in the parent array represents\n\t * a column being sorted upon (i.e. multi-sorting with two columns would have\n\t * 2 inner arrays). The inner arrays may have 2 or 3 elements. The first is\n\t * the column index that the sorting condition applies to, the second is the\n\t * direction of the sort (`desc` or `asc`) and, optionally, the third is the\n\t * index of the sorting order from the `column.sorting` initialisation array.\n\t *//**\n\t * Set the ordering for the table.\n\t *\n\t * @param {integer} order Column index to sort upon.\n\t * @param {string} direction Direction of the sort to be applied (`asc` or `desc`)\n\t * @returns {DataTables.Api} this\n\t *//**\n\t * Set the ordering for the table.\n\t *\n\t * @param {array} order 1D array of sorting information to be applied.\n\t * @param {array} [...] Optional additional sorting conditions\n\t * @returns {DataTables.Api} this\n\t *//**\n\t * Set the ordering for the table.\n\t *\n\t * @param {array} order 2D array of sorting information to be applied.\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'order()', function ( order, dir ) {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( order === undefined ) {\n\t\t\t// get\n\t\t\treturn ctx.length !== 0 ?\n\t\t\t\tctx[0].aaSorting :\n\t\t\t\tundefined;\n\t\t}\n\t\n\t\t// set\n\t\tif ( typeof order === 'number' ) {\n\t\t\t// Simple column / direction passed in\n\t\t\torder = [ [ order, dir ] ];\n\t\t}\n\t\telse if ( order.length && ! $.isArray( order[0] ) ) {\n\t\t\t// Arguments passed in (list of 1D arrays)\n\t\t\torder = Array.prototype.slice.call( arguments );\n\t\t}\n\t\t// otherwise a 2D array was passed in\n\t\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tsettings.aaSorting = order.slice();\n\t\t} );\n\t} );\n\t\n\t\n\t/**\n\t * Attach a sort listener to an element for a given column\n\t *\n\t * @param {node|jQuery|string} node Identifier for the element(s) to attach the\n\t * listener to. This can take the form of a single DOM node, a jQuery\n\t * collection of nodes or a jQuery selector which will identify the node(s).\n\t * @param {integer} column the column that a click on this node will sort on\n\t * @param {function} [callback] callback function when sort is run\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'order.listener()', function ( node, column, callback ) {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnSortAttachListener( settings, node, column, callback );\n\t\t} );\n\t} );\n\t\n\t\n\t_api_register( 'order.fixed()', function ( set ) {\n\t\tif ( ! set ) {\n\t\t\tvar ctx = this.context;\n\t\t\tvar fixed = ctx.length ?\n\t\t\t\tctx[0].aaSortingFixed :\n\t\t\t\tundefined;\n\t\n\t\t\treturn $.isArray( fixed ) ?\n\t\t\t\t{ pre: fixed } :\n\t\t\t\tfixed;\n\t\t}\n\t\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tsettings.aaSortingFixed = $.extend( true, {}, set );\n\t\t} );\n\t} );\n\t\n\t\n\t// Order by the selected column(s)\n\t_api_register( [\n\t\t'columns().order()',\n\t\t'column().order()'\n\t], function ( dir ) {\n\t\tvar that = this;\n\t\n\t\treturn this.iterator( 'table', function ( settings, i ) {\n\t\t\tvar sort = [];\n\t\n\t\t\t$.each( that[i], function (j, col) {\n\t\t\t\tsort.push( [ col, dir ] );\n\t\t\t} );\n\t\n\t\t\tsettings.aaSorting = sort;\n\t\t} );\n\t} );\n\t\n\t\n\t\n\t_api_register( 'search()', function ( input, regex, smart, caseInsen ) {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( input === undefined ) {\n\t\t\t// get\n\t\t\treturn ctx.length !== 0 ?\n\t\t\t\tctx[0].oPreviousSearch.sSearch :\n\t\t\t\tundefined;\n\t\t}\n\t\n\t\t// set\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tif ( ! settings.oFeatures.bFilter ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\n\t\t\t_fnFilterComplete( settings, $.extend( {}, settings.oPreviousSearch, {\n\t\t\t\t\"sSearch\": input+\"\",\n\t\t\t\t\"bRegex\": regex === null ? false : regex,\n\t\t\t\t\"bSmart\": smart === null ? true : smart,\n\t\t\t\t\"bCaseInsensitive\": caseInsen === null ? true : caseInsen\n\t\t\t} ), 1 );\n\t\t} );\n\t} );\n\t\n\t\n\t_api_registerPlural(\n\t\t'columns().search()',\n\t\t'column().search()',\n\t\tfunction ( input, regex, smart, caseInsen ) {\n\t\t\treturn this.iterator( 'column', function ( settings, column ) {\n\t\t\t\tvar preSearch = settings.aoPreSearchCols;\n\t\n\t\t\t\tif ( input === undefined ) {\n\t\t\t\t\t// get\n\t\t\t\t\treturn preSearch[ column ].sSearch;\n\t\t\t\t}\n\t\n\t\t\t\t// set\n\t\t\t\tif ( ! settings.oFeatures.bFilter ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\n\t\t\t\t$.extend( preSearch[ column ], {\n\t\t\t\t\t\"sSearch\": input+\"\",\n\t\t\t\t\t\"bRegex\": regex === null ? false : regex,\n\t\t\t\t\t\"bSmart\": smart === null ? true : smart,\n\t\t\t\t\t\"bCaseInsensitive\": caseInsen === null ? true : caseInsen\n\t\t\t\t} );\n\t\n\t\t\t\t_fnFilterComplete( settings, settings.oPreviousSearch, 1 );\n\t\t\t} );\n\t\t}\n\t);\n\t\n\t/*\n\t * State API methods\n\t */\n\t\n\t_api_register( 'state()', function () {\n\t\treturn this.context.length ?\n\t\t\tthis.context[0].oSavedState :\n\t\t\tnull;\n\t} );\n\t\n\t\n\t_api_register( 'state.clear()', function () {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t// Save an empty object\n\t\t\tsettings.fnStateSaveCallback.call( settings.oInstance, settings, {} );\n\t\t} );\n\t} );\n\t\n\t\n\t_api_register( 'state.loaded()', function () {\n\t\treturn this.context.length ?\n\t\t\tthis.context[0].oLoadedState :\n\t\t\tnull;\n\t} );\n\t\n\t\n\t_api_register( 'state.save()', function () {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnSaveState( settings );\n\t\t} );\n\t} );\n\t\n\t\n\t\n\t/**\n\t * Provide a common method for plug-ins to check the version of DataTables being\n\t * used, in order to ensure compatibility.\n\t *\n\t * @param {string} version Version string to check for, in the format \"X.Y.Z\".\n\t * Note that the formats \"X\" and \"X.Y\" are also acceptable.\n\t * @returns {boolean} true if this version of DataTables is greater or equal to\n\t * the required version, or false if this version of DataTales is not\n\t * suitable\n\t * @static\n\t * @dtopt API-Static\n\t *\n\t * @example\n\t * alert( $.fn.dataTable.versionCheck( '1.9.0' ) );\n\t */\n\tDataTable.versionCheck = DataTable.fnVersionCheck = function( version )\n\t{\n\t\tvar aThis = DataTable.version.split('.');\n\t\tvar aThat = version.split('.');\n\t\tvar iThis, iThat;\n\t\n\t\tfor ( var i=0, iLen=aThat.length ; i<iLen ; i++ ) {\n\t\t\tiThis = parseInt( aThis[i], 10 ) || 0;\n\t\t\tiThat = parseInt( aThat[i], 10 ) || 0;\n\t\n\t\t\t// Parts are the same, keep comparing\n\t\t\tif (iThis === iThat) {\n\t\t\t\tcontinue;\n\t\t\t}\n\t\n\t\t\t// Parts are different, return immediately\n\t\t\treturn iThis > iThat;\n\t\t}\n\t\n\t\treturn true;\n\t};\n\t\n\t\n\t/**\n\t * Check if a `<table>` node is a DataTable table already or not.\n\t *\n\t * @param {node|jquery|string} table Table node, jQuery object or jQuery\n\t * selector for the table to test. Note that if more than more than one\n\t * table is passed on, only the first will be checked\n\t * @returns {boolean} true the table given is a DataTable, or false otherwise\n\t * @static\n\t * @dtopt API-Static\n\t *\n\t * @example\n\t * if ( ! $.fn.DataTable.isDataTable( '#example' ) ) {\n\t * $('#example').dataTable();\n\t * }\n\t */\n\tDataTable.isDataTable = DataTable.fnIsDataTable = function ( table )\n\t{\n\t\tvar t = $(table).get(0);\n\t\tvar is = false;\n\t\n\t\t$.each( DataTable.settings, function (i, o) {\n\t\t\tvar head = o.nScrollHead ? $('table', o.nScrollHead)[0] : null;\n\t\t\tvar foot = o.nScrollFoot ? $('table', o.nScrollFoot)[0] : null;\n\t\n\t\t\tif ( o.nTable === t || head === t || foot === t ) {\n\t\t\t\tis = true;\n\t\t\t}\n\t\t} );\n\t\n\t\treturn is;\n\t};\n\t\n\t\n\t/**\n\t * Get all DataTable tables that have been initialised - optionally you can\n\t * select to get only currently visible tables.\n\t *\n\t * @param {boolean} [visible=false] Flag to indicate if you want all (default)\n\t * or visible tables only.\n\t * @returns {array} Array of `table` nodes (not DataTable instances) which are\n\t * DataTables\n\t * @static\n\t * @dtopt API-Static\n\t *\n\t * @example\n\t * $.each( $.fn.dataTable.tables(true), function () {\n\t * $(table).DataTable().columns.adjust();\n\t * } );\n\t */\n\tDataTable.tables = DataTable.fnTables = function ( visible )\n\t{\n\t\tvar api = false;\n\t\n\t\tif ( $.isPlainObject( visible ) ) {\n\t\t\tapi = visible.api;\n\t\t\tvisible = visible.visible;\n\t\t}\n\t\n\t\tvar a = $.map( DataTable.settings, function (o) {\n\t\t\tif ( !visible || (visible && $(o.nTable).is(':visible')) ) {\n\t\t\t\treturn o.nTable;\n\t\t\t}\n\t\t} );\n\t\n\t\treturn api ?\n\t\t\tnew _Api( a ) :\n\t\t\ta;\n\t};\n\t\n\t\n\t/**\n\t * Convert from camel case parameters to Hungarian notation. This is made public\n\t * for the extensions to provide the same ability as DataTables core to accept\n\t * either the 1.9 style Hungarian notation, or the 1.10+ style camelCase\n\t * parameters.\n\t *\n\t * @param {object} src The model object which holds all parameters that can be\n\t * mapped.\n\t * @param {object} user The object to convert from camel case to Hungarian.\n\t * @param {boolean} force When set to `true`, properties which already have a\n\t * Hungarian value in the `user` object will be overwritten. Otherwise they\n\t * won't be.\n\t */\n\tDataTable.camelToHungarian = _fnCamelToHungarian;\n\t\n\t\n\t\n\t/**\n\t *\n\t */\n\t_api_register( '$()', function ( selector, opts ) {\n\t\tvar\n\t\t\trows = this.rows( opts ).nodes(), // Get all rows\n\t\t\tjqRows = $(rows);\n\t\n\t\treturn $( [].concat(\n\t\t\tjqRows.filter( selector ).toArray(),\n\t\t\tjqRows.find( selector ).toArray()\n\t\t) );\n\t} );\n\t\n\t\n\t// jQuery functions to operate on the tables\n\t$.each( [ 'on', 'one', 'off' ], function (i, key) {\n\t\t_api_register( key+'()', function ( /* event, handler */ ) {\n\t\t\tvar args = Array.prototype.slice.call(arguments);\n\t\n\t\t\t// Add the `dt` namespace automatically if it isn't already present\n\t\t\tif ( ! args[0].match(/\\.dt\\b/) ) {\n\t\t\t\targs[0] += '.dt';\n\t\t\t}\n\t\n\t\t\tvar inst = $( this.tables().nodes() );\n\t\t\tinst[key].apply( inst, args );\n\t\t\treturn this;\n\t\t} );\n\t} );\n\t\n\t\n\t_api_register( 'clear()', function () {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnClearTable( settings );\n\t\t} );\n\t} );\n\t\n\t\n\t_api_register( 'settings()', function () {\n\t\treturn new _Api( this.context, this.context );\n\t} );\n\t\n\t\n\t_api_register( 'init()', function () {\n\t\tvar ctx = this.context;\n\t\treturn ctx.length ? ctx[0].oInit : null;\n\t} );\n\t\n\t\n\t_api_register( 'data()', function () {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\treturn _pluck( settings.aoData, '_aData' );\n\t\t} ).flatten();\n\t} );\n\t\n\t\n\t_api_register( 'destroy()', function ( remove ) {\n\t\tremove = remove || false;\n\t\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tvar orig = settings.nTableWrapper.parentNode;\n\t\t\tvar classes = settings.oClasses;\n\t\t\tvar table = settings.nTable;\n\t\t\tvar tbody = settings.nTBody;\n\t\t\tvar thead = settings.nTHead;\n\t\t\tvar tfoot = settings.nTFoot;\n\t\t\tvar jqTable = $(table);\n\t\t\tvar jqTbody = $(tbody);\n\t\t\tvar jqWrapper = $(settings.nTableWrapper);\n\t\t\tvar rows = $.map( settings.aoData, function (r) { return r.nTr; } );\n\t\t\tvar i, ien;\n\t\n\t\t\t// Flag to note that the table is currently being destroyed - no action\n\t\t\t// should be taken\n\t\t\tsettings.bDestroying = true;\n\t\n\t\t\t// Fire off the destroy callbacks for plug-ins etc\n\t\t\t_fnCallbackFire( settings, \"aoDestroyCallback\", \"destroy\", [settings] );\n\t\n\t\t\t// If not being removed from the document, make all columns visible\n\t\t\tif ( ! remove ) {\n\t\t\t\tnew _Api( settings ).columns().visible( true );\n\t\t\t}\n\t\n\t\t\t// Blitz all `DT` namespaced events (these are internal events, the\n\t\t\t// lowercase, `dt` events are user subscribed and they are responsible\n\t\t\t// for removing them\n\t\t\tjqWrapper.unbind('.DT').find(':not(tbody *)').unbind('.DT');\n\t\t\t$(window).unbind('.DT-'+settings.sInstance);\n\t\n\t\t\t// When scrolling we had to break the table up - restore it\n\t\t\tif ( table != thead.parentNode ) {\n\t\t\t\tjqTable.children('thead').detach();\n\t\t\t\tjqTable.append( thead );\n\t\t\t}\n\t\n\t\t\tif ( tfoot && table != tfoot.parentNode ) {\n\t\t\t\tjqTable.children('tfoot').detach();\n\t\t\t\tjqTable.append( tfoot );\n\t\t\t}\n\t\n\t\t\tsettings.aaSorting = [];\n\t\t\tsettings.aaSortingFixed = [];\n\t\t\t_fnSortingClasses( settings );\n\t\n\t\t\t$( rows ).removeClass( settings.asStripeClasses.join(' ') );\n\t\n\t\t\t$('th, td', thead).removeClass( classes.sSortable+' '+\n\t\t\t\tclasses.sSortableAsc+' '+classes.sSortableDesc+' '+classes.sSortableNone\n\t\t\t);\n\t\n\t\t\tif ( settings.bJUI ) {\n\t\t\t\t$('th span.'+classes.sSortIcon+ ', td span.'+classes.sSortIcon, thead).detach();\n\t\t\t\t$('th, td', thead).each( function () {\n\t\t\t\t\tvar wrapper = $('div.'+classes.sSortJUIWrapper, this);\n\t\t\t\t\t$(this).append( wrapper.contents() );\n\t\t\t\t\twrapper.detach();\n\t\t\t\t} );\n\t\t\t}\n\t\n\t\t\t// Add the TR elements back into the table in their original order\n\t\t\tjqTbody.children().detach();\n\t\t\tjqTbody.append( rows );\n\t\n\t\t\t// Remove the DataTables generated nodes, events and classes\n\t\t\tvar removedMethod = remove ? 'remove' : 'detach';\n\t\t\tjqTable[ removedMethod ]();\n\t\t\tjqWrapper[ removedMethod ]();\n\t\n\t\t\t// If we need to reattach the table to the document\n\t\t\tif ( ! remove && orig ) {\n\t\t\t\t// insertBefore acts like appendChild if !arg[1]\n\t\t\t\torig.insertBefore( table, settings.nTableReinsertBefore );\n\t\n\t\t\t\t// Restore the width of the original table - was read from the style property,\n\t\t\t\t// so we can restore directly to that\n\t\t\t\tjqTable\n\t\t\t\t\t.css( 'width', settings.sDestroyWidth )\n\t\t\t\t\t.removeClass( classes.sTable );\n\t\n\t\t\t\t// If the were originally stripe classes - then we add them back here.\n\t\t\t\t// Note this is not fool proof (for example if not all rows had stripe\n\t\t\t\t// classes - but it's a good effort without getting carried away\n\t\t\t\tien = settings.asDestroyStripes.length;\n\t\n\t\t\t\tif ( ien ) {\n\t\t\t\t\tjqTbody.children().each( function (i) {\n\t\t\t\t\t\t$(this).addClass( settings.asDestroyStripes[i % ien] );\n\t\t\t\t\t} );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t/* Remove the settings object from the settings array */\n\t\t\tvar idx = $.inArray( settings, DataTable.settings );\n\t\t\tif ( idx !== -1 ) {\n\t\t\t\tDataTable.settings.splice( idx, 1 );\n\t\t\t}\n\t\t} );\n\t} );\n\t\n\t\n\t// Add the `every()` method for rows, columns and cells in a compact form\n\t$.each( [ 'column', 'row', 'cell' ], function ( i, type ) {\n\t\t_api_register( type+'s().every()', function ( fn ) {\n\t\t\tvar opts = this.selector.opts;\n\t\t\tvar api = this;\n\t\n\t\t\treturn this.iterator( type, function ( settings, arg1, arg2, arg3, arg4 ) {\n\t\t\t\t// Rows and columns:\n\t\t\t\t// arg1 - index\n\t\t\t\t// arg2 - table counter\n\t\t\t\t// arg3 - loop counter\n\t\t\t\t// arg4 - undefined\n\t\t\t\t// Cells:\n\t\t\t\t// arg1 - row index\n\t\t\t\t// arg2 - column index\n\t\t\t\t// arg3 - table counter\n\t\t\t\t// arg4 - loop counter\n\t\t\t\tfn.call(\n\t\t\t\t\tapi[ type ](\n\t\t\t\t\t\targ1,\n\t\t\t\t\t\ttype==='cell' ? arg2 : opts,\n\t\t\t\t\t\ttype==='cell' ? opts : undefined\n\t\t\t\t\t),\n\t\t\t\t\targ1, arg2, arg3, arg4\n\t\t\t\t);\n\t\t\t} );\n\t\t} );\n\t} );\n\t\n\t\n\t// i18n method for extensions to be able to use the language object from the\n\t// DataTable\n\t_api_register( 'i18n()', function ( token, def, plural ) {\n\t\tvar ctx = this.context[0];\n\t\tvar resolved = _fnGetObjectDataFn( token )( ctx.oLanguage );\n\t\n\t\tif ( resolved === undefined ) {\n\t\t\tresolved = def;\n\t\t}\n\t\n\t\tif ( plural !== undefined && $.isPlainObject( resolved ) ) {\n\t\t\tresolved = resolved[ plural ] !== undefined ?\n\t\t\t\tresolved[ plural ] :\n\t\t\t\tresolved._;\n\t\t}\n\t\n\t\treturn resolved.replace( '%d', plural ); // nb: plural might be undefined,\n\t} );\n\t/**\n\t * Version string for plug-ins to check compatibility. Allowed format is\n\t * `a.b.c-d` where: a:int, b:int, c:int, d:string(dev|beta|alpha). `d` is used\n\t * only for non-release builds. See http://semver.org/ for more information.\n\t * @member\n\t * @type string\n\t * @default Version number\n\t */\n\tDataTable.version = \"1.10.12\";\n\n\t/**\n\t * Private data store, containing all of the settings objects that are\n\t * created for the tables on a given page.\n\t *\n\t * Note that the `DataTable.settings` object is aliased to\n\t * `jQuery.fn.dataTableExt` through which it may be accessed and\n\t * manipulated, or `jQuery.fn.dataTable.settings`.\n\t * @member\n\t * @type array\n\t * @default []\n\t * @private\n\t */\n\tDataTable.settings = [];\n\n\t/**\n\t * Object models container, for the various models that DataTables has\n\t * available to it. These models define the objects that are used to hold\n\t * the active state and configuration of the table.\n\t * @namespace\n\t */\n\tDataTable.models = {};\n\t\n\t\n\t\n\t/**\n\t * Template object for the way in which DataTables holds information about\n\t * search information for the global filter and individual column filters.\n\t * @namespace\n\t */\n\tDataTable.models.oSearch = {\n\t\t/**\n\t\t * Flag to indicate if the filtering should be case insensitive or not\n\t\t * @type boolean\n\t\t * @default true\n\t\t */\n\t\t\"bCaseInsensitive\": true,\n\t\n\t\t/**\n\t\t * Applied search term\n\t\t * @type string\n\t\t * @default <i>Empty string</i>\n\t\t */\n\t\t\"sSearch\": \"\",\n\t\n\t\t/**\n\t\t * Flag to indicate if the search term should be interpreted as a\n\t\t * regular expression (true) or not (false) and therefore and special\n\t\t * regex characters escaped.\n\t\t * @type boolean\n\t\t * @default false\n\t\t */\n\t\t\"bRegex\": false,\n\t\n\t\t/**\n\t\t * Flag to indicate if DataTables is to use its smart filtering or not.\n\t\t * @type boolean\n\t\t * @default true\n\t\t */\n\t\t\"bSmart\": true\n\t};\n\t\n\t\n\t\n\t\n\t/**\n\t * Template object for the way in which DataTables holds information about\n\t * each individual row. This is the object format used for the settings\n\t * aoData array.\n\t * @namespace\n\t */\n\tDataTable.models.oRow = {\n\t\t/**\n\t\t * TR element for the row\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTr\": null,\n\t\n\t\t/**\n\t\t * Array of TD elements for each row. This is null until the row has been\n\t\t * created.\n\t\t * @type array nodes\n\t\t * @default []\n\t\t */\n\t\t\"anCells\": null,\n\t\n\t\t/**\n\t\t * Data object from the original data source for the row. This is either\n\t\t * an array if using the traditional form of DataTables, or an object if\n\t\t * using mData options. The exact type will depend on the passed in\n\t\t * data from the data source, or will be an array if using DOM a data\n\t\t * source.\n\t\t * @type array|object\n\t\t * @default []\n\t\t */\n\t\t\"_aData\": [],\n\t\n\t\t/**\n\t\t * Sorting data cache - this array is ostensibly the same length as the\n\t\t * number of columns (although each index is generated only as it is\n\t\t * needed), and holds the data that is used for sorting each column in the\n\t\t * row. We do this cache generation at the start of the sort in order that\n\t\t * the formatting of the sort data need be done only once for each cell\n\t\t * per sort. This array should not be read from or written to by anything\n\t\t * other than the master sorting methods.\n\t\t * @type array\n\t\t * @default null\n\t\t * @private\n\t\t */\n\t\t\"_aSortData\": null,\n\t\n\t\t/**\n\t\t * Per cell filtering data cache. As per the sort data cache, used to\n\t\t * increase the performance of the filtering in DataTables\n\t\t * @type array\n\t\t * @default null\n\t\t * @private\n\t\t */\n\t\t\"_aFilterData\": null,\n\t\n\t\t/**\n\t\t * Filtering data cache. This is the same as the cell filtering cache, but\n\t\t * in this case a string rather than an array. This is easily computed with\n\t\t * a join on `_aFilterData`, but is provided as a cache so the join isn't\n\t\t * needed on every search (memory traded for performance)\n\t\t * @type array\n\t\t * @default null\n\t\t * @private\n\t\t */\n\t\t\"_sFilterRow\": null,\n\t\n\t\t/**\n\t\t * Cache of the class name that DataTables has applied to the row, so we\n\t\t * can quickly look at this variable rather than needing to do a DOM check\n\t\t * on className for the nTr property.\n\t\t * @type string\n\t\t * @default <i>Empty string</i>\n\t\t * @private\n\t\t */\n\t\t\"_sRowStripe\": \"\",\n\t\n\t\t/**\n\t\t * Denote if the original data source was from the DOM, or the data source\n\t\t * object. This is used for invalidating data, so DataTables can\n\t\t * automatically read data from the original source, unless uninstructed\n\t\t * otherwise.\n\t\t * @type string\n\t\t * @default null\n\t\t * @private\n\t\t */\n\t\t\"src\": null,\n\t\n\t\t/**\n\t\t * Index in the aoData array. This saves an indexOf lookup when we have the\n\t\t * object, but want to know the index\n\t\t * @type integer\n\t\t * @default -1\n\t\t * @private\n\t\t */\n\t\t\"idx\": -1\n\t};\n\t\n\t\n\t/**\n\t * Template object for the column information object in DataTables. This object\n\t * is held in the settings aoColumns array and contains all the information that\n\t * DataTables needs about each individual column.\n\t *\n\t * Note that this object is related to {@link DataTable.defaults.column}\n\t * but this one is the internal data store for DataTables's cache of columns.\n\t * It should NOT be manipulated outside of DataTables. Any configuration should\n\t * be done through the initialisation options.\n\t * @namespace\n\t */\n\tDataTable.models.oColumn = {\n\t\t/**\n\t\t * Column index. This could be worked out on-the-fly with $.inArray, but it\n\t\t * is faster to just hold it as a variable\n\t\t * @type integer\n\t\t * @default null\n\t\t */\n\t\t\"idx\": null,\n\t\n\t\t/**\n\t\t * A list of the columns that sorting should occur on when this column\n\t\t * is sorted. That this property is an array allows multi-column sorting\n\t\t * to be defined for a column (for example first name / last name columns\n\t\t * would benefit from this). The values are integers pointing to the\n\t\t * columns to be sorted on (typically it will be a single integer pointing\n\t\t * at itself, but that doesn't need to be the case).\n\t\t * @type array\n\t\t */\n\t\t\"aDataSort\": null,\n\t\n\t\t/**\n\t\t * Define the sorting directions that are applied to the column, in sequence\n\t\t * as the column is repeatedly sorted upon - i.e. the first value is used\n\t\t * as the sorting direction when the column if first sorted (clicked on).\n\t\t * Sort it again (click again) and it will move on to the next index.\n\t\t * Repeat until loop.\n\t\t * @type array\n\t\t */\n\t\t\"asSorting\": null,\n\t\n\t\t/**\n\t\t * Flag to indicate if the column is searchable, and thus should be included\n\t\t * in the filtering or not.\n\t\t * @type boolean\n\t\t */\n\t\t\"bSearchable\": null,\n\t\n\t\t/**\n\t\t * Flag to indicate if the column is sortable or not.\n\t\t * @type boolean\n\t\t */\n\t\t\"bSortable\": null,\n\t\n\t\t/**\n\t\t * Flag to indicate if the column is currently visible in the table or not\n\t\t * @type boolean\n\t\t */\n\t\t\"bVisible\": null,\n\t\n\t\t/**\n\t\t * Store for manual type assignment using the `column.type` option. This\n\t\t * is held in store so we can manipulate the column's `sType` property.\n\t\t * @type string\n\t\t * @default null\n\t\t * @private\n\t\t */\n\t\t\"_sManualType\": null,\n\t\n\t\t/**\n\t\t * Flag to indicate if HTML5 data attributes should be used as the data\n\t\t * source for filtering or sorting. True is either are.\n\t\t * @type boolean\n\t\t * @default false\n\t\t * @private\n\t\t */\n\t\t\"_bAttrSrc\": false,\n\t\n\t\t/**\n\t\t * Developer definable function that is called whenever a cell is created (Ajax source,\n\t\t * etc) or processed for input (DOM source). This can be used as a compliment to mRender\n\t\t * allowing you to modify the DOM element (add background colour for example) when the\n\t\t * element is available.\n\t\t * @type function\n\t\t * @param {element} nTd The TD node that has been created\n\t\t * @param {*} sData The Data for the cell\n\t\t * @param {array|object} oData The data for the whole row\n\t\t * @param {int} iRow The row index for the aoData data store\n\t\t * @default null\n\t\t */\n\t\t\"fnCreatedCell\": null,\n\t\n\t\t/**\n\t\t * Function to get data from a cell in a column. You should <b>never</b>\n\t\t * access data directly through _aData internally in DataTables - always use\n\t\t * the method attached to this property. It allows mData to function as\n\t\t * required. This function is automatically assigned by the column\n\t\t * initialisation method\n\t\t * @type function\n\t\t * @param {array|object} oData The data array/object for the array\n\t\t * (i.e. aoData[]._aData)\n\t\t * @param {string} sSpecific The specific data type you want to get -\n\t\t * 'display', 'type' 'filter' 'sort'\n\t\t * @returns {*} The data for the cell from the given row's data\n\t\t * @default null\n\t\t */\n\t\t\"fnGetData\": null,\n\t\n\t\t/**\n\t\t * Function to set data for a cell in the column. You should <b>never</b>\n\t\t * set the data directly to _aData internally in DataTables - always use\n\t\t * this method. It allows mData to function as required. This function\n\t\t * is automatically assigned by the column initialisation method\n\t\t * @type function\n\t\t * @param {array|object} oData The data array/object for the array\n\t\t * (i.e. aoData[]._aData)\n\t\t * @param {*} sValue Value to set\n\t\t * @default null\n\t\t */\n\t\t\"fnSetData\": null,\n\t\n\t\t/**\n\t\t * Property to read the value for the cells in the column from the data\n\t\t * source array / object. If null, then the default content is used, if a\n\t\t * function is given then the return from the function is used.\n\t\t * @type function|int|string|null\n\t\t * @default null\n\t\t */\n\t\t\"mData\": null,\n\t\n\t\t/**\n\t\t * Partner property to mData which is used (only when defined) to get\n\t\t * the data - i.e. it is basically the same as mData, but without the\n\t\t * 'set' option, and also the data fed to it is the result from mData.\n\t\t * This is the rendering method to match the data method of mData.\n\t\t * @type function|int|string|null\n\t\t * @default null\n\t\t */\n\t\t\"mRender\": null,\n\t\n\t\t/**\n\t\t * Unique header TH/TD element for this column - this is what the sorting\n\t\t * listener is attached to (if sorting is enabled.)\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTh\": null,\n\t\n\t\t/**\n\t\t * Unique footer TH/TD element for this column (if there is one). Not used\n\t\t * in DataTables as such, but can be used for plug-ins to reference the\n\t\t * footer for each column.\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTf\": null,\n\t\n\t\t/**\n\t\t * The class to apply to all TD elements in the table's TBODY for the column\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sClass\": null,\n\t\n\t\t/**\n\t\t * When DataTables calculates the column widths to assign to each column,\n\t\t * it finds the longest string in each column and then constructs a\n\t\t * temporary table and reads the widths from that. The problem with this\n\t\t * is that \"mmm\" is much wider then \"iiii\", but the latter is a longer\n\t\t * string - thus the calculation can go wrong (doing it properly and putting\n\t\t * it into an DOM object and measuring that is horribly(!) slow). Thus as\n\t\t * a \"work around\" we provide this option. It will append its value to the\n\t\t * text that is found to be the longest string for the column - i.e. padding.\n\t\t * @type string\n\t\t */\n\t\t\"sContentPadding\": null,\n\t\n\t\t/**\n\t\t * Allows a default value to be given for a column's data, and will be used\n\t\t * whenever a null data source is encountered (this can be because mData\n\t\t * is set to null, or because the data source itself is null).\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sDefaultContent\": null,\n\t\n\t\t/**\n\t\t * Name for the column, allowing reference to the column by name as well as\n\t\t * by index (needs a lookup to work by name).\n\t\t * @type string\n\t\t */\n\t\t\"sName\": null,\n\t\n\t\t/**\n\t\t * Custom sorting data type - defines which of the available plug-ins in\n\t\t * afnSortData the custom sorting will use - if any is defined.\n\t\t * @type string\n\t\t * @default std\n\t\t */\n\t\t\"sSortDataType\": 'std',\n\t\n\t\t/**\n\t\t * Class to be applied to the header element when sorting on this column\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sSortingClass\": null,\n\t\n\t\t/**\n\t\t * Class to be applied to the header element when sorting on this column -\n\t\t * when jQuery UI theming is used.\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sSortingClassJUI\": null,\n\t\n\t\t/**\n\t\t * Title of the column - what is seen in the TH element (nTh).\n\t\t * @type string\n\t\t */\n\t\t\"sTitle\": null,\n\t\n\t\t/**\n\t\t * Column sorting and filtering type\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sType\": null,\n\t\n\t\t/**\n\t\t * Width of the column\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sWidth\": null,\n\t\n\t\t/**\n\t\t * Width of the column when it was first \"encountered\"\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sWidthOrig\": null\n\t};\n\t\n\t\n\t/*\n\t * Developer note: The properties of the object below are given in Hungarian\n\t * notation, that was used as the interface for DataTables prior to v1.10, however\n\t * from v1.10 onwards the primary interface is camel case. In order to avoid\n\t * breaking backwards compatibility utterly with this change, the Hungarian\n\t * version is still, internally the primary interface, but is is not documented\n\t * - hence the @name tags in each doc comment. This allows a Javascript function\n\t * to create a map from Hungarian notation to camel case (going the other direction\n\t * would require each property to be listed, which would at around 3K to the size\n\t * of DataTables, while this method is about a 0.5K hit.\n\t *\n\t * Ultimately this does pave the way for Hungarian notation to be dropped\n\t * completely, but that is a massive amount of work and will break current\n\t * installs (therefore is on-hold until v2).\n\t */\n\t\n\t/**\n\t * Initialisation options that can be given to DataTables at initialisation\n\t * time.\n\t * @namespace\n\t */\n\tDataTable.defaults = {\n\t\t/**\n\t\t * An array of data to use for the table, passed in at initialisation which\n\t\t * will be used in preference to any data which is already in the DOM. This is\n\t\t * particularly useful for constructing tables purely in Javascript, for\n\t\t * example with a custom Ajax call.\n\t\t * @type array\n\t\t * @default null\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.data\n\t\t *\n\t\t * @example\n\t\t * // Using a 2D array data source\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"data\": [\n\t\t * ['Trident', 'Internet Explorer 4.0', 'Win 95+', 4, 'X'],\n\t\t * ['Trident', 'Internet Explorer 5.0', 'Win 95+', 5, 'C'],\n\t\t * ],\n\t\t * \"columns\": [\n\t\t * { \"title\": \"Engine\" },\n\t\t * { \"title\": \"Browser\" },\n\t\t * { \"title\": \"Platform\" },\n\t\t * { \"title\": \"Version\" },\n\t\t * { \"title\": \"Grade\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using an array of objects as a data source (`data`)\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"data\": [\n\t\t * {\n\t\t * \"engine\": \"Trident\",\n\t\t * \"browser\": \"Internet Explorer 4.0\",\n\t\t * \"platform\": \"Win 95+\",\n\t\t * \"version\": 4,\n\t\t * \"grade\": \"X\"\n\t\t * },\n\t\t * {\n\t\t * \"engine\": \"Trident\",\n\t\t * \"browser\": \"Internet Explorer 5.0\",\n\t\t * \"platform\": \"Win 95+\",\n\t\t * \"version\": 5,\n\t\t * \"grade\": \"C\"\n\t\t * }\n\t\t * ],\n\t\t * \"columns\": [\n\t\t * { \"title\": \"Engine\", \"data\": \"engine\" },\n\t\t * { \"title\": \"Browser\", \"data\": \"browser\" },\n\t\t * { \"title\": \"Platform\", \"data\": \"platform\" },\n\t\t * { \"title\": \"Version\", \"data\": \"version\" },\n\t\t * { \"title\": \"Grade\", \"data\": \"grade\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"aaData\": null,\n\t\n\t\n\t\t/**\n\t\t * If ordering is enabled, then DataTables will perform a first pass sort on\n\t\t * initialisation. You can define which column(s) the sort is performed\n\t\t * upon, and the sorting direction, with this variable. The `sorting` array\n\t\t * should contain an array for each column to be sorted initially containing\n\t\t * the column's index and a direction string ('asc' or 'desc').\n\t\t * @type array\n\t\t * @default [[0,'asc']]\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.order\n\t\t *\n\t\t * @example\n\t\t * // Sort by 3rd column first, and then 4th column\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"order\": [[2,'asc'], [3,'desc']]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * // No initial sorting\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"order\": []\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"aaSorting\": [[0,'asc']],\n\t\n\t\n\t\t/**\n\t\t * This parameter is basically identical to the `sorting` parameter, but\n\t\t * cannot be overridden by user interaction with the table. What this means\n\t\t * is that you could have a column (visible or hidden) which the sorting\n\t\t * will always be forced on first - any sorting after that (from the user)\n\t\t * will then be performed as required. This can be useful for grouping rows\n\t\t * together.\n\t\t * @type array\n\t\t * @default null\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.orderFixed\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"orderFixed\": [[0,'asc']]\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"aaSortingFixed\": [],\n\t\n\t\n\t\t/**\n\t\t * DataTables can be instructed to load data to display in the table from a\n\t\t * Ajax source. This option defines how that Ajax call is made and where to.\n\t\t *\n\t\t * The `ajax` property has three different modes of operation, depending on\n\t\t * how it is defined. These are:\n\t\t *\n\t\t * * `string` - Set the URL from where the data should be loaded from.\n\t\t * * `object` - Define properties for `jQuery.ajax`.\n\t\t * * `function` - Custom data get function\n\t\t *\n\t\t * `string`\n\t\t * --------\n\t\t *\n\t\t * As a string, the `ajax` property simply defines the URL from which\n\t\t * DataTables will load data.\n\t\t *\n\t\t * `object`\n\t\t * --------\n\t\t *\n\t\t * As an object, the parameters in the object are passed to\n\t\t * [jQuery.ajax](http://api.jquery.com/jQuery.ajax/) allowing fine control\n\t\t * of the Ajax request. DataTables has a number of default parameters which\n\t\t * you can override using this option. Please refer to the jQuery\n\t\t * documentation for a full description of the options available, although\n\t\t * the following parameters provide additional options in DataTables or\n\t\t * require special consideration:\n\t\t *\n\t\t * * `data` - As with jQuery, `data` can be provided as an object, but it\n\t\t * can also be used as a function to manipulate the data DataTables sends\n\t\t * to the server. The function takes a single parameter, an object of\n\t\t * parameters with the values that DataTables has readied for sending. An\n\t\t * object may be returned which will be merged into the DataTables\n\t\t * defaults, or you can add the items to the object that was passed in and\n\t\t * not return anything from the function. This supersedes `fnServerParams`\n\t\t * from DataTables 1.9-.\n\t\t *\n\t\t * * `dataSrc` - By default DataTables will look for the property `data` (or\n\t\t * `aaData` for compatibility with DataTables 1.9-) when obtaining data\n\t\t * from an Ajax source or for server-side processing - this parameter\n\t\t * allows that property to be changed. You can use Javascript dotted\n\t\t * object notation to get a data source for multiple levels of nesting, or\n\t\t * it my be used as a function. As a function it takes a single parameter,\n\t\t * the JSON returned from the server, which can be manipulated as\n\t\t * required, with the returned value being that used by DataTables as the\n\t\t * data source for the table. This supersedes `sAjaxDataProp` from\n\t\t * DataTables 1.9-.\n\t\t *\n\t\t * * `success` - Should not be overridden it is used internally in\n\t\t * DataTables. To manipulate / transform the data returned by the server\n\t\t * use `ajax.dataSrc`, or use `ajax` as a function (see below).\n\t\t *\n\t\t * `function`\n\t\t * ----------\n\t\t *\n\t\t * As a function, making the Ajax call is left up to yourself allowing\n\t\t * complete control of the Ajax request. Indeed, if desired, a method other\n\t\t * than Ajax could be used to obtain the required data, such as Web storage\n\t\t * or an AIR database.\n\t\t *\n\t\t * The function is given four parameters and no return is required. The\n\t\t * parameters are:\n\t\t *\n\t\t * 1. _object_ - Data to send to the server\n\t\t * 2. _function_ - Callback function that must be executed when the required\n\t\t * data has been obtained. That data should be passed into the callback\n\t\t * as the only parameter\n\t\t * 3. _object_ - DataTables settings object for the table\n\t\t *\n\t\t * Note that this supersedes `fnServerData` from DataTables 1.9-.\n\t\t *\n\t\t * @type string|object|function\n\t\t * @default null\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.ajax\n\t\t * @since 1.10.0\n\t\t *\n\t\t * @example\n\t\t * // Get JSON data from a file via Ajax.\n\t\t * // Note DataTables expects data in the form `{ data: [ ...data... ] }` by default).\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": \"data.json\"\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Get JSON data from a file via Ajax, using `dataSrc` to change\n\t\t * // `data` to `tableData` (i.e. `{ tableData: [ ...data... ] }`)\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": {\n\t\t * \"url\": \"data.json\",\n\t\t * \"dataSrc\": \"tableData\"\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Get JSON data from a file via Ajax, using `dataSrc` to read data\n\t\t * // from a plain array rather than an array in an object\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": {\n\t\t * \"url\": \"data.json\",\n\t\t * \"dataSrc\": \"\"\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Manipulate the data returned from the server - add a link to data\n\t\t * // (note this can, should, be done using `render` for the column - this\n\t\t * // is just a simple example of how the data can be manipulated).\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": {\n\t\t * \"url\": \"data.json\",\n\t\t * \"dataSrc\": function ( json ) {\n\t\t * for ( var i=0, ien=json.length ; i<ien ; i++ ) {\n\t\t * json[i][0] = '<a href=\"/message/'+json[i][0]+'>View message</a>';\n\t\t * }\n\t\t * return json;\n\t\t * }\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Add data to the request\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": {\n\t\t * \"url\": \"data.json\",\n\t\t * \"data\": function ( d ) {\n\t\t * return {\n\t\t * \"extra_search\": $('#extra').val()\n\t\t * };\n\t\t * }\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Send request as POST\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": {\n\t\t * \"url\": \"data.json\",\n\t\t * \"type\": \"POST\"\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Get the data from localStorage (could interface with a form for\n\t\t * // adding, editing and removing rows).\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": function (data, callback, settings) {\n\t\t * callback(\n\t\t * JSON.parse( localStorage.getItem('dataTablesData') )\n\t\t * );\n\t\t * }\n\t\t * } );\n\t\t */\n\t\t\"ajax\": null,\n\t\n\t\n\t\t/**\n\t\t * This parameter allows you to readily specify the entries in the length drop\n\t\t * down menu that DataTables shows when pagination is enabled. It can be\n\t\t * either a 1D array of options which will be used for both the displayed\n\t\t * option and the value, or a 2D array which will use the array in the first\n\t\t * position as the value, and the array in the second position as the\n\t\t * displayed options (useful for language strings such as 'All').\n\t\t *\n\t\t * Note that the `pageLength` property will be automatically set to the\n\t\t * first value given in this array, unless `pageLength` is also provided.\n\t\t * @type array\n\t\t * @default [ 10, 25, 50, 100 ]\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.lengthMenu\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"lengthMenu\": [[10, 25, 50, -1], [10, 25, 50, \"All\"]]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"aLengthMenu\": [ 10, 25, 50, 100 ],\n\t\n\t\n\t\t/**\n\t\t * The `columns` option in the initialisation parameter allows you to define\n\t\t * details about the way individual columns behave. For a full list of\n\t\t * column options that can be set, please see\n\t\t * {@link DataTable.defaults.column}. Note that if you use `columns` to\n\t\t * define your columns, you must have an entry in the array for every single\n\t\t * column that you have in your table (these can be null if you don't which\n\t\t * to specify any options).\n\t\t * @member\n\t\t *\n\t\t * @name DataTable.defaults.column\n\t\t */\n\t\t\"aoColumns\": null,\n\t\n\t\t/**\n\t\t * Very similar to `columns`, `columnDefs` allows you to target a specific\n\t\t * column, multiple columns, or all columns, using the `targets` property of\n\t\t * each object in the array. This allows great flexibility when creating\n\t\t * tables, as the `columnDefs` arrays can be of any length, targeting the\n\t\t * columns you specifically want. `columnDefs` may use any of the column\n\t\t * options available: {@link DataTable.defaults.column}, but it _must_\n\t\t * have `targets` defined in each object in the array. Values in the `targets`\n\t\t * array may be:\n\t\t * <ul>\n\t\t * <li>a string - class name will be matched on the TH for the column</li>\n\t\t * <li>0 or a positive integer - column index counting from the left</li>\n\t\t * <li>a negative integer - column index counting from the right</li>\n\t\t * <li>the string \"_all\" - all columns (i.e. assign a default)</li>\n\t\t * </ul>\n\t\t * @member\n\t\t *\n\t\t * @name DataTable.defaults.columnDefs\n\t\t */\n\t\t\"aoColumnDefs\": null,\n\t\n\t\n\t\t/**\n\t\t * Basically the same as `search`, this parameter defines the individual column\n\t\t * filtering state at initialisation time. The array must be of the same size\n\t\t * as the number of columns, and each element be an object with the parameters\n\t\t * `search` and `escapeRegex` (the latter is optional). 'null' is also\n\t\t * accepted and the default will be used.\n\t\t * @type array\n\t\t * @default []\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.searchCols\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"searchCols\": [\n\t\t * null,\n\t\t * { \"search\": \"My filter\" },\n\t\t * null,\n\t\t * { \"search\": \"^[0-9]\", \"escapeRegex\": false }\n\t\t * ]\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"aoSearchCols\": [],\n\t\n\t\n\t\t/**\n\t\t * An array of CSS classes that should be applied to displayed rows. This\n\t\t * array may be of any length, and DataTables will apply each class\n\t\t * sequentially, looping when required.\n\t\t * @type array\n\t\t * @default null <i>Will take the values determined by the `oClasses.stripe*`\n\t\t * options</i>\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.stripeClasses\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stripeClasses\": [ 'strip1', 'strip2', 'strip3' ]\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"asStripeClasses\": null,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable automatic column width calculation. This can be disabled\n\t\t * as an optimisation (it takes some time to calculate the widths) if the\n\t\t * tables widths are passed in using `columns`.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.autoWidth\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"autoWidth\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bAutoWidth\": true,\n\t\n\t\n\t\t/**\n\t\t * Deferred rendering can provide DataTables with a huge speed boost when you\n\t\t * are using an Ajax or JS data source for the table. This option, when set to\n\t\t * true, will cause DataTables to defer the creation of the table elements for\n\t\t * each row until they are needed for a draw - saving a significant amount of\n\t\t * time.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.deferRender\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": \"sources/arrays.txt\",\n\t\t * \"deferRender\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bDeferRender\": false,\n\t\n\t\n\t\t/**\n\t\t * Replace a DataTable which matches the given selector and replace it with\n\t\t * one which has the properties of the new initialisation object passed. If no\n\t\t * table matches the selector, then the new DataTable will be constructed as\n\t\t * per normal.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.destroy\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"srollY\": \"200px\",\n\t\t * \"paginate\": false\n\t\t * } );\n\t\t *\n\t\t * // Some time later....\n\t\t * $('#example').dataTable( {\n\t\t * \"filter\": false,\n\t\t * \"destroy\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bDestroy\": false,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable filtering of data. Filtering in DataTables is \"smart\" in\n\t\t * that it allows the end user to input multiple words (space separated) and\n\t\t * will match a row containing those words, even if not in the order that was\n\t\t * specified (this allow matching across multiple columns). Note that if you\n\t\t * wish to use filtering in DataTables this must remain 'true' - to remove the\n\t\t * default filtering input box and retain filtering abilities, please use\n\t\t * {@link DataTable.defaults.dom}.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.searching\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"searching\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bFilter\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable the table information display. This shows information\n\t\t * about the data that is currently visible on the page, including information\n\t\t * about filtered data if that action is being performed.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.info\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"info\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bInfo\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable jQuery UI ThemeRoller support (required as ThemeRoller requires some\n\t\t * slightly different and additional mark-up from what DataTables has\n\t\t * traditionally used).\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.jQueryUI\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"jQueryUI\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bJQueryUI\": false,\n\t\n\t\n\t\t/**\n\t\t * Allows the end user to select the size of a formatted page from a select\n\t\t * menu (sizes are 10, 25, 50 and 100). Requires pagination (`paginate`).\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.lengthChange\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"lengthChange\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bLengthChange\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable pagination.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.paging\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"paging\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bPaginate\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable the display of a 'processing' indicator when the table is\n\t\t * being processed (e.g. a sort). This is particularly useful for tables with\n\t\t * large amounts of data where it can take a noticeable amount of time to sort\n\t\t * the entries.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.processing\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"processing\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bProcessing\": false,\n\t\n\t\n\t\t/**\n\t\t * Retrieve the DataTables object for the given selector. Note that if the\n\t\t * table has already been initialised, this parameter will cause DataTables\n\t\t * to simply return the object that has already been set up - it will not take\n\t\t * account of any changes you might have made to the initialisation object\n\t\t * passed to DataTables (setting this parameter to true is an acknowledgement\n\t\t * that you understand this). `destroy` can be used to reinitialise a table if\n\t\t * you need.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.retrieve\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * initTable();\n\t\t * tableActions();\n\t\t * } );\n\t\t *\n\t\t * function initTable ()\n\t\t * {\n\t\t * return $('#example').dataTable( {\n\t\t * \"scrollY\": \"200px\",\n\t\t * \"paginate\": false,\n\t\t * \"retrieve\": true\n\t\t * } );\n\t\t * }\n\t\t *\n\t\t * function tableActions ()\n\t\t * {\n\t\t * var table = initTable();\n\t\t * // perform API operations with oTable\n\t\t * }\n\t\t */\n\t\t\"bRetrieve\": false,\n\t\n\t\n\t\t/**\n\t\t * When vertical (y) scrolling is enabled, DataTables will force the height of\n\t\t * the table's viewport to the given height at all times (useful for layout).\n\t\t * However, this can look odd when filtering data down to a small data set,\n\t\t * and the footer is left \"floating\" further down. This parameter (when\n\t\t * enabled) will cause DataTables to collapse the table's viewport down when\n\t\t * the result set will fit within the given Y height.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.scrollCollapse\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"scrollY\": \"200\",\n\t\t * \"scrollCollapse\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bScrollCollapse\": false,\n\t\n\t\n\t\t/**\n\t\t * Configure DataTables to use server-side processing. Note that the\n\t\t * `ajax` parameter must also be given in order to give DataTables a\n\t\t * source to obtain the required data for each draw.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Features\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.serverSide\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"serverSide\": true,\n\t\t * \"ajax\": \"xhr.php\"\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bServerSide\": false,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable sorting of columns. Sorting of individual columns can be\n\t\t * disabled by the `sortable` option for each column.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.ordering\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"ordering\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bSort\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or display DataTables' ability to sort multiple columns at the\n\t\t * same time (activated by shift-click by the user).\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.orderMulti\n\t\t *\n\t\t * @example\n\t\t * // Disable multiple column sorting ability\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"orderMulti\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bSortMulti\": true,\n\t\n\t\n\t\t/**\n\t\t * Allows control over whether DataTables should use the top (true) unique\n\t\t * cell that is found for a single column, or the bottom (false - default).\n\t\t * This is useful when using complex headers.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.orderCellsTop\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"orderCellsTop\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bSortCellsTop\": false,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable the addition of the classes `sorting\\_1`, `sorting\\_2` and\n\t\t * `sorting\\_3` to the columns which are currently being sorted on. This is\n\t\t * presented as a feature switch as it can increase processing time (while\n\t\t * classes are removed and added) so for large data sets you might want to\n\t\t * turn this off.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.orderClasses\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"orderClasses\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bSortClasses\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable state saving. When enabled HTML5 `localStorage` will be\n\t\t * used to save table display information such as pagination information,\n\t\t * display length, filtering and sorting. As such when the end user reloads\n\t\t * the page the display display will match what thy had previously set up.\n\t\t *\n\t\t * Due to the use of `localStorage` the default state saving is not supported\n\t\t * in IE6 or 7. If state saving is required in those browsers, use\n\t\t * `stateSaveCallback` to provide a storage solution such as cookies.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.stateSave\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bStateSave\": false,\n\t\n\t\n\t\t/**\n\t\t * This function is called when a TR element is created (and all TD child\n\t\t * elements have been inserted), or registered if using a DOM source, allowing\n\t\t * manipulation of the TR element (adding classes etc).\n\t\t * @type function\n\t\t * @param {node} row \"TR\" element for the current row\n\t\t * @param {array} data Raw data array for this row\n\t\t * @param {int} dataIndex The index of this row in the internal aoData array\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.createdRow\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"createdRow\": function( row, data, dataIndex ) {\n\t\t * // Bold the grade for all 'A' grade browsers\n\t\t * if ( data[4] == \"A\" )\n\t\t * {\n\t\t * $('td:eq(4)', row).html( '<b>A</b>' );\n\t\t * }\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnCreatedRow\": null,\n\t\n\t\n\t\t/**\n\t\t * This function is called on every 'draw' event, and allows you to\n\t\t * dynamically modify any aspect you want about the created DOM.\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.drawCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"drawCallback\": function( settings ) {\n\t\t * alert( 'DataTables has redrawn the table' );\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnDrawCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * Identical to fnHeaderCallback() but for the table footer this function\n\t\t * allows you to modify the table footer on every 'draw' event.\n\t\t * @type function\n\t\t * @param {node} foot \"TR\" element for the footer\n\t\t * @param {array} data Full table data (as derived from the original HTML)\n\t\t * @param {int} start Index for the current display starting point in the\n\t\t * display array\n\t\t * @param {int} end Index for the current display ending point in the\n\t\t * display array\n\t\t * @param {array int} display Index array to translate the visual position\n\t\t * to the full data array\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.footerCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"footerCallback\": function( tfoot, data, start, end, display ) {\n\t\t * tfoot.getElementsByTagName('th')[0].innerHTML = \"Starting index is \"+start;\n\t\t * }\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"fnFooterCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * When rendering large numbers in the information element for the table\n\t\t * (i.e. \"Showing 1 to 10 of 57 entries\") DataTables will render large numbers\n\t\t * to have a comma separator for the 'thousands' units (e.g. 1 million is\n\t\t * rendered as \"1,000,000\") to help readability for the end user. This\n\t\t * function will override the default method DataTables uses.\n\t\t * @type function\n\t\t * @member\n\t\t * @param {int} toFormat number to be formatted\n\t\t * @returns {string} formatted string for DataTables to show the number\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.formatNumber\n\t\t *\n\t\t * @example\n\t\t * // Format a number using a single quote for the separator (note that\n\t\t * // this can also be done with the language.thousands option)\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"formatNumber\": function ( toFormat ) {\n\t\t * return toFormat.toString().replace(\n\t\t * /\\B(?=(\\d{3})+(?!\\d))/g, \"'\"\n\t\t * );\n\t\t * };\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnFormatNumber\": function ( toFormat ) {\n\t\t\treturn toFormat.toString().replace(\n\t\t\t\t/\\B(?=(\\d{3})+(?!\\d))/g,\n\t\t\t\tthis.oLanguage.sThousands\n\t\t\t);\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * This function is called on every 'draw' event, and allows you to\n\t\t * dynamically modify the header row. This can be used to calculate and\n\t\t * display useful information about the table.\n\t\t * @type function\n\t\t * @param {node} head \"TR\" element for the header\n\t\t * @param {array} data Full table data (as derived from the original HTML)\n\t\t * @param {int} start Index for the current display starting point in the\n\t\t * display array\n\t\t * @param {int} end Index for the current display ending point in the\n\t\t * display array\n\t\t * @param {array int} display Index array to translate the visual position\n\t\t * to the full data array\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.headerCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"fheaderCallback\": function( head, data, start, end, display ) {\n\t\t * head.getElementsByTagName('th')[0].innerHTML = \"Displaying \"+(end-start)+\" records\";\n\t\t * }\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"fnHeaderCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * The information element can be used to convey information about the current\n\t\t * state of the table. Although the internationalisation options presented by\n\t\t * DataTables are quite capable of dealing with most customisations, there may\n\t\t * be times where you wish to customise the string further. This callback\n\t\t * allows you to do exactly that.\n\t\t * @type function\n\t\t * @param {object} oSettings DataTables settings object\n\t\t * @param {int} start Starting position in data for the draw\n\t\t * @param {int} end End position in data for the draw\n\t\t * @param {int} max Total number of rows in the table (regardless of\n\t\t * filtering)\n\t\t * @param {int} total Total number of rows in the data set, after filtering\n\t\t * @param {string} pre The string that DataTables has formatted using it's\n\t\t * own rules\n\t\t * @returns {string} The string to be displayed in the information element.\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.infoCallback\n\t\t *\n\t\t * @example\n\t\t * $('#example').dataTable( {\n\t\t * \"infoCallback\": function( settings, start, end, max, total, pre ) {\n\t\t * return start +\" to \"+ end;\n\t\t * }\n\t\t * } );\n\t\t */\n\t\t\"fnInfoCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * Called when the table has been initialised. Normally DataTables will\n\t\t * initialise sequentially and there will be no need for this function,\n\t\t * however, this does not hold true when using external language information\n\t\t * since that is obtained using an async XHR call.\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t * @param {object} json The JSON object request from the server - only\n\t\t * present if client-side Ajax sourced data is used\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.initComplete\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"initComplete\": function(settings, json) {\n\t\t * alert( 'DataTables has finished its initialisation.' );\n\t\t * }\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"fnInitComplete\": null,\n\t\n\t\n\t\t/**\n\t\t * Called at the very start of each table draw and can be used to cancel the\n\t\t * draw by returning false, any other return (including undefined) results in\n\t\t * the full draw occurring).\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t * @returns {boolean} False will cancel the draw, anything else (including no\n\t\t * return) will allow it to complete.\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.preDrawCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"preDrawCallback\": function( settings ) {\n\t\t * if ( $('#test').val() == 1 ) {\n\t\t * return false;\n\t\t * }\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnPreDrawCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * This function allows you to 'post process' each row after it have been\n\t\t * generated for each table draw, but before it is rendered on screen. This\n\t\t * function might be used for setting the row class name etc.\n\t\t * @type function\n\t\t * @param {node} row \"TR\" element for the current row\n\t\t * @param {array} data Raw data array for this row\n\t\t * @param {int} displayIndex The display index for the current table draw\n\t\t * @param {int} displayIndexFull The index of the data in the full list of\n\t\t * rows (after filtering)\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.rowCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"rowCallback\": function( row, data, displayIndex, displayIndexFull ) {\n\t\t * // Bold the grade for all 'A' grade browsers\n\t\t * if ( data[4] == \"A\" ) {\n\t\t * $('td:eq(4)', row).html( '<b>A</b>' );\n\t\t * }\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnRowCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * __Deprecated__ The functionality provided by this parameter has now been\n\t\t * superseded by that provided through `ajax`, which should be used instead.\n\t\t *\n\t\t * This parameter allows you to override the default function which obtains\n\t\t * the data from the server so something more suitable for your application.\n\t\t * For example you could use POST data, or pull information from a Gears or\n\t\t * AIR database.\n\t\t * @type function\n\t\t * @member\n\t\t * @param {string} source HTTP source to obtain the data from (`ajax`)\n\t\t * @param {array} data A key/value pair object containing the data to send\n\t\t * to the server\n\t\t * @param {function} callback to be called on completion of the data get\n\t\t * process that will draw the data on the page.\n\t\t * @param {object} settings DataTables settings object\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.serverData\n\t\t *\n\t\t * @deprecated 1.10. Please use `ajax` for this functionality now.\n\t\t */\n\t\t\"fnServerData\": null,\n\t\n\t\n\t\t/**\n\t\t * __Deprecated__ The functionality provided by this parameter has now been\n\t\t * superseded by that provided through `ajax`, which should be used instead.\n\t\t *\n\t\t * It is often useful to send extra data to the server when making an Ajax\n\t\t * request - for example custom filtering information, and this callback\n\t\t * function makes it trivial to send extra information to the server. The\n\t\t * passed in parameter is the data set that has been constructed by\n\t\t * DataTables, and you can add to this or modify it as you require.\n\t\t * @type function\n\t\t * @param {array} data Data array (array of objects which are name/value\n\t\t * pairs) that has been constructed by DataTables and will be sent to the\n\t\t * server. In the case of Ajax sourced data with server-side processing\n\t\t * this will be an empty array, for server-side processing there will be a\n\t\t * significant number of parameters!\n\t\t * @returns {undefined} Ensure that you modify the data array passed in,\n\t\t * as this is passed by reference.\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.serverParams\n\t\t *\n\t\t * @deprecated 1.10. Please use `ajax` for this functionality now.\n\t\t */\n\t\t\"fnServerParams\": null,\n\t\n\t\n\t\t/**\n\t\t * Load the table state. With this function you can define from where, and how, the\n\t\t * state of a table is loaded. By default DataTables will load from `localStorage`\n\t\t * but you might wish to use a server-side database or cookies.\n\t\t * @type function\n\t\t * @member\n\t\t * @param {object} settings DataTables settings object\n\t\t * @return {object} The DataTables state object to be loaded\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.stateLoadCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateLoadCallback\": function (settings) {\n\t\t * var o;\n\t\t *\n\t\t * // Send an Ajax request to the server to get the data. Note that\n\t\t * // this is a synchronous request.\n\t\t * $.ajax( {\n\t\t * \"url\": \"/state_load\",\n\t\t * \"async\": false,\n\t\t * \"dataType\": \"json\",\n\t\t * \"success\": function (json) {\n\t\t * o = json;\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * return o;\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnStateLoadCallback\": function ( settings ) {\n\t\t\ttry {\n\t\t\t\treturn JSON.parse(\n\t\t\t\t\t(settings.iStateDuration === -1 ? sessionStorage : localStorage).getItem(\n\t\t\t\t\t\t'DataTables_'+settings.sInstance+'_'+location.pathname\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\t} catch (e) {}\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Callback which allows modification of the saved state prior to loading that state.\n\t\t * This callback is called when the table is loading state from the stored data, but\n\t\t * prior to the settings object being modified by the saved state. Note that for\n\t\t * plug-in authors, you should use the `stateLoadParams` event to load parameters for\n\t\t * a plug-in.\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t * @param {object} data The state object that is to be loaded\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.stateLoadParams\n\t\t *\n\t\t * @example\n\t\t * // Remove a saved filter, so filtering is never loaded\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateLoadParams\": function (settings, data) {\n\t\t * data.oSearch.sSearch = \"\";\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Disallow state loading by returning false\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateLoadParams\": function (settings, data) {\n\t\t * return false;\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnStateLoadParams\": null,\n\t\n\t\n\t\t/**\n\t\t * Callback that is called when the state has been loaded from the state saving method\n\t\t * and the DataTables settings object has been modified as a result of the loaded state.\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t * @param {object} data The state object that was loaded\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.stateLoaded\n\t\t *\n\t\t * @example\n\t\t * // Show an alert with the filtering value that was saved\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateLoaded\": function (settings, data) {\n\t\t * alert( 'Saved filter was: '+data.oSearch.sSearch );\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnStateLoaded\": null,\n\t\n\t\n\t\t/**\n\t\t * Save the table state. This function allows you to define where and how the state\n\t\t * information for the table is stored By default DataTables will use `localStorage`\n\t\t * but you might wish to use a server-side database or cookies.\n\t\t * @type function\n\t\t * @member\n\t\t * @param {object} settings DataTables settings object\n\t\t * @param {object} data The state object to be saved\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.stateSaveCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateSaveCallback\": function (settings, data) {\n\t\t * // Send an Ajax request to the server with the state object\n\t\t * $.ajax( {\n\t\t * \"url\": \"/state_save\",\n\t\t * \"data\": data,\n\t\t * \"dataType\": \"json\",\n\t\t * \"method\": \"POST\"\n\t\t * \"success\": function () {}\n\t\t * } );\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnStateSaveCallback\": function ( settings, data ) {\n\t\t\ttry {\n\t\t\t\t(settings.iStateDuration === -1 ? sessionStorage : localStorage).setItem(\n\t\t\t\t\t'DataTables_'+settings.sInstance+'_'+location.pathname,\n\t\t\t\t\tJSON.stringify( data )\n\t\t\t\t);\n\t\t\t} catch (e) {}\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Callback which allows modification of the state to be saved. Called when the table\n\t\t * has changed state a new state save is required. This method allows modification of\n\t\t * the state saving object prior to actually doing the save, including addition or\n\t\t * other state properties or modification. Note that for plug-in authors, you should\n\t\t * use the `stateSaveParams` event to save parameters for a plug-in.\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t * @param {object} data The state object to be saved\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.stateSaveParams\n\t\t *\n\t\t * @example\n\t\t * // Remove a saved filter, so filtering is never saved\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateSaveParams\": function (settings, data) {\n\t\t * data.oSearch.sSearch = \"\";\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnStateSaveParams\": null,\n\t\n\t\n\t\t/**\n\t\t * Duration for which the saved state information is considered valid. After this period\n\t\t * has elapsed the state will be returned to the default.\n\t\t * Value is given in seconds.\n\t\t * @type int\n\t\t * @default 7200 <i>(2 hours)</i>\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.stateDuration\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateDuration\": 60*60*24; // 1 day\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"iStateDuration\": 7200,\n\t\n\t\n\t\t/**\n\t\t * When enabled DataTables will not make a request to the server for the first\n\t\t * page draw - rather it will use the data already on the page (no sorting etc\n\t\t * will be applied to it), thus saving on an XHR at load time. `deferLoading`\n\t\t * is used to indicate that deferred loading is required, but it is also used\n\t\t * to tell DataTables how many records there are in the full table (allowing\n\t\t * the information element and pagination to be displayed correctly). In the case\n\t\t * where a filtering is applied to the table on initial load, this can be\n\t\t * indicated by giving the parameter as an array, where the first element is\n\t\t * the number of records available after filtering and the second element is the\n\t\t * number of records without filtering (allowing the table information element\n\t\t * to be shown correctly).\n\t\t * @type int | array\n\t\t * @default null\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.deferLoading\n\t\t *\n\t\t * @example\n\t\t * // 57 records available in the table, no filtering applied\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"serverSide\": true,\n\t\t * \"ajax\": \"scripts/server_processing.php\",\n\t\t * \"deferLoading\": 57\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // 57 records after filtering, 100 without filtering (an initial filter applied)\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"serverSide\": true,\n\t\t * \"ajax\": \"scripts/server_processing.php\",\n\t\t * \"deferLoading\": [ 57, 100 ],\n\t\t * \"search\": {\n\t\t * \"search\": \"my_filter\"\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"iDeferLoading\": null,\n\t\n\t\n\t\t/**\n\t\t * Number of rows to display on a single page when using pagination. If\n\t\t * feature enabled (`lengthChange`) then the end user will be able to override\n\t\t * this to a custom setting using a pop-up menu.\n\t\t * @type int\n\t\t * @default 10\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.pageLength\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"pageLength\": 50\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"iDisplayLength\": 10,\n\t\n\t\n\t\t/**\n\t\t * Define the starting point for data display when using DataTables with\n\t\t * pagination. Note that this parameter is the number of records, rather than\n\t\t * the page number, so if you have 10 records per page and want to start on\n\t\t * the third page, it should be \"20\".\n\t\t * @type int\n\t\t * @default 0\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.displayStart\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"displayStart\": 20\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"iDisplayStart\": 0,\n\t\n\t\n\t\t/**\n\t\t * By default DataTables allows keyboard navigation of the table (sorting, paging,\n\t\t * and filtering) by adding a `tabindex` attribute to the required elements. This\n\t\t * allows you to tab through the controls and press the enter key to activate them.\n\t\t * The tabindex is default 0, meaning that the tab follows the flow of the document.\n\t\t * You can overrule this using this parameter if you wish. Use a value of -1 to\n\t\t * disable built-in keyboard navigation.\n\t\t * @type int\n\t\t * @default 0\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.tabIndex\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"tabIndex\": 1\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"iTabIndex\": 0,\n\t\n\t\n\t\t/**\n\t\t * Classes that DataTables assigns to the various components and features\n\t\t * that it adds to the HTML table. This allows classes to be configured\n\t\t * during initialisation in addition to through the static\n\t\t * {@link DataTable.ext.oStdClasses} object).\n\t\t * @namespace\n\t\t * @name DataTable.defaults.classes\n\t\t */\n\t\t\"oClasses\": {},\n\t\n\t\n\t\t/**\n\t\t * All strings that DataTables uses in the user interface that it creates\n\t\t * are defined in this object, allowing you to modified them individually or\n\t\t * completely replace them all as required.\n\t\t * @namespace\n\t\t * @name DataTable.defaults.language\n\t\t */\n\t\t\"oLanguage\": {\n\t\t\t/**\n\t\t\t * Strings that are used for WAI-ARIA labels and controls only (these are not\n\t\t\t * actually visible on the page, but will be read by screenreaders, and thus\n\t\t\t * must be internationalised as well).\n\t\t\t * @namespace\n\t\t\t * @name DataTable.defaults.language.aria\n\t\t\t */\n\t\t\t\"oAria\": {\n\t\t\t\t/**\n\t\t\t\t * ARIA label that is added to the table headers when the column may be\n\t\t\t\t * sorted ascending by activing the column (click or return when focused).\n\t\t\t\t * Note that the column header is prefixed to this string.\n\t\t\t\t * @type string\n\t\t\t\t * @default : activate to sort column ascending\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.aria.sortAscending\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"aria\": {\n\t\t\t\t * \"sortAscending\": \" - click/return to sort ascending\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sSortAscending\": \": activate to sort column ascending\",\n\t\n\t\t\t\t/**\n\t\t\t\t * ARIA label that is added to the table headers when the column may be\n\t\t\t\t * sorted descending by activing the column (click or return when focused).\n\t\t\t\t * Note that the column header is prefixed to this string.\n\t\t\t\t * @type string\n\t\t\t\t * @default : activate to sort column ascending\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.aria.sortDescending\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"aria\": {\n\t\t\t\t * \"sortDescending\": \" - click/return to sort descending\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sSortDescending\": \": activate to sort column descending\"\n\t\t\t},\n\t\n\t\t\t/**\n\t\t\t * Pagination string used by DataTables for the built-in pagination\n\t\t\t * control types.\n\t\t\t * @namespace\n\t\t\t * @name DataTable.defaults.language.paginate\n\t\t\t */\n\t\t\t\"oPaginate\": {\n\t\t\t\t/**\n\t\t\t\t * Text to use when using the 'full_numbers' type of pagination for the\n\t\t\t\t * button to take the user to the first page.\n\t\t\t\t * @type string\n\t\t\t\t * @default First\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.paginate.first\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"paginate\": {\n\t\t\t\t * \"first\": \"First page\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sFirst\": \"First\",\n\t\n\t\n\t\t\t\t/**\n\t\t\t\t * Text to use when using the 'full_numbers' type of pagination for the\n\t\t\t\t * button to take the user to the last page.\n\t\t\t\t * @type string\n\t\t\t\t * @default Last\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.paginate.last\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"paginate\": {\n\t\t\t\t * \"last\": \"Last page\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sLast\": \"Last\",\n\t\n\t\n\t\t\t\t/**\n\t\t\t\t * Text to use for the 'next' pagination button (to take the user to the\n\t\t\t\t * next page).\n\t\t\t\t * @type string\n\t\t\t\t * @default Next\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.paginate.next\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"paginate\": {\n\t\t\t\t * \"next\": \"Next page\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sNext\": \"Next\",\n\t\n\t\n\t\t\t\t/**\n\t\t\t\t * Text to use for the 'previous' pagination button (to take the user to\n\t\t\t\t * the previous page).\n\t\t\t\t * @type string\n\t\t\t\t * @default Previous\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.paginate.previous\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"paginate\": {\n\t\t\t\t * \"previous\": \"Previous page\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sPrevious\": \"Previous\"\n\t\t\t},\n\t\n\t\t\t/**\n\t\t\t * This string is shown in preference to `zeroRecords` when the table is\n\t\t\t * empty of data (regardless of filtering). Note that this is an optional\n\t\t\t * parameter - if it is not given, the value of `zeroRecords` will be used\n\t\t\t * instead (either the default or given value).\n\t\t\t * @type string\n\t\t\t * @default No data available in table\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.emptyTable\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"emptyTable\": \"No data available in table\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sEmptyTable\": \"No data available in table\",\n\t\n\t\n\t\t\t/**\n\t\t\t * This string gives information to the end user about the information\n\t\t\t * that is current on display on the page. The following tokens can be\n\t\t\t * used in the string and will be dynamically replaced as the table\n\t\t\t * display updates. This tokens can be placed anywhere in the string, or\n\t\t\t * removed as needed by the language requires:\n\t\t\t *\n\t\t\t * * `\\_START\\_` - Display index of the first record on the current page\n\t\t\t * * `\\_END\\_` - Display index of the last record on the current page\n\t\t\t * * `\\_TOTAL\\_` - Number of records in the table after filtering\n\t\t\t * * `\\_MAX\\_` - Number of records in the table without filtering\n\t\t\t * * `\\_PAGE\\_` - Current page number\n\t\t\t * * `\\_PAGES\\_` - Total number of pages of data in the table\n\t\t\t *\n\t\t\t * @type string\n\t\t\t * @default Showing _START_ to _END_ of _TOTAL_ entries\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.info\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"info\": \"Showing page _PAGE_ of _PAGES_\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sInfo\": \"Showing _START_ to _END_ of _TOTAL_ entries\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Display information string for when the table is empty. Typically the\n\t\t\t * format of this string should match `info`.\n\t\t\t * @type string\n\t\t\t * @default Showing 0 to 0 of 0 entries\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.infoEmpty\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"infoEmpty\": \"No entries to show\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sInfoEmpty\": \"Showing 0 to 0 of 0 entries\",\n\t\n\t\n\t\t\t/**\n\t\t\t * When a user filters the information in a table, this string is appended\n\t\t\t * to the information (`info`) to give an idea of how strong the filtering\n\t\t\t * is. The variable _MAX_ is dynamically updated.\n\t\t\t * @type string\n\t\t\t * @default (filtered from _MAX_ total entries)\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.infoFiltered\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"infoFiltered\": \" - filtering from _MAX_ records\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sInfoFiltered\": \"(filtered from _MAX_ total entries)\",\n\t\n\t\n\t\t\t/**\n\t\t\t * If can be useful to append extra information to the info string at times,\n\t\t\t * and this variable does exactly that. This information will be appended to\n\t\t\t * the `info` (`infoEmpty` and `infoFiltered` in whatever combination they are\n\t\t\t * being used) at all times.\n\t\t\t * @type string\n\t\t\t * @default <i>Empty string</i>\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.infoPostFix\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"infoPostFix\": \"All records shown are derived from real information.\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sInfoPostFix\": \"\",\n\t\n\t\n\t\t\t/**\n\t\t\t * This decimal place operator is a little different from the other\n\t\t\t * language options since DataTables doesn't output floating point\n\t\t\t * numbers, so it won't ever use this for display of a number. Rather,\n\t\t\t * what this parameter does is modify the sort methods of the table so\n\t\t\t * that numbers which are in a format which has a character other than\n\t\t\t * a period (`.`) as a decimal place will be sorted numerically.\n\t\t\t *\n\t\t\t * Note that numbers with different decimal places cannot be shown in\n\t\t\t * the same table and still be sortable, the table must be consistent.\n\t\t\t * However, multiple different tables on the page can use different\n\t\t\t * decimal place characters.\n\t\t\t * @type string\n\t\t\t * @default \n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.decimal\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"decimal\": \",\"\n\t\t\t * \"thousands\": \".\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sDecimal\": \"\",\n\t\n\t\n\t\t\t/**\n\t\t\t * DataTables has a build in number formatter (`formatNumber`) which is\n\t\t\t * used to format large numbers that are used in the table information.\n\t\t\t * By default a comma is used, but this can be trivially changed to any\n\t\t\t * character you wish with this parameter.\n\t\t\t * @type string\n\t\t\t * @default ,\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.thousands\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"thousands\": \"'\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sThousands\": \",\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Detail the action that will be taken when the drop down menu for the\n\t\t\t * pagination length option is changed. The '_MENU_' variable is replaced\n\t\t\t * with a default select list of 10, 25, 50 and 100, and can be replaced\n\t\t\t * with a custom select box if required.\n\t\t\t * @type string\n\t\t\t * @default Show _MENU_ entries\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.lengthMenu\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Language change only\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"lengthMenu\": \"Display _MENU_ records\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Language and options change\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"lengthMenu\": 'Display <select>'+\n\t\t\t * '<option value=\"10\">10</option>'+\n\t\t\t * '<option value=\"20\">20</option>'+\n\t\t\t * '<option value=\"30\">30</option>'+\n\t\t\t * '<option value=\"40\">40</option>'+\n\t\t\t * '<option value=\"50\">50</option>'+\n\t\t\t * '<option value=\"-1\">All</option>'+\n\t\t\t * '</select> records'\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sLengthMenu\": \"Show _MENU_ entries\",\n\t\n\t\n\t\t\t/**\n\t\t\t * When using Ajax sourced data and during the first draw when DataTables is\n\t\t\t * gathering the data, this message is shown in an empty row in the table to\n\t\t\t * indicate to the end user the the data is being loaded. Note that this\n\t\t\t * parameter is not used when loading data by server-side processing, just\n\t\t\t * Ajax sourced data with client-side processing.\n\t\t\t * @type string\n\t\t\t * @default Loading...\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.loadingRecords\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"loadingRecords\": \"Please wait - loading...\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sLoadingRecords\": \"Loading...\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Text which is displayed when the table is processing a user action\n\t\t\t * (usually a sort command or similar).\n\t\t\t * @type string\n\t\t\t * @default Processing...\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.processing\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"processing\": \"DataTables is currently busy\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sProcessing\": \"Processing...\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Details the actions that will be taken when the user types into the\n\t\t\t * filtering input text box. The variable \"_INPUT_\", if used in the string,\n\t\t\t * is replaced with the HTML text box for the filtering input allowing\n\t\t\t * control over where it appears in the string. If \"_INPUT_\" is not given\n\t\t\t * then the input box is appended to the string automatically.\n\t\t\t * @type string\n\t\t\t * @default Search:\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.search\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Input text box will be appended at the end automatically\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"search\": \"Filter records:\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Specify where the filter should appear\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"search\": \"Apply filter _INPUT_ to table\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sSearch\": \"Search:\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Assign a `placeholder` attribute to the search `input` element\n\t\t\t * @type string\n\t\t\t * @default \n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.searchPlaceholder\n\t\t\t */\n\t\t\t\"sSearchPlaceholder\": \"\",\n\t\n\t\n\t\t\t/**\n\t\t\t * All of the language information can be stored in a file on the\n\t\t\t * server-side, which DataTables will look up if this parameter is passed.\n\t\t\t * It must store the URL of the language file, which is in a JSON format,\n\t\t\t * and the object has the same properties as the oLanguage object in the\n\t\t\t * initialiser object (i.e. the above parameters). Please refer to one of\n\t\t\t * the example language files to see how this works in action.\n\t\t\t * @type string\n\t\t\t * @default <i>Empty string - i.e. disabled</i>\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.url\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"url\": \"http://www.sprymedia.co.uk/dataTables/lang.txt\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sUrl\": \"\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Text shown inside the table records when the is no information to be\n\t\t\t * displayed after filtering. `emptyTable` is shown when there is simply no\n\t\t\t * information in the table at all (regardless of filtering).\n\t\t\t * @type string\n\t\t\t * @default No matching records found\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.zeroRecords\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"zeroRecords\": \"No records to display\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sZeroRecords\": \"No matching records found\"\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * This parameter allows you to have define the global filtering state at\n\t\t * initialisation time. As an object the `search` parameter must be\n\t\t * defined, but all other parameters are optional. When `regex` is true,\n\t\t * the search string will be treated as a regular expression, when false\n\t\t * (default) it will be treated as a straight string. When `smart`\n\t\t * DataTables will use it's smart filtering methods (to word match at\n\t\t * any point in the data), when false this will not be done.\n\t\t * @namespace\n\t\t * @extends DataTable.models.oSearch\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.search\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"search\": {\"search\": \"Initial search\"}\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"oSearch\": $.extend( {}, DataTable.models.oSearch ),\n\t\n\t\n\t\t/**\n\t\t * __Deprecated__ The functionality provided by this parameter has now been\n\t\t * superseded by that provided through `ajax`, which should be used instead.\n\t\t *\n\t\t * By default DataTables will look for the property `data` (or `aaData` for\n\t\t * compatibility with DataTables 1.9-) when obtaining data from an Ajax\n\t\t * source or for server-side processing - this parameter allows that\n\t\t * property to be changed. You can use Javascript dotted object notation to\n\t\t * get a data source for multiple levels of nesting.\n\t\t * @type string\n\t\t * @default data\n\t\t *\n\t\t * @dtopt Options\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.ajaxDataProp\n\t\t *\n\t\t * @deprecated 1.10. Please use `ajax` for this functionality now.\n\t\t */\n\t\t\"sAjaxDataProp\": \"data\",\n\t\n\t\n\t\t/**\n\t\t * __Deprecated__ The functionality provided by this parameter has now been\n\t\t * superseded by that provided through `ajax`, which should be used instead.\n\t\t *\n\t\t * You can instruct DataTables to load data from an external\n\t\t * source using this parameter (use aData if you want to pass data in you\n\t\t * already have). Simply provide a url a JSON object can be obtained from.\n\t\t * @type string\n\t\t * @default null\n\t\t *\n\t\t * @dtopt Options\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.ajaxSource\n\t\t *\n\t\t * @deprecated 1.10. Please use `ajax` for this functionality now.\n\t\t */\n\t\t\"sAjaxSource\": null,\n\t\n\t\n\t\t/**\n\t\t * This initialisation variable allows you to specify exactly where in the\n\t\t * DOM you want DataTables to inject the various controls it adds to the page\n\t\t * (for example you might want the pagination controls at the top of the\n\t\t * table). DIV elements (with or without a custom class) can also be added to\n\t\t * aid styling. The follow syntax is used:\n\t\t * <ul>\n\t\t * <li>The following options are allowed:\n\t\t * <ul>\n\t\t * <li>'l' - Length changing</li>\n\t\t * <li>'f' - Filtering input</li>\n\t\t * <li>'t' - The table!</li>\n\t\t * <li>'i' - Information</li>\n\t\t * <li>'p' - Pagination</li>\n\t\t * <li>'r' - pRocessing</li>\n\t\t * </ul>\n\t\t * </li>\n\t\t * <li>The following constants are allowed:\n\t\t * <ul>\n\t\t * <li>'H' - jQueryUI theme \"header\" classes ('fg-toolbar ui-widget-header ui-corner-tl ui-corner-tr ui-helper-clearfix')</li>\n\t\t * <li>'F' - jQueryUI theme \"footer\" classes ('fg-toolbar ui-widget-header ui-corner-bl ui-corner-br ui-helper-clearfix')</li>\n\t\t * </ul>\n\t\t * </li>\n\t\t * <li>The following syntax is expected:\n\t\t * <ul>\n\t\t * <li>'<' and '>' - div elements</li>\n\t\t * <li>'<\"class\" and '>' - div with a class</li>\n\t\t * <li>'<\"#id\" and '>' - div with an ID</li>\n\t\t * </ul>\n\t\t * </li>\n\t\t * <li>Examples:\n\t\t * <ul>\n\t\t * <li>'<\"wrapper\"flipt>'</li>\n\t\t * <li>'<lf<t>ip>'</li>\n\t\t * </ul>\n\t\t * </li>\n\t\t * </ul>\n\t\t * @type string\n\t\t * @default lfrtip <i>(when `jQueryUI` is false)</i> <b>or</b>\n\t\t * <\"H\"lfr>t<\"F\"ip> <i>(when `jQueryUI` is true)</i>\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.dom\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"dom\": '<\"top\"i>rt<\"bottom\"flp><\"clear\">'\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sDom\": \"lfrtip\",\n\t\n\t\n\t\t/**\n\t\t * Search delay option. This will throttle full table searches that use the\n\t\t * DataTables provided search input element (it does not effect calls to\n\t\t * `dt-api search()`, providing a delay before the search is made.\n\t\t * @type integer\n\t\t * @default 0\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.searchDelay\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"searchDelay\": 200\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"searchDelay\": null,\n\t\n\t\n\t\t/**\n\t\t * DataTables features four different built-in options for the buttons to\n\t\t * display for pagination control:\n\t\t *\n\t\t * * `simple` - 'Previous' and 'Next' buttons only\n\t\t * * 'simple_numbers` - 'Previous' and 'Next' buttons, plus page numbers\n\t\t * * `full` - 'First', 'Previous', 'Next' and 'Last' buttons\n\t\t * * `full_numbers` - 'First', 'Previous', 'Next' and 'Last' buttons, plus\n\t\t * page numbers\n\t\t * \n\t\t * Further methods can be added using {@link DataTable.ext.oPagination}.\n\t\t * @type string\n\t\t * @default simple_numbers\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.pagingType\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"pagingType\": \"full_numbers\"\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"sPaginationType\": \"simple_numbers\",\n\t\n\t\n\t\t/**\n\t\t * Enable horizontal scrolling. When a table is too wide to fit into a\n\t\t * certain layout, or you have a large number of columns in the table, you\n\t\t * can enable x-scrolling to show the table in a viewport, which can be\n\t\t * scrolled. This property can be `true` which will allow the table to\n\t\t * scroll horizontally when needed, or any CSS unit, or a number (in which\n\t\t * case it will be treated as a pixel measurement). Setting as simply `true`\n\t\t * is recommended.\n\t\t * @type boolean|string\n\t\t * @default <i>blank string - i.e. disabled</i>\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.scrollX\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"scrollX\": true,\n\t\t * \"scrollCollapse\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sScrollX\": \"\",\n\t\n\t\n\t\t/**\n\t\t * This property can be used to force a DataTable to use more width than it\n\t\t * might otherwise do when x-scrolling is enabled. For example if you have a\n\t\t * table which requires to be well spaced, this parameter is useful for\n\t\t * \"over-sizing\" the table, and thus forcing scrolling. This property can by\n\t\t * any CSS unit, or a number (in which case it will be treated as a pixel\n\t\t * measurement).\n\t\t * @type string\n\t\t * @default <i>blank string - i.e. disabled</i>\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.scrollXInner\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"scrollX\": \"100%\",\n\t\t * \"scrollXInner\": \"110%\"\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sScrollXInner\": \"\",\n\t\n\t\n\t\t/**\n\t\t * Enable vertical scrolling. Vertical scrolling will constrain the DataTable\n\t\t * to the given height, and enable scrolling for any data which overflows the\n\t\t * current viewport. This can be used as an alternative to paging to display\n\t\t * a lot of data in a small area (although paging and scrolling can both be\n\t\t * enabled at the same time). This property can be any CSS unit, or a number\n\t\t * (in which case it will be treated as a pixel measurement).\n\t\t * @type string\n\t\t * @default <i>blank string - i.e. disabled</i>\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.scrollY\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"scrollY\": \"200px\",\n\t\t * \"paginate\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sScrollY\": \"\",\n\t\n\t\n\t\t/**\n\t\t * __Deprecated__ The functionality provided by this parameter has now been\n\t\t * superseded by that provided through `ajax`, which should be used instead.\n\t\t *\n\t\t * Set the HTTP method that is used to make the Ajax call for server-side\n\t\t * processing or Ajax sourced data.\n\t\t * @type string\n\t\t * @default GET\n\t\t *\n\t\t * @dtopt Options\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.serverMethod\n\t\t *\n\t\t * @deprecated 1.10. Please use `ajax` for this functionality now.\n\t\t */\n\t\t\"sServerMethod\": \"GET\",\n\t\n\t\n\t\t/**\n\t\t * DataTables makes use of renderers when displaying HTML elements for\n\t\t * a table. These renderers can be added or modified by plug-ins to\n\t\t * generate suitable mark-up for a site. For example the Bootstrap\n\t\t * integration plug-in for DataTables uses a paging button renderer to\n\t\t * display pagination buttons in the mark-up required by Bootstrap.\n\t\t *\n\t\t * For further information about the renderers available see\n\t\t * DataTable.ext.renderer\n\t\t * @type string|object\n\t\t * @default null\n\t\t *\n\t\t * @name DataTable.defaults.renderer\n\t\t *\n\t\t */\n\t\t\"renderer\": null,\n\t\n\t\n\t\t/**\n\t\t * Set the data property name that DataTables should use to get a row's id\n\t\t * to set as the `id` property in the node.\n\t\t * @type string\n\t\t * @default DT_RowId\n\t\t *\n\t\t * @name DataTable.defaults.rowId\n\t\t */\n\t\t\"rowId\": \"DT_RowId\"\n\t};\n\t\n\t_fnHungarianMap( DataTable.defaults );\n\t\n\t\n\t\n\t/*\n\t * Developer note - See note in model.defaults.js about the use of Hungarian\n\t * notation and camel case.\n\t */\n\t\n\t/**\n\t * Column options that can be given to DataTables at initialisation time.\n\t * @namespace\n\t */\n\tDataTable.defaults.column = {\n\t\t/**\n\t\t * Define which column(s) an order will occur on for this column. This\n\t\t * allows a column's ordering to take multiple columns into account when\n\t\t * doing a sort or use the data from a different column. For example first\n\t\t * name / last name columns make sense to do a multi-column sort over the\n\t\t * two columns.\n\t\t * @type array|int\n\t\t * @default null <i>Takes the value of the column index automatically</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.orderData\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"orderData\": [ 0, 1 ], \"targets\": [ 0 ] },\n\t\t * { \"orderData\": [ 1, 0 ], \"targets\": [ 1 ] },\n\t\t * { \"orderData\": 2, \"targets\": [ 2 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"orderData\": [ 0, 1 ] },\n\t\t * { \"orderData\": [ 1, 0 ] },\n\t\t * { \"orderData\": 2 },\n\t\t * null,\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"aDataSort\": null,\n\t\t\"iDataSort\": -1,\n\t\n\t\n\t\t/**\n\t\t * You can control the default ordering direction, and even alter the\n\t\t * behaviour of the sort handler (i.e. only allow ascending ordering etc)\n\t\t * using this parameter.\n\t\t * @type array\n\t\t * @default [ 'asc', 'desc' ]\n\t\t *\n\t\t * @name DataTable.defaults.column.orderSequence\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"orderSequence\": [ \"asc\" ], \"targets\": [ 1 ] },\n\t\t * { \"orderSequence\": [ \"desc\", \"asc\", \"asc\" ], \"targets\": [ 2 ] },\n\t\t * { \"orderSequence\": [ \"desc\" ], \"targets\": [ 3 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * null,\n\t\t * { \"orderSequence\": [ \"asc\" ] },\n\t\t * { \"orderSequence\": [ \"desc\", \"asc\", \"asc\" ] },\n\t\t * { \"orderSequence\": [ \"desc\" ] },\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"asSorting\": [ 'asc', 'desc' ],\n\t\n\t\n\t\t/**\n\t\t * Enable or disable filtering on the data in this column.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @name DataTable.defaults.column.searchable\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"searchable\": false, \"targets\": [ 0 ] }\n\t\t * ] } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"searchable\": false },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ] } );\n\t\t * } );\n\t\t */\n\t\t\"bSearchable\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable ordering on this column.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @name DataTable.defaults.column.orderable\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"orderable\": false, \"targets\": [ 0 ] }\n\t\t * ] } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"orderable\": false },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ] } );\n\t\t * } );\n\t\t */\n\t\t\"bSortable\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable the display of this column.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @name DataTable.defaults.column.visible\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"visible\": false, \"targets\": [ 0 ] }\n\t\t * ] } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"visible\": false },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ] } );\n\t\t * } );\n\t\t */\n\t\t\"bVisible\": true,\n\t\n\t\n\t\t/**\n\t\t * Developer definable function that is called whenever a cell is created (Ajax source,\n\t\t * etc) or processed for input (DOM source). This can be used as a compliment to mRender\n\t\t * allowing you to modify the DOM element (add background colour for example) when the\n\t\t * element is available.\n\t\t * @type function\n\t\t * @param {element} td The TD node that has been created\n\t\t * @param {*} cellData The Data for the cell\n\t\t * @param {array|object} rowData The data for the whole row\n\t\t * @param {int} row The row index for the aoData data store\n\t\t * @param {int} col The column index for aoColumns\n\t\t *\n\t\t * @name DataTable.defaults.column.createdCell\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [3],\n\t\t * \"createdCell\": function (td, cellData, rowData, row, col) {\n\t\t * if ( cellData == \"1.7\" ) {\n\t\t * $(td).css('color', 'blue')\n\t\t * }\n\t\t * }\n\t\t * } ]\n\t\t * });\n\t\t * } );\n\t\t */\n\t\t\"fnCreatedCell\": null,\n\t\n\t\n\t\t/**\n\t\t * This parameter has been replaced by `data` in DataTables to ensure naming\n\t\t * consistency. `dataProp` can still be used, as there is backwards\n\t\t * compatibility in DataTables for this option, but it is strongly\n\t\t * recommended that you use `data` in preference to `dataProp`.\n\t\t * @name DataTable.defaults.column.dataProp\n\t\t */\n\t\n\t\n\t\t/**\n\t\t * This property can be used to read data from any data source property,\n\t\t * including deeply nested objects / properties. `data` can be given in a\n\t\t * number of different ways which effect its behaviour:\n\t\t *\n\t\t * * `integer` - treated as an array index for the data source. This is the\n\t\t * default that DataTables uses (incrementally increased for each column).\n\t\t * * `string` - read an object property from the data source. There are\n\t\t * three 'special' options that can be used in the string to alter how\n\t\t * DataTables reads the data from the source object:\n\t\t * * `.` - Dotted Javascript notation. Just as you use a `.` in\n\t\t * Javascript to read from nested objects, so to can the options\n\t\t * specified in `data`. For example: `browser.version` or\n\t\t * `browser.name`. If your object parameter name contains a period, use\n\t\t * `\\\\` to escape it - i.e. `first\\\\.name`.\n\t\t * * `[]` - Array notation. DataTables can automatically combine data\n\t\t * from and array source, joining the data with the characters provided\n\t\t * between the two brackets. For example: `name[, ]` would provide a\n\t\t * comma-space separated list from the source array. If no characters\n\t\t * are provided between the brackets, the original array source is\n\t\t * returned.\n\t\t * * `()` - Function notation. Adding `()` to the end of a parameter will\n\t\t * execute a function of the name given. For example: `browser()` for a\n\t\t * simple function on the data source, `browser.version()` for a\n\t\t * function in a nested property or even `browser().version` to get an\n\t\t * object property if the function called returns an object. Note that\n\t\t * function notation is recommended for use in `render` rather than\n\t\t * `data` as it is much simpler to use as a renderer.\n\t\t * * `null` - use the original data source for the row rather than plucking\n\t\t * data directly from it. This action has effects on two other\n\t\t * initialisation options:\n\t\t * * `defaultContent` - When null is given as the `data` option and\n\t\t * `defaultContent` is specified for the column, the value defined by\n\t\t * `defaultContent` will be used for the cell.\n\t\t * * `render` - When null is used for the `data` option and the `render`\n\t\t * option is specified for the column, the whole data source for the\n\t\t * row is used for the renderer.\n\t\t * * `function` - the function given will be executed whenever DataTables\n\t\t * needs to set or get the data for a cell in the column. The function\n\t\t * takes three parameters:\n\t\t * * Parameters:\n\t\t * * `{array|object}` The data source for the row\n\t\t * * `{string}` The type call data requested - this will be 'set' when\n\t\t * setting data or 'filter', 'display', 'type', 'sort' or undefined\n\t\t * when gathering data. Note that when `undefined` is given for the\n\t\t * type DataTables expects to get the raw data for the object back<\n\t\t * * `{*}` Data to set when the second parameter is 'set'.\n\t\t * * Return:\n\t\t * * The return value from the function is not required when 'set' is\n\t\t * the type of call, but otherwise the return is what will be used\n\t\t * for the data requested.\n\t\t *\n\t\t * Note that `data` is a getter and setter option. If you just require\n\t\t * formatting of data for output, you will likely want to use `render` which\n\t\t * is simply a getter and thus simpler to use.\n\t\t *\n\t\t * Note that prior to DataTables 1.9.2 `data` was called `mDataProp`. The\n\t\t * name change reflects the flexibility of this property and is consistent\n\t\t * with the naming of mRender. If 'mDataProp' is given, then it will still\n\t\t * be used by DataTables, as it automatically maps the old name to the new\n\t\t * if required.\n\t\t *\n\t\t * @type string|int|function|null\n\t\t * @default null <i>Use automatically calculated column index</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.data\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Read table data from objects\n\t\t * // JSON structure for each row:\n\t\t * // {\n\t\t * // \"engine\": {value},\n\t\t * // \"browser\": {value},\n\t\t * // \"platform\": {value},\n\t\t * // \"version\": {value},\n\t\t * // \"grade\": {value}\n\t\t * // }\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"ajaxSource\": \"sources/objects.txt\",\n\t\t * \"columns\": [\n\t\t * { \"data\": \"engine\" },\n\t\t * { \"data\": \"browser\" },\n\t\t * { \"data\": \"platform\" },\n\t\t * { \"data\": \"version\" },\n\t\t * { \"data\": \"grade\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Read information from deeply nested objects\n\t\t * // JSON structure for each row:\n\t\t * // {\n\t\t * // \"engine\": {value},\n\t\t * // \"browser\": {value},\n\t\t * // \"platform\": {\n\t\t * // \"inner\": {value}\n\t\t * // },\n\t\t * // \"details\": [\n\t\t * // {value}, {value}\n\t\t * // ]\n\t\t * // }\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"ajaxSource\": \"sources/deep.txt\",\n\t\t * \"columns\": [\n\t\t * { \"data\": \"engine\" },\n\t\t * { \"data\": \"browser\" },\n\t\t * { \"data\": \"platform.inner\" },\n\t\t * { \"data\": \"platform.details.0\" },\n\t\t * { \"data\": \"platform.details.1\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `data` as a function to provide different information for\n\t\t * // sorting, filtering and display. In this case, currency (price)\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": function ( source, type, val ) {\n\t\t * if (type === 'set') {\n\t\t * source.price = val;\n\t\t * // Store the computed dislay and filter values for efficiency\n\t\t * source.price_display = val==\"\" ? \"\" : \"$\"+numberFormat(val);\n\t\t * source.price_filter = val==\"\" ? \"\" : \"$\"+numberFormat(val)+\" \"+val;\n\t\t * return;\n\t\t * }\n\t\t * else if (type === 'display') {\n\t\t * return source.price_display;\n\t\t * }\n\t\t * else if (type === 'filter') {\n\t\t * return source.price_filter;\n\t\t * }\n\t\t * // 'sort', 'type' and undefined all just use the integer\n\t\t * return source.price;\n\t\t * }\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using default content\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": null,\n\t\t * \"defaultContent\": \"Click to edit\"\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using array notation - outputting a list from an array\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": \"name[, ]\"\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t */\n\t\t\"mData\": null,\n\t\n\t\n\t\t/**\n\t\t * This property is the rendering partner to `data` and it is suggested that\n\t\t * when you want to manipulate data for display (including filtering,\n\t\t * sorting etc) without altering the underlying data for the table, use this\n\t\t * property. `render` can be considered to be the the read only companion to\n\t\t * `data` which is read / write (then as such more complex). Like `data`\n\t\t * this option can be given in a number of different ways to effect its\n\t\t * behaviour:\n\t\t *\n\t\t * * `integer` - treated as an array index for the data source. This is the\n\t\t * default that DataTables uses (incrementally increased for each column).\n\t\t * * `string` - read an object property from the data source. There are\n\t\t * three 'special' options that can be used in the string to alter how\n\t\t * DataTables reads the data from the source object:\n\t\t * * `.` - Dotted Javascript notation. Just as you use a `.` in\n\t\t * Javascript to read from nested objects, so to can the options\n\t\t * specified in `data`. For example: `browser.version` or\n\t\t * `browser.name`. If your object parameter name contains a period, use\n\t\t * `\\\\` to escape it - i.e. `first\\\\.name`.\n\t\t * * `[]` - Array notation. DataTables can automatically combine data\n\t\t * from and array source, joining the data with the characters provided\n\t\t * between the two brackets. For example: `name[, ]` would provide a\n\t\t * comma-space separated list from the source array. If no characters\n\t\t * are provided between the brackets, the original array source is\n\t\t * returned.\n\t\t * * `()` - Function notation. Adding `()` to the end of a parameter will\n\t\t * execute a function of the name given. For example: `browser()` for a\n\t\t * simple function on the data source, `browser.version()` for a\n\t\t * function in a nested property or even `browser().version` to get an\n\t\t * object property if the function called returns an object.\n\t\t * * `object` - use different data for the different data types requested by\n\t\t * DataTables ('filter', 'display', 'type' or 'sort'). The property names\n\t\t * of the object is the data type the property refers to and the value can\n\t\t * defined using an integer, string or function using the same rules as\n\t\t * `render` normally does. Note that an `_` option _must_ be specified.\n\t\t * This is the default value to use if you haven't specified a value for\n\t\t * the data type requested by DataTables.\n\t\t * * `function` - the function given will be executed whenever DataTables\n\t\t * needs to set or get the data for a cell in the column. The function\n\t\t * takes three parameters:\n\t\t * * Parameters:\n\t\t * * {array|object} The data source for the row (based on `data`)\n\t\t * * {string} The type call data requested - this will be 'filter',\n\t\t * 'display', 'type' or 'sort'.\n\t\t * * {array|object} The full data source for the row (not based on\n\t\t * `data`)\n\t\t * * Return:\n\t\t * * The return value from the function is what will be used for the\n\t\t * data requested.\n\t\t *\n\t\t * @type string|int|function|object|null\n\t\t * @default null Use the data source value.\n\t\t *\n\t\t * @name DataTable.defaults.column.render\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Create a comma separated list from an array of objects\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"ajaxSource\": \"sources/deep.txt\",\n\t\t * \"columns\": [\n\t\t * { \"data\": \"engine\" },\n\t\t * { \"data\": \"browser\" },\n\t\t * {\n\t\t * \"data\": \"platform\",\n\t\t * \"render\": \"[, ].name\"\n\t\t * }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Execute a function to obtain data\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": null, // Use the full data source object for the renderer's source\n\t\t * \"render\": \"browserName()\"\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // As an object, extracting different data for the different types\n\t\t * // This would be used with a data source such as:\n\t\t * // { \"phone\": 5552368, \"phone_filter\": \"5552368 555-2368\", \"phone_display\": \"555-2368\" }\n\t\t * // Here the `phone` integer is used for sorting and type detection, while `phone_filter`\n\t\t * // (which has both forms) is used for filtering for if a user inputs either format, while\n\t\t * // the formatted phone number is the one that is shown in the table.\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": null, // Use the full data source object for the renderer's source\n\t\t * \"render\": {\n\t\t * \"_\": \"phone\",\n\t\t * \"filter\": \"phone_filter\",\n\t\t * \"display\": \"phone_display\"\n\t\t * }\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Use as a function to create a link from the data source\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": \"download_link\",\n\t\t * \"render\": function ( data, type, full ) {\n\t\t * return '<a href=\"'+data+'\">Download</a>';\n\t\t * }\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"mRender\": null,\n\t\n\t\n\t\t/**\n\t\t * Change the cell type created for the column - either TD cells or TH cells. This\n\t\t * can be useful as TH cells have semantic meaning in the table body, allowing them\n\t\t * to act as a header for a row (you may wish to add scope='row' to the TH elements).\n\t\t * @type string\n\t\t * @default td\n\t\t *\n\t\t * @name DataTable.defaults.column.cellType\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Make the first column use TH cells\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"cellType\": \"th\"\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sCellType\": \"td\",\n\t\n\t\n\t\t/**\n\t\t * Class to give to each cell in this column.\n\t\t * @type string\n\t\t * @default <i>Empty string</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.class\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"class\": \"my_class\", \"targets\": [ 0 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"class\": \"my_class\" },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sClass\": \"\",\n\t\n\t\t/**\n\t\t * When DataTables calculates the column widths to assign to each column,\n\t\t * it finds the longest string in each column and then constructs a\n\t\t * temporary table and reads the widths from that. The problem with this\n\t\t * is that \"mmm\" is much wider then \"iiii\", but the latter is a longer\n\t\t * string - thus the calculation can go wrong (doing it properly and putting\n\t\t * it into an DOM object and measuring that is horribly(!) slow). Thus as\n\t\t * a \"work around\" we provide this option. It will append its value to the\n\t\t * text that is found to be the longest string for the column - i.e. padding.\n\t\t * Generally you shouldn't need this!\n\t\t * @type string\n\t\t * @default <i>Empty string<i>\n\t\t *\n\t\t * @name DataTable.defaults.column.contentPadding\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * {\n\t\t * \"contentPadding\": \"mmm\"\n\t\t * }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sContentPadding\": \"\",\n\t\n\t\n\t\t/**\n\t\t * Allows a default value to be given for a column's data, and will be used\n\t\t * whenever a null data source is encountered (this can be because `data`\n\t\t * is set to null, or because the data source itself is null).\n\t\t * @type string\n\t\t * @default null\n\t\t *\n\t\t * @name DataTable.defaults.column.defaultContent\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * {\n\t\t * \"data\": null,\n\t\t * \"defaultContent\": \"Edit\",\n\t\t * \"targets\": [ -1 ]\n\t\t * }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * {\n\t\t * \"data\": null,\n\t\t * \"defaultContent\": \"Edit\"\n\t\t * }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sDefaultContent\": null,\n\t\n\t\n\t\t/**\n\t\t * This parameter is only used in DataTables' server-side processing. It can\n\t\t * be exceptionally useful to know what columns are being displayed on the\n\t\t * client side, and to map these to database fields. When defined, the names\n\t\t * also allow DataTables to reorder information from the server if it comes\n\t\t * back in an unexpected order (i.e. if you switch your columns around on the\n\t\t * client-side, your server-side code does not also need updating).\n\t\t * @type string\n\t\t * @default <i>Empty string</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.name\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"name\": \"engine\", \"targets\": [ 0 ] },\n\t\t * { \"name\": \"browser\", \"targets\": [ 1 ] },\n\t\t * { \"name\": \"platform\", \"targets\": [ 2 ] },\n\t\t * { \"name\": \"version\", \"targets\": [ 3 ] },\n\t\t * { \"name\": \"grade\", \"targets\": [ 4 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"name\": \"engine\" },\n\t\t * { \"name\": \"browser\" },\n\t\t * { \"name\": \"platform\" },\n\t\t * { \"name\": \"version\" },\n\t\t * { \"name\": \"grade\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sName\": \"\",\n\t\n\t\n\t\t/**\n\t\t * Defines a data source type for the ordering which can be used to read\n\t\t * real-time information from the table (updating the internally cached\n\t\t * version) prior to ordering. This allows ordering to occur on user\n\t\t * editable elements such as form inputs.\n\t\t * @type string\n\t\t * @default std\n\t\t *\n\t\t * @name DataTable.defaults.column.orderDataType\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"orderDataType\": \"dom-text\", \"targets\": [ 2, 3 ] },\n\t\t * { \"type\": \"numeric\", \"targets\": [ 3 ] },\n\t\t * { \"orderDataType\": \"dom-select\", \"targets\": [ 4 ] },\n\t\t * { \"orderDataType\": \"dom-checkbox\", \"targets\": [ 5 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * null,\n\t\t * null,\n\t\t * { \"orderDataType\": \"dom-text\" },\n\t\t * { \"orderDataType\": \"dom-text\", \"type\": \"numeric\" },\n\t\t * { \"orderDataType\": \"dom-select\" },\n\t\t * { \"orderDataType\": \"dom-checkbox\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sSortDataType\": \"std\",\n\t\n\t\n\t\t/**\n\t\t * The title of this column.\n\t\t * @type string\n\t\t * @default null <i>Derived from the 'TH' value for this column in the\n\t\t * original HTML table.</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.title\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"title\": \"My column title\", \"targets\": [ 0 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"title\": \"My column title\" },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sTitle\": null,\n\t\n\t\n\t\t/**\n\t\t * The type allows you to specify how the data for this column will be\n\t\t * ordered. Four types (string, numeric, date and html (which will strip\n\t\t * HTML tags before ordering)) are currently available. Note that only date\n\t\t * formats understood by Javascript's Date() object will be accepted as type\n\t\t * date. For example: \"Mar 26, 2008 5:03 PM\". May take the values: 'string',\n\t\t * 'numeric', 'date' or 'html' (by default). Further types can be adding\n\t\t * through plug-ins.\n\t\t * @type string\n\t\t * @default null <i>Auto-detected from raw data</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.type\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"type\": \"html\", \"targets\": [ 0 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"type\": \"html\" },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sType\": null,\n\t\n\t\n\t\t/**\n\t\t * Defining the width of the column, this parameter may take any CSS value\n\t\t * (3em, 20px etc). DataTables applies 'smart' widths to columns which have not\n\t\t * been given a specific width through this interface ensuring that the table\n\t\t * remains readable.\n\t\t * @type string\n\t\t * @default null <i>Automatic</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.width\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"width\": \"20%\", \"targets\": [ 0 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"width\": \"20%\" },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sWidth\": null\n\t};\n\t\n\t_fnHungarianMap( DataTable.defaults.column );\n\t\n\t\n\t\n\t/**\n\t * DataTables settings object - this holds all the information needed for a\n\t * given table, including configuration, data and current application of the\n\t * table options. DataTables does not have a single instance for each DataTable\n\t * with the settings attached to that instance, but rather instances of the\n\t * DataTable \"class\" are created on-the-fly as needed (typically by a\n\t * $().dataTable() call) and the settings object is then applied to that\n\t * instance.\n\t *\n\t * Note that this object is related to {@link DataTable.defaults} but this\n\t * one is the internal data store for DataTables's cache of columns. It should\n\t * NOT be manipulated outside of DataTables. Any configuration should be done\n\t * through the initialisation options.\n\t * @namespace\n\t * @todo Really should attach the settings object to individual instances so we\n\t * don't need to create new instances on each $().dataTable() call (if the\n\t * table already exists). It would also save passing oSettings around and\n\t * into every single function. However, this is a very significant\n\t * architecture change for DataTables and will almost certainly break\n\t * backwards compatibility with older installations. This is something that\n\t * will be done in 2.0.\n\t */\n\tDataTable.models.oSettings = {\n\t\t/**\n\t\t * Primary features of DataTables and their enablement state.\n\t\t * @namespace\n\t\t */\n\t\t\"oFeatures\": {\n\t\n\t\t\t/**\n\t\t\t * Flag to say if DataTables should automatically try to calculate the\n\t\t\t * optimum table and columns widths (true) or not (false).\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bAutoWidth\": null,\n\t\n\t\t\t/**\n\t\t\t * Delay the creation of TR and TD elements until they are actually\n\t\t\t * needed by a driven page draw. This can give a significant speed\n\t\t\t * increase for Ajax source and Javascript source data, but makes no\n\t\t\t * difference at all fro DOM and server-side processing tables.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bDeferRender\": null,\n\t\n\t\t\t/**\n\t\t\t * Enable filtering on the table or not. Note that if this is disabled\n\t\t\t * then there is no filtering at all on the table, including fnFilter.\n\t\t\t * To just remove the filtering input use sDom and remove the 'f' option.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bFilter\": null,\n\t\n\t\t\t/**\n\t\t\t * Table information element (the 'Showing x of y records' div) enable\n\t\t\t * flag.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bInfo\": null,\n\t\n\t\t\t/**\n\t\t\t * Present a user control allowing the end user to change the page size\n\t\t\t * when pagination is enabled.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bLengthChange\": null,\n\t\n\t\t\t/**\n\t\t\t * Pagination enabled or not. Note that if this is disabled then length\n\t\t\t * changing must also be disabled.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bPaginate\": null,\n\t\n\t\t\t/**\n\t\t\t * Processing indicator enable flag whenever DataTables is enacting a\n\t\t\t * user request - typically an Ajax request for server-side processing.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bProcessing\": null,\n\t\n\t\t\t/**\n\t\t\t * Server-side processing enabled flag - when enabled DataTables will\n\t\t\t * get all data from the server for every draw - there is no filtering,\n\t\t\t * sorting or paging done on the client-side.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bServerSide\": null,\n\t\n\t\t\t/**\n\t\t\t * Sorting enablement flag.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bSort\": null,\n\t\n\t\t\t/**\n\t\t\t * Multi-column sorting\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bSortMulti\": null,\n\t\n\t\t\t/**\n\t\t\t * Apply a class to the columns which are being sorted to provide a\n\t\t\t * visual highlight or not. This can slow things down when enabled since\n\t\t\t * there is a lot of DOM interaction.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bSortClasses\": null,\n\t\n\t\t\t/**\n\t\t\t * State saving enablement flag.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bStateSave\": null\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Scrolling settings for a table.\n\t\t * @namespace\n\t\t */\n\t\t\"oScroll\": {\n\t\t\t/**\n\t\t\t * When the table is shorter in height than sScrollY, collapse the\n\t\t\t * table container down to the height of the table (when true).\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bCollapse\": null,\n\t\n\t\t\t/**\n\t\t\t * Width of the scrollbar for the web-browser's platform. Calculated\n\t\t\t * during table initialisation.\n\t\t\t * @type int\n\t\t\t * @default 0\n\t\t\t */\n\t\t\t\"iBarWidth\": 0,\n\t\n\t\t\t/**\n\t\t\t * Viewport width for horizontal scrolling. Horizontal scrolling is\n\t\t\t * disabled if an empty string.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type string\n\t\t\t */\n\t\t\t\"sX\": null,\n\t\n\t\t\t/**\n\t\t\t * Width to expand the table to when using x-scrolling. Typically you\n\t\t\t * should not need to use this.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type string\n\t\t\t * @deprecated\n\t\t\t */\n\t\t\t\"sXInner\": null,\n\t\n\t\t\t/**\n\t\t\t * Viewport height for vertical scrolling. Vertical scrolling is disabled\n\t\t\t * if an empty string.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type string\n\t\t\t */\n\t\t\t\"sY\": null\n\t\t},\n\t\n\t\t/**\n\t\t * Language information for the table.\n\t\t * @namespace\n\t\t * @extends DataTable.defaults.oLanguage\n\t\t */\n\t\t\"oLanguage\": {\n\t\t\t/**\n\t\t\t * Information callback function. See\n\t\t\t * {@link DataTable.defaults.fnInfoCallback}\n\t\t\t * @type function\n\t\t\t * @default null\n\t\t\t */\n\t\t\t\"fnInfoCallback\": null\n\t\t},\n\t\n\t\t/**\n\t\t * Browser support parameters\n\t\t * @namespace\n\t\t */\n\t\t\"oBrowser\": {\n\t\t\t/**\n\t\t\t * Indicate if the browser incorrectly calculates width:100% inside a\n\t\t\t * scrolling element (IE6/7)\n\t\t\t * @type boolean\n\t\t\t * @default false\n\t\t\t */\n\t\t\t\"bScrollOversize\": false,\n\t\n\t\t\t/**\n\t\t\t * Determine if the vertical scrollbar is on the right or left of the\n\t\t\t * scrolling container - needed for rtl language layout, although not\n\t\t\t * all browsers move the scrollbar (Safari).\n\t\t\t * @type boolean\n\t\t\t * @default false\n\t\t\t */\n\t\t\t\"bScrollbarLeft\": false,\n\t\n\t\t\t/**\n\t\t\t * Flag for if `getBoundingClientRect` is fully supported or not\n\t\t\t * @type boolean\n\t\t\t * @default false\n\t\t\t */\n\t\t\t\"bBounding\": false,\n\t\n\t\t\t/**\n\t\t\t * Browser scrollbar width\n\t\t\t * @type integer\n\t\t\t * @default 0\n\t\t\t */\n\t\t\t\"barWidth\": 0\n\t\t},\n\t\n\t\n\t\t\"ajax\": null,\n\t\n\t\n\t\t/**\n\t\t * Array referencing the nodes which are used for the features. The\n\t\t * parameters of this object match what is allowed by sDom - i.e.\n\t\t * <ul>\n\t\t * <li>'l' - Length changing</li>\n\t\t * <li>'f' - Filtering input</li>\n\t\t * <li>'t' - The table!</li>\n\t\t * <li>'i' - Information</li>\n\t\t * <li>'p' - Pagination</li>\n\t\t * <li>'r' - pRocessing</li>\n\t\t * </ul>\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aanFeatures\": [],\n\t\n\t\t/**\n\t\t * Store data information - see {@link DataTable.models.oRow} for detailed\n\t\t * information.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoData\": [],\n\t\n\t\t/**\n\t\t * Array of indexes which are in the current display (after filtering etc)\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aiDisplay\": [],\n\t\n\t\t/**\n\t\t * Array of indexes for display - no filtering\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aiDisplayMaster\": [],\n\t\n\t\t/**\n\t\t * Map of row ids to data indexes\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\t\"aIds\": {},\n\t\n\t\t/**\n\t\t * Store information about each column that is in use\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoColumns\": [],\n\t\n\t\t/**\n\t\t * Store information about the table's header\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoHeader\": [],\n\t\n\t\t/**\n\t\t * Store information about the table's footer\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoFooter\": [],\n\t\n\t\t/**\n\t\t * Store the applied global search information in case we want to force a\n\t\t * research or compare the old search to a new one.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @namespace\n\t\t * @extends DataTable.models.oSearch\n\t\t */\n\t\t\"oPreviousSearch\": {},\n\t\n\t\t/**\n\t\t * Store the applied search for each column - see\n\t\t * {@link DataTable.models.oSearch} for the format that is used for the\n\t\t * filtering information for each column.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoPreSearchCols\": [],\n\t\n\t\t/**\n\t\t * Sorting that is applied to the table. Note that the inner arrays are\n\t\t * used in the following manner:\n\t\t * <ul>\n\t\t * <li>Index 0 - column number</li>\n\t\t * <li>Index 1 - current sorting direction</li>\n\t\t * </ul>\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type array\n\t\t * @todo These inner arrays should really be objects\n\t\t */\n\t\t\"aaSorting\": null,\n\t\n\t\t/**\n\t\t * Sorting that is always applied to the table (i.e. prefixed in front of\n\t\t * aaSorting).\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aaSortingFixed\": [],\n\t\n\t\t/**\n\t\t * Classes to use for the striping of a table.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"asStripeClasses\": null,\n\t\n\t\t/**\n\t\t * If restoring a table - we should restore its striping classes as well\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"asDestroyStripes\": [],\n\t\n\t\t/**\n\t\t * If restoring a table - we should restore its width\n\t\t * @type int\n\t\t * @default 0\n\t\t */\n\t\t\"sDestroyWidth\": 0,\n\t\n\t\t/**\n\t\t * Callback functions array for every time a row is inserted (i.e. on a draw).\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoRowCallback\": [],\n\t\n\t\t/**\n\t\t * Callback functions for the header on each draw.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoHeaderCallback\": [],\n\t\n\t\t/**\n\t\t * Callback function for the footer on each draw.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoFooterCallback\": [],\n\t\n\t\t/**\n\t\t * Array of callback functions for draw callback functions\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoDrawCallback\": [],\n\t\n\t\t/**\n\t\t * Array of callback functions for row created function\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoRowCreatedCallback\": [],\n\t\n\t\t/**\n\t\t * Callback functions for just before the table is redrawn. A return of\n\t\t * false will be used to cancel the draw.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoPreDrawCallback\": [],\n\t\n\t\t/**\n\t\t * Callback functions for when the table has been initialised.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoInitComplete\": [],\n\t\n\t\n\t\t/**\n\t\t * Callbacks for modifying the settings to be stored for state saving, prior to\n\t\t * saving state.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoStateSaveParams\": [],\n\t\n\t\t/**\n\t\t * Callbacks for modifying the settings that have been stored for state saving\n\t\t * prior to using the stored values to restore the state.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoStateLoadParams\": [],\n\t\n\t\t/**\n\t\t * Callbacks for operating on the settings object once the saved state has been\n\t\t * loaded\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoStateLoaded\": [],\n\t\n\t\t/**\n\t\t * Cache the table ID for quick access\n\t\t * @type string\n\t\t * @default <i>Empty string</i>\n\t\t */\n\t\t\"sTableId\": \"\",\n\t\n\t\t/**\n\t\t * The TABLE node for the main table\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTable\": null,\n\t\n\t\t/**\n\t\t * Permanent ref to the thead element\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTHead\": null,\n\t\n\t\t/**\n\t\t * Permanent ref to the tfoot element - if it exists\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTFoot\": null,\n\t\n\t\t/**\n\t\t * Permanent ref to the tbody element\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTBody\": null,\n\t\n\t\t/**\n\t\t * Cache the wrapper node (contains all DataTables controlled elements)\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTableWrapper\": null,\n\t\n\t\t/**\n\t\t * Indicate if when using server-side processing the loading of data\n\t\t * should be deferred until the second draw.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type boolean\n\t\t * @default false\n\t\t */\n\t\t\"bDeferLoading\": false,\n\t\n\t\t/**\n\t\t * Indicate if all required information has been read in\n\t\t * @type boolean\n\t\t * @default false\n\t\t */\n\t\t\"bInitialised\": false,\n\t\n\t\t/**\n\t\t * Information about open rows. Each object in the array has the parameters\n\t\t * 'nTr' and 'nParent'\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoOpenRows\": [],\n\t\n\t\t/**\n\t\t * Dictate the positioning of DataTables' control elements - see\n\t\t * {@link DataTable.model.oInit.sDom}.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sDom\": null,\n\t\n\t\t/**\n\t\t * Search delay (in mS)\n\t\t * @type integer\n\t\t * @default null\n\t\t */\n\t\t\"searchDelay\": null,\n\t\n\t\t/**\n\t\t * Which type of pagination should be used.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type string\n\t\t * @default two_button\n\t\t */\n\t\t\"sPaginationType\": \"two_button\",\n\t\n\t\t/**\n\t\t * The state duration (for `stateSave`) in seconds.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type int\n\t\t * @default 0\n\t\t */\n\t\t\"iStateDuration\": 0,\n\t\n\t\t/**\n\t\t * Array of callback functions for state saving. Each array element is an\n\t\t * object with the following parameters:\n\t\t * <ul>\n\t\t * <li>function:fn - function to call. Takes two parameters, oSettings\n\t\t * and the JSON string to save that has been thus far created. Returns\n\t\t * a JSON string to be inserted into a json object\n\t\t * (i.e. '\"param\": [ 0, 1, 2]')</li>\n\t\t * <li>string:sName - name of callback</li>\n\t\t * </ul>\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoStateSave\": [],\n\t\n\t\t/**\n\t\t * Array of callback functions for state loading. Each array element is an\n\t\t * object with the following parameters:\n\t\t * <ul>\n\t\t * <li>function:fn - function to call. Takes two parameters, oSettings\n\t\t * and the object stored. May return false to cancel state loading</li>\n\t\t * <li>string:sName - name of callback</li>\n\t\t * </ul>\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoStateLoad\": [],\n\t\n\t\t/**\n\t\t * State that was saved. Useful for back reference\n\t\t * @type object\n\t\t * @default null\n\t\t */\n\t\t\"oSavedState\": null,\n\t\n\t\t/**\n\t\t * State that was loaded. Useful for back reference\n\t\t * @type object\n\t\t * @default null\n\t\t */\n\t\t\"oLoadedState\": null,\n\t\n\t\t/**\n\t\t * Source url for AJAX data for the table.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sAjaxSource\": null,\n\t\n\t\t/**\n\t\t * Property from a given object from which to read the table data from. This\n\t\t * can be an empty string (when not server-side processing), in which case\n\t\t * it is assumed an an array is given directly.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type string\n\t\t */\n\t\t\"sAjaxDataProp\": null,\n\t\n\t\t/**\n\t\t * Note if draw should be blocked while getting data\n\t\t * @type boolean\n\t\t * @default true\n\t\t */\n\t\t\"bAjaxDataGet\": true,\n\t\n\t\t/**\n\t\t * The last jQuery XHR object that was used for server-side data gathering.\n\t\t * This can be used for working with the XHR information in one of the\n\t\t * callbacks\n\t\t * @type object\n\t\t * @default null\n\t\t */\n\t\t\"jqXHR\": null,\n\t\n\t\t/**\n\t\t * JSON returned from the server in the last Ajax request\n\t\t * @type object\n\t\t * @default undefined\n\t\t */\n\t\t\"json\": undefined,\n\t\n\t\t/**\n\t\t * Data submitted as part of the last Ajax request\n\t\t * @type object\n\t\t * @default undefined\n\t\t */\n\t\t\"oAjaxData\": undefined,\n\t\n\t\t/**\n\t\t * Function to get the server-side data.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type function\n\t\t */\n\t\t\"fnServerData\": null,\n\t\n\t\t/**\n\t\t * Functions which are called prior to sending an Ajax request so extra\n\t\t * parameters can easily be sent to the server\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoServerParams\": [],\n\t\n\t\t/**\n\t\t * Send the XHR HTTP method - GET or POST (could be PUT or DELETE if\n\t\t * required).\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type string\n\t\t */\n\t\t\"sServerMethod\": null,\n\t\n\t\t/**\n\t\t * Format numbers for display.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type function\n\t\t */\n\t\t\"fnFormatNumber\": null,\n\t\n\t\t/**\n\t\t * List of options that can be used for the user selectable length menu.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aLengthMenu\": null,\n\t\n\t\t/**\n\t\t * Counter for the draws that the table does. Also used as a tracker for\n\t\t * server-side processing\n\t\t * @type int\n\t\t * @default 0\n\t\t */\n\t\t\"iDraw\": 0,\n\t\n\t\t/**\n\t\t * Indicate if a redraw is being done - useful for Ajax\n\t\t * @type boolean\n\t\t * @default false\n\t\t */\n\t\t\"bDrawing\": false,\n\t\n\t\t/**\n\t\t * Draw index (iDraw) of the last error when parsing the returned data\n\t\t * @type int\n\t\t * @default -1\n\t\t */\n\t\t\"iDrawError\": -1,\n\t\n\t\t/**\n\t\t * Paging display length\n\t\t * @type int\n\t\t * @default 10\n\t\t */\n\t\t\"_iDisplayLength\": 10,\n\t\n\t\t/**\n\t\t * Paging start point - aiDisplay index\n\t\t * @type int\n\t\t * @default 0\n\t\t */\n\t\t\"_iDisplayStart\": 0,\n\t\n\t\t/**\n\t\t * Server-side processing - number of records in the result set\n\t\t * (i.e. before filtering), Use fnRecordsTotal rather than\n\t\t * this property to get the value of the number of records, regardless of\n\t\t * the server-side processing setting.\n\t\t * @type int\n\t\t * @default 0\n\t\t * @private\n\t\t */\n\t\t\"_iRecordsTotal\": 0,\n\t\n\t\t/**\n\t\t * Server-side processing - number of records in the current display set\n\t\t * (i.e. after filtering). Use fnRecordsDisplay rather than\n\t\t * this property to get the value of the number of records, regardless of\n\t\t * the server-side processing setting.\n\t\t * @type boolean\n\t\t * @default 0\n\t\t * @private\n\t\t */\n\t\t\"_iRecordsDisplay\": 0,\n\t\n\t\t/**\n\t\t * Flag to indicate if jQuery UI marking and classes should be used.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type boolean\n\t\t */\n\t\t\"bJUI\": null,\n\t\n\t\t/**\n\t\t * The classes to use for the table\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\t\"oClasses\": {},\n\t\n\t\t/**\n\t\t * Flag attached to the settings object so you can check in the draw\n\t\t * callback if filtering has been done in the draw. Deprecated in favour of\n\t\t * events.\n\t\t * @type boolean\n\t\t * @default false\n\t\t * @deprecated\n\t\t */\n\t\t\"bFiltered\": false,\n\t\n\t\t/**\n\t\t * Flag attached to the settings object so you can check in the draw\n\t\t * callback if sorting has been done in the draw. Deprecated in favour of\n\t\t * events.\n\t\t * @type boolean\n\t\t * @default false\n\t\t * @deprecated\n\t\t */\n\t\t\"bSorted\": false,\n\t\n\t\t/**\n\t\t * Indicate that if multiple rows are in the header and there is more than\n\t\t * one unique cell per column, if the top one (true) or bottom one (false)\n\t\t * should be used for sorting / title by DataTables.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type boolean\n\t\t */\n\t\t\"bSortCellsTop\": null,\n\t\n\t\t/**\n\t\t * Initialisation object that is used for the table\n\t\t * @type object\n\t\t * @default null\n\t\t */\n\t\t\"oInit\": null,\n\t\n\t\t/**\n\t\t * Destroy callback functions - for plug-ins to attach themselves to the\n\t\t * destroy so they can clean up markup and events.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoDestroyCallback\": [],\n\t\n\t\n\t\t/**\n\t\t * Get the number of records in the current record set, before filtering\n\t\t * @type function\n\t\t */\n\t\t\"fnRecordsTotal\": function ()\n\t\t{\n\t\t\treturn _fnDataSource( this ) == 'ssp' ?\n\t\t\t\tthis._iRecordsTotal * 1 :\n\t\t\t\tthis.aiDisplayMaster.length;\n\t\t},\n\t\n\t\t/**\n\t\t * Get the number of records in the current record set, after filtering\n\t\t * @type function\n\t\t */\n\t\t\"fnRecordsDisplay\": function ()\n\t\t{\n\t\t\treturn _fnDataSource( this ) == 'ssp' ?\n\t\t\t\tthis._iRecordsDisplay * 1 :\n\t\t\t\tthis.aiDisplay.length;\n\t\t},\n\t\n\t\t/**\n\t\t * Get the display end point - aiDisplay index\n\t\t * @type function\n\t\t */\n\t\t\"fnDisplayEnd\": function ()\n\t\t{\n\t\t\tvar\n\t\t\t\tlen = this._iDisplayLength,\n\t\t\t\tstart = this._iDisplayStart,\n\t\t\t\tcalc = start + len,\n\t\t\t\trecords = this.aiDisplay.length,\n\t\t\t\tfeatures = this.oFeatures,\n\t\t\t\tpaginate = features.bPaginate;\n\t\n\t\t\tif ( features.bServerSide ) {\n\t\t\t\treturn paginate === false || len === -1 ?\n\t\t\t\t\tstart + records :\n\t\t\t\t\tMath.min( start+len, this._iRecordsDisplay );\n\t\t\t}\n\t\t\telse {\n\t\t\t\treturn ! paginate || calc>records || len===-1 ?\n\t\t\t\t\trecords :\n\t\t\t\t\tcalc;\n\t\t\t}\n\t\t},\n\t\n\t\t/**\n\t\t * The DataTables object for this table\n\t\t * @type object\n\t\t * @default null\n\t\t */\n\t\t\"oInstance\": null,\n\t\n\t\t/**\n\t\t * Unique identifier for each instance of the DataTables object. If there\n\t\t * is an ID on the table node, then it takes that value, otherwise an\n\t\t * incrementing internal counter is used.\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sInstance\": null,\n\t\n\t\t/**\n\t\t * tabindex attribute value that is added to DataTables control elements, allowing\n\t\t * keyboard navigation of the table and its controls.\n\t\t */\n\t\t\"iTabIndex\": 0,\n\t\n\t\t/**\n\t\t * DIV container for the footer scrolling table if scrolling\n\t\t */\n\t\t\"nScrollHead\": null,\n\t\n\t\t/**\n\t\t * DIV container for the footer scrolling table if scrolling\n\t\t */\n\t\t\"nScrollFoot\": null,\n\t\n\t\t/**\n\t\t * Last applied sort\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aLastSort\": [],\n\t\n\t\t/**\n\t\t * Stored plug-in instances\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\t\"oPlugins\": {},\n\t\n\t\t/**\n\t\t * Function used to get a row's id from the row's data\n\t\t * @type function\n\t\t * @default null\n\t\t */\n\t\t\"rowIdFn\": null,\n\t\n\t\t/**\n\t\t * Data location where to store a row's id\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"rowId\": null\n\t};\n\n\t/**\n\t * Extension object for DataTables that is used to provide all extension\n\t * options.\n\t *\n\t * Note that the `DataTable.ext` object is available through\n\t * `jQuery.fn.dataTable.ext` where it may be accessed and manipulated. It is\n\t * also aliased to `jQuery.fn.dataTableExt` for historic reasons.\n\t * @namespace\n\t * @extends DataTable.models.ext\n\t */\n\t\n\t\n\t/**\n\t * DataTables extensions\n\t * \n\t * This namespace acts as a collection area for plug-ins that can be used to\n\t * extend DataTables capabilities. Indeed many of the build in methods\n\t * use this method to provide their own capabilities (sorting methods for\n\t * example).\n\t *\n\t * Note that this namespace is aliased to `jQuery.fn.dataTableExt` for legacy\n\t * reasons\n\t *\n\t * @namespace\n\t */\n\tDataTable.ext = _ext = {\n\t\t/**\n\t\t * Buttons. For use with the Buttons extension for DataTables. This is\n\t\t * defined here so other extensions can define buttons regardless of load\n\t\t * order. It is _not_ used by DataTables core.\n\t\t *\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\tbuttons: {},\n\t\n\t\n\t\t/**\n\t\t * Element class names\n\t\t *\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\tclasses: {},\n\t\n\t\n\t\t/**\n\t\t * DataTables build type (expanded by the download builder)\n\t\t *\n\t\t * @type string\n\t\t */\n\t\tbuilder: \"-source-\",\n\t\n\t\n\t\t/**\n\t\t * Error reporting.\n\t\t * \n\t\t * How should DataTables report an error. Can take the value 'alert',\n\t\t * 'throw', 'none' or a function.\n\t\t *\n\t\t * @type string|function\n\t\t * @default alert\n\t\t */\n\t\terrMode: \"alert\",\n\t\n\t\n\t\t/**\n\t\t * Feature plug-ins.\n\t\t * \n\t\t * This is an array of objects which describe the feature plug-ins that are\n\t\t * available to DataTables. These feature plug-ins are then available for\n\t\t * use through the `dom` initialisation option.\n\t\t * \n\t\t * Each feature plug-in is described by an object which must have the\n\t\t * following properties:\n\t\t * \n\t\t * * `fnInit` - function that is used to initialise the plug-in,\n\t\t * * `cFeature` - a character so the feature can be enabled by the `dom`\n\t\t * instillation option. This is case sensitive.\n\t\t *\n\t\t * The `fnInit` function has the following input parameters:\n\t\t *\n\t\t * 1. `{object}` DataTables settings object: see\n\t\t * {@link DataTable.models.oSettings}\n\t\t *\n\t\t * And the following return is expected:\n\t\t * \n\t\t * * {node|null} The element which contains your feature. Note that the\n\t\t * return may also be void if your plug-in does not require to inject any\n\t\t * DOM elements into DataTables control (`dom`) - for example this might\n\t\t * be useful when developing a plug-in which allows table control via\n\t\t * keyboard entry\n\t\t *\n\t\t * @type array\n\t\t *\n\t\t * @example\n\t\t * $.fn.dataTable.ext.features.push( {\n\t\t * \"fnInit\": function( oSettings ) {\n\t\t * return new TableTools( { \"oDTSettings\": oSettings } );\n\t\t * },\n\t\t * \"cFeature\": \"T\"\n\t\t * } );\n\t\t */\n\t\tfeature: [],\n\t\n\t\n\t\t/**\n\t\t * Row searching.\n\t\t * \n\t\t * This method of searching is complimentary to the default type based\n\t\t * searching, and a lot more comprehensive as it allows you complete control\n\t\t * over the searching logic. Each element in this array is a function\n\t\t * (parameters described below) that is called for every row in the table,\n\t\t * and your logic decides if it should be included in the searching data set\n\t\t * or not.\n\t\t *\n\t\t * Searching functions have the following input parameters:\n\t\t *\n\t\t * 1. `{object}` DataTables settings object: see\n\t\t * {@link DataTable.models.oSettings}\n\t\t * 2. `{array|object}` Data for the row to be processed (same as the\n\t\t * original format that was passed in as the data source, or an array\n\t\t * from a DOM data source\n\t\t * 3. `{int}` Row index ({@link DataTable.models.oSettings.aoData}), which\n\t\t * can be useful to retrieve the `TR` element if you need DOM interaction.\n\t\t *\n\t\t * And the following return is expected:\n\t\t *\n\t\t * * {boolean} Include the row in the searched result set (true) or not\n\t\t * (false)\n\t\t *\n\t\t * Note that as with the main search ability in DataTables, technically this\n\t\t * is \"filtering\", since it is subtractive. However, for consistency in\n\t\t * naming we call it searching here.\n\t\t *\n\t\t * @type array\n\t\t * @default []\n\t\t *\n\t\t * @example\n\t\t * // The following example shows custom search being applied to the\n\t\t * // fourth column (i.e. the data[3] index) based on two input values\n\t\t * // from the end-user, matching the data in a certain range.\n\t\t * $.fn.dataTable.ext.search.push(\n\t\t * function( settings, data, dataIndex ) {\n\t\t * var min = document.getElementById('min').value * 1;\n\t\t * var max = document.getElementById('max').value * 1;\n\t\t * var version = data[3] == \"-\" ? 0 : data[3]*1;\n\t\t *\n\t\t * if ( min == \"\" && max == \"\" ) {\n\t\t * return true;\n\t\t * }\n\t\t * else if ( min == \"\" && version < max ) {\n\t\t * return true;\n\t\t * }\n\t\t * else if ( min < version && \"\" == max ) {\n\t\t * return true;\n\t\t * }\n\t\t * else if ( min < version && version < max ) {\n\t\t * return true;\n\t\t * }\n\t\t * return false;\n\t\t * }\n\t\t * );\n\t\t */\n\t\tsearch: [],\n\t\n\t\n\t\t/**\n\t\t * Selector extensions\n\t\t *\n\t\t * The `selector` option can be used to extend the options available for the\n\t\t * selector modifier options (`selector-modifier` object data type) that\n\t\t * each of the three built in selector types offer (row, column and cell +\n\t\t * their plural counterparts). For example the Select extension uses this\n\t\t * mechanism to provide an option to select only rows, columns and cells\n\t\t * that have been marked as selected by the end user (`{selected: true}`),\n\t\t * which can be used in conjunction with the existing built in selector\n\t\t * options.\n\t\t *\n\t\t * Each property is an array to which functions can be pushed. The functions\n\t\t * take three attributes:\n\t\t *\n\t\t * * Settings object for the host table\n\t\t * * Options object (`selector-modifier` object type)\n\t\t * * Array of selected item indexes\n\t\t *\n\t\t * The return is an array of the resulting item indexes after the custom\n\t\t * selector has been applied.\n\t\t *\n\t\t * @type object\n\t\t */\n\t\tselector: {\n\t\t\tcell: [],\n\t\t\tcolumn: [],\n\t\t\trow: []\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Internal functions, exposed for used in plug-ins.\n\t\t * \n\t\t * Please note that you should not need to use the internal methods for\n\t\t * anything other than a plug-in (and even then, try to avoid if possible).\n\t\t * The internal function may change between releases.\n\t\t *\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\tinternal: {},\n\t\n\t\n\t\t/**\n\t\t * Legacy configuration options. Enable and disable legacy options that\n\t\t * are available in DataTables.\n\t\t *\n\t\t * @type object\n\t\t */\n\t\tlegacy: {\n\t\t\t/**\n\t\t\t * Enable / disable DataTables 1.9 compatible server-side processing\n\t\t\t * requests\n\t\t\t *\n\t\t\t * @type boolean\n\t\t\t * @default null\n\t\t\t */\n\t\t\tajax: null\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Pagination plug-in methods.\n\t\t * \n\t\t * Each entry in this object is a function and defines which buttons should\n\t\t * be shown by the pagination rendering method that is used for the table:\n\t\t * {@link DataTable.ext.renderer.pageButton}. The renderer addresses how the\n\t\t * buttons are displayed in the document, while the functions here tell it\n\t\t * what buttons to display. This is done by returning an array of button\n\t\t * descriptions (what each button will do).\n\t\t *\n\t\t * Pagination types (the four built in options and any additional plug-in\n\t\t * options defined here) can be used through the `paginationType`\n\t\t * initialisation parameter.\n\t\t *\n\t\t * The functions defined take two parameters:\n\t\t *\n\t\t * 1. `{int} page` The current page index\n\t\t * 2. `{int} pages` The number of pages in the table\n\t\t *\n\t\t * Each function is expected to return an array where each element of the\n\t\t * array can be one of:\n\t\t *\n\t\t * * `first` - Jump to first page when activated\n\t\t * * `last` - Jump to last page when activated\n\t\t * * `previous` - Show previous page when activated\n\t\t * * `next` - Show next page when activated\n\t\t * * `{int}` - Show page of the index given\n\t\t * * `{array}` - A nested array containing the above elements to add a\n\t\t * containing 'DIV' element (might be useful for styling).\n\t\t *\n\t\t * Note that DataTables v1.9- used this object slightly differently whereby\n\t\t * an object with two functions would be defined for each plug-in. That\n\t\t * ability is still supported by DataTables 1.10+ to provide backwards\n\t\t * compatibility, but this option of use is now decremented and no longer\n\t\t * documented in DataTables 1.10+.\n\t\t *\n\t\t * @type object\n\t\t * @default {}\n\t\t *\n\t\t * @example\n\t\t * // Show previous, next and current page buttons only\n\t\t * $.fn.dataTableExt.oPagination.current = function ( page, pages ) {\n\t\t * return [ 'previous', page, 'next' ];\n\t\t * };\n\t\t */\n\t\tpager: {},\n\t\n\t\n\t\trenderer: {\n\t\t\tpageButton: {},\n\t\t\theader: {}\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Ordering plug-ins - custom data source\n\t\t * \n\t\t * The extension options for ordering of data available here is complimentary\n\t\t * to the default type based ordering that DataTables typically uses. It\n\t\t * allows much greater control over the the data that is being used to\n\t\t * order a column, but is necessarily therefore more complex.\n\t\t * \n\t\t * This type of ordering is useful if you want to do ordering based on data\n\t\t * live from the DOM (for example the contents of an 'input' element) rather\n\t\t * than just the static string that DataTables knows of.\n\t\t * \n\t\t * The way these plug-ins work is that you create an array of the values you\n\t\t * wish to be ordering for the column in question and then return that\n\t\t * array. The data in the array much be in the index order of the rows in\n\t\t * the table (not the currently ordering order!). Which order data gathering\n\t\t * function is run here depends on the `dt-init columns.orderDataType`\n\t\t * parameter that is used for the column (if any).\n\t\t *\n\t\t * The functions defined take two parameters:\n\t\t *\n\t\t * 1. `{object}` DataTables settings object: see\n\t\t * {@link DataTable.models.oSettings}\n\t\t * 2. `{int}` Target column index\n\t\t *\n\t\t * Each function is expected to return an array:\n\t\t *\n\t\t * * `{array}` Data for the column to be ordering upon\n\t\t *\n\t\t * @type array\n\t\t *\n\t\t * @example\n\t\t * // Ordering using `input` node values\n\t\t * $.fn.dataTable.ext.order['dom-text'] = function ( settings, col )\n\t\t * {\n\t\t * return this.api().column( col, {order:'index'} ).nodes().map( function ( td, i ) {\n\t\t * return $('input', td).val();\n\t\t * } );\n\t\t * }\n\t\t */\n\t\torder: {},\n\t\n\t\n\t\t/**\n\t\t * Type based plug-ins.\n\t\t *\n\t\t * Each column in DataTables has a type assigned to it, either by automatic\n\t\t * detection or by direct assignment using the `type` option for the column.\n\t\t * The type of a column will effect how it is ordering and search (plug-ins\n\t\t * can also make use of the column type if required).\n\t\t *\n\t\t * @namespace\n\t\t */\n\t\ttype: {\n\t\t\t/**\n\t\t\t * Type detection functions.\n\t\t\t *\n\t\t\t * The functions defined in this object are used to automatically detect\n\t\t\t * a column's type, making initialisation of DataTables super easy, even\n\t\t\t * when complex data is in the table.\n\t\t\t *\n\t\t\t * The functions defined take two parameters:\n\t\t\t *\n\t\t * 1. `{*}` Data from the column cell to be analysed\n\t\t * 2. `{settings}` DataTables settings object. This can be used to\n\t\t * perform context specific type detection - for example detection\n\t\t * based on language settings such as using a comma for a decimal\n\t\t * place. Generally speaking the options from the settings will not\n\t\t * be required\n\t\t\t *\n\t\t\t * Each function is expected to return:\n\t\t\t *\n\t\t\t * * `{string|null}` Data type detected, or null if unknown (and thus\n\t\t\t * pass it on to the other type detection functions.\n\t\t\t *\n\t\t\t * @type array\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Currency type detection plug-in:\n\t\t\t * $.fn.dataTable.ext.type.detect.push(\n\t\t\t * function ( data, settings ) {\n\t\t\t * // Check the numeric part\n\t\t\t * if ( ! $.isNumeric( data.substring(1) ) ) {\n\t\t\t * return null;\n\t\t\t * }\n\t\t\t *\n\t\t\t * // Check prefixed by currency\n\t\t\t * if ( data.charAt(0) == '$' || data.charAt(0) == '£' ) {\n\t\t\t * return 'currency';\n\t\t\t * }\n\t\t\t * return null;\n\t\t\t * }\n\t\t\t * );\n\t\t\t */\n\t\t\tdetect: [],\n\t\n\t\n\t\t\t/**\n\t\t\t * Type based search formatting.\n\t\t\t *\n\t\t\t * The type based searching functions can be used to pre-format the\n\t\t\t * data to be search on. For example, it can be used to strip HTML\n\t\t\t * tags or to de-format telephone numbers for numeric only searching.\n\t\t\t *\n\t\t\t * Note that is a search is not defined for a column of a given type,\n\t\t\t * no search formatting will be performed.\n\t\t\t * \n\t\t\t * Pre-processing of searching data plug-ins - When you assign the sType\n\t\t\t * for a column (or have it automatically detected for you by DataTables\n\t\t\t * or a type detection plug-in), you will typically be using this for\n\t\t\t * custom sorting, but it can also be used to provide custom searching\n\t\t\t * by allowing you to pre-processing the data and returning the data in\n\t\t\t * the format that should be searched upon. This is done by adding\n\t\t\t * functions this object with a parameter name which matches the sType\n\t\t\t * for that target column. This is the corollary of <i>afnSortData</i>\n\t\t\t * for searching data.\n\t\t\t *\n\t\t\t * The functions defined take a single parameter:\n\t\t\t *\n\t\t * 1. `{*}` Data from the column cell to be prepared for searching\n\t\t\t *\n\t\t\t * Each function is expected to return:\n\t\t\t *\n\t\t\t * * `{string|null}` Formatted string that will be used for the searching.\n\t\t\t *\n\t\t\t * @type object\n\t\t\t * @default {}\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $.fn.dataTable.ext.type.search['title-numeric'] = function ( d ) {\n\t\t\t * return d.replace(/\\n/g,\" \").replace( /<.*?>/g, \"\" );\n\t\t\t * }\n\t\t\t */\n\t\t\tsearch: {},\n\t\n\t\n\t\t\t/**\n\t\t\t * Type based ordering.\n\t\t\t *\n\t\t\t * The column type tells DataTables what ordering to apply to the table\n\t\t\t * when a column is sorted upon. The order for each type that is defined,\n\t\t\t * is defined by the functions available in this object.\n\t\t\t *\n\t\t\t * Each ordering option can be described by three properties added to\n\t\t\t * this object:\n\t\t\t *\n\t\t\t * * `{type}-pre` - Pre-formatting function\n\t\t\t * * `{type}-asc` - Ascending order function\n\t\t\t * * `{type}-desc` - Descending order function\n\t\t\t *\n\t\t\t * All three can be used together, only `{type}-pre` or only\n\t\t\t * `{type}-asc` and `{type}-desc` together. It is generally recommended\n\t\t\t * that only `{type}-pre` is used, as this provides the optimal\n\t\t\t * implementation in terms of speed, although the others are provided\n\t\t\t * for compatibility with existing Javascript sort functions.\n\t\t\t *\n\t\t\t * `{type}-pre`: Functions defined take a single parameter:\n\t\t\t *\n\t\t * 1. `{*}` Data from the column cell to be prepared for ordering\n\t\t\t *\n\t\t\t * And return:\n\t\t\t *\n\t\t\t * * `{*}` Data to be sorted upon\n\t\t\t *\n\t\t\t * `{type}-asc` and `{type}-desc`: Functions are typical Javascript sort\n\t\t\t * functions, taking two parameters:\n\t\t\t *\n\t\t * 1. `{*}` Data to compare to the second parameter\n\t\t * 2. `{*}` Data to compare to the first parameter\n\t\t\t *\n\t\t\t * And returning:\n\t\t\t *\n\t\t\t * * `{*}` Ordering match: <0 if first parameter should be sorted lower\n\t\t\t * than the second parameter, ===0 if the two parameters are equal and\n\t\t\t * >0 if the first parameter should be sorted height than the second\n\t\t\t * parameter.\n\t\t\t * \n\t\t\t * @type object\n\t\t\t * @default {}\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Numeric ordering of formatted numbers with a pre-formatter\n\t\t\t * $.extend( $.fn.dataTable.ext.type.order, {\n\t\t\t * \"string-pre\": function(x) {\n\t\t\t * a = (a === \"-\" || a === \"\") ? 0 : a.replace( /[^\\d\\-\\.]/g, \"\" );\n\t\t\t * return parseFloat( a );\n\t\t\t * }\n\t\t\t * } );\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Case-sensitive string ordering, with no pre-formatting method\n\t\t\t * $.extend( $.fn.dataTable.ext.order, {\n\t\t\t * \"string-case-asc\": function(x,y) {\n\t\t\t * return ((x < y) ? -1 : ((x > y) ? 1 : 0));\n\t\t\t * },\n\t\t\t * \"string-case-desc\": function(x,y) {\n\t\t\t * return ((x < y) ? 1 : ((x > y) ? -1 : 0));\n\t\t\t * }\n\t\t\t * } );\n\t\t\t */\n\t\t\torder: {}\n\t\t},\n\t\n\t\t/**\n\t\t * Unique DataTables instance counter\n\t\t *\n\t\t * @type int\n\t\t * @private\n\t\t */\n\t\t_unique: 0,\n\t\n\t\n\t\t//\n\t\t// Depreciated\n\t\t// The following properties are retained for backwards compatiblity only.\n\t\t// The should not be used in new projects and will be removed in a future\n\t\t// version\n\t\t//\n\t\n\t\t/**\n\t\t * Version check function.\n\t\t * @type function\n\t\t * @depreciated Since 1.10\n\t\t */\n\t\tfnVersionCheck: DataTable.fnVersionCheck,\n\t\n\t\n\t\t/**\n\t\t * Index for what 'this' index API functions should use\n\t\t * @type int\n\t\t * @deprecated Since v1.10\n\t\t */\n\t\tiApiIndex: 0,\n\t\n\t\n\t\t/**\n\t\t * jQuery UI class container\n\t\t * @type object\n\t\t * @deprecated Since v1.10\n\t\t */\n\t\toJUIClasses: {},\n\t\n\t\n\t\t/**\n\t\t * Software version\n\t\t * @type string\n\t\t * @deprecated Since v1.10\n\t\t */\n\t\tsVersion: DataTable.version\n\t};\n\t\n\t\n\t//\n\t// Backwards compatibility. Alias to pre 1.10 Hungarian notation counter parts\n\t//\n\t$.extend( _ext, {\n\t\tafnFiltering: _ext.search,\n\t\taTypes: _ext.type.detect,\n\t\tofnSearch: _ext.type.search,\n\t\toSort: _ext.type.order,\n\t\tafnSortData: _ext.order,\n\t\taoFeatures: _ext.feature,\n\t\toApi: _ext.internal,\n\t\toStdClasses: _ext.classes,\n\t\toPagination: _ext.pager\n\t} );\n\t\n\t\n\t$.extend( DataTable.ext.classes, {\n\t\t\"sTable\": \"dataTable\",\n\t\t\"sNoFooter\": \"no-footer\",\n\t\n\t\t/* Paging buttons */\n\t\t\"sPageButton\": \"paginate_button\",\n\t\t\"sPageButtonActive\": \"current\",\n\t\t\"sPageButtonDisabled\": \"disabled\",\n\t\n\t\t/* Striping classes */\n\t\t\"sStripeOdd\": \"odd\",\n\t\t\"sStripeEven\": \"even\",\n\t\n\t\t/* Empty row */\n\t\t\"sRowEmpty\": \"dataTables_empty\",\n\t\n\t\t/* Features */\n\t\t\"sWrapper\": \"dataTables_wrapper\",\n\t\t\"sFilter\": \"dataTables_filter\",\n\t\t\"sInfo\": \"dataTables_info\",\n\t\t\"sPaging\": \"dataTables_paginate paging_\", /* Note that the type is postfixed */\n\t\t\"sLength\": \"dataTables_length\",\n\t\t\"sProcessing\": \"dataTables_processing\",\n\t\n\t\t/* Sorting */\n\t\t\"sSortAsc\": \"sorting_asc\",\n\t\t\"sSortDesc\": \"sorting_desc\",\n\t\t\"sSortable\": \"sorting\", /* Sortable in both directions */\n\t\t\"sSortableAsc\": \"sorting_asc_disabled\",\n\t\t\"sSortableDesc\": \"sorting_desc_disabled\",\n\t\t\"sSortableNone\": \"sorting_disabled\",\n\t\t\"sSortColumn\": \"sorting_\", /* Note that an int is postfixed for the sorting order */\n\t\n\t\t/* Filtering */\n\t\t\"sFilterInput\": \"\",\n\t\n\t\t/* Page length */\n\t\t\"sLengthSelect\": \"\",\n\t\n\t\t/* Scrolling */\n\t\t\"sScrollWrapper\": \"dataTables_scroll\",\n\t\t\"sScrollHead\": \"dataTables_scrollHead\",\n\t\t\"sScrollHeadInner\": \"dataTables_scrollHeadInner\",\n\t\t\"sScrollBody\": \"dataTables_scrollBody\",\n\t\t\"sScrollFoot\": \"dataTables_scrollFoot\",\n\t\t\"sScrollFootInner\": \"dataTables_scrollFootInner\",\n\t\n\t\t/* Misc */\n\t\t\"sHeaderTH\": \"\",\n\t\t\"sFooterTH\": \"\",\n\t\n\t\t// Deprecated\n\t\t\"sSortJUIAsc\": \"\",\n\t\t\"sSortJUIDesc\": \"\",\n\t\t\"sSortJUI\": \"\",\n\t\t\"sSortJUIAscAllowed\": \"\",\n\t\t\"sSortJUIDescAllowed\": \"\",\n\t\t\"sSortJUIWrapper\": \"\",\n\t\t\"sSortIcon\": \"\",\n\t\t\"sJUIHeader\": \"\",\n\t\t\"sJUIFooter\": \"\"\n\t} );\n\t\n\t\n\t(function() {\n\t\n\t// Reused strings for better compression. Closure compiler appears to have a\n\t// weird edge case where it is trying to expand strings rather than use the\n\t// variable version. This results in about 200 bytes being added, for very\n\t// little preference benefit since it this run on script load only.\n\tvar _empty = '';\n\t_empty = '';\n\t\n\tvar _stateDefault = _empty + 'ui-state-default';\n\tvar _sortIcon = _empty + 'css_right ui-icon ui-icon-';\n\tvar _headerFooter = _empty + 'fg-toolbar ui-toolbar ui-widget-header ui-helper-clearfix';\n\t\n\t$.extend( DataTable.ext.oJUIClasses, DataTable.ext.classes, {\n\t\t/* Full numbers paging buttons */\n\t\t\"sPageButton\": \"fg-button ui-button \"+_stateDefault,\n\t\t\"sPageButtonActive\": \"ui-state-disabled\",\n\t\t\"sPageButtonDisabled\": \"ui-state-disabled\",\n\t\n\t\t/* Features */\n\t\t\"sPaging\": \"dataTables_paginate fg-buttonset ui-buttonset fg-buttonset-multi \"+\n\t\t\t\"ui-buttonset-multi paging_\", /* Note that the type is postfixed */\n\t\n\t\t/* Sorting */\n\t\t\"sSortAsc\": _stateDefault+\" sorting_asc\",\n\t\t\"sSortDesc\": _stateDefault+\" sorting_desc\",\n\t\t\"sSortable\": _stateDefault+\" sorting\",\n\t\t\"sSortableAsc\": _stateDefault+\" sorting_asc_disabled\",\n\t\t\"sSortableDesc\": _stateDefault+\" sorting_desc_disabled\",\n\t\t\"sSortableNone\": _stateDefault+\" sorting_disabled\",\n\t\t\"sSortJUIAsc\": _sortIcon+\"triangle-1-n\",\n\t\t\"sSortJUIDesc\": _sortIcon+\"triangle-1-s\",\n\t\t\"sSortJUI\": _sortIcon+\"carat-2-n-s\",\n\t\t\"sSortJUIAscAllowed\": _sortIcon+\"carat-1-n\",\n\t\t\"sSortJUIDescAllowed\": _sortIcon+\"carat-1-s\",\n\t\t\"sSortJUIWrapper\": \"DataTables_sort_wrapper\",\n\t\t\"sSortIcon\": \"DataTables_sort_icon\",\n\t\n\t\t/* Scrolling */\n\t\t\"sScrollHead\": \"dataTables_scrollHead \"+_stateDefault,\n\t\t\"sScrollFoot\": \"dataTables_scrollFoot \"+_stateDefault,\n\t\n\t\t/* Misc */\n\t\t\"sHeaderTH\": _stateDefault,\n\t\t\"sFooterTH\": _stateDefault,\n\t\t\"sJUIHeader\": _headerFooter+\" ui-corner-tl ui-corner-tr\",\n\t\t\"sJUIFooter\": _headerFooter+\" ui-corner-bl ui-corner-br\"\n\t} );\n\t\n\t}());\n\t\n\t\n\t\n\tvar extPagination = DataTable.ext.pager;\n\t\n\tfunction _numbers ( page, pages ) {\n\t\tvar\n\t\t\tnumbers = [],\n\t\t\tbuttons = extPagination.numbers_length,\n\t\t\thalf = Math.floor( buttons / 2 ),\n\t\t\ti = 1;\n\t\n\t\tif ( pages <= buttons ) {\n\t\t\tnumbers = _range( 0, pages );\n\t\t}\n\t\telse if ( page <= half ) {\n\t\t\tnumbers = _range( 0, buttons-2 );\n\t\t\tnumbers.push( 'ellipsis' );\n\t\t\tnumbers.push( pages-1 );\n\t\t}\n\t\telse if ( page >= pages - 1 - half ) {\n\t\t\tnumbers = _range( pages-(buttons-2), pages );\n\t\t\tnumbers.splice( 0, 0, 'ellipsis' ); // no unshift in ie6\n\t\t\tnumbers.splice( 0, 0, 0 );\n\t\t}\n\t\telse {\n\t\t\tnumbers = _range( page-half+2, page+half-1 );\n\t\t\tnumbers.push( 'ellipsis' );\n\t\t\tnumbers.push( pages-1 );\n\t\t\tnumbers.splice( 0, 0, 'ellipsis' );\n\t\t\tnumbers.splice( 0, 0, 0 );\n\t\t}\n\t\n\t\tnumbers.DT_el = 'span';\n\t\treturn numbers;\n\t}\n\t\n\t\n\t$.extend( extPagination, {\n\t\tsimple: function ( page, pages ) {\n\t\t\treturn [ 'previous', 'next' ];\n\t\t},\n\t\n\t\tfull: function ( page, pages ) {\n\t\t\treturn [ 'first', 'previous', 'next', 'last' ];\n\t\t},\n\t\n\t\tnumbers: function ( page, pages ) {\n\t\t\treturn [ _numbers(page, pages) ];\n\t\t},\n\t\n\t\tsimple_numbers: function ( page, pages ) {\n\t\t\treturn [ 'previous', _numbers(page, pages), 'next' ];\n\t\t},\n\t\n\t\tfull_numbers: function ( page, pages ) {\n\t\t\treturn [ 'first', 'previous', _numbers(page, pages), 'next', 'last' ];\n\t\t},\n\t\n\t\t// For testing and plug-ins to use\n\t\t_numbers: _numbers,\n\t\n\t\t// Number of number buttons (including ellipsis) to show. _Must be odd!_\n\t\tnumbers_length: 7\n\t} );\n\t\n\t\n\t$.extend( true, DataTable.ext.renderer, {\n\t\tpageButton: {\n\t\t\t_: function ( settings, host, idx, buttons, page, pages ) {\n\t\t\t\tvar classes = settings.oClasses;\n\t\t\t\tvar lang = settings.oLanguage.oPaginate;\n\t\t\t\tvar aria = settings.oLanguage.oAria.paginate || {};\n\t\t\t\tvar btnDisplay, btnClass, counter=0;\n\t\n\t\t\t\tvar attach = function( container, buttons ) {\n\t\t\t\t\tvar i, ien, node, button;\n\t\t\t\t\tvar clickHandler = function ( e ) {\n\t\t\t\t\t\t_fnPageChange( settings, e.data.action, true );\n\t\t\t\t\t};\n\t\n\t\t\t\t\tfor ( i=0, ien=buttons.length ; i<ien ; i++ ) {\n\t\t\t\t\t\tbutton = buttons[i];\n\t\n\t\t\t\t\t\tif ( $.isArray( button ) ) {\n\t\t\t\t\t\t\tvar inner = $( '<'+(button.DT_el || 'div')+'/>' )\n\t\t\t\t\t\t\t\t.appendTo( container );\n\t\t\t\t\t\t\tattach( inner, button );\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tbtnDisplay = null;\n\t\t\t\t\t\t\tbtnClass = '';\n\t\n\t\t\t\t\t\t\tswitch ( button ) {\n\t\t\t\t\t\t\t\tcase 'ellipsis':\n\t\t\t\t\t\t\t\t\tcontainer.append('<span class=\"ellipsis\">…</span>');\n\t\t\t\t\t\t\t\t\tbreak;\n\t\n\t\t\t\t\t\t\t\tcase 'first':\n\t\t\t\t\t\t\t\t\tbtnDisplay = lang.sFirst;\n\t\t\t\t\t\t\t\t\tbtnClass = button + (page > 0 ?\n\t\t\t\t\t\t\t\t\t\t'' : ' '+classes.sPageButtonDisabled);\n\t\t\t\t\t\t\t\t\tbreak;\n\t\n\t\t\t\t\t\t\t\tcase 'previous':\n\t\t\t\t\t\t\t\t\tbtnDisplay = lang.sPrevious;\n\t\t\t\t\t\t\t\t\tbtnClass = button + (page > 0 ?\n\t\t\t\t\t\t\t\t\t\t'' : ' '+classes.sPageButtonDisabled);\n\t\t\t\t\t\t\t\t\tbreak;\n\t\n\t\t\t\t\t\t\t\tcase 'next':\n\t\t\t\t\t\t\t\t\tbtnDisplay = lang.sNext;\n\t\t\t\t\t\t\t\t\tbtnClass = button + (page < pages-1 ?\n\t\t\t\t\t\t\t\t\t\t'' : ' '+classes.sPageButtonDisabled);\n\t\t\t\t\t\t\t\t\tbreak;\n\t\n\t\t\t\t\t\t\t\tcase 'last':\n\t\t\t\t\t\t\t\t\tbtnDisplay = lang.sLast;\n\t\t\t\t\t\t\t\t\tbtnClass = button + (page < pages-1 ?\n\t\t\t\t\t\t\t\t\t\t'' : ' '+classes.sPageButtonDisabled);\n\t\t\t\t\t\t\t\t\tbreak;\n\t\n\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\tbtnDisplay = button + 1;\n\t\t\t\t\t\t\t\t\tbtnClass = page === button ?\n\t\t\t\t\t\t\t\t\t\tclasses.sPageButtonActive : '';\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t\tif ( btnDisplay !== null ) {\n\t\t\t\t\t\t\t\tnode = $('<a>', {\n\t\t\t\t\t\t\t\t\t\t'class': classes.sPageButton+' '+btnClass,\n\t\t\t\t\t\t\t\t\t\t'aria-controls': settings.sTableId,\n\t\t\t\t\t\t\t\t\t\t'aria-label': aria[ button ],\n\t\t\t\t\t\t\t\t\t\t'data-dt-idx': counter,\n\t\t\t\t\t\t\t\t\t\t'tabindex': settings.iTabIndex,\n\t\t\t\t\t\t\t\t\t\t'id': idx === 0 && typeof button === 'string' ?\n\t\t\t\t\t\t\t\t\t\t\tsettings.sTableId +'_'+ button :\n\t\t\t\t\t\t\t\t\t\t\tnull\n\t\t\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t\t\t\t.html( btnDisplay )\n\t\t\t\t\t\t\t\t\t.appendTo( container );\n\t\n\t\t\t\t\t\t\t\t_fnBindAction(\n\t\t\t\t\t\t\t\t\tnode, {action: button}, clickHandler\n\t\t\t\t\t\t\t\t);\n\t\n\t\t\t\t\t\t\t\tcounter++;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t};\n\t\n\t\t\t\t// IE9 throws an 'unknown error' if document.activeElement is used\n\t\t\t\t// inside an iframe or frame. Try / catch the error. Not good for\n\t\t\t\t// accessibility, but neither are frames.\n\t\t\t\tvar activeEl;\n\t\n\t\t\t\ttry {\n\t\t\t\t\t// Because this approach is destroying and recreating the paging\n\t\t\t\t\t// elements, focus is lost on the select button which is bad for\n\t\t\t\t\t// accessibility. So we want to restore focus once the draw has\n\t\t\t\t\t// completed\n\t\t\t\t\tactiveEl = $(host).find(document.activeElement).data('dt-idx');\n\t\t\t\t}\n\t\t\t\tcatch (e) {}\n\t\n\t\t\t\tattach( $(host).empty(), buttons );\n\t\n\t\t\t\tif ( activeEl ) {\n\t\t\t\t\t$(host).find( '[data-dt-idx='+activeEl+']' ).focus();\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t} );\n\t\n\t\n\t\n\t// Built in type detection. See model.ext.aTypes for information about\n\t// what is required from this methods.\n\t$.extend( DataTable.ext.type.detect, [\n\t\t// Plain numbers - first since V8 detects some plain numbers as dates\n\t\t// e.g. Date.parse('55') (but not all, e.g. Date.parse('22')...).\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\tvar decimal = settings.oLanguage.sDecimal;\n\t\t\treturn _isNumber( d, decimal ) ? 'num'+decimal : null;\n\t\t},\n\t\n\t\t// Dates (only those recognised by the browser's Date.parse)\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\t// V8 will remove any unknown characters at the start and end of the\n\t\t\t// expression, leading to false matches such as `$245.12` or `10%` being\n\t\t\t// a valid date. See forum thread 18941 for detail.\n\t\t\tif ( d && !(d instanceof Date) && ( ! _re_date_start.test(d) || ! _re_date_end.test(d) ) ) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\tvar parsed = Date.parse(d);\n\t\t\treturn (parsed !== null && !isNaN(parsed)) || _empty(d) ? 'date' : null;\n\t\t},\n\t\n\t\t// Formatted numbers\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\tvar decimal = settings.oLanguage.sDecimal;\n\t\t\treturn _isNumber( d, decimal, true ) ? 'num-fmt'+decimal : null;\n\t\t},\n\t\n\t\t// HTML numeric\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\tvar decimal = settings.oLanguage.sDecimal;\n\t\t\treturn _htmlNumeric( d, decimal ) ? 'html-num'+decimal : null;\n\t\t},\n\t\n\t\t// HTML numeric, formatted\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\tvar decimal = settings.oLanguage.sDecimal;\n\t\t\treturn _htmlNumeric( d, decimal, true ) ? 'html-num-fmt'+decimal : null;\n\t\t},\n\t\n\t\t// HTML (this is strict checking - there must be html)\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\treturn _empty( d ) || (typeof d === 'string' && d.indexOf('<') !== -1) ?\n\t\t\t\t'html' : null;\n\t\t}\n\t] );\n\t\n\t\n\t\n\t// Filter formatting functions. See model.ext.ofnSearch for information about\n\t// what is required from these methods.\n\t// \n\t// Note that additional search methods are added for the html numbers and\n\t// html formatted numbers by `_addNumericSort()` when we know what the decimal\n\t// place is\n\t\n\t\n\t$.extend( DataTable.ext.type.search, {\n\t\thtml: function ( data ) {\n\t\t\treturn _empty(data) ?\n\t\t\t\tdata :\n\t\t\t\ttypeof data === 'string' ?\n\t\t\t\t\tdata\n\t\t\t\t\t\t.replace( _re_new_lines, \" \" )\n\t\t\t\t\t\t.replace( _re_html, \"\" ) :\n\t\t\t\t\t'';\n\t\t},\n\t\n\t\tstring: function ( data ) {\n\t\t\treturn _empty(data) ?\n\t\t\t\tdata :\n\t\t\t\ttypeof data === 'string' ?\n\t\t\t\t\tdata.replace( _re_new_lines, \" \" ) :\n\t\t\t\t\tdata;\n\t\t}\n\t} );\n\t\n\t\n\t\n\tvar __numericReplace = function ( d, decimalPlace, re1, re2 ) {\n\t\tif ( d !== 0 && (!d || d === '-') ) {\n\t\t\treturn -Infinity;\n\t\t}\n\t\n\t\t// If a decimal place other than `.` is used, it needs to be given to the\n\t\t// function so we can detect it and replace with a `.` which is the only\n\t\t// decimal place Javascript recognises - it is not locale aware.\n\t\tif ( decimalPlace ) {\n\t\t\td = _numToDecimal( d, decimalPlace );\n\t\t}\n\t\n\t\tif ( d.replace ) {\n\t\t\tif ( re1 ) {\n\t\t\t\td = d.replace( re1, '' );\n\t\t\t}\n\t\n\t\t\tif ( re2 ) {\n\t\t\t\td = d.replace( re2, '' );\n\t\t\t}\n\t\t}\n\t\n\t\treturn d * 1;\n\t};\n\t\n\t\n\t// Add the numeric 'deformatting' functions for sorting and search. This is done\n\t// in a function to provide an easy ability for the language options to add\n\t// additional methods if a non-period decimal place is used.\n\tfunction _addNumericSort ( decimalPlace ) {\n\t\t$.each(\n\t\t\t{\n\t\t\t\t// Plain numbers\n\t\t\t\t\"num\": function ( d ) {\n\t\t\t\t\treturn __numericReplace( d, decimalPlace );\n\t\t\t\t},\n\t\n\t\t\t\t// Formatted numbers\n\t\t\t\t\"num-fmt\": function ( d ) {\n\t\t\t\t\treturn __numericReplace( d, decimalPlace, _re_formatted_numeric );\n\t\t\t\t},\n\t\n\t\t\t\t// HTML numeric\n\t\t\t\t\"html-num\": function ( d ) {\n\t\t\t\t\treturn __numericReplace( d, decimalPlace, _re_html );\n\t\t\t\t},\n\t\n\t\t\t\t// HTML numeric, formatted\n\t\t\t\t\"html-num-fmt\": function ( d ) {\n\t\t\t\t\treturn __numericReplace( d, decimalPlace, _re_html, _re_formatted_numeric );\n\t\t\t\t}\n\t\t\t},\n\t\t\tfunction ( key, fn ) {\n\t\t\t\t// Add the ordering method\n\t\t\t\t_ext.type.order[ key+decimalPlace+'-pre' ] = fn;\n\t\n\t\t\t\t// For HTML types add a search formatter that will strip the HTML\n\t\t\t\tif ( key.match(/^html\\-/) ) {\n\t\t\t\t\t_ext.type.search[ key+decimalPlace ] = _ext.type.search.html;\n\t\t\t\t}\n\t\t\t}\n\t\t);\n\t}\n\t\n\t\n\t// Default sort methods\n\t$.extend( _ext.type.order, {\n\t\t// Dates\n\t\t\"date-pre\": function ( d ) {\n\t\t\treturn Date.parse( d ) || 0;\n\t\t},\n\t\n\t\t// html\n\t\t\"html-pre\": function ( a ) {\n\t\t\treturn _empty(a) ?\n\t\t\t\t'' :\n\t\t\t\ta.replace ?\n\t\t\t\t\ta.replace( /<.*?>/g, \"\" ).toLowerCase() :\n\t\t\t\t\ta+'';\n\t\t},\n\t\n\t\t// string\n\t\t\"string-pre\": function ( a ) {\n\t\t\t// This is a little complex, but faster than always calling toString,\n\t\t\t// http://jsperf.com/tostring-v-check\n\t\t\treturn _empty(a) ?\n\t\t\t\t'' :\n\t\t\t\ttypeof a === 'string' ?\n\t\t\t\t\ta.toLowerCase() :\n\t\t\t\t\t! a.toString ?\n\t\t\t\t\t\t'' :\n\t\t\t\t\t\ta.toString();\n\t\t},\n\t\n\t\t// string-asc and -desc are retained only for compatibility with the old\n\t\t// sort methods\n\t\t\"string-asc\": function ( x, y ) {\n\t\t\treturn ((x < y) ? -1 : ((x > y) ? 1 : 0));\n\t\t},\n\t\n\t\t\"string-desc\": function ( x, y ) {\n\t\t\treturn ((x < y) ? 1 : ((x > y) ? -1 : 0));\n\t\t}\n\t} );\n\t\n\t\n\t// Numeric sorting types - order doesn't matter here\n\t_addNumericSort( '' );\n\t\n\t\n\t$.extend( true, DataTable.ext.renderer, {\n\t\theader: {\n\t\t\t_: function ( settings, cell, column, classes ) {\n\t\t\t\t// No additional mark-up required\n\t\t\t\t// Attach a sort listener to update on sort - note that using the\n\t\t\t\t// `DT` namespace will allow the event to be removed automatically\n\t\t\t\t// on destroy, while the `dt` namespaced event is the one we are\n\t\t\t\t// listening for\n\t\t\t\t$(settings.nTable).on( 'order.dt.DT', function ( e, ctx, sorting, columns ) {\n\t\t\t\t\tif ( settings !== ctx ) { // need to check this this is the host\n\t\t\t\t\t\treturn; // table, not a nested one\n\t\t\t\t\t}\n\t\n\t\t\t\t\tvar colIdx = column.idx;\n\t\n\t\t\t\t\tcell\n\t\t\t\t\t\t.removeClass(\n\t\t\t\t\t\t\tcolumn.sSortingClass +' '+\n\t\t\t\t\t\t\tclasses.sSortAsc +' '+\n\t\t\t\t\t\t\tclasses.sSortDesc\n\t\t\t\t\t\t)\n\t\t\t\t\t\t.addClass( columns[ colIdx ] == 'asc' ?\n\t\t\t\t\t\t\tclasses.sSortAsc : columns[ colIdx ] == 'desc' ?\n\t\t\t\t\t\t\t\tclasses.sSortDesc :\n\t\t\t\t\t\t\t\tcolumn.sSortingClass\n\t\t\t\t\t\t);\n\t\t\t\t} );\n\t\t\t},\n\t\n\t\t\tjqueryui: function ( settings, cell, column, classes ) {\n\t\t\t\t$('<div/>')\n\t\t\t\t\t.addClass( classes.sSortJUIWrapper )\n\t\t\t\t\t.append( cell.contents() )\n\t\t\t\t\t.append( $('<span/>')\n\t\t\t\t\t\t.addClass( classes.sSortIcon+' '+column.sSortingClassJUI )\n\t\t\t\t\t)\n\t\t\t\t\t.appendTo( cell );\n\t\n\t\t\t\t// Attach a sort listener to update on sort\n\t\t\t\t$(settings.nTable).on( 'order.dt.DT', function ( e, ctx, sorting, columns ) {\n\t\t\t\t\tif ( settings !== ctx ) {\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\n\t\t\t\t\tvar colIdx = column.idx;\n\t\n\t\t\t\t\tcell\n\t\t\t\t\t\t.removeClass( classes.sSortAsc +\" \"+classes.sSortDesc )\n\t\t\t\t\t\t.addClass( columns[ colIdx ] == 'asc' ?\n\t\t\t\t\t\t\tclasses.sSortAsc : columns[ colIdx ] == 'desc' ?\n\t\t\t\t\t\t\t\tclasses.sSortDesc :\n\t\t\t\t\t\t\t\tcolumn.sSortingClass\n\t\t\t\t\t\t);\n\t\n\t\t\t\t\tcell\n\t\t\t\t\t\t.find( 'span.'+classes.sSortIcon )\n\t\t\t\t\t\t.removeClass(\n\t\t\t\t\t\t\tclasses.sSortJUIAsc +\" \"+\n\t\t\t\t\t\t\tclasses.sSortJUIDesc +\" \"+\n\t\t\t\t\t\t\tclasses.sSortJUI +\" \"+\n\t\t\t\t\t\t\tclasses.sSortJUIAscAllowed +\" \"+\n\t\t\t\t\t\t\tclasses.sSortJUIDescAllowed\n\t\t\t\t\t\t)\n\t\t\t\t\t\t.addClass( columns[ colIdx ] == 'asc' ?\n\t\t\t\t\t\t\tclasses.sSortJUIAsc : columns[ colIdx ] == 'desc' ?\n\t\t\t\t\t\t\t\tclasses.sSortJUIDesc :\n\t\t\t\t\t\t\t\tcolumn.sSortingClassJUI\n\t\t\t\t\t\t);\n\t\t\t\t} );\n\t\t\t}\n\t\t}\n\t} );\n\t\n\t/*\n\t * Public helper functions. These aren't used internally by DataTables, or\n\t * called by any of the options passed into DataTables, but they can be used\n\t * externally by developers working with DataTables. They are helper functions\n\t * to make working with DataTables a little bit easier.\n\t */\n\t\n\tvar __htmlEscapeEntities = function ( d ) {\n\t\treturn typeof d === 'string' ?\n\t\t\td.replace(/</g, '<').replace(/>/g, '>').replace(/\"/g, '"') :\n\t\t\td;\n\t};\n\t\n\t/**\n\t * Helpers for `columns.render`.\n\t *\n\t * The options defined here can be used with the `columns.render` initialisation\n\t * option to provide a display renderer. The following functions are defined:\n\t *\n\t * * `number` - Will format numeric data (defined by `columns.data`) for\n\t * display, retaining the original unformatted data for sorting and filtering.\n\t * It takes 5 parameters:\n\t * * `string` - Thousands grouping separator\n\t * * `string` - Decimal point indicator\n\t * * `integer` - Number of decimal points to show\n\t * * `string` (optional) - Prefix.\n\t * * `string` (optional) - Postfix (/suffix).\n\t * * `text` - Escape HTML to help prevent XSS attacks. It has no optional\n\t * parameters.\n\t *\n\t * @example\n\t * // Column definition using the number renderer\n\t * {\n\t * data: \"salary\",\n\t * render: $.fn.dataTable.render.number( '\\'', '.', 0, '$' )\n\t * }\n\t *\n\t * @namespace\n\t */\n\tDataTable.render = {\n\t\tnumber: function ( thousands, decimal, precision, prefix, postfix ) {\n\t\t\treturn {\n\t\t\t\tdisplay: function ( d ) {\n\t\t\t\t\tif ( typeof d !== 'number' && typeof d !== 'string' ) {\n\t\t\t\t\t\treturn d;\n\t\t\t\t\t}\n\t\n\t\t\t\t\tvar negative = d < 0 ? '-' : '';\n\t\t\t\t\tvar flo = parseFloat( d );\n\t\n\t\t\t\t\t// If NaN then there isn't much formatting that we can do - just\n\t\t\t\t\t// return immediately, escaping any HTML (this was supposed to\n\t\t\t\t\t// be a number after all)\n\t\t\t\t\tif ( isNaN( flo ) ) {\n\t\t\t\t\t\treturn __htmlEscapeEntities( d );\n\t\t\t\t\t}\n\t\n\t\t\t\t\td = Math.abs( flo );\n\t\n\t\t\t\t\tvar intPart = parseInt( d, 10 );\n\t\t\t\t\tvar floatPart = precision ?\n\t\t\t\t\t\tdecimal+(d - intPart).toFixed( precision ).substring( 2 ):\n\t\t\t\t\t\t'';\n\t\n\t\t\t\t\treturn negative + (prefix||'') +\n\t\t\t\t\t\tintPart.toString().replace(\n\t\t\t\t\t\t\t/\\B(?=(\\d{3})+(?!\\d))/g, thousands\n\t\t\t\t\t\t) +\n\t\t\t\t\t\tfloatPart +\n\t\t\t\t\t\t(postfix||'');\n\t\t\t\t}\n\t\t\t};\n\t\t},\n\t\n\t\ttext: function () {\n\t\t\treturn {\n\t\t\t\tdisplay: __htmlEscapeEntities\n\t\t\t};\n\t\t}\n\t};\n\t\n\t\n\t/*\n\t * This is really a good bit rubbish this method of exposing the internal methods\n\t * publicly... - To be fixed in 2.0 using methods on the prototype\n\t */\n\t\n\t\n\t/**\n\t * Create a wrapper function for exporting an internal functions to an external API.\n\t * @param {string} fn API function name\n\t * @returns {function} wrapped function\n\t * @memberof DataTable#internal\n\t */\n\tfunction _fnExternApiFunc (fn)\n\t{\n\t\treturn function() {\n\t\t\tvar args = [_fnSettingsFromNode( this[DataTable.ext.iApiIndex] )].concat(\n\t\t\t\tArray.prototype.slice.call(arguments)\n\t\t\t);\n\t\t\treturn DataTable.ext.internal[fn].apply( this, args );\n\t\t};\n\t}\n\t\n\t\n\t/**\n\t * Reference to internal functions for use by plug-in developers. Note that\n\t * these methods are references to internal functions and are considered to be\n\t * private. If you use these methods, be aware that they are liable to change\n\t * between versions.\n\t * @namespace\n\t */\n\t$.extend( DataTable.ext.internal, {\n\t\t_fnExternApiFunc: _fnExternApiFunc,\n\t\t_fnBuildAjax: _fnBuildAjax,\n\t\t_fnAjaxUpdate: _fnAjaxUpdate,\n\t\t_fnAjaxParameters: _fnAjaxParameters,\n\t\t_fnAjaxUpdateDraw: _fnAjaxUpdateDraw,\n\t\t_fnAjaxDataSrc: _fnAjaxDataSrc,\n\t\t_fnAddColumn: _fnAddColumn,\n\t\t_fnColumnOptions: _fnColumnOptions,\n\t\t_fnAdjustColumnSizing: _fnAdjustColumnSizing,\n\t\t_fnVisibleToColumnIndex: _fnVisibleToColumnIndex,\n\t\t_fnColumnIndexToVisible: _fnColumnIndexToVisible,\n\t\t_fnVisbleColumns: _fnVisbleColumns,\n\t\t_fnGetColumns: _fnGetColumns,\n\t\t_fnColumnTypes: _fnColumnTypes,\n\t\t_fnApplyColumnDefs: _fnApplyColumnDefs,\n\t\t_fnHungarianMap: _fnHungarianMap,\n\t\t_fnCamelToHungarian: _fnCamelToHungarian,\n\t\t_fnLanguageCompat: _fnLanguageCompat,\n\t\t_fnBrowserDetect: _fnBrowserDetect,\n\t\t_fnAddData: _fnAddData,\n\t\t_fnAddTr: _fnAddTr,\n\t\t_fnNodeToDataIndex: _fnNodeToDataIndex,\n\t\t_fnNodeToColumnIndex: _fnNodeToColumnIndex,\n\t\t_fnGetCellData: _fnGetCellData,\n\t\t_fnSetCellData: _fnSetCellData,\n\t\t_fnSplitObjNotation: _fnSplitObjNotation,\n\t\t_fnGetObjectDataFn: _fnGetObjectDataFn,\n\t\t_fnSetObjectDataFn: _fnSetObjectDataFn,\n\t\t_fnGetDataMaster: _fnGetDataMaster,\n\t\t_fnClearTable: _fnClearTable,\n\t\t_fnDeleteIndex: _fnDeleteIndex,\n\t\t_fnInvalidate: _fnInvalidate,\n\t\t_fnGetRowElements: _fnGetRowElements,\n\t\t_fnCreateTr: _fnCreateTr,\n\t\t_fnBuildHead: _fnBuildHead,\n\t\t_fnDrawHead: _fnDrawHead,\n\t\t_fnDraw: _fnDraw,\n\t\t_fnReDraw: _fnReDraw,\n\t\t_fnAddOptionsHtml: _fnAddOptionsHtml,\n\t\t_fnDetectHeader: _fnDetectHeader,\n\t\t_fnGetUniqueThs: _fnGetUniqueThs,\n\t\t_fnFeatureHtmlFilter: _fnFeatureHtmlFilter,\n\t\t_fnFilterComplete: _fnFilterComplete,\n\t\t_fnFilterCustom: _fnFilterCustom,\n\t\t_fnFilterColumn: _fnFilterColumn,\n\t\t_fnFilter: _fnFilter,\n\t\t_fnFilterCreateSearch: _fnFilterCreateSearch,\n\t\t_fnEscapeRegex: _fnEscapeRegex,\n\t\t_fnFilterData: _fnFilterData,\n\t\t_fnFeatureHtmlInfo: _fnFeatureHtmlInfo,\n\t\t_fnUpdateInfo: _fnUpdateInfo,\n\t\t_fnInfoMacros: _fnInfoMacros,\n\t\t_fnInitialise: _fnInitialise,\n\t\t_fnInitComplete: _fnInitComplete,\n\t\t_fnLengthChange: _fnLengthChange,\n\t\t_fnFeatureHtmlLength: _fnFeatureHtmlLength,\n\t\t_fnFeatureHtmlPaginate: _fnFeatureHtmlPaginate,\n\t\t_fnPageChange: _fnPageChange,\n\t\t_fnFeatureHtmlProcessing: _fnFeatureHtmlProcessing,\n\t\t_fnProcessingDisplay: _fnProcessingDisplay,\n\t\t_fnFeatureHtmlTable: _fnFeatureHtmlTable,\n\t\t_fnScrollDraw: _fnScrollDraw,\n\t\t_fnApplyToChildren: _fnApplyToChildren,\n\t\t_fnCalculateColumnWidths: _fnCalculateColumnWidths,\n\t\t_fnThrottle: _fnThrottle,\n\t\t_fnConvertToWidth: _fnConvertToWidth,\n\t\t_fnGetWidestNode: _fnGetWidestNode,\n\t\t_fnGetMaxLenString: _fnGetMaxLenString,\n\t\t_fnStringToCss: _fnStringToCss,\n\t\t_fnSortFlatten: _fnSortFlatten,\n\t\t_fnSort: _fnSort,\n\t\t_fnSortAria: _fnSortAria,\n\t\t_fnSortListener: _fnSortListener,\n\t\t_fnSortAttachListener: _fnSortAttachListener,\n\t\t_fnSortingClasses: _fnSortingClasses,\n\t\t_fnSortData: _fnSortData,\n\t\t_fnSaveState: _fnSaveState,\n\t\t_fnLoadState: _fnLoadState,\n\t\t_fnSettingsFromNode: _fnSettingsFromNode,\n\t\t_fnLog: _fnLog,\n\t\t_fnMap: _fnMap,\n\t\t_fnBindAction: _fnBindAction,\n\t\t_fnCallbackReg: _fnCallbackReg,\n\t\t_fnCallbackFire: _fnCallbackFire,\n\t\t_fnLengthOverflow: _fnLengthOverflow,\n\t\t_fnRenderer: _fnRenderer,\n\t\t_fnDataSource: _fnDataSource,\n\t\t_fnRowAttributes: _fnRowAttributes,\n\t\t_fnCalculateEnd: function () {} // Used by a lot of plug-ins, but redundant\n\t\t // in 1.10, so this dead-end function is\n\t\t // added to prevent errors\n\t} );\n\t\n\n\t// jQuery access\n\t$.fn.dataTable = DataTable;\n\n\t// Provide access to the host jQuery object (circular reference)\n\tDataTable.$ = $;\n\n\t// Legacy aliases\n\t$.fn.dataTableSettings = DataTable.settings;\n\t$.fn.dataTableExt = DataTable.ext;\n\n\t// With a capital `D` we return a DataTables API instance rather than a\n\t// jQuery object\n\t$.fn.DataTable = function ( opts ) {\n\t\treturn $(this).dataTable( opts ).api();\n\t};\n\n\t// All properties that are available to $.fn.dataTable should also be\n\t// available on $.fn.DataTable\n\t$.each( DataTable, function ( prop, val ) {\n\t\t$.fn.DataTable[ prop ] = val;\n\t} );\n\n\n\t// Information about events fired by DataTables - for documentation.\n\t/**\n\t * Draw event, fired whenever the table is redrawn on the page, at the same\n\t * point as fnDrawCallback. This may be useful for binding events or\n\t * performing calculations when the table is altered at all.\n\t * @name DataTable#draw.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * Search event, fired when the searching applied to the table (using the\n\t * built-in global search, or column filters) is altered.\n\t * @name DataTable#search.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * Page change event, fired when the paging of the table is altered.\n\t * @name DataTable#page.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * Order event, fired when the ordering applied to the table is altered.\n\t * @name DataTable#order.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * DataTables initialisation complete event, fired when the table is fully\n\t * drawn, including Ajax data loaded, if Ajax data is required.\n\t * @name DataTable#init.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} oSettings DataTables settings object\n\t * @param {object} json The JSON object request from the server - only\n\t * present if client-side Ajax sourced data is used</li></ol>\n\t */\n\n\t/**\n\t * State save event, fired when the table has changed state a new state save\n\t * is required. This event allows modification of the state saving object\n\t * prior to actually doing the save, including addition or other state\n\t * properties (for plug-ins) or modification of a DataTables core property.\n\t * @name DataTable#stateSaveParams.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} oSettings DataTables settings object\n\t * @param {object} json The state information to be saved\n\t */\n\n\t/**\n\t * State load event, fired when the table is loading state from the stored\n\t * data, but prior to the settings object being modified by the saved state\n\t * - allowing modification of the saved state is required or loading of\n\t * state for a plug-in.\n\t * @name DataTable#stateLoadParams.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} oSettings DataTables settings object\n\t * @param {object} json The saved state information\n\t */\n\n\t/**\n\t * State loaded event, fired when state has been loaded from stored data and\n\t * the settings object has been modified by the loaded data.\n\t * @name DataTable#stateLoaded.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} oSettings DataTables settings object\n\t * @param {object} json The saved state information\n\t */\n\n\t/**\n\t * Processing event, fired when DataTables is doing some kind of processing\n\t * (be it, order, searcg or anything else). It can be used to indicate to\n\t * the end user that there is something happening, or that something has\n\t * finished.\n\t * @name DataTable#processing.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} oSettings DataTables settings object\n\t * @param {boolean} bShow Flag for if DataTables is doing processing or not\n\t */\n\n\t/**\n\t * Ajax (XHR) event, fired whenever an Ajax request is completed from a\n\t * request to made to the server for new data. This event is called before\n\t * DataTables processed the returned data, so it can also be used to pre-\n\t * process the data returned from the server, if needed.\n\t *\n\t * Note that this trigger is called in `fnServerData`, if you override\n\t * `fnServerData` and which to use this event, you need to trigger it in you\n\t * success function.\n\t * @name DataTable#xhr.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t * @param {object} json JSON returned from the server\n\t *\n\t * @example\n\t * // Use a custom property returned from the server in another DOM element\n\t * $('#table').dataTable().on('xhr.dt', function (e, settings, json) {\n\t * $('#status').html( json.status );\n\t * } );\n\t *\n\t * @example\n\t * // Pre-process the data returned from the server\n\t * $('#table').dataTable().on('xhr.dt', function (e, settings, json) {\n\t * for ( var i=0, ien=json.aaData.length ; i<ien ; i++ ) {\n\t * json.aaData[i].sum = json.aaData[i].one + json.aaData[i].two;\n\t * }\n\t * // Note no return - manipulate the data directly in the JSON object.\n\t * } );\n\t */\n\n\t/**\n\t * Destroy event, fired when the DataTable is destroyed by calling fnDestroy\n\t * or passing the bDestroy:true parameter in the initialisation object. This\n\t * can be used to remove bound events, added DOM nodes, etc.\n\t * @name DataTable#destroy.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * Page length change event, fired when number of records to show on each\n\t * page (the length) is changed.\n\t * @name DataTable#length.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t * @param {integer} len New length\n\t */\n\n\t/**\n\t * Column sizing has changed.\n\t * @name DataTable#column-sizing.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * Column visibility has changed.\n\t * @name DataTable#column-visibility.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t * @param {int} column Column index\n\t * @param {bool} vis `false` if column now hidden, or `true` if visible\n\t */\n\n\treturn $.fn.dataTable;\n}));\n\n},{\"jquery\":18}],13:[function(require,module,exports){\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nfunction EventEmitter() {\n this._events = this._events || {};\n this._maxListeners = this._maxListeners || undefined;\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nEventEmitter.defaultMaxListeners = 10;\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function(n) {\n if (!isNumber(n) || n < 0 || isNaN(n))\n throw TypeError('n must be a positive number');\n this._maxListeners = n;\n return this;\n};\n\nEventEmitter.prototype.emit = function(type) {\n var er, handler, len, args, i, listeners;\n\n if (!this._events)\n this._events = {};\n\n // If there is no 'error' event listener then throw.\n if (type === 'error') {\n if (!this._events.error ||\n (isObject(this._events.error) && !this._events.error.length)) {\n er = arguments[1];\n if (er instanceof Error) {\n throw er; // Unhandled 'error' event\n } else {\n // At least give some kind of context to the user\n var err = new Error('Uncaught, unspecified \"error\" event. (' + er + ')');\n err.context = er;\n throw err;\n }\n }\n }\n\n handler = this._events[type];\n\n if (isUndefined(handler))\n return false;\n\n if (isFunction(handler)) {\n switch (arguments.length) {\n // fast cases\n case 1:\n handler.call(this);\n break;\n case 2:\n handler.call(this, arguments[1]);\n break;\n case 3:\n handler.call(this, arguments[1], arguments[2]);\n break;\n // slower\n default:\n args = Array.prototype.slice.call(arguments, 1);\n handler.apply(this, args);\n }\n } else if (isObject(handler)) {\n args = Array.prototype.slice.call(arguments, 1);\n listeners = handler.slice();\n len = listeners.length;\n for (i = 0; i < len; i++)\n listeners[i].apply(this, args);\n }\n\n return true;\n};\n\nEventEmitter.prototype.addListener = function(type, listener) {\n var m;\n\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n if (!this._events)\n this._events = {};\n\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (this._events.newListener)\n this.emit('newListener', type,\n isFunction(listener.listener) ?\n listener.listener : listener);\n\n if (!this._events[type])\n // Optimize the case of one listener. Don't need the extra array object.\n this._events[type] = listener;\n else if (isObject(this._events[type]))\n // If we've already got an array, just append.\n this._events[type].push(listener);\n else\n // Adding the second element, need to change to array.\n this._events[type] = [this._events[type], listener];\n\n // Check for listener leak\n if (isObject(this._events[type]) && !this._events[type].warned) {\n if (!isUndefined(this._maxListeners)) {\n m = this._maxListeners;\n } else {\n m = EventEmitter.defaultMaxListeners;\n }\n\n if (m && m > 0 && this._events[type].length > m) {\n this._events[type].warned = true;\n console.error('(node) warning: possible EventEmitter memory ' +\n 'leak detected. %d listeners added. ' +\n 'Use emitter.setMaxListeners() to increase limit.',\n this._events[type].length);\n if (typeof console.trace === 'function') {\n // not supported in IE 10\n console.trace();\n }\n }\n }\n\n return this;\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.once = function(type, listener) {\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n var fired = false;\n\n function g() {\n this.removeListener(type, g);\n\n if (!fired) {\n fired = true;\n listener.apply(this, arguments);\n }\n }\n\n g.listener = listener;\n this.on(type, g);\n\n return this;\n};\n\n// emits a 'removeListener' event iff the listener was removed\nEventEmitter.prototype.removeListener = function(type, listener) {\n var list, position, length, i;\n\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n if (!this._events || !this._events[type])\n return this;\n\n list = this._events[type];\n length = list.length;\n position = -1;\n\n if (list === listener ||\n (isFunction(list.listener) && list.listener === listener)) {\n delete this._events[type];\n if (this._events.removeListener)\n this.emit('removeListener', type, listener);\n\n } else if (isObject(list)) {\n for (i = length; i-- > 0;) {\n if (list[i] === listener ||\n (list[i].listener && list[i].listener === listener)) {\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (list.length === 1) {\n list.length = 0;\n delete this._events[type];\n } else {\n list.splice(position, 1);\n }\n\n if (this._events.removeListener)\n this.emit('removeListener', type, listener);\n }\n\n return this;\n};\n\nEventEmitter.prototype.removeAllListeners = function(type) {\n var key, listeners;\n\n if (!this._events)\n return this;\n\n // not listening for removeListener, no need to emit\n if (!this._events.removeListener) {\n if (arguments.length === 0)\n this._events = {};\n else if (this._events[type])\n delete this._events[type];\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n for (key in this._events) {\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = {};\n return this;\n }\n\n listeners = this._events[type];\n\n if (isFunction(listeners)) {\n this.removeListener(type, listeners);\n } else if (listeners) {\n // LIFO order\n while (listeners.length)\n this.removeListener(type, listeners[listeners.length - 1]);\n }\n delete this._events[type];\n\n return this;\n};\n\nEventEmitter.prototype.listeners = function(type) {\n var ret;\n if (!this._events || !this._events[type])\n ret = [];\n else if (isFunction(this._events[type]))\n ret = [this._events[type]];\n else\n ret = this._events[type].slice();\n return ret;\n};\n\nEventEmitter.prototype.listenerCount = function(type) {\n if (this._events) {\n var evlistener = this._events[type];\n\n if (isFunction(evlistener))\n return 1;\n else if (evlistener)\n return evlistener.length;\n }\n return 0;\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n return emitter.listenerCount(type);\n};\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\n\n},{}],14:[function(require,module,exports){\nvar jQuery = require('jquery');\n\n/*!\n * jQuery UI Core 1.10.4\n * http://jqueryui.com\n *\n * Copyright 2014 jQuery Foundation and other contributors\n * Released under the MIT license.\n * http://jquery.org/license\n *\n * http://api.jqueryui.com/category/ui-core/\n */\n(function( $, undefined ) {\n\nvar uuid = 0,\n\truniqueId = /^ui-id-\\d+$/;\n\n// $.ui might exist from components with no dependencies, e.g., $.ui.position\n$.ui = $.ui || {};\n\n$.extend( $.ui, {\n\tversion: \"1.10.4\",\n\n\tkeyCode: {\n\t\tBACKSPACE: 8,\n\t\tCOMMA: 188,\n\t\tDELETE: 46,\n\t\tDOWN: 40,\n\t\tEND: 35,\n\t\tENTER: 13,\n\t\tESCAPE: 27,\n\t\tHOME: 36,\n\t\tLEFT: 37,\n\t\tNUMPAD_ADD: 107,\n\t\tNUMPAD_DECIMAL: 110,\n\t\tNUMPAD_DIVIDE: 111,\n\t\tNUMPAD_ENTER: 108,\n\t\tNUMPAD_MULTIPLY: 106,\n\t\tNUMPAD_SUBTRACT: 109,\n\t\tPAGE_DOWN: 34,\n\t\tPAGE_UP: 33,\n\t\tPERIOD: 190,\n\t\tRIGHT: 39,\n\t\tSPACE: 32,\n\t\tTAB: 9,\n\t\tUP: 38\n\t}\n});\n\n// plugins\n$.fn.extend({\n\tfocus: (function( orig ) {\n\t\treturn function( delay, fn ) {\n\t\t\treturn typeof delay === \"number\" ?\n\t\t\t\tthis.each(function() {\n\t\t\t\t\tvar elem = this;\n\t\t\t\t\tsetTimeout(function() {\n\t\t\t\t\t\t$( elem ).focus();\n\t\t\t\t\t\tif ( fn ) {\n\t\t\t\t\t\t\tfn.call( elem );\n\t\t\t\t\t\t}\n\t\t\t\t\t}, delay );\n\t\t\t\t}) :\n\t\t\t\torig.apply( this, arguments );\n\t\t};\n\t})( $.fn.focus ),\n\n\tscrollParent: function() {\n\t\tvar scrollParent;\n\t\tif (($.ui.ie && (/(static|relative)/).test(this.css(\"position\"))) || (/absolute/).test(this.css(\"position\"))) {\n\t\t\tscrollParent = this.parents().filter(function() {\n\t\t\t\treturn (/(relative|absolute|fixed)/).test($.css(this,\"position\")) && (/(auto|scroll)/).test($.css(this,\"overflow\")+$.css(this,\"overflow-y\")+$.css(this,\"overflow-x\"));\n\t\t\t}).eq(0);\n\t\t} else {\n\t\t\tscrollParent = this.parents().filter(function() {\n\t\t\t\treturn (/(auto|scroll)/).test($.css(this,\"overflow\")+$.css(this,\"overflow-y\")+$.css(this,\"overflow-x\"));\n\t\t\t}).eq(0);\n\t\t}\n\n\t\treturn (/fixed/).test(this.css(\"position\")) || !scrollParent.length ? $(document) : scrollParent;\n\t},\n\n\tzIndex: function( zIndex ) {\n\t\tif ( zIndex !== undefined ) {\n\t\t\treturn this.css( \"zIndex\", zIndex );\n\t\t}\n\n\t\tif ( this.length ) {\n\t\t\tvar elem = $( this[ 0 ] ), position, value;\n\t\t\twhile ( elem.length && elem[ 0 ] !== document ) {\n\t\t\t\t// Ignore z-index if position is set to a value where z-index is ignored by the browser\n\t\t\t\t// This makes behavior of this function consistent across browsers\n\t\t\t\t// WebKit always returns auto if the element is positioned\n\t\t\t\tposition = elem.css( \"position\" );\n\t\t\t\tif ( position === \"absolute\" || position === \"relative\" || position === \"fixed\" ) {\n\t\t\t\t\t// IE returns 0 when zIndex is not specified\n\t\t\t\t\t// other browsers return a string\n\t\t\t\t\t// we ignore the case of nested elements with an explicit value of 0\n\t\t\t\t\t// <div style=\"z-index: -10;\"><div style=\"z-index: 0;\"></div></div>\n\t\t\t\t\tvalue = parseInt( elem.css( \"zIndex\" ), 10 );\n\t\t\t\t\tif ( !isNaN( value ) && value !== 0 ) {\n\t\t\t\t\t\treturn value;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telem = elem.parent();\n\t\t\t}\n\t\t}\n\n\t\treturn 0;\n\t},\n\n\tuniqueId: function() {\n\t\treturn this.each(function() {\n\t\t\tif ( !this.id ) {\n\t\t\t\tthis.id = \"ui-id-\" + (++uuid);\n\t\t\t}\n\t\t});\n\t},\n\n\tremoveUniqueId: function() {\n\t\treturn this.each(function() {\n\t\t\tif ( runiqueId.test( this.id ) ) {\n\t\t\t\t$( this ).removeAttr( \"id\" );\n\t\t\t}\n\t\t});\n\t}\n});\n\n// selectors\nfunction focusable( element, isTabIndexNotNaN ) {\n\tvar map, mapName, img,\n\t\tnodeName = element.nodeName.toLowerCase();\n\tif ( \"area\" === nodeName ) {\n\t\tmap = element.parentNode;\n\t\tmapName = map.name;\n\t\tif ( !element.href || !mapName || map.nodeName.toLowerCase() !== \"map\" ) {\n\t\t\treturn false;\n\t\t}\n\t\timg = $( \"img[usemap=#\" + mapName + \"]\" )[0];\n\t\treturn !!img && visible( img );\n\t}\n\treturn ( /input|select|textarea|button|object/.test( nodeName ) ?\n\t\t!element.disabled :\n\t\t\"a\" === nodeName ?\n\t\t\telement.href || isTabIndexNotNaN :\n\t\t\tisTabIndexNotNaN) &&\n\t\t// the element and all of its ancestors must be visible\n\t\tvisible( element );\n}\n\nfunction visible( element ) {\n\treturn $.expr.filters.visible( element ) &&\n\t\t!$( element ).parents().addBack().filter(function() {\n\t\t\treturn $.css( this, \"visibility\" ) === \"hidden\";\n\t\t}).length;\n}\n\n$.extend( $.expr[ \":\" ], {\n\tdata: $.expr.createPseudo ?\n\t\t$.expr.createPseudo(function( dataName ) {\n\t\t\treturn function( elem ) {\n\t\t\t\treturn !!$.data( elem, dataName );\n\t\t\t};\n\t\t}) :\n\t\t// support: jQuery <1.8\n\t\tfunction( elem, i, match ) {\n\t\t\treturn !!$.data( elem, match[ 3 ] );\n\t\t},\n\n\tfocusable: function( element ) {\n\t\treturn focusable( element, !isNaN( $.attr( element, \"tabindex\" ) ) );\n\t},\n\n\ttabbable: function( element ) {\n\t\tvar tabIndex = $.attr( element, \"tabindex\" ),\n\t\t\tisTabIndexNaN = isNaN( tabIndex );\n\t\treturn ( isTabIndexNaN || tabIndex >= 0 ) && focusable( element, !isTabIndexNaN );\n\t}\n});\n\n// support: jQuery <1.8\nif ( !$( \"<a>\" ).outerWidth( 1 ).jquery ) {\n\t$.each( [ \"Width\", \"Height\" ], function( i, name ) {\n\t\tvar side = name === \"Width\" ? [ \"Left\", \"Right\" ] : [ \"Top\", \"Bottom\" ],\n\t\t\ttype = name.toLowerCase(),\n\t\t\torig = {\n\t\t\t\tinnerWidth: $.fn.innerWidth,\n\t\t\t\tinnerHeight: $.fn.innerHeight,\n\t\t\t\touterWidth: $.fn.outerWidth,\n\t\t\t\touterHeight: $.fn.outerHeight\n\t\t\t};\n\n\t\tfunction reduce( elem, size, border, margin ) {\n\t\t\t$.each( side, function() {\n\t\t\t\tsize -= parseFloat( $.css( elem, \"padding\" + this ) ) || 0;\n\t\t\t\tif ( border ) {\n\t\t\t\t\tsize -= parseFloat( $.css( elem, \"border\" + this + \"Width\" ) ) || 0;\n\t\t\t\t}\n\t\t\t\tif ( margin ) {\n\t\t\t\t\tsize -= parseFloat( $.css( elem, \"margin\" + this ) ) || 0;\n\t\t\t\t}\n\t\t\t});\n\t\t\treturn size;\n\t\t}\n\n\t\t$.fn[ \"inner\" + name ] = function( size ) {\n\t\t\tif ( size === undefined ) {\n\t\t\t\treturn orig[ \"inner\" + name ].call( this );\n\t\t\t}\n\n\t\t\treturn this.each(function() {\n\t\t\t\t$( this ).css( type, reduce( this, size ) + \"px\" );\n\t\t\t});\n\t\t};\n\n\t\t$.fn[ \"outer\" + name] = function( size, margin ) {\n\t\t\tif ( typeof size !== \"number\" ) {\n\t\t\t\treturn orig[ \"outer\" + name ].call( this, size );\n\t\t\t}\n\n\t\t\treturn this.each(function() {\n\t\t\t\t$( this).css( type, reduce( this, size, true, margin ) + \"px\" );\n\t\t\t});\n\t\t};\n\t});\n}\n\n// support: jQuery <1.8\nif ( !$.fn.addBack ) {\n\t$.fn.addBack = function( selector ) {\n\t\treturn this.add( selector == null ?\n\t\t\tthis.prevObject : this.prevObject.filter( selector )\n\t\t);\n\t};\n}\n\n// support: jQuery 1.6.1, 1.6.2 (http://bugs.jquery.com/ticket/9413)\nif ( $( \"<a>\" ).data( \"a-b\", \"a\" ).removeData( \"a-b\" ).data( \"a-b\" ) ) {\n\t$.fn.removeData = (function( removeData ) {\n\t\treturn function( key ) {\n\t\t\tif ( arguments.length ) {\n\t\t\t\treturn removeData.call( this, $.camelCase( key ) );\n\t\t\t} else {\n\t\t\t\treturn removeData.call( this );\n\t\t\t}\n\t\t};\n\t})( $.fn.removeData );\n}\n\n\n\n\n\n// deprecated\n$.ui.ie = !!/msie [\\w.]+/.exec( navigator.userAgent.toLowerCase() );\n\n$.support.selectstart = \"onselectstart\" in document.createElement( \"div\" );\n$.fn.extend({\n\tdisableSelection: function() {\n\t\treturn this.bind( ( $.support.selectstart ? \"selectstart\" : \"mousedown\" ) +\n\t\t\t\".ui-disableSelection\", function( event ) {\n\t\t\t\tevent.preventDefault();\n\t\t\t});\n\t},\n\n\tenableSelection: function() {\n\t\treturn this.unbind( \".ui-disableSelection\" );\n\t}\n});\n\n$.extend( $.ui, {\n\t// $.ui.plugin is deprecated. Use $.widget() extensions instead.\n\tplugin: {\n\t\tadd: function( module, option, set ) {\n\t\t\tvar i,\n\t\t\t\tproto = $.ui[ module ].prototype;\n\t\t\tfor ( i in set ) {\n\t\t\t\tproto.plugins[ i ] = proto.plugins[ i ] || [];\n\t\t\t\tproto.plugins[ i ].push( [ option, set[ i ] ] );\n\t\t\t}\n\t\t},\n\t\tcall: function( instance, name, args ) {\n\t\t\tvar i,\n\t\t\t\tset = instance.plugins[ name ];\n\t\t\tif ( !set || !instance.element[ 0 ].parentNode || instance.element[ 0 ].parentNode.nodeType === 11 ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tfor ( i = 0; i < set.length; i++ ) {\n\t\t\t\tif ( instance.options[ set[ i ][ 0 ] ] ) {\n\t\t\t\t\tset[ i ][ 1 ].apply( instance.element, args );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\t// only used by resizable\n\thasScroll: function( el, a ) {\n\n\t\t//If overflow is hidden, the element might have extra content, but the user wants to hide it\n\t\tif ( $( el ).css( \"overflow\" ) === \"hidden\") {\n\t\t\treturn false;\n\t\t}\n\n\t\tvar scroll = ( a && a === \"left\" ) ? \"scrollLeft\" : \"scrollTop\",\n\t\t\thas = false;\n\n\t\tif ( el[ scroll ] > 0 ) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// TODO: determine which cases actually cause this to happen\n\t\t// if the element doesn't have the scroll set, see if it's possible to\n\t\t// set the scroll\n\t\tel[ scroll ] = 1;\n\t\thas = ( el[ scroll ] > 0 );\n\t\tel[ scroll ] = 0;\n\t\treturn has;\n\t}\n});\n\n})( jQuery );\n\n},{\"jquery\":18}],15:[function(require,module,exports){\nvar jQuery = require('jquery');\nrequire('./widget');\n\n/*!\n * jQuery UI Mouse 1.10.4\n * http://jqueryui.com\n *\n * Copyright 2014 jQuery Foundation and other contributors\n * Released under the MIT license.\n * http://jquery.org/license\n *\n * http://api.jqueryui.com/mouse/\n *\n * Depends:\n *\tjquery.ui.widget.js\n */\n(function( $, undefined ) {\n\nvar mouseHandled = false;\n$( document ).mouseup( function() {\n\tmouseHandled = false;\n});\n\n$.widget(\"ui.mouse\", {\n\tversion: \"1.10.4\",\n\toptions: {\n\t\tcancel: \"input,textarea,button,select,option\",\n\t\tdistance: 1,\n\t\tdelay: 0\n\t},\n\t_mouseInit: function() {\n\t\tvar that = this;\n\n\t\tthis.element\n\t\t\t.bind(\"mousedown.\"+this.widgetName, function(event) {\n\t\t\t\treturn that._mouseDown(event);\n\t\t\t})\n\t\t\t.bind(\"click.\"+this.widgetName, function(event) {\n\t\t\t\tif (true === $.data(event.target, that.widgetName + \".preventClickEvent\")) {\n\t\t\t\t\t$.removeData(event.target, that.widgetName + \".preventClickEvent\");\n\t\t\t\t\tevent.stopImmediatePropagation();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t});\n\n\t\tthis.started = false;\n\t},\n\n\t// TODO: make sure destroying one instance of mouse doesn't mess with\n\t// other instances of mouse\n\t_mouseDestroy: function() {\n\t\tthis.element.unbind(\".\"+this.widgetName);\n\t\tif ( this._mouseMoveDelegate ) {\n\t\t\t$(document)\n\t\t\t\t.unbind(\"mousemove.\"+this.widgetName, this._mouseMoveDelegate)\n\t\t\t\t.unbind(\"mouseup.\"+this.widgetName, this._mouseUpDelegate);\n\t\t}\n\t},\n\n\t_mouseDown: function(event) {\n\t\t// don't let more than one widget handle mouseStart\n\t\tif( mouseHandled ) { return; }\n\n\t\t// we may have missed mouseup (out of window)\n\t\t(this._mouseStarted && this._mouseUp(event));\n\n\t\tthis._mouseDownEvent = event;\n\n\t\tvar that = this,\n\t\t\tbtnIsLeft = (event.which === 1),\n\t\t\t// event.target.nodeName works around a bug in IE 8 with\n\t\t\t// disabled inputs (#7620)\n\t\t\telIsCancel = (typeof this.options.cancel === \"string\" && event.target.nodeName ? $(event.target).closest(this.options.cancel).length : false);\n\t\tif (!btnIsLeft || elIsCancel || !this._mouseCapture(event)) {\n\t\t\treturn true;\n\t\t}\n\n\t\tthis.mouseDelayMet = !this.options.delay;\n\t\tif (!this.mouseDelayMet) {\n\t\t\tthis._mouseDelayTimer = setTimeout(function() {\n\t\t\t\tthat.mouseDelayMet = true;\n\t\t\t}, this.options.delay);\n\t\t}\n\n\t\tif (this._mouseDistanceMet(event) && this._mouseDelayMet(event)) {\n\t\t\tthis._mouseStarted = (this._mouseStart(event) !== false);\n\t\t\tif (!this._mouseStarted) {\n\t\t\t\tevent.preventDefault();\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\t// Click event may never have fired (Gecko & Opera)\n\t\tif (true === $.data(event.target, this.widgetName + \".preventClickEvent\")) {\n\t\t\t$.removeData(event.target, this.widgetName + \".preventClickEvent\");\n\t\t}\n\n\t\t// these delegates are required to keep context\n\t\tthis._mouseMoveDelegate = function(event) {\n\t\t\treturn that._mouseMove(event);\n\t\t};\n\t\tthis._mouseUpDelegate = function(event) {\n\t\t\treturn that._mouseUp(event);\n\t\t};\n\t\t$(document)\n\t\t\t.bind(\"mousemove.\"+this.widgetName, this._mouseMoveDelegate)\n\t\t\t.bind(\"mouseup.\"+this.widgetName, this._mouseUpDelegate);\n\n\t\tevent.preventDefault();\n\n\t\tmouseHandled = true;\n\t\treturn true;\n\t},\n\n\t_mouseMove: function(event) {\n\t\t// IE mouseup check - mouseup happened when mouse was out of window\n\t\tif ($.ui.ie && ( !document.documentMode || document.documentMode < 9 ) && !event.button) {\n\t\t\treturn this._mouseUp(event);\n\t\t}\n\n\t\tif (this._mouseStarted) {\n\t\t\tthis._mouseDrag(event);\n\t\t\treturn event.preventDefault();\n\t\t}\n\n\t\tif (this._mouseDistanceMet(event) && this._mouseDelayMet(event)) {\n\t\t\tthis._mouseStarted =\n\t\t\t\t(this._mouseStart(this._mouseDownEvent, event) !== false);\n\t\t\t(this._mouseStarted ? this._mouseDrag(event) : this._mouseUp(event));\n\t\t}\n\n\t\treturn !this._mouseStarted;\n\t},\n\n\t_mouseUp: function(event) {\n\t\t$(document)\n\t\t\t.unbind(\"mousemove.\"+this.widgetName, this._mouseMoveDelegate)\n\t\t\t.unbind(\"mouseup.\"+this.widgetName, this._mouseUpDelegate);\n\n\t\tif (this._mouseStarted) {\n\t\t\tthis._mouseStarted = false;\n\n\t\t\tif (event.target === this._mouseDownEvent.target) {\n\t\t\t\t$.data(event.target, this.widgetName + \".preventClickEvent\", true);\n\t\t\t}\n\n\t\t\tthis._mouseStop(event);\n\t\t}\n\n\t\treturn false;\n\t},\n\n\t_mouseDistanceMet: function(event) {\n\t\treturn (Math.max(\n\t\t\t\tMath.abs(this._mouseDownEvent.pageX - event.pageX),\n\t\t\t\tMath.abs(this._mouseDownEvent.pageY - event.pageY)\n\t\t\t) >= this.options.distance\n\t\t);\n\t},\n\n\t_mouseDelayMet: function(/* event */) {\n\t\treturn this.mouseDelayMet;\n\t},\n\n\t// These are placeholder methods, to be overriden by extending plugin\n\t_mouseStart: function(/* event */) {},\n\t_mouseDrag: function(/* event */) {},\n\t_mouseStop: function(/* event */) {},\n\t_mouseCapture: function(/* event */) { return true; }\n});\n\n})(jQuery);\n\n},{\"./widget\":17,\"jquery\":18}],16:[function(require,module,exports){\nvar jQuery = require('jquery');\nrequire('./core');\nrequire('./mouse');\nrequire('./widget');\n\n/*!\n * jQuery UI Sortable 1.10.4\n * http://jqueryui.com\n *\n * Copyright 2014 jQuery Foundation and other contributors\n * Released under the MIT license.\n * http://jquery.org/license\n *\n * http://api.jqueryui.com/sortable/\n *\n * Depends:\n *\tjquery.ui.core.js\n *\tjquery.ui.mouse.js\n *\tjquery.ui.widget.js\n */\n(function( $, undefined ) {\n\nfunction isOverAxis( x, reference, size ) {\n\treturn ( x > reference ) && ( x < ( reference + size ) );\n}\n\nfunction isFloating(item) {\n\treturn (/left|right/).test(item.css(\"float\")) || (/inline|table-cell/).test(item.css(\"display\"));\n}\n\n$.widget(\"ui.sortable\", $.ui.mouse, {\n\tversion: \"1.10.4\",\n\twidgetEventPrefix: \"sort\",\n\tready: false,\n\toptions: {\n\t\tappendTo: \"parent\",\n\t\taxis: false,\n\t\tconnectWith: false,\n\t\tcontainment: false,\n\t\tcursor: \"auto\",\n\t\tcursorAt: false,\n\t\tdropOnEmpty: true,\n\t\tforcePlaceholderSize: false,\n\t\tforceHelperSize: false,\n\t\tgrid: false,\n\t\thandle: false,\n\t\thelper: \"original\",\n\t\titems: \"> *\",\n\t\topacity: false,\n\t\tplaceholder: false,\n\t\trevert: false,\n\t\tscroll: true,\n\t\tscrollSensitivity: 20,\n\t\tscrollSpeed: 20,\n\t\tscope: \"default\",\n\t\ttolerance: \"intersect\",\n\t\tzIndex: 1000,\n\n\t\t// callbacks\n\t\tactivate: null,\n\t\tbeforeStop: null,\n\t\tchange: null,\n\t\tdeactivate: null,\n\t\tout: null,\n\t\tover: null,\n\t\treceive: null,\n\t\tremove: null,\n\t\tsort: null,\n\t\tstart: null,\n\t\tstop: null,\n\t\tupdate: null\n\t},\n\t_create: function() {\n\n\t\tvar o = this.options;\n\t\tthis.containerCache = {};\n\t\tthis.element.addClass(\"ui-sortable\");\n\n\t\t//Get the items\n\t\tthis.refresh();\n\n\t\t//Let's determine if the items are being displayed horizontally\n\t\tthis.floating = this.items.length ? o.axis === \"x\" || isFloating(this.items[0].item) : false;\n\n\t\t//Let's determine the parent's offset\n\t\tthis.offset = this.element.offset();\n\n\t\t//Initialize mouse events for interaction\n\t\tthis._mouseInit();\n\n\t\t//We're ready to go\n\t\tthis.ready = true;\n\n\t},\n\n\t_destroy: function() {\n\t\tthis.element\n\t\t\t.removeClass(\"ui-sortable ui-sortable-disabled\");\n\t\tthis._mouseDestroy();\n\n\t\tfor ( var i = this.items.length - 1; i >= 0; i-- ) {\n\t\t\tthis.items[i].item.removeData(this.widgetName + \"-item\");\n\t\t}\n\n\t\treturn this;\n\t},\n\n\t_setOption: function(key, value){\n\t\tif ( key === \"disabled\" ) {\n\t\t\tthis.options[ key ] = value;\n\n\t\t\tthis.widget().toggleClass( \"ui-sortable-disabled\", !!value );\n\t\t} else {\n\t\t\t// Don't call widget base _setOption for disable as it adds ui-state-disabled class\n\t\t\t$.Widget.prototype._setOption.apply(this, arguments);\n\t\t}\n\t},\n\n\t_mouseCapture: function(event, overrideHandle) {\n\t\tvar currentItem = null,\n\t\t\tvalidHandle = false,\n\t\t\tthat = this;\n\n\t\tif (this.reverting) {\n\t\t\treturn false;\n\t\t}\n\n\t\tif(this.options.disabled || this.options.type === \"static\") {\n\t\t\treturn false;\n\t\t}\n\n\t\t//We have to refresh the items data once first\n\t\tthis._refreshItems(event);\n\n\t\t//Find out if the clicked node (or one of its parents) is a actual item in this.items\n\t\t$(event.target).parents().each(function() {\n\t\t\tif($.data(this, that.widgetName + \"-item\") === that) {\n\t\t\t\tcurrentItem = $(this);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t\tif($.data(event.target, that.widgetName + \"-item\") === that) {\n\t\t\tcurrentItem = $(event.target);\n\t\t}\n\n\t\tif(!currentItem) {\n\t\t\treturn false;\n\t\t}\n\t\tif(this.options.handle && !overrideHandle) {\n\t\t\t$(this.options.handle, currentItem).find(\"*\").addBack().each(function() {\n\t\t\t\tif(this === event.target) {\n\t\t\t\t\tvalidHandle = true;\n\t\t\t\t}\n\t\t\t});\n\t\t\tif(!validHandle) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tthis.currentItem = currentItem;\n\t\tthis._removeCurrentsFromItems();\n\t\treturn true;\n\n\t},\n\n\t_mouseStart: function(event, overrideHandle, noActivation) {\n\n\t\tvar i, body,\n\t\t\to = this.options;\n\n\t\tthis.currentContainer = this;\n\n\t\t//We only need to call refreshPositions, because the refreshItems call has been moved to mouseCapture\n\t\tthis.refreshPositions();\n\n\t\t//Create and append the visible helper\n\t\tthis.helper = this._createHelper(event);\n\n\t\t//Cache the helper size\n\t\tthis._cacheHelperProportions();\n\n\t\t/*\n\t\t * - Position generation -\n\t\t * This block generates everything position related - it's the core of draggables.\n\t\t */\n\n\t\t//Cache the margins of the original element\n\t\tthis._cacheMargins();\n\n\t\t//Get the next scrolling parent\n\t\tthis.scrollParent = this.helper.scrollParent();\n\n\t\t//The element's absolute position on the page minus margins\n\t\tthis.offset = this.currentItem.offset();\n\t\tthis.offset = {\n\t\t\ttop: this.offset.top - this.margins.top,\n\t\t\tleft: this.offset.left - this.margins.left\n\t\t};\n\n\t\t$.extend(this.offset, {\n\t\t\tclick: { //Where the click happened, relative to the element\n\t\t\t\tleft: event.pageX - this.offset.left,\n\t\t\t\ttop: event.pageY - this.offset.top\n\t\t\t},\n\t\t\tparent: this._getParentOffset(),\n\t\t\trelative: this._getRelativeOffset() //This is a relative to absolute position minus the actual position calculation - only used for relative positioned helper\n\t\t});\n\n\t\t// Only after we got the offset, we can change the helper's position to absolute\n\t\t// TODO: Still need to figure out a way to make relative sorting possible\n\t\tthis.helper.css(\"position\", \"absolute\");\n\t\tthis.cssPosition = this.helper.css(\"position\");\n\n\t\t//Generate the original position\n\t\tthis.originalPosition = this._generatePosition(event);\n\t\tthis.originalPageX = event.pageX;\n\t\tthis.originalPageY = event.pageY;\n\n\t\t//Adjust the mouse offset relative to the helper if \"cursorAt\" is supplied\n\t\t(o.cursorAt && this._adjustOffsetFromHelper(o.cursorAt));\n\n\t\t//Cache the former DOM position\n\t\tthis.domPosition = { prev: this.currentItem.prev()[0], parent: this.currentItem.parent()[0] };\n\n\t\t//If the helper is not the original, hide the original so it's not playing any role during the drag, won't cause anything bad this way\n\t\tif(this.helper[0] !== this.currentItem[0]) {\n\t\t\tthis.currentItem.hide();\n\t\t}\n\n\t\t//Create the placeholder\n\t\tthis._createPlaceholder();\n\n\t\t//Set a containment if given in the options\n\t\tif(o.containment) {\n\t\t\tthis._setContainment();\n\t\t}\n\n\t\tif( o.cursor && o.cursor !== \"auto\" ) { // cursor option\n\t\t\tbody = this.document.find( \"body\" );\n\n\t\t\t// support: IE\n\t\t\tthis.storedCursor = body.css( \"cursor\" );\n\t\t\tbody.css( \"cursor\", o.cursor );\n\n\t\t\tthis.storedStylesheet = $( \"<style>*{ cursor: \"+o.cursor+\" !important; }</style>\" ).appendTo( body );\n\t\t}\n\n\t\tif(o.opacity) { // opacity option\n\t\t\tif (this.helper.css(\"opacity\")) {\n\t\t\t\tthis._storedOpacity = this.helper.css(\"opacity\");\n\t\t\t}\n\t\t\tthis.helper.css(\"opacity\", o.opacity);\n\t\t}\n\n\t\tif(o.zIndex) { // zIndex option\n\t\t\tif (this.helper.css(\"zIndex\")) {\n\t\t\t\tthis._storedZIndex = this.helper.css(\"zIndex\");\n\t\t\t}\n\t\t\tthis.helper.css(\"zIndex\", o.zIndex);\n\t\t}\n\n\t\t//Prepare scrolling\n\t\tif(this.scrollParent[0] !== document && this.scrollParent[0].tagName !== \"HTML\") {\n\t\t\tthis.overflowOffset = this.scrollParent.offset();\n\t\t}\n\n\t\t//Call callbacks\n\t\tthis._trigger(\"start\", event, this._uiHash());\n\n\t\t//Recache the helper size\n\t\tif(!this._preserveHelperProportions) {\n\t\t\tthis._cacheHelperProportions();\n\t\t}\n\n\n\t\t//Post \"activate\" events to possible containers\n\t\tif( !noActivation ) {\n\t\t\tfor ( i = this.containers.length - 1; i >= 0; i-- ) {\n\t\t\t\tthis.containers[ i ]._trigger( \"activate\", event, this._uiHash( this ) );\n\t\t\t}\n\t\t}\n\n\t\t//Prepare possible droppables\n\t\tif($.ui.ddmanager) {\n\t\t\t$.ui.ddmanager.current = this;\n\t\t}\n\n\t\tif ($.ui.ddmanager && !o.dropBehaviour) {\n\t\t\t$.ui.ddmanager.prepareOffsets(this, event);\n\t\t}\n\n\t\tthis.dragging = true;\n\n\t\tthis.helper.addClass(\"ui-sortable-helper\");\n\t\tthis._mouseDrag(event); //Execute the drag once - this causes the helper not to be visible before getting its correct position\n\t\treturn true;\n\n\t},\n\n\t_mouseDrag: function(event) {\n\t\tvar i, item, itemElement, intersection,\n\t\t\to = this.options,\n\t\t\tscrolled = false;\n\n\t\t//Compute the helpers position\n\t\tthis.position = this._generatePosition(event);\n\t\tthis.positionAbs = this._convertPositionTo(\"absolute\");\n\n\t\tif (!this.lastPositionAbs) {\n\t\t\tthis.lastPositionAbs = this.positionAbs;\n\t\t}\n\n\t\t//Do scrolling\n\t\tif(this.options.scroll) {\n\t\t\tif(this.scrollParent[0] !== document && this.scrollParent[0].tagName !== \"HTML\") {\n\n\t\t\t\tif((this.overflowOffset.top + this.scrollParent[0].offsetHeight) - event.pageY < o.scrollSensitivity) {\n\t\t\t\t\tthis.scrollParent[0].scrollTop = scrolled = this.scrollParent[0].scrollTop + o.scrollSpeed;\n\t\t\t\t} else if(event.pageY - this.overflowOffset.top < o.scrollSensitivity) {\n\t\t\t\t\tthis.scrollParent[0].scrollTop = scrolled = this.scrollParent[0].scrollTop - o.scrollSpeed;\n\t\t\t\t}\n\n\t\t\t\tif((this.overflowOffset.left + this.scrollParent[0].offsetWidth) - event.pageX < o.scrollSensitivity) {\n\t\t\t\t\tthis.scrollParent[0].scrollLeft = scrolled = this.scrollParent[0].scrollLeft + o.scrollSpeed;\n\t\t\t\t} else if(event.pageX - this.overflowOffset.left < o.scrollSensitivity) {\n\t\t\t\t\tthis.scrollParent[0].scrollLeft = scrolled = this.scrollParent[0].scrollLeft - o.scrollSpeed;\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tif(event.pageY - $(document).scrollTop() < o.scrollSensitivity) {\n\t\t\t\t\tscrolled = $(document).scrollTop($(document).scrollTop() - o.scrollSpeed);\n\t\t\t\t} else if($(window).height() - (event.pageY - $(document).scrollTop()) < o.scrollSensitivity) {\n\t\t\t\t\tscrolled = $(document).scrollTop($(document).scrollTop() + o.scrollSpeed);\n\t\t\t\t}\n\n\t\t\t\tif(event.pageX - $(document).scrollLeft() < o.scrollSensitivity) {\n\t\t\t\t\tscrolled = $(document).scrollLeft($(document).scrollLeft() - o.scrollSpeed);\n\t\t\t\t} else if($(window).width() - (event.pageX - $(document).scrollLeft()) < o.scrollSensitivity) {\n\t\t\t\t\tscrolled = $(document).scrollLeft($(document).scrollLeft() + o.scrollSpeed);\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif(scrolled !== false && $.ui.ddmanager && !o.dropBehaviour) {\n\t\t\t\t$.ui.ddmanager.prepareOffsets(this, event);\n\t\t\t}\n\t\t}\n\n\t\t//Regenerate the absolute position used for position checks\n\t\tthis.positionAbs = this._convertPositionTo(\"absolute\");\n\n\t\t//Set the helper position\n\t\tif(!this.options.axis || this.options.axis !== \"y\") {\n\t\t\tthis.helper[0].style.left = this.position.left+\"px\";\n\t\t}\n\t\tif(!this.options.axis || this.options.axis !== \"x\") {\n\t\t\tthis.helper[0].style.top = this.position.top+\"px\";\n\t\t}\n\n\t\t//Rearrange\n\t\tfor (i = this.items.length - 1; i >= 0; i--) {\n\n\t\t\t//Cache variables and intersection, continue if no intersection\n\t\t\titem = this.items[i];\n\t\t\titemElement = item.item[0];\n\t\t\tintersection = this._intersectsWithPointer(item);\n\t\t\tif (!intersection) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// Only put the placeholder inside the current Container, skip all\n\t\t\t// items from other containers. This works because when moving\n\t\t\t// an item from one container to another the\n\t\t\t// currentContainer is switched before the placeholder is moved.\n\t\t\t//\n\t\t\t// Without this, moving items in \"sub-sortables\" can cause\n\t\t\t// the placeholder to jitter beetween the outer and inner container.\n\t\t\tif (item.instance !== this.currentContainer) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// cannot intersect with itself\n\t\t\t// no useless actions that have been done before\n\t\t\t// no action if the item moved is the parent of the item checked\n\t\t\tif (itemElement !== this.currentItem[0] &&\n\t\t\t\tthis.placeholder[intersection === 1 ? \"next\" : \"prev\"]()[0] !== itemElement &&\n\t\t\t\t!$.contains(this.placeholder[0], itemElement) &&\n\t\t\t\t(this.options.type === \"semi-dynamic\" ? !$.contains(this.element[0], itemElement) : true)\n\t\t\t) {\n\n\t\t\t\tthis.direction = intersection === 1 ? \"down\" : \"up\";\n\n\t\t\t\tif (this.options.tolerance === \"pointer\" || this._intersectsWithSides(item)) {\n\t\t\t\t\tthis._rearrange(event, item);\n\t\t\t\t} else {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tthis._trigger(\"change\", event, this._uiHash());\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\t//Post events to containers\n\t\tthis._contactContainers(event);\n\n\t\t//Interconnect with droppables\n\t\tif($.ui.ddmanager) {\n\t\t\t$.ui.ddmanager.drag(this, event);\n\t\t}\n\n\t\t//Call callbacks\n\t\tthis._trigger(\"sort\", event, this._uiHash());\n\n\t\tthis.lastPositionAbs = this.positionAbs;\n\t\treturn false;\n\n\t},\n\n\t_mouseStop: function(event, noPropagation) {\n\n\t\tif(!event) {\n\t\t\treturn;\n\t\t}\n\n\t\t//If we are using droppables, inform the manager about the drop\n\t\tif ($.ui.ddmanager && !this.options.dropBehaviour) {\n\t\t\t$.ui.ddmanager.drop(this, event);\n\t\t}\n\n\t\tif(this.options.revert) {\n\t\t\tvar that = this,\n\t\t\t\tcur = this.placeholder.offset(),\n\t\t\t\taxis = this.options.axis,\n\t\t\t\tanimation = {};\n\n\t\t\tif ( !axis || axis === \"x\" ) {\n\t\t\t\tanimation.left = cur.left - this.offset.parent.left - this.margins.left + (this.offsetParent[0] === document.body ? 0 : this.offsetParent[0].scrollLeft);\n\t\t\t}\n\t\t\tif ( !axis || axis === \"y\" ) {\n\t\t\t\tanimation.top = cur.top - this.offset.parent.top - this.margins.top + (this.offsetParent[0] === document.body ? 0 : this.offsetParent[0].scrollTop);\n\t\t\t}\n\t\t\tthis.reverting = true;\n\t\t\t$(this.helper).animate( animation, parseInt(this.options.revert, 10) || 500, function() {\n\t\t\t\tthat._clear(event);\n\t\t\t});\n\t\t} else {\n\t\t\tthis._clear(event, noPropagation);\n\t\t}\n\n\t\treturn false;\n\n\t},\n\n\tcancel: function() {\n\n\t\tif(this.dragging) {\n\n\t\t\tthis._mouseUp({ target: null });\n\n\t\t\tif(this.options.helper === \"original\") {\n\t\t\t\tthis.currentItem.css(this._storedCSS).removeClass(\"ui-sortable-helper\");\n\t\t\t} else {\n\t\t\t\tthis.currentItem.show();\n\t\t\t}\n\n\t\t\t//Post deactivating events to containers\n\t\t\tfor (var i = this.containers.length - 1; i >= 0; i--){\n\t\t\t\tthis.containers[i]._trigger(\"deactivate\", null, this._uiHash(this));\n\t\t\t\tif(this.containers[i].containerCache.over) {\n\t\t\t\t\tthis.containers[i]._trigger(\"out\", null, this._uiHash(this));\n\t\t\t\t\tthis.containers[i].containerCache.over = 0;\n\t\t\t\t}\n\t\t\t}\n\n\t\t}\n\n\t\tif (this.placeholder) {\n\t\t\t//$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node!\n\t\t\tif(this.placeholder[0].parentNode) {\n\t\t\t\tthis.placeholder[0].parentNode.removeChild(this.placeholder[0]);\n\t\t\t}\n\t\t\tif(this.options.helper !== \"original\" && this.helper && this.helper[0].parentNode) {\n\t\t\t\tthis.helper.remove();\n\t\t\t}\n\n\t\t\t$.extend(this, {\n\t\t\t\thelper: null,\n\t\t\t\tdragging: false,\n\t\t\t\treverting: false,\n\t\t\t\t_noFinalSort: null\n\t\t\t});\n\n\t\t\tif(this.domPosition.prev) {\n\t\t\t\t$(this.domPosition.prev).after(this.currentItem);\n\t\t\t} else {\n\t\t\t\t$(this.domPosition.parent).prepend(this.currentItem);\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tserialize: function(o) {\n\n\t\tvar items = this._getItemsAsjQuery(o && o.connected),\n\t\t\tstr = [];\n\t\to = o || {};\n\n\t\t$(items).each(function() {\n\t\t\tvar res = ($(o.item || this).attr(o.attribute || \"id\") || \"\").match(o.expression || (/(.+)[\\-=_](.+)/));\n\t\t\tif (res) {\n\t\t\t\tstr.push((o.key || res[1]+\"[]\")+\"=\"+(o.key && o.expression ? res[1] : res[2]));\n\t\t\t}\n\t\t});\n\n\t\tif(!str.length && o.key) {\n\t\t\tstr.push(o.key + \"=\");\n\t\t}\n\n\t\treturn str.join(\"&\");\n\n\t},\n\n\ttoArray: function(o) {\n\n\t\tvar items = this._getItemsAsjQuery(o && o.connected),\n\t\t\tret = [];\n\n\t\to = o || {};\n\n\t\titems.each(function() { ret.push($(o.item || this).attr(o.attribute || \"id\") || \"\"); });\n\t\treturn ret;\n\n\t},\n\n\t/* Be careful with the following core functions */\n\t_intersectsWith: function(item) {\n\n\t\tvar x1 = this.positionAbs.left,\n\t\t\tx2 = x1 + this.helperProportions.width,\n\t\t\ty1 = this.positionAbs.top,\n\t\t\ty2 = y1 + this.helperProportions.height,\n\t\t\tl = item.left,\n\t\t\tr = l + item.width,\n\t\t\tt = item.top,\n\t\t\tb = t + item.height,\n\t\t\tdyClick = this.offset.click.top,\n\t\t\tdxClick = this.offset.click.left,\n\t\t\tisOverElementHeight = ( this.options.axis === \"x\" ) || ( ( y1 + dyClick ) > t && ( y1 + dyClick ) < b ),\n\t\t\tisOverElementWidth = ( this.options.axis === \"y\" ) || ( ( x1 + dxClick ) > l && ( x1 + dxClick ) < r ),\n\t\t\tisOverElement = isOverElementHeight && isOverElementWidth;\n\n\t\tif ( this.options.tolerance === \"pointer\" ||\n\t\t\tthis.options.forcePointerForContainers ||\n\t\t\t(this.options.tolerance !== \"pointer\" && this.helperProportions[this.floating ? \"width\" : \"height\"] > item[this.floating ? \"width\" : \"height\"])\n\t\t) {\n\t\t\treturn isOverElement;\n\t\t} else {\n\n\t\t\treturn (l < x1 + (this.helperProportions.width / 2) && // Right Half\n\t\t\t\tx2 - (this.helperProportions.width / 2) < r && // Left Half\n\t\t\t\tt < y1 + (this.helperProportions.height / 2) && // Bottom Half\n\t\t\t\ty2 - (this.helperProportions.height / 2) < b ); // Top Half\n\n\t\t}\n\t},\n\n\t_intersectsWithPointer: function(item) {\n\n\t\tvar isOverElementHeight = (this.options.axis === \"x\") || isOverAxis(this.positionAbs.top + this.offset.click.top, item.top, item.height),\n\t\t\tisOverElementWidth = (this.options.axis === \"y\") || isOverAxis(this.positionAbs.left + this.offset.click.left, item.left, item.width),\n\t\t\tisOverElement = isOverElementHeight && isOverElementWidth,\n\t\t\tverticalDirection = this._getDragVerticalDirection(),\n\t\t\thorizontalDirection = this._getDragHorizontalDirection();\n\n\t\tif (!isOverElement) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn this.floating ?\n\t\t\t( ((horizontalDirection && horizontalDirection === \"right\") || verticalDirection === \"down\") ? 2 : 1 )\n\t\t\t: ( verticalDirection && (verticalDirection === \"down\" ? 2 : 1) );\n\n\t},\n\n\t_intersectsWithSides: function(item) {\n\n\t\tvar isOverBottomHalf = isOverAxis(this.positionAbs.top + this.offset.click.top, item.top + (item.height/2), item.height),\n\t\t\tisOverRightHalf = isOverAxis(this.positionAbs.left + this.offset.click.left, item.left + (item.width/2), item.width),\n\t\t\tverticalDirection = this._getDragVerticalDirection(),\n\t\t\thorizontalDirection = this._getDragHorizontalDirection();\n\n\t\tif (this.floating && horizontalDirection) {\n\t\t\treturn ((horizontalDirection === \"right\" && isOverRightHalf) || (horizontalDirection === \"left\" && !isOverRightHalf));\n\t\t} else {\n\t\t\treturn verticalDirection && ((verticalDirection === \"down\" && isOverBottomHalf) || (verticalDirection === \"up\" && !isOverBottomHalf));\n\t\t}\n\n\t},\n\n\t_getDragVerticalDirection: function() {\n\t\tvar delta = this.positionAbs.top - this.lastPositionAbs.top;\n\t\treturn delta !== 0 && (delta > 0 ? \"down\" : \"up\");\n\t},\n\n\t_getDragHorizontalDirection: function() {\n\t\tvar delta = this.positionAbs.left - this.lastPositionAbs.left;\n\t\treturn delta !== 0 && (delta > 0 ? \"right\" : \"left\");\n\t},\n\n\trefresh: function(event) {\n\t\tthis._refreshItems(event);\n\t\tthis.refreshPositions();\n\t\treturn this;\n\t},\n\n\t_connectWith: function() {\n\t\tvar options = this.options;\n\t\treturn options.connectWith.constructor === String ? [options.connectWith] : options.connectWith;\n\t},\n\n\t_getItemsAsjQuery: function(connected) {\n\n\t\tvar i, j, cur, inst,\n\t\t\titems = [],\n\t\t\tqueries = [],\n\t\t\tconnectWith = this._connectWith();\n\n\t\tif(connectWith && connected) {\n\t\t\tfor (i = connectWith.length - 1; i >= 0; i--){\n\t\t\t\tcur = $(connectWith[i]);\n\t\t\t\tfor ( j = cur.length - 1; j >= 0; j--){\n\t\t\t\t\tinst = $.data(cur[j], this.widgetFullName);\n\t\t\t\t\tif(inst && inst !== this && !inst.options.disabled) {\n\t\t\t\t\t\tqueries.push([$.isFunction(inst.options.items) ? inst.options.items.call(inst.element) : $(inst.options.items, inst.element).not(\".ui-sortable-helper\").not(\".ui-sortable-placeholder\"), inst]);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tqueries.push([$.isFunction(this.options.items) ? this.options.items.call(this.element, null, { options: this.options, item: this.currentItem }) : $(this.options.items, this.element).not(\".ui-sortable-helper\").not(\".ui-sortable-placeholder\"), this]);\n\n\t\tfunction addItems() {\n\t\t\titems.push( this );\n\t\t}\n\t\tfor (i = queries.length - 1; i >= 0; i--){\n\t\t\tqueries[i][0].each( addItems );\n\t\t}\n\n\t\treturn $(items);\n\n\t},\n\n\t_removeCurrentsFromItems: function() {\n\n\t\tvar list = this.currentItem.find(\":data(\" + this.widgetName + \"-item)\");\n\n\t\tthis.items = $.grep(this.items, function (item) {\n\t\t\tfor (var j=0; j < list.length; j++) {\n\t\t\t\tif(list[j] === item.item[0]) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t});\n\n\t},\n\n\t_refreshItems: function(event) {\n\n\t\tthis.items = [];\n\t\tthis.containers = [this];\n\n\t\tvar i, j, cur, inst, targetData, _queries, item, queriesLength,\n\t\t\titems = this.items,\n\t\t\tqueries = [[$.isFunction(this.options.items) ? this.options.items.call(this.element[0], event, { item: this.currentItem }) : $(this.options.items, this.element), this]],\n\t\t\tconnectWith = this._connectWith();\n\n\t\tif(connectWith && this.ready) { //Shouldn't be run the first time through due to massive slow-down\n\t\t\tfor (i = connectWith.length - 1; i >= 0; i--){\n\t\t\t\tcur = $(connectWith[i]);\n\t\t\t\tfor (j = cur.length - 1; j >= 0; j--){\n\t\t\t\t\tinst = $.data(cur[j], this.widgetFullName);\n\t\t\t\t\tif(inst && inst !== this && !inst.options.disabled) {\n\t\t\t\t\t\tqueries.push([$.isFunction(inst.options.items) ? inst.options.items.call(inst.element[0], event, { item: this.currentItem }) : $(inst.options.items, inst.element), inst]);\n\t\t\t\t\t\tthis.containers.push(inst);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tfor (i = queries.length - 1; i >= 0; i--) {\n\t\t\ttargetData = queries[i][1];\n\t\t\t_queries = queries[i][0];\n\n\t\t\tfor (j=0, queriesLength = _queries.length; j < queriesLength; j++) {\n\t\t\t\titem = $(_queries[j]);\n\n\t\t\t\titem.data(this.widgetName + \"-item\", targetData); // Data for target checking (mouse manager)\n\n\t\t\t\titems.push({\n\t\t\t\t\titem: item,\n\t\t\t\t\tinstance: targetData,\n\t\t\t\t\twidth: 0, height: 0,\n\t\t\t\t\tleft: 0, top: 0\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t},\n\n\trefreshPositions: function(fast) {\n\n\t\t//This has to be redone because due to the item being moved out/into the offsetParent, the offsetParent's position will change\n\t\tif(this.offsetParent && this.helper) {\n\t\t\tthis.offset.parent = this._getParentOffset();\n\t\t}\n\n\t\tvar i, item, t, p;\n\n\t\tfor (i = this.items.length - 1; i >= 0; i--){\n\t\t\titem = this.items[i];\n\n\t\t\t//We ignore calculating positions of all connected containers when we're not over them\n\t\t\tif(item.instance !== this.currentContainer && this.currentContainer && item.item[0] !== this.currentItem[0]) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tt = this.options.toleranceElement ? $(this.options.toleranceElement, item.item) : item.item;\n\n\t\t\tif (!fast) {\n\t\t\t\titem.width = t.outerWidth();\n\t\t\t\titem.height = t.outerHeight();\n\t\t\t}\n\n\t\t\tp = t.offset();\n\t\t\titem.left = p.left;\n\t\t\titem.top = p.top;\n\t\t}\n\n\t\tif(this.options.custom && this.options.custom.refreshContainers) {\n\t\t\tthis.options.custom.refreshContainers.call(this);\n\t\t} else {\n\t\t\tfor (i = this.containers.length - 1; i >= 0; i--){\n\t\t\t\tp = this.containers[i].element.offset();\n\t\t\t\tthis.containers[i].containerCache.left = p.left;\n\t\t\t\tthis.containers[i].containerCache.top = p.top;\n\t\t\t\tthis.containers[i].containerCache.width\t= this.containers[i].element.outerWidth();\n\t\t\t\tthis.containers[i].containerCache.height = this.containers[i].element.outerHeight();\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\t_createPlaceholder: function(that) {\n\t\tthat = that || this;\n\t\tvar className,\n\t\t\to = that.options;\n\n\t\tif(!o.placeholder || o.placeholder.constructor === String) {\n\t\t\tclassName = o.placeholder;\n\t\t\to.placeholder = {\n\t\t\t\telement: function() {\n\n\t\t\t\t\tvar nodeName = that.currentItem[0].nodeName.toLowerCase(),\n\t\t\t\t\t\telement = $( \"<\" + nodeName + \">\", that.document[0] )\n\t\t\t\t\t\t\t.addClass(className || that.currentItem[0].className+\" ui-sortable-placeholder\")\n\t\t\t\t\t\t\t.removeClass(\"ui-sortable-helper\");\n\n\t\t\t\t\tif ( nodeName === \"tr\" ) {\n\t\t\t\t\t\tthat.currentItem.children().each(function() {\n\t\t\t\t\t\t\t$( \"<td> </td>\", that.document[0] )\n\t\t\t\t\t\t\t\t.attr( \"colspan\", $( this ).attr( \"colspan\" ) || 1 )\n\t\t\t\t\t\t\t\t.appendTo( element );\n\t\t\t\t\t\t});\n\t\t\t\t\t} else if ( nodeName === \"img\" ) {\n\t\t\t\t\t\telement.attr( \"src\", that.currentItem.attr( \"src\" ) );\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( !className ) {\n\t\t\t\t\t\telement.css( \"visibility\", \"hidden\" );\n\t\t\t\t\t}\n\n\t\t\t\t\treturn element;\n\t\t\t\t},\n\t\t\t\tupdate: function(container, p) {\n\n\t\t\t\t\t// 1. If a className is set as 'placeholder option, we don't force sizes - the class is responsible for that\n\t\t\t\t\t// 2. The option 'forcePlaceholderSize can be enabled to force it even if a class name is specified\n\t\t\t\t\tif(className && !o.forcePlaceholderSize) {\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\t//If the element doesn't have a actual height by itself (without styles coming from a stylesheet), it receives the inline height from the dragged item\n\t\t\t\t\tif(!p.height()) { p.height(that.currentItem.innerHeight() - parseInt(that.currentItem.css(\"paddingTop\")||0, 10) - parseInt(that.currentItem.css(\"paddingBottom\")||0, 10)); }\n\t\t\t\t\tif(!p.width()) { p.width(that.currentItem.innerWidth() - parseInt(that.currentItem.css(\"paddingLeft\")||0, 10) - parseInt(that.currentItem.css(\"paddingRight\")||0, 10)); }\n\t\t\t\t}\n\t\t\t};\n\t\t}\n\n\t\t//Create the placeholder\n\t\tthat.placeholder = $(o.placeholder.element.call(that.element, that.currentItem));\n\n\t\t//Append it after the actual current item\n\t\tthat.currentItem.after(that.placeholder);\n\n\t\t//Update the size of the placeholder (TODO: Logic to fuzzy, see line 316/317)\n\t\to.placeholder.update(that, that.placeholder);\n\n\t},\n\n\t_contactContainers: function(event) {\n\t\tvar i, j, dist, itemWithLeastDistance, posProperty, sizeProperty, base, cur, nearBottom, floating,\n\t\t\tinnermostContainer = null,\n\t\t\tinnermostIndex = null;\n\n\t\t// get innermost container that intersects with item\n\t\tfor (i = this.containers.length - 1; i >= 0; i--) {\n\n\t\t\t// never consider a container that's located within the item itself\n\t\t\tif($.contains(this.currentItem[0], this.containers[i].element[0])) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif(this._intersectsWith(this.containers[i].containerCache)) {\n\n\t\t\t\t// if we've already found a container and it's more \"inner\" than this, then continue\n\t\t\t\tif(innermostContainer && $.contains(this.containers[i].element[0], innermostContainer.element[0])) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tinnermostContainer = this.containers[i];\n\t\t\t\tinnermostIndex = i;\n\n\t\t\t} else {\n\t\t\t\t// container doesn't intersect. trigger \"out\" event if necessary\n\t\t\t\tif(this.containers[i].containerCache.over) {\n\t\t\t\t\tthis.containers[i]._trigger(\"out\", event, this._uiHash(this));\n\t\t\t\t\tthis.containers[i].containerCache.over = 0;\n\t\t\t\t}\n\t\t\t}\n\n\t\t}\n\n\t\t// if no intersecting containers found, return\n\t\tif(!innermostContainer) {\n\t\t\treturn;\n\t\t}\n\n\t\t// move the item into the container if it's not there already\n\t\tif(this.containers.length === 1) {\n\t\t\tif (!this.containers[innermostIndex].containerCache.over) {\n\t\t\t\tthis.containers[innermostIndex]._trigger(\"over\", event, this._uiHash(this));\n\t\t\t\tthis.containers[innermostIndex].containerCache.over = 1;\n\t\t\t}\n\t\t} else {\n\n\t\t\t//When entering a new container, we will find the item with the least distance and append our item near it\n\t\t\tdist = 10000;\n\t\t\titemWithLeastDistance = null;\n\t\t\tfloating = innermostContainer.floating || isFloating(this.currentItem);\n\t\t\tposProperty = floating ? \"left\" : \"top\";\n\t\t\tsizeProperty = floating ? \"width\" : \"height\";\n\t\t\tbase = this.positionAbs[posProperty] + this.offset.click[posProperty];\n\t\t\tfor (j = this.items.length - 1; j >= 0; j--) {\n\t\t\t\tif(!$.contains(this.containers[innermostIndex].element[0], this.items[j].item[0])) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tif(this.items[j].item[0] === this.currentItem[0]) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tif (floating && !isOverAxis(this.positionAbs.top + this.offset.click.top, this.items[j].top, this.items[j].height)) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tcur = this.items[j].item.offset()[posProperty];\n\t\t\t\tnearBottom = false;\n\t\t\t\tif(Math.abs(cur - base) > Math.abs(cur + this.items[j][sizeProperty] - base)){\n\t\t\t\t\tnearBottom = true;\n\t\t\t\t\tcur += this.items[j][sizeProperty];\n\t\t\t\t}\n\n\t\t\t\tif(Math.abs(cur - base) < dist) {\n\t\t\t\t\tdist = Math.abs(cur - base); itemWithLeastDistance = this.items[j];\n\t\t\t\t\tthis.direction = nearBottom ? \"up\": \"down\";\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t//Check if dropOnEmpty is enabled\n\t\t\tif(!itemWithLeastDistance && !this.options.dropOnEmpty) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif(this.currentContainer === this.containers[innermostIndex]) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\titemWithLeastDistance ? this._rearrange(event, itemWithLeastDistance, null, true) : this._rearrange(event, null, this.containers[innermostIndex].element, true);\n\t\t\tthis._trigger(\"change\", event, this._uiHash());\n\t\t\tthis.containers[innermostIndex]._trigger(\"change\", event, this._uiHash(this));\n\t\t\tthis.currentContainer = this.containers[innermostIndex];\n\n\t\t\t//Update the placeholder\n\t\t\tthis.options.placeholder.update(this.currentContainer, this.placeholder);\n\n\t\t\tthis.containers[innermostIndex]._trigger(\"over\", event, this._uiHash(this));\n\t\t\tthis.containers[innermostIndex].containerCache.over = 1;\n\t\t}\n\n\n\t},\n\n\t_createHelper: function(event) {\n\n\t\tvar o = this.options,\n\t\t\thelper = $.isFunction(o.helper) ? $(o.helper.apply(this.element[0], [event, this.currentItem])) : (o.helper === \"clone\" ? this.currentItem.clone() : this.currentItem);\n\n\t\t//Add the helper to the DOM if that didn't happen already\n\t\tif(!helper.parents(\"body\").length) {\n\t\t\t$(o.appendTo !== \"parent\" ? o.appendTo : this.currentItem[0].parentNode)[0].appendChild(helper[0]);\n\t\t}\n\n\t\tif(helper[0] === this.currentItem[0]) {\n\t\t\tthis._storedCSS = { width: this.currentItem[0].style.width, height: this.currentItem[0].style.height, position: this.currentItem.css(\"position\"), top: this.currentItem.css(\"top\"), left: this.currentItem.css(\"left\") };\n\t\t}\n\n\t\tif(!helper[0].style.width || o.forceHelperSize) {\n\t\t\thelper.width(this.currentItem.width());\n\t\t}\n\t\tif(!helper[0].style.height || o.forceHelperSize) {\n\t\t\thelper.height(this.currentItem.height());\n\t\t}\n\n\t\treturn helper;\n\n\t},\n\n\t_adjustOffsetFromHelper: function(obj) {\n\t\tif (typeof obj === \"string\") {\n\t\t\tobj = obj.split(\" \");\n\t\t}\n\t\tif ($.isArray(obj)) {\n\t\t\tobj = {left: +obj[0], top: +obj[1] || 0};\n\t\t}\n\t\tif (\"left\" in obj) {\n\t\t\tthis.offset.click.left = obj.left + this.margins.left;\n\t\t}\n\t\tif (\"right\" in obj) {\n\t\t\tthis.offset.click.left = this.helperProportions.width - obj.right + this.margins.left;\n\t\t}\n\t\tif (\"top\" in obj) {\n\t\t\tthis.offset.click.top = obj.top + this.margins.top;\n\t\t}\n\t\tif (\"bottom\" in obj) {\n\t\t\tthis.offset.click.top = this.helperProportions.height - obj.bottom + this.margins.top;\n\t\t}\n\t},\n\n\t_getParentOffset: function() {\n\n\n\t\t//Get the offsetParent and cache its position\n\t\tthis.offsetParent = this.helper.offsetParent();\n\t\tvar po = this.offsetParent.offset();\n\n\t\t// This is a special case where we need to modify a offset calculated on start, since the following happened:\n\t\t// 1. The position of the helper is absolute, so it's position is calculated based on the next positioned parent\n\t\t// 2. The actual offset parent is a child of the scroll parent, and the scroll parent isn't the document, which means that\n\t\t// the scroll is included in the initial calculation of the offset of the parent, and never recalculated upon drag\n\t\tif(this.cssPosition === \"absolute\" && this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) {\n\t\t\tpo.left += this.scrollParent.scrollLeft();\n\t\t\tpo.top += this.scrollParent.scrollTop();\n\t\t}\n\n\t\t// This needs to be actually done for all browsers, since pageX/pageY includes this information\n\t\t// with an ugly IE fix\n\t\tif( this.offsetParent[0] === document.body || (this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() === \"html\" && $.ui.ie)) {\n\t\t\tpo = { top: 0, left: 0 };\n\t\t}\n\n\t\treturn {\n\t\t\ttop: po.top + (parseInt(this.offsetParent.css(\"borderTopWidth\"),10) || 0),\n\t\t\tleft: po.left + (parseInt(this.offsetParent.css(\"borderLeftWidth\"),10) || 0)\n\t\t};\n\n\t},\n\n\t_getRelativeOffset: function() {\n\n\t\tif(this.cssPosition === \"relative\") {\n\t\t\tvar p = this.currentItem.position();\n\t\t\treturn {\n\t\t\t\ttop: p.top - (parseInt(this.helper.css(\"top\"),10) || 0) + this.scrollParent.scrollTop(),\n\t\t\t\tleft: p.left - (parseInt(this.helper.css(\"left\"),10) || 0) + this.scrollParent.scrollLeft()\n\t\t\t};\n\t\t} else {\n\t\t\treturn { top: 0, left: 0 };\n\t\t}\n\n\t},\n\n\t_cacheMargins: function() {\n\t\tthis.margins = {\n\t\t\tleft: (parseInt(this.currentItem.css(\"marginLeft\"),10) || 0),\n\t\t\ttop: (parseInt(this.currentItem.css(\"marginTop\"),10) || 0)\n\t\t};\n\t},\n\n\t_cacheHelperProportions: function() {\n\t\tthis.helperProportions = {\n\t\t\twidth: this.helper.outerWidth(),\n\t\t\theight: this.helper.outerHeight()\n\t\t};\n\t},\n\n\t_setContainment: function() {\n\n\t\tvar ce, co, over,\n\t\t\to = this.options;\n\t\tif(o.containment === \"parent\") {\n\t\t\to.containment = this.helper[0].parentNode;\n\t\t}\n\t\tif(o.containment === \"document\" || o.containment === \"window\") {\n\t\t\tthis.containment = [\n\t\t\t\t0 - this.offset.relative.left - this.offset.parent.left,\n\t\t\t\t0 - this.offset.relative.top - this.offset.parent.top,\n\t\t\t\t$(o.containment === \"document\" ? document : window).width() - this.helperProportions.width - this.margins.left,\n\t\t\t\t($(o.containment === \"document\" ? document : window).height() || document.body.parentNode.scrollHeight) - this.helperProportions.height - this.margins.top\n\t\t\t];\n\t\t}\n\n\t\tif(!(/^(document|window|parent)$/).test(o.containment)) {\n\t\t\tce = $(o.containment)[0];\n\t\t\tco = $(o.containment).offset();\n\t\t\tover = ($(ce).css(\"overflow\") !== \"hidden\");\n\n\t\t\tthis.containment = [\n\t\t\t\tco.left + (parseInt($(ce).css(\"borderLeftWidth\"),10) || 0) + (parseInt($(ce).css(\"paddingLeft\"),10) || 0) - this.margins.left,\n\t\t\t\tco.top + (parseInt($(ce).css(\"borderTopWidth\"),10) || 0) + (parseInt($(ce).css(\"paddingTop\"),10) || 0) - this.margins.top,\n\t\t\t\tco.left+(over ? Math.max(ce.scrollWidth,ce.offsetWidth) : ce.offsetWidth) - (parseInt($(ce).css(\"borderLeftWidth\"),10) || 0) - (parseInt($(ce).css(\"paddingRight\"),10) || 0) - this.helperProportions.width - this.margins.left,\n\t\t\t\tco.top+(over ? Math.max(ce.scrollHeight,ce.offsetHeight) : ce.offsetHeight) - (parseInt($(ce).css(\"borderTopWidth\"),10) || 0) - (parseInt($(ce).css(\"paddingBottom\"),10) || 0) - this.helperProportions.height - this.margins.top\n\t\t\t];\n\t\t}\n\n\t},\n\n\t_convertPositionTo: function(d, pos) {\n\n\t\tif(!pos) {\n\t\t\tpos = this.position;\n\t\t}\n\t\tvar mod = d === \"absolute\" ? 1 : -1,\n\t\t\tscroll = this.cssPosition === \"absolute\" && !(this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent : this.scrollParent,\n\t\t\tscrollIsRootNode = (/(html|body)/i).test(scroll[0].tagName);\n\n\t\treturn {\n\t\t\ttop: (\n\t\t\t\tpos.top\t+\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t// The absolute mouse position\n\t\t\t\tthis.offset.relative.top * mod +\t\t\t\t\t\t\t\t\t\t// Only for relative positioned nodes: Relative offset from element to offset parent\n\t\t\t\tthis.offset.parent.top * mod -\t\t\t\t\t\t\t\t\t\t\t// The offsetParent's offset without borders (offset + border)\n\t\t\t\t( ( this.cssPosition === \"fixed\" ? -this.scrollParent.scrollTop() : ( scrollIsRootNode ? 0 : scroll.scrollTop() ) ) * mod)\n\t\t\t),\n\t\t\tleft: (\n\t\t\t\tpos.left +\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t// The absolute mouse position\n\t\t\t\tthis.offset.relative.left * mod +\t\t\t\t\t\t\t\t\t\t// Only for relative positioned nodes: Relative offset from element to offset parent\n\t\t\t\tthis.offset.parent.left * mod\t-\t\t\t\t\t\t\t\t\t\t// The offsetParent's offset without borders (offset + border)\n\t\t\t\t( ( this.cssPosition === \"fixed\" ? -this.scrollParent.scrollLeft() : scrollIsRootNode ? 0 : scroll.scrollLeft() ) * mod)\n\t\t\t)\n\t\t};\n\n\t},\n\n\t_generatePosition: function(event) {\n\n\t\tvar top, left,\n\t\t\to = this.options,\n\t\t\tpageX = event.pageX,\n\t\t\tpageY = event.pageY,\n\t\t\tscroll = this.cssPosition === \"absolute\" && !(this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent : this.scrollParent, scrollIsRootNode = (/(html|body)/i).test(scroll[0].tagName);\n\n\t\t// This is another very weird special case that only happens for relative elements:\n\t\t// 1. If the css position is relative\n\t\t// 2. and the scroll parent is the document or similar to the offset parent\n\t\t// we have to refresh the relative offset during the scroll so there are no jumps\n\t\tif(this.cssPosition === \"relative\" && !(this.scrollParent[0] !== document && this.scrollParent[0] !== this.offsetParent[0])) {\n\t\t\tthis.offset.relative = this._getRelativeOffset();\n\t\t}\n\n\t\t/*\n\t\t * - Position constraining -\n\t\t * Constrain the position to a mix of grid, containment.\n\t\t */\n\n\t\tif(this.originalPosition) { //If we are not dragging yet, we won't check for options\n\n\t\t\tif(this.containment) {\n\t\t\t\tif(event.pageX - this.offset.click.left < this.containment[0]) {\n\t\t\t\t\tpageX = this.containment[0] + this.offset.click.left;\n\t\t\t\t}\n\t\t\t\tif(event.pageY - this.offset.click.top < this.containment[1]) {\n\t\t\t\t\tpageY = this.containment[1] + this.offset.click.top;\n\t\t\t\t}\n\t\t\t\tif(event.pageX - this.offset.click.left > this.containment[2]) {\n\t\t\t\t\tpageX = this.containment[2] + this.offset.click.left;\n\t\t\t\t}\n\t\t\t\tif(event.pageY - this.offset.click.top > this.containment[3]) {\n\t\t\t\t\tpageY = this.containment[3] + this.offset.click.top;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif(o.grid) {\n\t\t\t\ttop = this.originalPageY + Math.round((pageY - this.originalPageY) / o.grid[1]) * o.grid[1];\n\t\t\t\tpageY = this.containment ? ( (top - this.offset.click.top >= this.containment[1] && top - this.offset.click.top <= this.containment[3]) ? top : ((top - this.offset.click.top >= this.containment[1]) ? top - o.grid[1] : top + o.grid[1])) : top;\n\n\t\t\t\tleft = this.originalPageX + Math.round((pageX - this.originalPageX) / o.grid[0]) * o.grid[0];\n\t\t\t\tpageX = this.containment ? ( (left - this.offset.click.left >= this.containment[0] && left - this.offset.click.left <= this.containment[2]) ? left : ((left - this.offset.click.left >= this.containment[0]) ? left - o.grid[0] : left + o.grid[0])) : left;\n\t\t\t}\n\n\t\t}\n\n\t\treturn {\n\t\t\ttop: (\n\t\t\t\tpageY -\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t// The absolute mouse position\n\t\t\t\tthis.offset.click.top -\t\t\t\t\t\t\t\t\t\t\t\t\t// Click offset (relative to the element)\n\t\t\t\tthis.offset.relative.top\t-\t\t\t\t\t\t\t\t\t\t\t// Only for relative positioned nodes: Relative offset from element to offset parent\n\t\t\t\tthis.offset.parent.top +\t\t\t\t\t\t\t\t\t\t\t\t// The offsetParent's offset without borders (offset + border)\n\t\t\t\t( ( this.cssPosition === \"fixed\" ? -this.scrollParent.scrollTop() : ( scrollIsRootNode ? 0 : scroll.scrollTop() ) ))\n\t\t\t),\n\t\t\tleft: (\n\t\t\t\tpageX -\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t// The absolute mouse position\n\t\t\t\tthis.offset.click.left -\t\t\t\t\t\t\t\t\t\t\t\t// Click offset (relative to the element)\n\t\t\t\tthis.offset.relative.left\t-\t\t\t\t\t\t\t\t\t\t\t// Only for relative positioned nodes: Relative offset from element to offset parent\n\t\t\t\tthis.offset.parent.left +\t\t\t\t\t\t\t\t\t\t\t\t// The offsetParent's offset without borders (offset + border)\n\t\t\t\t( ( this.cssPosition === \"fixed\" ? -this.scrollParent.scrollLeft() : scrollIsRootNode ? 0 : scroll.scrollLeft() ))\n\t\t\t)\n\t\t};\n\n\t},\n\n\t_rearrange: function(event, i, a, hardRefresh) {\n\n\t\ta ? a[0].appendChild(this.placeholder[0]) : i.item[0].parentNode.insertBefore(this.placeholder[0], (this.direction === \"down\" ? i.item[0] : i.item[0].nextSibling));\n\n\t\t//Various things done here to improve the performance:\n\t\t// 1. we create a setTimeout, that calls refreshPositions\n\t\t// 2. on the instance, we have a counter variable, that get's higher after every append\n\t\t// 3. on the local scope, we copy the counter variable, and check in the timeout, if it's still the same\n\t\t// 4. this lets only the last addition to the timeout stack through\n\t\tthis.counter = this.counter ? ++this.counter : 1;\n\t\tvar counter = this.counter;\n\n\t\tthis._delay(function() {\n\t\t\tif(counter === this.counter) {\n\t\t\t\tthis.refreshPositions(!hardRefresh); //Precompute after each DOM insertion, NOT on mousemove\n\t\t\t}\n\t\t});\n\n\t},\n\n\t_clear: function(event, noPropagation) {\n\n\t\tthis.reverting = false;\n\t\t// We delay all events that have to be triggered to after the point where the placeholder has been removed and\n\t\t// everything else normalized again\n\t\tvar i,\n\t\t\tdelayedTriggers = [];\n\n\t\t// We first have to update the dom position of the actual currentItem\n\t\t// Note: don't do it if the current item is already removed (by a user), or it gets reappended (see #4088)\n\t\tif(!this._noFinalSort && this.currentItem.parent().length) {\n\t\t\tthis.placeholder.before(this.currentItem);\n\t\t}\n\t\tthis._noFinalSort = null;\n\n\t\tif(this.helper[0] === this.currentItem[0]) {\n\t\t\tfor(i in this._storedCSS) {\n\t\t\t\tif(this._storedCSS[i] === \"auto\" || this._storedCSS[i] === \"static\") {\n\t\t\t\t\tthis._storedCSS[i] = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t\tthis.currentItem.css(this._storedCSS).removeClass(\"ui-sortable-helper\");\n\t\t} else {\n\t\t\tthis.currentItem.show();\n\t\t}\n\n\t\tif(this.fromOutside && !noPropagation) {\n\t\t\tdelayedTriggers.push(function(event) { this._trigger(\"receive\", event, this._uiHash(this.fromOutside)); });\n\t\t}\n\t\tif((this.fromOutside || this.domPosition.prev !== this.currentItem.prev().not(\".ui-sortable-helper\")[0] || this.domPosition.parent !== this.currentItem.parent()[0]) && !noPropagation) {\n\t\t\tdelayedTriggers.push(function(event) { this._trigger(\"update\", event, this._uiHash()); }); //Trigger update callback if the DOM position has changed\n\t\t}\n\n\t\t// Check if the items Container has Changed and trigger appropriate\n\t\t// events.\n\t\tif (this !== this.currentContainer) {\n\t\t\tif(!noPropagation) {\n\t\t\t\tdelayedTriggers.push(function(event) { this._trigger(\"remove\", event, this._uiHash()); });\n\t\t\t\tdelayedTriggers.push((function(c) { return function(event) { c._trigger(\"receive\", event, this._uiHash(this)); }; }).call(this, this.currentContainer));\n\t\t\t\tdelayedTriggers.push((function(c) { return function(event) { c._trigger(\"update\", event, this._uiHash(this)); }; }).call(this, this.currentContainer));\n\t\t\t}\n\t\t}\n\n\n\t\t//Post events to containers\n\t\tfunction delayEvent( type, instance, container ) {\n\t\t\treturn function( event ) {\n\t\t\t\tcontainer._trigger( type, event, instance._uiHash( instance ) );\n\t\t\t};\n\t\t}\n\t\tfor (i = this.containers.length - 1; i >= 0; i--){\n\t\t\tif (!noPropagation) {\n\t\t\t\tdelayedTriggers.push( delayEvent( \"deactivate\", this, this.containers[ i ] ) );\n\t\t\t}\n\t\t\tif(this.containers[i].containerCache.over) {\n\t\t\t\tdelayedTriggers.push( delayEvent( \"out\", this, this.containers[ i ] ) );\n\t\t\t\tthis.containers[i].containerCache.over = 0;\n\t\t\t}\n\t\t}\n\n\t\t//Do what was originally in plugins\n\t\tif ( this.storedCursor ) {\n\t\t\tthis.document.find( \"body\" ).css( \"cursor\", this.storedCursor );\n\t\t\tthis.storedStylesheet.remove();\n\t\t}\n\t\tif(this._storedOpacity) {\n\t\t\tthis.helper.css(\"opacity\", this._storedOpacity);\n\t\t}\n\t\tif(this._storedZIndex) {\n\t\t\tthis.helper.css(\"zIndex\", this._storedZIndex === \"auto\" ? \"\" : this._storedZIndex);\n\t\t}\n\n\t\tthis.dragging = false;\n\t\tif(this.cancelHelperRemoval) {\n\t\t\tif(!noPropagation) {\n\t\t\t\tthis._trigger(\"beforeStop\", event, this._uiHash());\n\t\t\t\tfor (i=0; i < delayedTriggers.length; i++) {\n\t\t\t\t\tdelayedTriggers[i].call(this, event);\n\t\t\t\t} //Trigger all delayed events\n\t\t\t\tthis._trigger(\"stop\", event, this._uiHash());\n\t\t\t}\n\n\t\t\tthis.fromOutside = false;\n\t\t\treturn false;\n\t\t}\n\n\t\tif(!noPropagation) {\n\t\t\tthis._trigger(\"beforeStop\", event, this._uiHash());\n\t\t}\n\n\t\t//$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node!\n\t\tthis.placeholder[0].parentNode.removeChild(this.placeholder[0]);\n\n\t\tif(this.helper[0] !== this.currentItem[0]) {\n\t\t\tthis.helper.remove();\n\t\t}\n\t\tthis.helper = null;\n\n\t\tif(!noPropagation) {\n\t\t\tfor (i=0; i < delayedTriggers.length; i++) {\n\t\t\t\tdelayedTriggers[i].call(this, event);\n\t\t\t} //Trigger all delayed events\n\t\t\tthis._trigger(\"stop\", event, this._uiHash());\n\t\t}\n\n\t\tthis.fromOutside = false;\n\t\treturn true;\n\n\t},\n\n\t_trigger: function() {\n\t\tif ($.Widget.prototype._trigger.apply(this, arguments) === false) {\n\t\t\tthis.cancel();\n\t\t}\n\t},\n\n\t_uiHash: function(_inst) {\n\t\tvar inst = _inst || this;\n\t\treturn {\n\t\t\thelper: inst.helper,\n\t\t\tplaceholder: inst.placeholder || $([]),\n\t\t\tposition: inst.position,\n\t\t\toriginalPosition: inst.originalPosition,\n\t\t\toffset: inst.positionAbs,\n\t\t\titem: inst.currentItem,\n\t\t\tsender: _inst ? _inst.element : null\n\t\t};\n\t}\n\n});\n\n})(jQuery);\n\n},{\"./core\":14,\"./mouse\":15,\"./widget\":17,\"jquery\":18}],17:[function(require,module,exports){\nvar jQuery = require('jquery');\n\n/*!\n * jQuery UI Widget 1.10.4\n * http://jqueryui.com\n *\n * Copyright 2014 jQuery Foundation and other contributors\n * Released under the MIT license.\n * http://jquery.org/license\n *\n * http://api.jqueryui.com/jQuery.widget/\n */\n(function( $, undefined ) {\n\nvar uuid = 0,\n\tslice = Array.prototype.slice,\n\t_cleanData = $.cleanData;\n$.cleanData = function( elems ) {\n\tfor ( var i = 0, elem; (elem = elems[i]) != null; i++ ) {\n\t\ttry {\n\t\t\t$( elem ).triggerHandler( \"remove\" );\n\t\t// http://bugs.jquery.com/ticket/8235\n\t\t} catch( e ) {}\n\t}\n\t_cleanData( elems );\n};\n\n$.widget = function( name, base, prototype ) {\n\tvar fullName, existingConstructor, constructor, basePrototype,\n\t\t// proxiedPrototype allows the provided prototype to remain unmodified\n\t\t// so that it can be used as a mixin for multiple widgets (#8876)\n\t\tproxiedPrototype = {},\n\t\tnamespace = name.split( \".\" )[ 0 ];\n\n\tname = name.split( \".\" )[ 1 ];\n\tfullName = namespace + \"-\" + name;\n\n\tif ( !prototype ) {\n\t\tprototype = base;\n\t\tbase = $.Widget;\n\t}\n\n\t// create selector for plugin\n\t$.expr[ \":\" ][ fullName.toLowerCase() ] = function( elem ) {\n\t\treturn !!$.data( elem, fullName );\n\t};\n\n\t$[ namespace ] = $[ namespace ] || {};\n\texistingConstructor = $[ namespace ][ name ];\n\tconstructor = $[ namespace ][ name ] = function( options, element ) {\n\t\t// allow instantiation without \"new\" keyword\n\t\tif ( !this._createWidget ) {\n\t\t\treturn new constructor( options, element );\n\t\t}\n\n\t\t// allow instantiation without initializing for simple inheritance\n\t\t// must use \"new\" keyword (the code above always passes args)\n\t\tif ( arguments.length ) {\n\t\t\tthis._createWidget( options, element );\n\t\t}\n\t};\n\t// extend with the existing constructor to carry over any static properties\n\t$.extend( constructor, existingConstructor, {\n\t\tversion: prototype.version,\n\t\t// copy the object used to create the prototype in case we need to\n\t\t// redefine the widget later\n\t\t_proto: $.extend( {}, prototype ),\n\t\t// track widgets that inherit from this widget in case this widget is\n\t\t// redefined after a widget inherits from it\n\t\t_childConstructors: []\n\t});\n\n\tbasePrototype = new base();\n\t// we need to make the options hash a property directly on the new instance\n\t// otherwise we'll modify the options hash on the prototype that we're\n\t// inheriting from\n\tbasePrototype.options = $.widget.extend( {}, basePrototype.options );\n\t$.each( prototype, function( prop, value ) {\n\t\tif ( !$.isFunction( value ) ) {\n\t\t\tproxiedPrototype[ prop ] = value;\n\t\t\treturn;\n\t\t}\n\t\tproxiedPrototype[ prop ] = (function() {\n\t\t\tvar _super = function() {\n\t\t\t\t\treturn base.prototype[ prop ].apply( this, arguments );\n\t\t\t\t},\n\t\t\t\t_superApply = function( args ) {\n\t\t\t\t\treturn base.prototype[ prop ].apply( this, args );\n\t\t\t\t};\n\t\t\treturn function() {\n\t\t\t\tvar __super = this._super,\n\t\t\t\t\t__superApply = this._superApply,\n\t\t\t\t\treturnValue;\n\n\t\t\t\tthis._super = _super;\n\t\t\t\tthis._superApply = _superApply;\n\n\t\t\t\treturnValue = value.apply( this, arguments );\n\n\t\t\t\tthis._super = __super;\n\t\t\t\tthis._superApply = __superApply;\n\n\t\t\t\treturn returnValue;\n\t\t\t};\n\t\t})();\n\t});\n\tconstructor.prototype = $.widget.extend( basePrototype, {\n\t\t// TODO: remove support for widgetEventPrefix\n\t\t// always use the name + a colon as the prefix, e.g., draggable:start\n\t\t// don't prefix for widgets that aren't DOM-based\n\t\twidgetEventPrefix: existingConstructor ? (basePrototype.widgetEventPrefix || name) : name\n\t}, proxiedPrototype, {\n\t\tconstructor: constructor,\n\t\tnamespace: namespace,\n\t\twidgetName: name,\n\t\twidgetFullName: fullName\n\t});\n\n\t// If this widget is being redefined then we need to find all widgets that\n\t// are inheriting from it and redefine all of them so that they inherit from\n\t// the new version of this widget. We're essentially trying to replace one\n\t// level in the prototype chain.\n\tif ( existingConstructor ) {\n\t\t$.each( existingConstructor._childConstructors, function( i, child ) {\n\t\t\tvar childPrototype = child.prototype;\n\n\t\t\t// redefine the child widget using the same prototype that was\n\t\t\t// originally used, but inherit from the new version of the base\n\t\t\t$.widget( childPrototype.namespace + \".\" + childPrototype.widgetName, constructor, child._proto );\n\t\t});\n\t\t// remove the list of existing child constructors from the old constructor\n\t\t// so the old child constructors can be garbage collected\n\t\tdelete existingConstructor._childConstructors;\n\t} else {\n\t\tbase._childConstructors.push( constructor );\n\t}\n\n\t$.widget.bridge( name, constructor );\n};\n\n$.widget.extend = function( target ) {\n\tvar input = slice.call( arguments, 1 ),\n\t\tinputIndex = 0,\n\t\tinputLength = input.length,\n\t\tkey,\n\t\tvalue;\n\tfor ( ; inputIndex < inputLength; inputIndex++ ) {\n\t\tfor ( key in input[ inputIndex ] ) {\n\t\t\tvalue = input[ inputIndex ][ key ];\n\t\t\tif ( input[ inputIndex ].hasOwnProperty( key ) && value !== undefined ) {\n\t\t\t\t// Clone objects\n\t\t\t\tif ( $.isPlainObject( value ) ) {\n\t\t\t\t\ttarget[ key ] = $.isPlainObject( target[ key ] ) ?\n\t\t\t\t\t\t$.widget.extend( {}, target[ key ], value ) :\n\t\t\t\t\t\t// Don't extend strings, arrays, etc. with objects\n\t\t\t\t\t\t$.widget.extend( {}, value );\n\t\t\t\t// Copy everything else by reference\n\t\t\t\t} else {\n\t\t\t\t\ttarget[ key ] = value;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\treturn target;\n};\n\n$.widget.bridge = function( name, object ) {\n\tvar fullName = object.prototype.widgetFullName || name;\n\t$.fn[ name ] = function( options ) {\n\t\tvar isMethodCall = typeof options === \"string\",\n\t\t\targs = slice.call( arguments, 1 ),\n\t\t\treturnValue = this;\n\n\t\t// allow multiple hashes to be passed on init\n\t\toptions = !isMethodCall && args.length ?\n\t\t\t$.widget.extend.apply( null, [ options ].concat(args) ) :\n\t\t\toptions;\n\n\t\tif ( isMethodCall ) {\n\t\t\tthis.each(function() {\n\t\t\t\tvar methodValue,\n\t\t\t\t\tinstance = $.data( this, fullName );\n\t\t\t\tif ( !instance ) {\n\t\t\t\t\treturn $.error( \"cannot call methods on \" + name + \" prior to initialization; \" +\n\t\t\t\t\t\t\"attempted to call method '\" + options + \"'\" );\n\t\t\t\t}\n\t\t\t\tif ( !$.isFunction( instance[options] ) || options.charAt( 0 ) === \"_\" ) {\n\t\t\t\t\treturn $.error( \"no such method '\" + options + \"' for \" + name + \" widget instance\" );\n\t\t\t\t}\n\t\t\t\tmethodValue = instance[ options ].apply( instance, args );\n\t\t\t\tif ( methodValue !== instance && methodValue !== undefined ) {\n\t\t\t\t\treturnValue = methodValue && methodValue.jquery ?\n\t\t\t\t\t\treturnValue.pushStack( methodValue.get() ) :\n\t\t\t\t\t\tmethodValue;\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tthis.each(function() {\n\t\t\t\tvar instance = $.data( this, fullName );\n\t\t\t\tif ( instance ) {\n\t\t\t\t\tinstance.option( options || {} )._init();\n\t\t\t\t} else {\n\t\t\t\t\t$.data( this, fullName, new object( options, this ) );\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\treturn returnValue;\n\t};\n};\n\n$.Widget = function( /* options, element */ ) {};\n$.Widget._childConstructors = [];\n\n$.Widget.prototype = {\n\twidgetName: \"widget\",\n\twidgetEventPrefix: \"\",\n\tdefaultElement: \"<div>\",\n\toptions: {\n\t\tdisabled: false,\n\n\t\t// callbacks\n\t\tcreate: null\n\t},\n\t_createWidget: function( options, element ) {\n\t\telement = $( element || this.defaultElement || this )[ 0 ];\n\t\tthis.element = $( element );\n\t\tthis.uuid = uuid++;\n\t\tthis.eventNamespace = \".\" + this.widgetName + this.uuid;\n\t\tthis.options = $.widget.extend( {},\n\t\t\tthis.options,\n\t\t\tthis._getCreateOptions(),\n\t\t\toptions );\n\n\t\tthis.bindings = $();\n\t\tthis.hoverable = $();\n\t\tthis.focusable = $();\n\n\t\tif ( element !== this ) {\n\t\t\t$.data( element, this.widgetFullName, this );\n\t\t\tthis._on( true, this.element, {\n\t\t\t\tremove: function( event ) {\n\t\t\t\t\tif ( event.target === element ) {\n\t\t\t\t\t\tthis.destroy();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t\tthis.document = $( element.style ?\n\t\t\t\t// element within the document\n\t\t\t\telement.ownerDocument :\n\t\t\t\t// element is window or document\n\t\t\t\telement.document || element );\n\t\t\tthis.window = $( this.document[0].defaultView || this.document[0].parentWindow );\n\t\t}\n\n\t\tthis._create();\n\t\tthis._trigger( \"create\", null, this._getCreateEventData() );\n\t\tthis._init();\n\t},\n\t_getCreateOptions: $.noop,\n\t_getCreateEventData: $.noop,\n\t_create: $.noop,\n\t_init: $.noop,\n\n\tdestroy: function() {\n\t\tthis._destroy();\n\t\t// we can probably remove the unbind calls in 2.0\n\t\t// all event bindings should go through this._on()\n\t\tthis.element\n\t\t\t.unbind( this.eventNamespace )\n\t\t\t// 1.9 BC for #7810\n\t\t\t// TODO remove dual storage\n\t\t\t.removeData( this.widgetName )\n\t\t\t.removeData( this.widgetFullName )\n\t\t\t// support: jquery <1.6.3\n\t\t\t// http://bugs.jquery.com/ticket/9413\n\t\t\t.removeData( $.camelCase( this.widgetFullName ) );\n\t\tthis.widget()\n\t\t\t.unbind( this.eventNamespace )\n\t\t\t.removeAttr( \"aria-disabled\" )\n\t\t\t.removeClass(\n\t\t\t\tthis.widgetFullName + \"-disabled \" +\n\t\t\t\t\"ui-state-disabled\" );\n\n\t\t// clean up events and states\n\t\tthis.bindings.unbind( this.eventNamespace );\n\t\tthis.hoverable.removeClass( \"ui-state-hover\" );\n\t\tthis.focusable.removeClass( \"ui-state-focus\" );\n\t},\n\t_destroy: $.noop,\n\n\twidget: function() {\n\t\treturn this.element;\n\t},\n\n\toption: function( key, value ) {\n\t\tvar options = key,\n\t\t\tparts,\n\t\t\tcurOption,\n\t\t\ti;\n\n\t\tif ( arguments.length === 0 ) {\n\t\t\t// don't return a reference to the internal hash\n\t\t\treturn $.widget.extend( {}, this.options );\n\t\t}\n\n\t\tif ( typeof key === \"string\" ) {\n\t\t\t// handle nested keys, e.g., \"foo.bar\" => { foo: { bar: ___ } }\n\t\t\toptions = {};\n\t\t\tparts = key.split( \".\" );\n\t\t\tkey = parts.shift();\n\t\t\tif ( parts.length ) {\n\t\t\t\tcurOption = options[ key ] = $.widget.extend( {}, this.options[ key ] );\n\t\t\t\tfor ( i = 0; i < parts.length - 1; i++ ) {\n\t\t\t\t\tcurOption[ parts[ i ] ] = curOption[ parts[ i ] ] || {};\n\t\t\t\t\tcurOption = curOption[ parts[ i ] ];\n\t\t\t\t}\n\t\t\t\tkey = parts.pop();\n\t\t\t\tif ( arguments.length === 1 ) {\n\t\t\t\t\treturn curOption[ key ] === undefined ? null : curOption[ key ];\n\t\t\t\t}\n\t\t\t\tcurOption[ key ] = value;\n\t\t\t} else {\n\t\t\t\tif ( arguments.length === 1 ) {\n\t\t\t\t\treturn this.options[ key ] === undefined ? null : this.options[ key ];\n\t\t\t\t}\n\t\t\t\toptions[ key ] = value;\n\t\t\t}\n\t\t}\n\n\t\tthis._setOptions( options );\n\n\t\treturn this;\n\t},\n\t_setOptions: function( options ) {\n\t\tvar key;\n\n\t\tfor ( key in options ) {\n\t\t\tthis._setOption( key, options[ key ] );\n\t\t}\n\n\t\treturn this;\n\t},\n\t_setOption: function( key, value ) {\n\t\tthis.options[ key ] = value;\n\n\t\tif ( key === \"disabled\" ) {\n\t\t\tthis.widget()\n\t\t\t\t.toggleClass( this.widgetFullName + \"-disabled ui-state-disabled\", !!value )\n\t\t\t\t.attr( \"aria-disabled\", value );\n\t\t\tthis.hoverable.removeClass( \"ui-state-hover\" );\n\t\t\tthis.focusable.removeClass( \"ui-state-focus\" );\n\t\t}\n\n\t\treturn this;\n\t},\n\n\tenable: function() {\n\t\treturn this._setOption( \"disabled\", false );\n\t},\n\tdisable: function() {\n\t\treturn this._setOption( \"disabled\", true );\n\t},\n\n\t_on: function( suppressDisabledCheck, element, handlers ) {\n\t\tvar delegateElement,\n\t\t\tinstance = this;\n\n\t\t// no suppressDisabledCheck flag, shuffle arguments\n\t\tif ( typeof suppressDisabledCheck !== \"boolean\" ) {\n\t\t\thandlers = element;\n\t\t\telement = suppressDisabledCheck;\n\t\t\tsuppressDisabledCheck = false;\n\t\t}\n\n\t\t// no element argument, shuffle and use this.element\n\t\tif ( !handlers ) {\n\t\t\thandlers = element;\n\t\t\telement = this.element;\n\t\t\tdelegateElement = this.widget();\n\t\t} else {\n\t\t\t// accept selectors, DOM elements\n\t\t\telement = delegateElement = $( element );\n\t\t\tthis.bindings = this.bindings.add( element );\n\t\t}\n\n\t\t$.each( handlers, function( event, handler ) {\n\t\t\tfunction handlerProxy() {\n\t\t\t\t// allow widgets to customize the disabled handling\n\t\t\t\t// - disabled as an array instead of boolean\n\t\t\t\t// - disabled class as method for disabling individual parts\n\t\t\t\tif ( !suppressDisabledCheck &&\n\t\t\t\t\t\t( instance.options.disabled === true ||\n\t\t\t\t\t\t\t$( this ).hasClass( \"ui-state-disabled\" ) ) ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\treturn ( typeof handler === \"string\" ? instance[ handler ] : handler )\n\t\t\t\t\t.apply( instance, arguments );\n\t\t\t}\n\n\t\t\t// copy the guid so direct unbinding works\n\t\t\tif ( typeof handler !== \"string\" ) {\n\t\t\t\thandlerProxy.guid = handler.guid =\n\t\t\t\t\thandler.guid || handlerProxy.guid || $.guid++;\n\t\t\t}\n\n\t\t\tvar match = event.match( /^(\\w+)\\s*(.*)$/ ),\n\t\t\t\teventName = match[1] + instance.eventNamespace,\n\t\t\t\tselector = match[2];\n\t\t\tif ( selector ) {\n\t\t\t\tdelegateElement.delegate( selector, eventName, handlerProxy );\n\t\t\t} else {\n\t\t\t\telement.bind( eventName, handlerProxy );\n\t\t\t}\n\t\t});\n\t},\n\n\t_off: function( element, eventName ) {\n\t\teventName = (eventName || \"\").split( \" \" ).join( this.eventNamespace + \" \" ) + this.eventNamespace;\n\t\telement.unbind( eventName ).undelegate( eventName );\n\t},\n\n\t_delay: function( handler, delay ) {\n\t\tfunction handlerProxy() {\n\t\t\treturn ( typeof handler === \"string\" ? instance[ handler ] : handler )\n\t\t\t\t.apply( instance, arguments );\n\t\t}\n\t\tvar instance = this;\n\t\treturn setTimeout( handlerProxy, delay || 0 );\n\t},\n\n\t_hoverable: function( element ) {\n\t\tthis.hoverable = this.hoverable.add( element );\n\t\tthis._on( element, {\n\t\t\tmouseenter: function( event ) {\n\t\t\t\t$( event.currentTarget ).addClass( \"ui-state-hover\" );\n\t\t\t},\n\t\t\tmouseleave: function( event ) {\n\t\t\t\t$( event.currentTarget ).removeClass( \"ui-state-hover\" );\n\t\t\t}\n\t\t});\n\t},\n\n\t_focusable: function( element ) {\n\t\tthis.focusable = this.focusable.add( element );\n\t\tthis._on( element, {\n\t\t\tfocusin: function( event ) {\n\t\t\t\t$( event.currentTarget ).addClass( \"ui-state-focus\" );\n\t\t\t},\n\t\t\tfocusout: function( event ) {\n\t\t\t\t$( event.currentTarget ).removeClass( \"ui-state-focus\" );\n\t\t\t}\n\t\t});\n\t},\n\n\t_trigger: function( type, event, data ) {\n\t\tvar prop, orig,\n\t\t\tcallback = this.options[ type ];\n\n\t\tdata = data || {};\n\t\tevent = $.Event( event );\n\t\tevent.type = ( type === this.widgetEventPrefix ?\n\t\t\ttype :\n\t\t\tthis.widgetEventPrefix + type ).toLowerCase();\n\t\t// the original event may come from any element\n\t\t// so we need to reset the target on the new event\n\t\tevent.target = this.element[ 0 ];\n\n\t\t// copy original event properties over to the new event\n\t\torig = event.originalEvent;\n\t\tif ( orig ) {\n\t\t\tfor ( prop in orig ) {\n\t\t\t\tif ( !( prop in event ) ) {\n\t\t\t\t\tevent[ prop ] = orig[ prop ];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.element.trigger( event, data );\n\t\treturn !( $.isFunction( callback ) &&\n\t\t\tcallback.apply( this.element[0], [ event ].concat( data ) ) === false ||\n\t\t\tevent.isDefaultPrevented() );\n\t}\n};\n\n$.each( { show: \"fadeIn\", hide: \"fadeOut\" }, function( method, defaultEffect ) {\n\t$.Widget.prototype[ \"_\" + method ] = function( element, options, callback ) {\n\t\tif ( typeof options === \"string\" ) {\n\t\t\toptions = { effect: options };\n\t\t}\n\t\tvar hasOptions,\n\t\t\teffectName = !options ?\n\t\t\t\tmethod :\n\t\t\t\toptions === true || typeof options === \"number\" ?\n\t\t\t\t\tdefaultEffect :\n\t\t\t\t\toptions.effect || defaultEffect;\n\t\toptions = options || {};\n\t\tif ( typeof options === \"number\" ) {\n\t\t\toptions = { duration: options };\n\t\t}\n\t\thasOptions = !$.isEmptyObject( options );\n\t\toptions.complete = callback;\n\t\tif ( options.delay ) {\n\t\t\telement.delay( options.delay );\n\t\t}\n\t\tif ( hasOptions && $.effects && $.effects.effect[ effectName ] ) {\n\t\t\telement[ method ]( options );\n\t\t} else if ( effectName !== method && element[ effectName ] ) {\n\t\t\telement[ effectName ]( options.duration, options.easing, callback );\n\t\t} else {\n\t\t\telement.queue(function( next ) {\n\t\t\t\t$( this )[ method ]();\n\t\t\t\tif ( callback ) {\n\t\t\t\t\tcallback.call( element[ 0 ] );\n\t\t\t\t}\n\t\t\t\tnext();\n\t\t\t});\n\t\t}\n\t};\n});\n\n})( jQuery );\n\n},{\"jquery\":18}],18:[function(require,module,exports){\n/*!\n * jQuery JavaScript Library v2.2.4\n * http://jquery.com/\n *\n * Includes Sizzle.js\n * http://sizzlejs.com/\n *\n * Copyright jQuery Foundation and other contributors\n * Released under the MIT license\n * http://jquery.org/license\n *\n * Date: 2016-05-20T17:23Z\n */\n\n(function( global, factory ) {\n\n\tif ( typeof module === \"object\" && typeof module.exports === \"object\" ) {\n\t\t// For CommonJS and CommonJS-like environments where a proper `window`\n\t\t// is present, execute the factory and get jQuery.\n\t\t// For environments that do not have a `window` with a `document`\n\t\t// (such as Node.js), expose a factory as module.exports.\n\t\t// This accentuates the need for the creation of a real `window`.\n\t\t// e.g. var jQuery = require(\"jquery\")(window);\n\t\t// See ticket #14549 for more info.\n\t\tmodule.exports = global.document ?\n\t\t\tfactory( global, true ) :\n\t\t\tfunction( w ) {\n\t\t\t\tif ( !w.document ) {\n\t\t\t\t\tthrow new Error( \"jQuery requires a window with a document\" );\n\t\t\t\t}\n\t\t\t\treturn factory( w );\n\t\t\t};\n\t} else {\n\t\tfactory( global );\n\t}\n\n// Pass this if window is not defined yet\n}(typeof window !== \"undefined\" ? window : this, function( window, noGlobal ) {\n\n// Support: Firefox 18+\n// Can't be in strict mode, several libs including ASP.NET trace\n// the stack via arguments.caller.callee and Firefox dies if\n// you try to trace through \"use strict\" call chains. (#13335)\n//\"use strict\";\nvar arr = [];\n\nvar document = window.document;\n\nvar slice = arr.slice;\n\nvar concat = arr.concat;\n\nvar push = arr.push;\n\nvar indexOf = arr.indexOf;\n\nvar class2type = {};\n\nvar toString = class2type.toString;\n\nvar hasOwn = class2type.hasOwnProperty;\n\nvar support = {};\n\n\n\nvar\n\tversion = \"2.2.4\",\n\n\t// Define a local copy of jQuery\n\tjQuery = function( selector, context ) {\n\n\t\t// The jQuery object is actually just the init constructor 'enhanced'\n\t\t// Need init if jQuery is called (just allow error to be thrown if not included)\n\t\treturn new jQuery.fn.init( selector, context );\n\t},\n\n\t// Support: Android<4.1\n\t// Make sure we trim BOM and NBSP\n\trtrim = /^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g,\n\n\t// Matches dashed string for camelizing\n\trmsPrefix = /^-ms-/,\n\trdashAlpha = /-([\\da-z])/gi,\n\n\t// Used by jQuery.camelCase as callback to replace()\n\tfcamelCase = function( all, letter ) {\n\t\treturn letter.toUpperCase();\n\t};\n\njQuery.fn = jQuery.prototype = {\n\n\t// The current version of jQuery being used\n\tjquery: version,\n\n\tconstructor: jQuery,\n\n\t// Start with an empty selector\n\tselector: \"\",\n\n\t// The default length of a jQuery object is 0\n\tlength: 0,\n\n\ttoArray: function() {\n\t\treturn slice.call( this );\n\t},\n\n\t// Get the Nth element in the matched element set OR\n\t// Get the whole matched element set as a clean array\n\tget: function( num ) {\n\t\treturn num != null ?\n\n\t\t\t// Return just the one element from the set\n\t\t\t( num < 0 ? this[ num + this.length ] : this[ num ] ) :\n\n\t\t\t// Return all the elements in a clean array\n\t\t\tslice.call( this );\n\t},\n\n\t// Take an array of elements and push it onto the stack\n\t// (returning the new matched element set)\n\tpushStack: function( elems ) {\n\n\t\t// Build a new jQuery matched element set\n\t\tvar ret = jQuery.merge( this.constructor(), elems );\n\n\t\t// Add the old object onto the stack (as a reference)\n\t\tret.prevObject = this;\n\t\tret.context = this.context;\n\n\t\t// Return the newly-formed element set\n\t\treturn ret;\n\t},\n\n\t// Execute a callback for every element in the matched set.\n\teach: function( callback ) {\n\t\treturn jQuery.each( this, callback );\n\t},\n\n\tmap: function( callback ) {\n\t\treturn this.pushStack( jQuery.map( this, function( elem, i ) {\n\t\t\treturn callback.call( elem, i, elem );\n\t\t} ) );\n\t},\n\n\tslice: function() {\n\t\treturn this.pushStack( slice.apply( this, arguments ) );\n\t},\n\n\tfirst: function() {\n\t\treturn this.eq( 0 );\n\t},\n\n\tlast: function() {\n\t\treturn this.eq( -1 );\n\t},\n\n\teq: function( i ) {\n\t\tvar len = this.length,\n\t\t\tj = +i + ( i < 0 ? len : 0 );\n\t\treturn this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] );\n\t},\n\n\tend: function() {\n\t\treturn this.prevObject || this.constructor();\n\t},\n\n\t// For internal use only.\n\t// Behaves like an Array's method, not like a jQuery method.\n\tpush: push,\n\tsort: arr.sort,\n\tsplice: arr.splice\n};\n\njQuery.extend = jQuery.fn.extend = function() {\n\tvar options, name, src, copy, copyIsArray, clone,\n\t\ttarget = arguments[ 0 ] || {},\n\t\ti = 1,\n\t\tlength = arguments.length,\n\t\tdeep = false;\n\n\t// Handle a deep copy situation\n\tif ( typeof target === \"boolean\" ) {\n\t\tdeep = target;\n\n\t\t// Skip the boolean and the target\n\t\ttarget = arguments[ i ] || {};\n\t\ti++;\n\t}\n\n\t// Handle case when target is a string or something (possible in deep copy)\n\tif ( typeof target !== \"object\" && !jQuery.isFunction( target ) ) {\n\t\ttarget = {};\n\t}\n\n\t// Extend jQuery itself if only one argument is passed\n\tif ( i === length ) {\n\t\ttarget = this;\n\t\ti--;\n\t}\n\n\tfor ( ; i < length; i++ ) {\n\n\t\t// Only deal with non-null/undefined values\n\t\tif ( ( options = arguments[ i ] ) != null ) {\n\n\t\t\t// Extend the base object\n\t\t\tfor ( name in options ) {\n\t\t\t\tsrc = target[ name ];\n\t\t\t\tcopy = options[ name ];\n\n\t\t\t\t// Prevent never-ending loop\n\t\t\t\tif ( target === copy ) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Recurse if we're merging plain objects or arrays\n\t\t\t\tif ( deep && copy && ( jQuery.isPlainObject( copy ) ||\n\t\t\t\t\t( copyIsArray = jQuery.isArray( copy ) ) ) ) {\n\n\t\t\t\t\tif ( copyIsArray ) {\n\t\t\t\t\t\tcopyIsArray = false;\n\t\t\t\t\t\tclone = src && jQuery.isArray( src ) ? src : [];\n\n\t\t\t\t\t} else {\n\t\t\t\t\t\tclone = src && jQuery.isPlainObject( src ) ? src : {};\n\t\t\t\t\t}\n\n\t\t\t\t\t// Never move original objects, clone them\n\t\t\t\t\ttarget[ name ] = jQuery.extend( deep, clone, copy );\n\n\t\t\t\t// Don't bring in undefined values\n\t\t\t\t} else if ( copy !== undefined ) {\n\t\t\t\t\ttarget[ name ] = copy;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Return the modified object\n\treturn target;\n};\n\njQuery.extend( {\n\n\t// Unique for each copy of jQuery on the page\n\texpando: \"jQuery\" + ( version + Math.random() ).replace( /\\D/g, \"\" ),\n\n\t// Assume jQuery is ready without the ready module\n\tisReady: true,\n\n\terror: function( msg ) {\n\t\tthrow new Error( msg );\n\t},\n\n\tnoop: function() {},\n\n\tisFunction: function( obj ) {\n\t\treturn jQuery.type( obj ) === \"function\";\n\t},\n\n\tisArray: Array.isArray,\n\n\tisWindow: function( obj ) {\n\t\treturn obj != null && obj === obj.window;\n\t},\n\n\tisNumeric: function( obj ) {\n\n\t\t// parseFloat NaNs numeric-cast false positives (null|true|false|\"\")\n\t\t// ...but misinterprets leading-number strings, particularly hex literals (\"0x...\")\n\t\t// subtraction forces infinities to NaN\n\t\t// adding 1 corrects loss of precision from parseFloat (#15100)\n\t\tvar realStringObj = obj && obj.toString();\n\t\treturn !jQuery.isArray( obj ) && ( realStringObj - parseFloat( realStringObj ) + 1 ) >= 0;\n\t},\n\n\tisPlainObject: function( obj ) {\n\t\tvar key;\n\n\t\t// Not plain objects:\n\t\t// - Any object or value whose internal [[Class]] property is not \"[object Object]\"\n\t\t// - DOM nodes\n\t\t// - window\n\t\tif ( jQuery.type( obj ) !== \"object\" || obj.nodeType || jQuery.isWindow( obj ) ) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Not own constructor property must be Object\n\t\tif ( obj.constructor &&\n\t\t\t\t!hasOwn.call( obj, \"constructor\" ) &&\n\t\t\t\t!hasOwn.call( obj.constructor.prototype || {}, \"isPrototypeOf\" ) ) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Own properties are enumerated firstly, so to speed up,\n\t\t// if last one is own, then all properties are own\n\t\tfor ( key in obj ) {}\n\n\t\treturn key === undefined || hasOwn.call( obj, key );\n\t},\n\n\tisEmptyObject: function( obj ) {\n\t\tvar name;\n\t\tfor ( name in obj ) {\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t},\n\n\ttype: function( obj ) {\n\t\tif ( obj == null ) {\n\t\t\treturn obj + \"\";\n\t\t}\n\n\t\t// Support: Android<4.0, iOS<6 (functionish RegExp)\n\t\treturn typeof obj === \"object\" || typeof obj === \"function\" ?\n\t\t\tclass2type[ toString.call( obj ) ] || \"object\" :\n\t\t\ttypeof obj;\n\t},\n\n\t// Evaluates a script in a global context\n\tglobalEval: function( code ) {\n\t\tvar script,\n\t\t\tindirect = eval;\n\n\t\tcode = jQuery.trim( code );\n\n\t\tif ( code ) {\n\n\t\t\t// If the code includes a valid, prologue position\n\t\t\t// strict mode pragma, execute code by injecting a\n\t\t\t// script tag into the document.\n\t\t\tif ( code.indexOf( \"use strict\" ) === 1 ) {\n\t\t\t\tscript = document.createElement( \"script\" );\n\t\t\t\tscript.text = code;\n\t\t\t\tdocument.head.appendChild( script ).parentNode.removeChild( script );\n\t\t\t} else {\n\n\t\t\t\t// Otherwise, avoid the DOM node creation, insertion\n\t\t\t\t// and removal by using an indirect global eval\n\n\t\t\t\tindirect( code );\n\t\t\t}\n\t\t}\n\t},\n\n\t// Convert dashed to camelCase; used by the css and data modules\n\t// Support: IE9-11+\n\t// Microsoft forgot to hump their vendor prefix (#9572)\n\tcamelCase: function( string ) {\n\t\treturn string.replace( rmsPrefix, \"ms-\" ).replace( rdashAlpha, fcamelCase );\n\t},\n\n\tnodeName: function( elem, name ) {\n\t\treturn elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase();\n\t},\n\n\teach: function( obj, callback ) {\n\t\tvar length, i = 0;\n\n\t\tif ( isArrayLike( obj ) ) {\n\t\t\tlength = obj.length;\n\t\t\tfor ( ; i < length; i++ ) {\n\t\t\t\tif ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tfor ( i in obj ) {\n\t\t\t\tif ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn obj;\n\t},\n\n\t// Support: Android<4.1\n\ttrim: function( text ) {\n\t\treturn text == null ?\n\t\t\t\"\" :\n\t\t\t( text + \"\" ).replace( rtrim, \"\" );\n\t},\n\n\t// results is for internal usage only\n\tmakeArray: function( arr, results ) {\n\t\tvar ret = results || [];\n\n\t\tif ( arr != null ) {\n\t\t\tif ( isArrayLike( Object( arr ) ) ) {\n\t\t\t\tjQuery.merge( ret,\n\t\t\t\t\ttypeof arr === \"string\" ?\n\t\t\t\t\t[ arr ] : arr\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tpush.call( ret, arr );\n\t\t\t}\n\t\t}\n\n\t\treturn ret;\n\t},\n\n\tinArray: function( elem, arr, i ) {\n\t\treturn arr == null ? -1 : indexOf.call( arr, elem, i );\n\t},\n\n\tmerge: function( first, second ) {\n\t\tvar len = +second.length,\n\t\t\tj = 0,\n\t\t\ti = first.length;\n\n\t\tfor ( ; j < len; j++ ) {\n\t\t\tfirst[ i++ ] = second[ j ];\n\t\t}\n\n\t\tfirst.length = i;\n\n\t\treturn first;\n\t},\n\n\tgrep: function( elems, callback, invert ) {\n\t\tvar callbackInverse,\n\t\t\tmatches = [],\n\t\t\ti = 0,\n\t\t\tlength = elems.length,\n\t\t\tcallbackExpect = !invert;\n\n\t\t// Go through the array, only saving the items\n\t\t// that pass the validator function\n\t\tfor ( ; i < length; i++ ) {\n\t\t\tcallbackInverse = !callback( elems[ i ], i );\n\t\t\tif ( callbackInverse !== callbackExpect ) {\n\t\t\t\tmatches.push( elems[ i ] );\n\t\t\t}\n\t\t}\n\n\t\treturn matches;\n\t},\n\n\t// arg is for internal usage only\n\tmap: function( elems, callback, arg ) {\n\t\tvar length, value,\n\t\t\ti = 0,\n\t\t\tret = [];\n\n\t\t// Go through the array, translating each of the items to their new values\n\t\tif ( isArrayLike( elems ) ) {\n\t\t\tlength = elems.length;\n\t\t\tfor ( ; i < length; i++ ) {\n\t\t\t\tvalue = callback( elems[ i ], i, arg );\n\n\t\t\t\tif ( value != null ) {\n\t\t\t\t\tret.push( value );\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Go through every key on the object,\n\t\t} else {\n\t\t\tfor ( i in elems ) {\n\t\t\t\tvalue = callback( elems[ i ], i, arg );\n\n\t\t\t\tif ( value != null ) {\n\t\t\t\t\tret.push( value );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Flatten any nested arrays\n\t\treturn concat.apply( [], ret );\n\t},\n\n\t// A global GUID counter for objects\n\tguid: 1,\n\n\t// Bind a function to a context, optionally partially applying any\n\t// arguments.\n\tproxy: function( fn, context ) {\n\t\tvar tmp, args, proxy;\n\n\t\tif ( typeof context === \"string\" ) {\n\t\t\ttmp = fn[ context ];\n\t\t\tcontext = fn;\n\t\t\tfn = tmp;\n\t\t}\n\n\t\t// Quick check to determine if target is callable, in the spec\n\t\t// this throws a TypeError, but we will just return undefined.\n\t\tif ( !jQuery.isFunction( fn ) ) {\n\t\t\treturn undefined;\n\t\t}\n\n\t\t// Simulated bind\n\t\targs = slice.call( arguments, 2 );\n\t\tproxy = function() {\n\t\t\treturn fn.apply( context || this, args.concat( slice.call( arguments ) ) );\n\t\t};\n\n\t\t// Set the guid of unique handler to the same of original handler, so it can be removed\n\t\tproxy.guid = fn.guid = fn.guid || jQuery.guid++;\n\n\t\treturn proxy;\n\t},\n\n\tnow: Date.now,\n\n\t// jQuery.support is not used in Core but other projects attach their\n\t// properties to it so it needs to exist.\n\tsupport: support\n} );\n\n// JSHint would error on this code due to the Symbol not being defined in ES5.\n// Defining this global in .jshintrc would create a danger of using the global\n// unguarded in another place, it seems safer to just disable JSHint for these\n// three lines.\n/* jshint ignore: start */\nif ( typeof Symbol === \"function\" ) {\n\tjQuery.fn[ Symbol.iterator ] = arr[ Symbol.iterator ];\n}\n/* jshint ignore: end */\n\n// Populate the class2type map\njQuery.each( \"Boolean Number String Function Array Date RegExp Object Error Symbol\".split( \" \" ),\nfunction( i, name ) {\n\tclass2type[ \"[object \" + name + \"]\" ] = name.toLowerCase();\n} );\n\nfunction isArrayLike( obj ) {\n\n\t// Support: iOS 8.2 (not reproducible in simulator)\n\t// `in` check used to prevent JIT error (gh-2145)\n\t// hasOwn isn't used here due to false negatives\n\t// regarding Nodelist length in IE\n\tvar length = !!obj && \"length\" in obj && obj.length,\n\t\ttype = jQuery.type( obj );\n\n\tif ( type === \"function\" || jQuery.isWindow( obj ) ) {\n\t\treturn false;\n\t}\n\n\treturn type === \"array\" || length === 0 ||\n\t\ttypeof length === \"number\" && length > 0 && ( length - 1 ) in obj;\n}\nvar Sizzle =\n/*!\n * Sizzle CSS Selector Engine v2.2.1\n * http://sizzlejs.com/\n *\n * Copyright jQuery Foundation and other contributors\n * Released under the MIT license\n * http://jquery.org/license\n *\n * Date: 2015-10-17\n */\n(function( window ) {\n\nvar i,\n\tsupport,\n\tExpr,\n\tgetText,\n\tisXML,\n\ttokenize,\n\tcompile,\n\tselect,\n\toutermostContext,\n\tsortInput,\n\thasDuplicate,\n\n\t// Local document vars\n\tsetDocument,\n\tdocument,\n\tdocElem,\n\tdocumentIsHTML,\n\trbuggyQSA,\n\trbuggyMatches,\n\tmatches,\n\tcontains,\n\n\t// Instance-specific data\n\texpando = \"sizzle\" + 1 * new Date(),\n\tpreferredDoc = window.document,\n\tdirruns = 0,\n\tdone = 0,\n\tclassCache = createCache(),\n\ttokenCache = createCache(),\n\tcompilerCache = createCache(),\n\tsortOrder = function( a, b ) {\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t}\n\t\treturn 0;\n\t},\n\n\t// General-purpose constants\n\tMAX_NEGATIVE = 1 << 31,\n\n\t// Instance methods\n\thasOwn = ({}).hasOwnProperty,\n\tarr = [],\n\tpop = arr.pop,\n\tpush_native = arr.push,\n\tpush = arr.push,\n\tslice = arr.slice,\n\t// Use a stripped-down indexOf as it's faster than native\n\t// http://jsperf.com/thor-indexof-vs-for/5\n\tindexOf = function( list, elem ) {\n\t\tvar i = 0,\n\t\t\tlen = list.length;\n\t\tfor ( ; i < len; i++ ) {\n\t\t\tif ( list[i] === elem ) {\n\t\t\t\treturn i;\n\t\t\t}\n\t\t}\n\t\treturn -1;\n\t},\n\n\tbooleans = \"checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped\",\n\n\t// Regular expressions\n\n\t// http://www.w3.org/TR/css3-selectors/#whitespace\n\twhitespace = \"[\\\\x20\\\\t\\\\r\\\\n\\\\f]\",\n\n\t// http://www.w3.org/TR/CSS21/syndata.html#value-def-identifier\n\tidentifier = \"(?:\\\\\\\\.|[\\\\w-]|[^\\\\x00-\\\\xa0])+\",\n\n\t// Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors\n\tattributes = \"\\\\[\" + whitespace + \"*(\" + identifier + \")(?:\" + whitespace +\n\t\t// Operator (capture 2)\n\t\t\"*([*^$|!~]?=)\" + whitespace +\n\t\t// \"Attribute values must be CSS identifiers [capture 5] or strings [capture 3 or capture 4]\"\n\t\t\"*(?:'((?:\\\\\\\\.|[^\\\\\\\\'])*)'|\\\"((?:\\\\\\\\.|[^\\\\\\\\\\\"])*)\\\"|(\" + identifier + \"))|)\" + whitespace +\n\t\t\"*\\\\]\",\n\n\tpseudos = \":(\" + identifier + \")(?:\\\\((\" +\n\t\t// To reduce the number of selectors needing tokenize in the preFilter, prefer arguments:\n\t\t// 1. quoted (capture 3; capture 4 or capture 5)\n\t\t\"('((?:\\\\\\\\.|[^\\\\\\\\'])*)'|\\\"((?:\\\\\\\\.|[^\\\\\\\\\\\"])*)\\\")|\" +\n\t\t// 2. simple (capture 6)\n\t\t\"((?:\\\\\\\\.|[^\\\\\\\\()[\\\\]]|\" + attributes + \")*)|\" +\n\t\t// 3. anything else (capture 2)\n\t\t\".*\" +\n\t\t\")\\\\)|)\",\n\n\t// Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter\n\trwhitespace = new RegExp( whitespace + \"+\", \"g\" ),\n\trtrim = new RegExp( \"^\" + whitespace + \"+|((?:^|[^\\\\\\\\])(?:\\\\\\\\.)*)\" + whitespace + \"+$\", \"g\" ),\n\n\trcomma = new RegExp( \"^\" + whitespace + \"*,\" + whitespace + \"*\" ),\n\trcombinators = new RegExp( \"^\" + whitespace + \"*([>+~]|\" + whitespace + \")\" + whitespace + \"*\" ),\n\n\trattributeQuotes = new RegExp( \"=\" + whitespace + \"*([^\\\\]'\\\"]*?)\" + whitespace + \"*\\\\]\", \"g\" ),\n\n\trpseudo = new RegExp( pseudos ),\n\tridentifier = new RegExp( \"^\" + identifier + \"$\" ),\n\n\tmatchExpr = {\n\t\t\"ID\": new RegExp( \"^#(\" + identifier + \")\" ),\n\t\t\"CLASS\": new RegExp( \"^\\\\.(\" + identifier + \")\" ),\n\t\t\"TAG\": new RegExp( \"^(\" + identifier + \"|[*])\" ),\n\t\t\"ATTR\": new RegExp( \"^\" + attributes ),\n\t\t\"PSEUDO\": new RegExp( \"^\" + pseudos ),\n\t\t\"CHILD\": new RegExp( \"^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\\\(\" + whitespace +\n\t\t\t\"*(even|odd|(([+-]|)(\\\\d*)n|)\" + whitespace + \"*(?:([+-]|)\" + whitespace +\n\t\t\t\"*(\\\\d+)|))\" + whitespace + \"*\\\\)|)\", \"i\" ),\n\t\t\"bool\": new RegExp( \"^(?:\" + booleans + \")$\", \"i\" ),\n\t\t// For use in libraries implementing .is()\n\t\t// We use this for POS matching in `select`\n\t\t\"needsContext\": new RegExp( \"^\" + whitespace + \"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\\\(\" +\n\t\t\twhitespace + \"*((?:-\\\\d)?\\\\d*)\" + whitespace + \"*\\\\)|)(?=[^-]|$)\", \"i\" )\n\t},\n\n\trinputs = /^(?:input|select|textarea|button)$/i,\n\trheader = /^h\\d$/i,\n\n\trnative = /^[^{]+\\{\\s*\\[native \\w/,\n\n\t// Easily-parseable/retrievable ID or TAG or CLASS selectors\n\trquickExpr = /^(?:#([\\w-]+)|(\\w+)|\\.([\\w-]+))$/,\n\n\trsibling = /[+~]/,\n\trescape = /'|\\\\/g,\n\n\t// CSS escapes http://www.w3.org/TR/CSS21/syndata.html#escaped-characters\n\trunescape = new RegExp( \"\\\\\\\\([\\\\da-f]{1,6}\" + whitespace + \"?|(\" + whitespace + \")|.)\", \"ig\" ),\n\tfunescape = function( _, escaped, escapedWhitespace ) {\n\t\tvar high = \"0x\" + escaped - 0x10000;\n\t\t// NaN means non-codepoint\n\t\t// Support: Firefox<24\n\t\t// Workaround erroneous numeric interpretation of +\"0x\"\n\t\treturn high !== high || escapedWhitespace ?\n\t\t\tescaped :\n\t\t\thigh < 0 ?\n\t\t\t\t// BMP codepoint\n\t\t\t\tString.fromCharCode( high + 0x10000 ) :\n\t\t\t\t// Supplemental Plane codepoint (surrogate pair)\n\t\t\t\tString.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 );\n\t},\n\n\t// Used for iframes\n\t// See setDocument()\n\t// Removing the function wrapper causes a \"Permission Denied\"\n\t// error in IE\n\tunloadHandler = function() {\n\t\tsetDocument();\n\t};\n\n// Optimize for push.apply( _, NodeList )\ntry {\n\tpush.apply(\n\t\t(arr = slice.call( preferredDoc.childNodes )),\n\t\tpreferredDoc.childNodes\n\t);\n\t// Support: Android<4.0\n\t// Detect silently failing push.apply\n\tarr[ preferredDoc.childNodes.length ].nodeType;\n} catch ( e ) {\n\tpush = { apply: arr.length ?\n\n\t\t// Leverage slice if possible\n\t\tfunction( target, els ) {\n\t\t\tpush_native.apply( target, slice.call(els) );\n\t\t} :\n\n\t\t// Support: IE<9\n\t\t// Otherwise append directly\n\t\tfunction( target, els ) {\n\t\t\tvar j = target.length,\n\t\t\t\ti = 0;\n\t\t\t// Can't trust NodeList.length\n\t\t\twhile ( (target[j++] = els[i++]) ) {}\n\t\t\ttarget.length = j - 1;\n\t\t}\n\t};\n}\n\nfunction Sizzle( selector, context, results, seed ) {\n\tvar m, i, elem, nid, nidselect, match, groups, newSelector,\n\t\tnewContext = context && context.ownerDocument,\n\n\t\t// nodeType defaults to 9, since context defaults to document\n\t\tnodeType = context ? context.nodeType : 9;\n\n\tresults = results || [];\n\n\t// Return early from calls with invalid selector or context\n\tif ( typeof selector !== \"string\" || !selector ||\n\t\tnodeType !== 1 && nodeType !== 9 && nodeType !== 11 ) {\n\n\t\treturn results;\n\t}\n\n\t// Try to shortcut find operations (as opposed to filters) in HTML documents\n\tif ( !seed ) {\n\n\t\tif ( ( context ? context.ownerDocument || context : preferredDoc ) !== document ) {\n\t\t\tsetDocument( context );\n\t\t}\n\t\tcontext = context || document;\n\n\t\tif ( documentIsHTML ) {\n\n\t\t\t// If the selector is sufficiently simple, try using a \"get*By*\" DOM method\n\t\t\t// (excepting DocumentFragment context, where the methods don't exist)\n\t\t\tif ( nodeType !== 11 && (match = rquickExpr.exec( selector )) ) {\n\n\t\t\t\t// ID selector\n\t\t\t\tif ( (m = match[1]) ) {\n\n\t\t\t\t\t// Document context\n\t\t\t\t\tif ( nodeType === 9 ) {\n\t\t\t\t\t\tif ( (elem = context.getElementById( m )) ) {\n\n\t\t\t\t\t\t\t// Support: IE, Opera, Webkit\n\t\t\t\t\t\t\t// TODO: identify versions\n\t\t\t\t\t\t\t// getElementById can match elements by name instead of ID\n\t\t\t\t\t\t\tif ( elem.id === m ) {\n\t\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t// Element context\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// Support: IE, Opera, Webkit\n\t\t\t\t\t\t// TODO: identify versions\n\t\t\t\t\t\t// getElementById can match elements by name instead of ID\n\t\t\t\t\t\tif ( newContext && (elem = newContext.getElementById( m )) &&\n\t\t\t\t\t\t\tcontains( context, elem ) &&\n\t\t\t\t\t\t\telem.id === m ) {\n\n\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t// Type selector\n\t\t\t\t} else if ( match[2] ) {\n\t\t\t\t\tpush.apply( results, context.getElementsByTagName( selector ) );\n\t\t\t\t\treturn results;\n\n\t\t\t\t// Class selector\n\t\t\t\t} else if ( (m = match[3]) && support.getElementsByClassName &&\n\t\t\t\t\tcontext.getElementsByClassName ) {\n\n\t\t\t\t\tpush.apply( results, context.getElementsByClassName( m ) );\n\t\t\t\t\treturn results;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Take advantage of querySelectorAll\n\t\t\tif ( support.qsa &&\n\t\t\t\t!compilerCache[ selector + \" \" ] &&\n\t\t\t\t(!rbuggyQSA || !rbuggyQSA.test( selector )) ) {\n\n\t\t\t\tif ( nodeType !== 1 ) {\n\t\t\t\t\tnewContext = context;\n\t\t\t\t\tnewSelector = selector;\n\n\t\t\t\t// qSA looks outside Element context, which is not what we want\n\t\t\t\t// Thanks to Andrew Dupont for this workaround technique\n\t\t\t\t// Support: IE <=8\n\t\t\t\t// Exclude object elements\n\t\t\t\t} else if ( context.nodeName.toLowerCase() !== \"object\" ) {\n\n\t\t\t\t\t// Capture the context ID, setting it first if necessary\n\t\t\t\t\tif ( (nid = context.getAttribute( \"id\" )) ) {\n\t\t\t\t\t\tnid = nid.replace( rescape, \"\\\\$&\" );\n\t\t\t\t\t} else {\n\t\t\t\t\t\tcontext.setAttribute( \"id\", (nid = expando) );\n\t\t\t\t\t}\n\n\t\t\t\t\t// Prefix every selector in the list\n\t\t\t\t\tgroups = tokenize( selector );\n\t\t\t\t\ti = groups.length;\n\t\t\t\t\tnidselect = ridentifier.test( nid ) ? \"#\" + nid : \"[id='\" + nid + \"']\";\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tgroups[i] = nidselect + \" \" + toSelector( groups[i] );\n\t\t\t\t\t}\n\t\t\t\t\tnewSelector = groups.join( \",\" );\n\n\t\t\t\t\t// Expand context for sibling selectors\n\t\t\t\t\tnewContext = rsibling.test( selector ) && testContext( context.parentNode ) ||\n\t\t\t\t\t\tcontext;\n\t\t\t\t}\n\n\t\t\t\tif ( newSelector ) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tpush.apply( results,\n\t\t\t\t\t\t\tnewContext.querySelectorAll( newSelector )\n\t\t\t\t\t\t);\n\t\t\t\t\t\treturn results;\n\t\t\t\t\t} catch ( qsaError ) {\n\t\t\t\t\t} finally {\n\t\t\t\t\t\tif ( nid === expando ) {\n\t\t\t\t\t\t\tcontext.removeAttribute( \"id\" );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// All others\n\treturn select( selector.replace( rtrim, \"$1\" ), context, results, seed );\n}\n\n/**\n * Create key-value caches of limited size\n * @returns {function(string, object)} Returns the Object data after storing it on itself with\n *\tproperty name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength)\n *\tdeleting the oldest entry\n */\nfunction createCache() {\n\tvar keys = [];\n\n\tfunction cache( key, value ) {\n\t\t// Use (key + \" \") to avoid collision with native prototype properties (see Issue #157)\n\t\tif ( keys.push( key + \" \" ) > Expr.cacheLength ) {\n\t\t\t// Only keep the most recent entries\n\t\t\tdelete cache[ keys.shift() ];\n\t\t}\n\t\treturn (cache[ key + \" \" ] = value);\n\t}\n\treturn cache;\n}\n\n/**\n * Mark a function for special use by Sizzle\n * @param {Function} fn The function to mark\n */\nfunction markFunction( fn ) {\n\tfn[ expando ] = true;\n\treturn fn;\n}\n\n/**\n * Support testing using an element\n * @param {Function} fn Passed the created div and expects a boolean result\n */\nfunction assert( fn ) {\n\tvar div = document.createElement(\"div\");\n\n\ttry {\n\t\treturn !!fn( div );\n\t} catch (e) {\n\t\treturn false;\n\t} finally {\n\t\t// Remove from its parent by default\n\t\tif ( div.parentNode ) {\n\t\t\tdiv.parentNode.removeChild( div );\n\t\t}\n\t\t// release memory in IE\n\t\tdiv = null;\n\t}\n}\n\n/**\n * Adds the same handler for all of the specified attrs\n * @param {String} attrs Pipe-separated list of attributes\n * @param {Function} handler The method that will be applied\n */\nfunction addHandle( attrs, handler ) {\n\tvar arr = attrs.split(\"|\"),\n\t\ti = arr.length;\n\n\twhile ( i-- ) {\n\t\tExpr.attrHandle[ arr[i] ] = handler;\n\t}\n}\n\n/**\n * Checks document order of two siblings\n * @param {Element} a\n * @param {Element} b\n * @returns {Number} Returns less than 0 if a precedes b, greater than 0 if a follows b\n */\nfunction siblingCheck( a, b ) {\n\tvar cur = b && a,\n\t\tdiff = cur && a.nodeType === 1 && b.nodeType === 1 &&\n\t\t\t( ~b.sourceIndex || MAX_NEGATIVE ) -\n\t\t\t( ~a.sourceIndex || MAX_NEGATIVE );\n\n\t// Use IE sourceIndex if available on both nodes\n\tif ( diff ) {\n\t\treturn diff;\n\t}\n\n\t// Check if b follows a\n\tif ( cur ) {\n\t\twhile ( (cur = cur.nextSibling) ) {\n\t\t\tif ( cur === b ) {\n\t\t\t\treturn -1;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn a ? 1 : -1;\n}\n\n/**\n * Returns a function to use in pseudos for input types\n * @param {String} type\n */\nfunction createInputPseudo( type ) {\n\treturn function( elem ) {\n\t\tvar name = elem.nodeName.toLowerCase();\n\t\treturn name === \"input\" && elem.type === type;\n\t};\n}\n\n/**\n * Returns a function to use in pseudos for buttons\n * @param {String} type\n */\nfunction createButtonPseudo( type ) {\n\treturn function( elem ) {\n\t\tvar name = elem.nodeName.toLowerCase();\n\t\treturn (name === \"input\" || name === \"button\") && elem.type === type;\n\t};\n}\n\n/**\n * Returns a function to use in pseudos for positionals\n * @param {Function} fn\n */\nfunction createPositionalPseudo( fn ) {\n\treturn markFunction(function( argument ) {\n\t\targument = +argument;\n\t\treturn markFunction(function( seed, matches ) {\n\t\t\tvar j,\n\t\t\t\tmatchIndexes = fn( [], seed.length, argument ),\n\t\t\t\ti = matchIndexes.length;\n\n\t\t\t// Match elements found at the specified indexes\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( seed[ (j = matchIndexes[i]) ] ) {\n\t\t\t\t\tseed[j] = !(matches[j] = seed[j]);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t});\n}\n\n/**\n * Checks a node for validity as a Sizzle context\n * @param {Element|Object=} context\n * @returns {Element|Object|Boolean} The input node if acceptable, otherwise a falsy value\n */\nfunction testContext( context ) {\n\treturn context && typeof context.getElementsByTagName !== \"undefined\" && context;\n}\n\n// Expose support vars for convenience\nsupport = Sizzle.support = {};\n\n/**\n * Detects XML nodes\n * @param {Element|Object} elem An element or a document\n * @returns {Boolean} True iff elem is a non-HTML XML node\n */\nisXML = Sizzle.isXML = function( elem ) {\n\t// documentElement is verified for cases where it doesn't yet exist\n\t// (such as loading iframes in IE - #4833)\n\tvar documentElement = elem && (elem.ownerDocument || elem).documentElement;\n\treturn documentElement ? documentElement.nodeName !== \"HTML\" : false;\n};\n\n/**\n * Sets document-related variables once based on the current document\n * @param {Element|Object} [doc] An element or document object to use to set the document\n * @returns {Object} Returns the current document\n */\nsetDocument = Sizzle.setDocument = function( node ) {\n\tvar hasCompare, parent,\n\t\tdoc = node ? node.ownerDocument || node : preferredDoc;\n\n\t// Return early if doc is invalid or already selected\n\tif ( doc === document || doc.nodeType !== 9 || !doc.documentElement ) {\n\t\treturn document;\n\t}\n\n\t// Update global variables\n\tdocument = doc;\n\tdocElem = document.documentElement;\n\tdocumentIsHTML = !isXML( document );\n\n\t// Support: IE 9-11, Edge\n\t// Accessing iframe documents after unload throws \"permission denied\" errors (jQuery #13936)\n\tif ( (parent = document.defaultView) && parent.top !== parent ) {\n\t\t// Support: IE 11\n\t\tif ( parent.addEventListener ) {\n\t\t\tparent.addEventListener( \"unload\", unloadHandler, false );\n\n\t\t// Support: IE 9 - 10 only\n\t\t} else if ( parent.attachEvent ) {\n\t\t\tparent.attachEvent( \"onunload\", unloadHandler );\n\t\t}\n\t}\n\n\t/* Attributes\n\t---------------------------------------------------------------------- */\n\n\t// Support: IE<8\n\t// Verify that getAttribute really returns attributes and not properties\n\t// (excepting IE8 booleans)\n\tsupport.attributes = assert(function( div ) {\n\t\tdiv.className = \"i\";\n\t\treturn !div.getAttribute(\"className\");\n\t});\n\n\t/* getElement(s)By*\n\t---------------------------------------------------------------------- */\n\n\t// Check if getElementsByTagName(\"*\") returns only elements\n\tsupport.getElementsByTagName = assert(function( div ) {\n\t\tdiv.appendChild( document.createComment(\"\") );\n\t\treturn !div.getElementsByTagName(\"*\").length;\n\t});\n\n\t// Support: IE<9\n\tsupport.getElementsByClassName = rnative.test( document.getElementsByClassName );\n\n\t// Support: IE<10\n\t// Check if getElementById returns elements by name\n\t// The broken getElementById methods don't pick up programatically-set names,\n\t// so use a roundabout getElementsByName test\n\tsupport.getById = assert(function( div ) {\n\t\tdocElem.appendChild( div ).id = expando;\n\t\treturn !document.getElementsByName || !document.getElementsByName( expando ).length;\n\t});\n\n\t// ID find and filter\n\tif ( support.getById ) {\n\t\tExpr.find[\"ID\"] = function( id, context ) {\n\t\t\tif ( typeof context.getElementById !== \"undefined\" && documentIsHTML ) {\n\t\t\t\tvar m = context.getElementById( id );\n\t\t\t\treturn m ? [ m ] : [];\n\t\t\t}\n\t\t};\n\t\tExpr.filter[\"ID\"] = function( id ) {\n\t\t\tvar attrId = id.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\treturn elem.getAttribute(\"id\") === attrId;\n\t\t\t};\n\t\t};\n\t} else {\n\t\t// Support: IE6/7\n\t\t// getElementById is not reliable as a find shortcut\n\t\tdelete Expr.find[\"ID\"];\n\n\t\tExpr.filter[\"ID\"] = function( id ) {\n\t\t\tvar attrId = id.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\tvar node = typeof elem.getAttributeNode !== \"undefined\" &&\n\t\t\t\t\telem.getAttributeNode(\"id\");\n\t\t\t\treturn node && node.value === attrId;\n\t\t\t};\n\t\t};\n\t}\n\n\t// Tag\n\tExpr.find[\"TAG\"] = support.getElementsByTagName ?\n\t\tfunction( tag, context ) {\n\t\t\tif ( typeof context.getElementsByTagName !== \"undefined\" ) {\n\t\t\t\treturn context.getElementsByTagName( tag );\n\n\t\t\t// DocumentFragment nodes don't have gEBTN\n\t\t\t} else if ( support.qsa ) {\n\t\t\t\treturn context.querySelectorAll( tag );\n\t\t\t}\n\t\t} :\n\n\t\tfunction( tag, context ) {\n\t\t\tvar elem,\n\t\t\t\ttmp = [],\n\t\t\t\ti = 0,\n\t\t\t\t// By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too\n\t\t\t\tresults = context.getElementsByTagName( tag );\n\n\t\t\t// Filter out possible comments\n\t\t\tif ( tag === \"*\" ) {\n\t\t\t\twhile ( (elem = results[i++]) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 ) {\n\t\t\t\t\t\ttmp.push( elem );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn tmp;\n\t\t\t}\n\t\t\treturn results;\n\t\t};\n\n\t// Class\n\tExpr.find[\"CLASS\"] = support.getElementsByClassName && function( className, context ) {\n\t\tif ( typeof context.getElementsByClassName !== \"undefined\" && documentIsHTML ) {\n\t\t\treturn context.getElementsByClassName( className );\n\t\t}\n\t};\n\n\t/* QSA/matchesSelector\n\t---------------------------------------------------------------------- */\n\n\t// QSA and matchesSelector support\n\n\t// matchesSelector(:active) reports false when true (IE9/Opera 11.5)\n\trbuggyMatches = [];\n\n\t// qSa(:focus) reports false when true (Chrome 21)\n\t// We allow this because of a bug in IE8/9 that throws an error\n\t// whenever `document.activeElement` is accessed on an iframe\n\t// So, we allow :focus to pass through QSA all the time to avoid the IE error\n\t// See http://bugs.jquery.com/ticket/13378\n\trbuggyQSA = [];\n\n\tif ( (support.qsa = rnative.test( document.querySelectorAll )) ) {\n\t\t// Build QSA regex\n\t\t// Regex strategy adopted from Diego Perini\n\t\tassert(function( div ) {\n\t\t\t// Select is set to empty string on purpose\n\t\t\t// This is to test IE's treatment of not explicitly\n\t\t\t// setting a boolean content attribute,\n\t\t\t// since its presence should be enough\n\t\t\t// http://bugs.jquery.com/ticket/12359\n\t\t\tdocElem.appendChild( div ).innerHTML = \"<a id='\" + expando + \"'></a>\" +\n\t\t\t\t\"<select id='\" + expando + \"-\\r\\\\' msallowcapture=''>\" +\n\t\t\t\t\"<option selected=''></option></select>\";\n\n\t\t\t// Support: IE8, Opera 11-12.16\n\t\t\t// Nothing should be selected when empty strings follow ^= or $= or *=\n\t\t\t// The test attribute must be unknown in Opera but \"safe\" for WinRT\n\t\t\t// http://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section\n\t\t\tif ( div.querySelectorAll(\"[msallowcapture^='']\").length ) {\n\t\t\t\trbuggyQSA.push( \"[*^$]=\" + whitespace + \"*(?:''|\\\"\\\")\" );\n\t\t\t}\n\n\t\t\t// Support: IE8\n\t\t\t// Boolean attributes and \"value\" are not treated correctly\n\t\t\tif ( !div.querySelectorAll(\"[selected]\").length ) {\n\t\t\t\trbuggyQSA.push( \"\\\\[\" + whitespace + \"*(?:value|\" + booleans + \")\" );\n\t\t\t}\n\n\t\t\t// Support: Chrome<29, Android<4.4, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.8+\n\t\t\tif ( !div.querySelectorAll( \"[id~=\" + expando + \"-]\" ).length ) {\n\t\t\t\trbuggyQSA.push(\"~=\");\n\t\t\t}\n\n\t\t\t// Webkit/Opera - :checked should return selected option elements\n\t\t\t// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked\n\t\t\t// IE8 throws error here and will not see later tests\n\t\t\tif ( !div.querySelectorAll(\":checked\").length ) {\n\t\t\t\trbuggyQSA.push(\":checked\");\n\t\t\t}\n\n\t\t\t// Support: Safari 8+, iOS 8+\n\t\t\t// https://bugs.webkit.org/show_bug.cgi?id=136851\n\t\t\t// In-page `selector#id sibing-combinator selector` fails\n\t\t\tif ( !div.querySelectorAll( \"a#\" + expando + \"+*\" ).length ) {\n\t\t\t\trbuggyQSA.push(\".#.+[+~]\");\n\t\t\t}\n\t\t});\n\n\t\tassert(function( div ) {\n\t\t\t// Support: Windows 8 Native Apps\n\t\t\t// The type and name attributes are restricted during .innerHTML assignment\n\t\t\tvar input = document.createElement(\"input\");\n\t\t\tinput.setAttribute( \"type\", \"hidden\" );\n\t\t\tdiv.appendChild( input ).setAttribute( \"name\", \"D\" );\n\n\t\t\t// Support: IE8\n\t\t\t// Enforce case-sensitivity of name attribute\n\t\t\tif ( div.querySelectorAll(\"[name=d]\").length ) {\n\t\t\t\trbuggyQSA.push( \"name\" + whitespace + \"*[*^$|!~]?=\" );\n\t\t\t}\n\n\t\t\t// FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled)\n\t\t\t// IE8 throws error here and will not see later tests\n\t\t\tif ( !div.querySelectorAll(\":enabled\").length ) {\n\t\t\t\trbuggyQSA.push( \":enabled\", \":disabled\" );\n\t\t\t}\n\n\t\t\t// Opera 10-11 does not throw on post-comma invalid pseudos\n\t\t\tdiv.querySelectorAll(\"*,:x\");\n\t\t\trbuggyQSA.push(\",.*:\");\n\t\t});\n\t}\n\n\tif ( (support.matchesSelector = rnative.test( (matches = docElem.matches ||\n\t\tdocElem.webkitMatchesSelector ||\n\t\tdocElem.mozMatchesSelector ||\n\t\tdocElem.oMatchesSelector ||\n\t\tdocElem.msMatchesSelector) )) ) {\n\n\t\tassert(function( div ) {\n\t\t\t// Check to see if it's possible to do matchesSelector\n\t\t\t// on a disconnected node (IE 9)\n\t\t\tsupport.disconnectedMatch = matches.call( div, \"div\" );\n\n\t\t\t// This should fail with an exception\n\t\t\t// Gecko does not error, returns false instead\n\t\t\tmatches.call( div, \"[s!='']:x\" );\n\t\t\trbuggyMatches.push( \"!=\", pseudos );\n\t\t});\n\t}\n\n\trbuggyQSA = rbuggyQSA.length && new RegExp( rbuggyQSA.join(\"|\") );\n\trbuggyMatches = rbuggyMatches.length && new RegExp( rbuggyMatches.join(\"|\") );\n\n\t/* Contains\n\t---------------------------------------------------------------------- */\n\thasCompare = rnative.test( docElem.compareDocumentPosition );\n\n\t// Element contains another\n\t// Purposefully self-exclusive\n\t// As in, an element does not contain itself\n\tcontains = hasCompare || rnative.test( docElem.contains ) ?\n\t\tfunction( a, b ) {\n\t\t\tvar adown = a.nodeType === 9 ? a.documentElement : a,\n\t\t\t\tbup = b && b.parentNode;\n\t\t\treturn a === bup || !!( bup && bup.nodeType === 1 && (\n\t\t\t\tadown.contains ?\n\t\t\t\t\tadown.contains( bup ) :\n\t\t\t\t\ta.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16\n\t\t\t));\n\t\t} :\n\t\tfunction( a, b ) {\n\t\t\tif ( b ) {\n\t\t\t\twhile ( (b = b.parentNode) ) {\n\t\t\t\t\tif ( b === a ) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n\n\t/* Sorting\n\t---------------------------------------------------------------------- */\n\n\t// Document order sorting\n\tsortOrder = hasCompare ?\n\tfunction( a, b ) {\n\n\t\t// Flag for duplicate removal\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t\treturn 0;\n\t\t}\n\n\t\t// Sort on method existence if only one input has compareDocumentPosition\n\t\tvar compare = !a.compareDocumentPosition - !b.compareDocumentPosition;\n\t\tif ( compare ) {\n\t\t\treturn compare;\n\t\t}\n\n\t\t// Calculate position if both inputs belong to the same document\n\t\tcompare = ( a.ownerDocument || a ) === ( b.ownerDocument || b ) ?\n\t\t\ta.compareDocumentPosition( b ) :\n\n\t\t\t// Otherwise we know they are disconnected\n\t\t\t1;\n\n\t\t// Disconnected nodes\n\t\tif ( compare & 1 ||\n\t\t\t(!support.sortDetached && b.compareDocumentPosition( a ) === compare) ) {\n\n\t\t\t// Choose the first element that is related to our preferred document\n\t\t\tif ( a === document || a.ownerDocument === preferredDoc && contains(preferredDoc, a) ) {\n\t\t\t\treturn -1;\n\t\t\t}\n\t\t\tif ( b === document || b.ownerDocument === preferredDoc && contains(preferredDoc, b) ) {\n\t\t\t\treturn 1;\n\t\t\t}\n\n\t\t\t// Maintain original order\n\t\t\treturn sortInput ?\n\t\t\t\t( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :\n\t\t\t\t0;\n\t\t}\n\n\t\treturn compare & 4 ? -1 : 1;\n\t} :\n\tfunction( a, b ) {\n\t\t// Exit early if the nodes are identical\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t\treturn 0;\n\t\t}\n\n\t\tvar cur,\n\t\t\ti = 0,\n\t\t\taup = a.parentNode,\n\t\t\tbup = b.parentNode,\n\t\t\tap = [ a ],\n\t\t\tbp = [ b ];\n\n\t\t// Parentless nodes are either documents or disconnected\n\t\tif ( !aup || !bup ) {\n\t\t\treturn a === document ? -1 :\n\t\t\t\tb === document ? 1 :\n\t\t\t\taup ? -1 :\n\t\t\t\tbup ? 1 :\n\t\t\t\tsortInput ?\n\t\t\t\t( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :\n\t\t\t\t0;\n\n\t\t// If the nodes are siblings, we can do a quick check\n\t\t} else if ( aup === bup ) {\n\t\t\treturn siblingCheck( a, b );\n\t\t}\n\n\t\t// Otherwise we need full lists of their ancestors for comparison\n\t\tcur = a;\n\t\twhile ( (cur = cur.parentNode) ) {\n\t\t\tap.unshift( cur );\n\t\t}\n\t\tcur = b;\n\t\twhile ( (cur = cur.parentNode) ) {\n\t\t\tbp.unshift( cur );\n\t\t}\n\n\t\t// Walk down the tree looking for a discrepancy\n\t\twhile ( ap[i] === bp[i] ) {\n\t\t\ti++;\n\t\t}\n\n\t\treturn i ?\n\t\t\t// Do a sibling check if the nodes have a common ancestor\n\t\t\tsiblingCheck( ap[i], bp[i] ) :\n\n\t\t\t// Otherwise nodes in our document sort first\n\t\t\tap[i] === preferredDoc ? -1 :\n\t\t\tbp[i] === preferredDoc ? 1 :\n\t\t\t0;\n\t};\n\n\treturn document;\n};\n\nSizzle.matches = function( expr, elements ) {\n\treturn Sizzle( expr, null, null, elements );\n};\n\nSizzle.matchesSelector = function( elem, expr ) {\n\t// Set document vars if needed\n\tif ( ( elem.ownerDocument || elem ) !== document ) {\n\t\tsetDocument( elem );\n\t}\n\n\t// Make sure that attribute selectors are quoted\n\texpr = expr.replace( rattributeQuotes, \"='$1']\" );\n\n\tif ( support.matchesSelector && documentIsHTML &&\n\t\t!compilerCache[ expr + \" \" ] &&\n\t\t( !rbuggyMatches || !rbuggyMatches.test( expr ) ) &&\n\t\t( !rbuggyQSA || !rbuggyQSA.test( expr ) ) ) {\n\n\t\ttry {\n\t\t\tvar ret = matches.call( elem, expr );\n\n\t\t\t// IE 9's matchesSelector returns false on disconnected nodes\n\t\t\tif ( ret || support.disconnectedMatch ||\n\t\t\t\t\t// As well, disconnected nodes are said to be in a document\n\t\t\t\t\t// fragment in IE 9\n\t\t\t\t\telem.document && elem.document.nodeType !== 11 ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\t\t} catch (e) {}\n\t}\n\n\treturn Sizzle( expr, document, null, [ elem ] ).length > 0;\n};\n\nSizzle.contains = function( context, elem ) {\n\t// Set document vars if needed\n\tif ( ( context.ownerDocument || context ) !== document ) {\n\t\tsetDocument( context );\n\t}\n\treturn contains( context, elem );\n};\n\nSizzle.attr = function( elem, name ) {\n\t// Set document vars if needed\n\tif ( ( elem.ownerDocument || elem ) !== document ) {\n\t\tsetDocument( elem );\n\t}\n\n\tvar fn = Expr.attrHandle[ name.toLowerCase() ],\n\t\t// Don't get fooled by Object.prototype properties (jQuery #13807)\n\t\tval = fn && hasOwn.call( Expr.attrHandle, name.toLowerCase() ) ?\n\t\t\tfn( elem, name, !documentIsHTML ) :\n\t\t\tundefined;\n\n\treturn val !== undefined ?\n\t\tval :\n\t\tsupport.attributes || !documentIsHTML ?\n\t\t\telem.getAttribute( name ) :\n\t\t\t(val = elem.getAttributeNode(name)) && val.specified ?\n\t\t\t\tval.value :\n\t\t\t\tnull;\n};\n\nSizzle.error = function( msg ) {\n\tthrow new Error( \"Syntax error, unrecognized expression: \" + msg );\n};\n\n/**\n * Document sorting and removing duplicates\n * @param {ArrayLike} results\n */\nSizzle.uniqueSort = function( results ) {\n\tvar elem,\n\t\tduplicates = [],\n\t\tj = 0,\n\t\ti = 0;\n\n\t// Unless we *know* we can detect duplicates, assume their presence\n\thasDuplicate = !support.detectDuplicates;\n\tsortInput = !support.sortStable && results.slice( 0 );\n\tresults.sort( sortOrder );\n\n\tif ( hasDuplicate ) {\n\t\twhile ( (elem = results[i++]) ) {\n\t\t\tif ( elem === results[ i ] ) {\n\t\t\t\tj = duplicates.push( i );\n\t\t\t}\n\t\t}\n\t\twhile ( j-- ) {\n\t\t\tresults.splice( duplicates[ j ], 1 );\n\t\t}\n\t}\n\n\t// Clear input after sorting to release objects\n\t// See https://github.com/jquery/sizzle/pull/225\n\tsortInput = null;\n\n\treturn results;\n};\n\n/**\n * Utility function for retrieving the text value of an array of DOM nodes\n * @param {Array|Element} elem\n */\ngetText = Sizzle.getText = function( elem ) {\n\tvar node,\n\t\tret = \"\",\n\t\ti = 0,\n\t\tnodeType = elem.nodeType;\n\n\tif ( !nodeType ) {\n\t\t// If no nodeType, this is expected to be an array\n\t\twhile ( (node = elem[i++]) ) {\n\t\t\t// Do not traverse comment nodes\n\t\t\tret += getText( node );\n\t\t}\n\t} else if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) {\n\t\t// Use textContent for elements\n\t\t// innerText usage removed for consistency of new lines (jQuery #11153)\n\t\tif ( typeof elem.textContent === \"string\" ) {\n\t\t\treturn elem.textContent;\n\t\t} else {\n\t\t\t// Traverse its children\n\t\t\tfor ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {\n\t\t\t\tret += getText( elem );\n\t\t\t}\n\t\t}\n\t} else if ( nodeType === 3 || nodeType === 4 ) {\n\t\treturn elem.nodeValue;\n\t}\n\t// Do not include comment or processing instruction nodes\n\n\treturn ret;\n};\n\nExpr = Sizzle.selectors = {\n\n\t// Can be adjusted by the user\n\tcacheLength: 50,\n\n\tcreatePseudo: markFunction,\n\n\tmatch: matchExpr,\n\n\tattrHandle: {},\n\n\tfind: {},\n\n\trelative: {\n\t\t\">\": { dir: \"parentNode\", first: true },\n\t\t\" \": { dir: \"parentNode\" },\n\t\t\"+\": { dir: \"previousSibling\", first: true },\n\t\t\"~\": { dir: \"previousSibling\" }\n\t},\n\n\tpreFilter: {\n\t\t\"ATTR\": function( match ) {\n\t\t\tmatch[1] = match[1].replace( runescape, funescape );\n\n\t\t\t// Move the given value to match[3] whether quoted or unquoted\n\t\t\tmatch[3] = ( match[3] || match[4] || match[5] || \"\" ).replace( runescape, funescape );\n\n\t\t\tif ( match[2] === \"~=\" ) {\n\t\t\t\tmatch[3] = \" \" + match[3] + \" \";\n\t\t\t}\n\n\t\t\treturn match.slice( 0, 4 );\n\t\t},\n\n\t\t\"CHILD\": function( match ) {\n\t\t\t/* matches from matchExpr[\"CHILD\"]\n\t\t\t\t1 type (only|nth|...)\n\t\t\t\t2 what (child|of-type)\n\t\t\t\t3 argument (even|odd|\\d*|\\d*n([+-]\\d+)?|...)\n\t\t\t\t4 xn-component of xn+y argument ([+-]?\\d*n|)\n\t\t\t\t5 sign of xn-component\n\t\t\t\t6 x of xn-component\n\t\t\t\t7 sign of y-component\n\t\t\t\t8 y of y-component\n\t\t\t*/\n\t\t\tmatch[1] = match[1].toLowerCase();\n\n\t\t\tif ( match[1].slice( 0, 3 ) === \"nth\" ) {\n\t\t\t\t// nth-* requires argument\n\t\t\t\tif ( !match[3] ) {\n\t\t\t\t\tSizzle.error( match[0] );\n\t\t\t\t}\n\n\t\t\t\t// numeric x and y parameters for Expr.filter.CHILD\n\t\t\t\t// remember that false/true cast respectively to 0/1\n\t\t\t\tmatch[4] = +( match[4] ? match[5] + (match[6] || 1) : 2 * ( match[3] === \"even\" || match[3] === \"odd\" ) );\n\t\t\t\tmatch[5] = +( ( match[7] + match[8] ) || match[3] === \"odd\" );\n\n\t\t\t// other types prohibit arguments\n\t\t\t} else if ( match[3] ) {\n\t\t\t\tSizzle.error( match[0] );\n\t\t\t}\n\n\t\t\treturn match;\n\t\t},\n\n\t\t\"PSEUDO\": function( match ) {\n\t\t\tvar excess,\n\t\t\t\tunquoted = !match[6] && match[2];\n\n\t\t\tif ( matchExpr[\"CHILD\"].test( match[0] ) ) {\n\t\t\t\treturn null;\n\t\t\t}\n\n\t\t\t// Accept quoted arguments as-is\n\t\t\tif ( match[3] ) {\n\t\t\t\tmatch[2] = match[4] || match[5] || \"\";\n\n\t\t\t// Strip excess characters from unquoted arguments\n\t\t\t} else if ( unquoted && rpseudo.test( unquoted ) &&\n\t\t\t\t// Get excess from tokenize (recursively)\n\t\t\t\t(excess = tokenize( unquoted, true )) &&\n\t\t\t\t// advance to the next closing parenthesis\n\t\t\t\t(excess = unquoted.indexOf( \")\", unquoted.length - excess ) - unquoted.length) ) {\n\n\t\t\t\t// excess is a negative index\n\t\t\t\tmatch[0] = match[0].slice( 0, excess );\n\t\t\t\tmatch[2] = unquoted.slice( 0, excess );\n\t\t\t}\n\n\t\t\t// Return only captures needed by the pseudo filter method (type and argument)\n\t\t\treturn match.slice( 0, 3 );\n\t\t}\n\t},\n\n\tfilter: {\n\n\t\t\"TAG\": function( nodeNameSelector ) {\n\t\t\tvar nodeName = nodeNameSelector.replace( runescape, funescape ).toLowerCase();\n\t\t\treturn nodeNameSelector === \"*\" ?\n\t\t\t\tfunction() { return true; } :\n\t\t\t\tfunction( elem ) {\n\t\t\t\t\treturn elem.nodeName && elem.nodeName.toLowerCase() === nodeName;\n\t\t\t\t};\n\t\t},\n\n\t\t\"CLASS\": function( className ) {\n\t\t\tvar pattern = classCache[ className + \" \" ];\n\n\t\t\treturn pattern ||\n\t\t\t\t(pattern = new RegExp( \"(^|\" + whitespace + \")\" + className + \"(\" + whitespace + \"|$)\" )) &&\n\t\t\t\tclassCache( className, function( elem ) {\n\t\t\t\t\treturn pattern.test( typeof elem.className === \"string\" && elem.className || typeof elem.getAttribute !== \"undefined\" && elem.getAttribute(\"class\") || \"\" );\n\t\t\t\t});\n\t\t},\n\n\t\t\"ATTR\": function( name, operator, check ) {\n\t\t\treturn function( elem ) {\n\t\t\t\tvar result = Sizzle.attr( elem, name );\n\n\t\t\t\tif ( result == null ) {\n\t\t\t\t\treturn operator === \"!=\";\n\t\t\t\t}\n\t\t\t\tif ( !operator ) {\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\n\t\t\t\tresult += \"\";\n\n\t\t\t\treturn operator === \"=\" ? result === check :\n\t\t\t\t\toperator === \"!=\" ? result !== check :\n\t\t\t\t\toperator === \"^=\" ? check && result.indexOf( check ) === 0 :\n\t\t\t\t\toperator === \"*=\" ? check && result.indexOf( check ) > -1 :\n\t\t\t\t\toperator === \"$=\" ? check && result.slice( -check.length ) === check :\n\t\t\t\t\toperator === \"~=\" ? ( \" \" + result.replace( rwhitespace, \" \" ) + \" \" ).indexOf( check ) > -1 :\n\t\t\t\t\toperator === \"|=\" ? result === check || result.slice( 0, check.length + 1 ) === check + \"-\" :\n\t\t\t\t\tfalse;\n\t\t\t};\n\t\t},\n\n\t\t\"CHILD\": function( type, what, argument, first, last ) {\n\t\t\tvar simple = type.slice( 0, 3 ) !== \"nth\",\n\t\t\t\tforward = type.slice( -4 ) !== \"last\",\n\t\t\t\tofType = what === \"of-type\";\n\n\t\t\treturn first === 1 && last === 0 ?\n\n\t\t\t\t// Shortcut for :nth-*(n)\n\t\t\t\tfunction( elem ) {\n\t\t\t\t\treturn !!elem.parentNode;\n\t\t\t\t} :\n\n\t\t\t\tfunction( elem, context, xml ) {\n\t\t\t\t\tvar cache, uniqueCache, outerCache, node, nodeIndex, start,\n\t\t\t\t\t\tdir = simple !== forward ? \"nextSibling\" : \"previousSibling\",\n\t\t\t\t\t\tparent = elem.parentNode,\n\t\t\t\t\t\tname = ofType && elem.nodeName.toLowerCase(),\n\t\t\t\t\t\tuseCache = !xml && !ofType,\n\t\t\t\t\t\tdiff = false;\n\n\t\t\t\t\tif ( parent ) {\n\n\t\t\t\t\t\t// :(first|last|only)-(child|of-type)\n\t\t\t\t\t\tif ( simple ) {\n\t\t\t\t\t\t\twhile ( dir ) {\n\t\t\t\t\t\t\t\tnode = elem;\n\t\t\t\t\t\t\t\twhile ( (node = node[ dir ]) ) {\n\t\t\t\t\t\t\t\t\tif ( ofType ?\n\t\t\t\t\t\t\t\t\t\tnode.nodeName.toLowerCase() === name :\n\t\t\t\t\t\t\t\t\t\tnode.nodeType === 1 ) {\n\n\t\t\t\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t// Reverse direction for :only-* (if we haven't yet done so)\n\t\t\t\t\t\t\t\tstart = dir = type === \"only\" && !start && \"nextSibling\";\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tstart = [ forward ? parent.firstChild : parent.lastChild ];\n\n\t\t\t\t\t\t// non-xml :nth-child(...) stores cache data on `parent`\n\t\t\t\t\t\tif ( forward && useCache ) {\n\n\t\t\t\t\t\t\t// Seek `elem` from a previously-cached index\n\n\t\t\t\t\t\t\t// ...in a gzip-friendly way\n\t\t\t\t\t\t\tnode = parent;\n\t\t\t\t\t\t\touterCache = node[ expando ] || (node[ expando ] = {});\n\n\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t(outerCache[ node.uniqueID ] = {});\n\n\t\t\t\t\t\t\tcache = uniqueCache[ type ] || [];\n\t\t\t\t\t\t\tnodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];\n\t\t\t\t\t\t\tdiff = nodeIndex && cache[ 2 ];\n\t\t\t\t\t\t\tnode = nodeIndex && parent.childNodes[ nodeIndex ];\n\n\t\t\t\t\t\t\twhile ( (node = ++nodeIndex && node && node[ dir ] ||\n\n\t\t\t\t\t\t\t\t// Fallback to seeking `elem` from the start\n\t\t\t\t\t\t\t\t(diff = nodeIndex = 0) || start.pop()) ) {\n\n\t\t\t\t\t\t\t\t// When found, cache indexes on `parent` and break\n\t\t\t\t\t\t\t\tif ( node.nodeType === 1 && ++diff && node === elem ) {\n\t\t\t\t\t\t\t\t\tuniqueCache[ type ] = [ dirruns, nodeIndex, diff ];\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// Use previously-cached element index if available\n\t\t\t\t\t\t\tif ( useCache ) {\n\t\t\t\t\t\t\t\t// ...in a gzip-friendly way\n\t\t\t\t\t\t\t\tnode = elem;\n\t\t\t\t\t\t\t\touterCache = node[ expando ] || (node[ expando ] = {});\n\n\t\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t\t(outerCache[ node.uniqueID ] = {});\n\n\t\t\t\t\t\t\t\tcache = uniqueCache[ type ] || [];\n\t\t\t\t\t\t\t\tnodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];\n\t\t\t\t\t\t\t\tdiff = nodeIndex;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// xml :nth-child(...)\n\t\t\t\t\t\t\t// or :nth-last-child(...) or :nth(-last)?-of-type(...)\n\t\t\t\t\t\t\tif ( diff === false ) {\n\t\t\t\t\t\t\t\t// Use the same loop as above to seek `elem` from the start\n\t\t\t\t\t\t\t\twhile ( (node = ++nodeIndex && node && node[ dir ] ||\n\t\t\t\t\t\t\t\t\t(diff = nodeIndex = 0) || start.pop()) ) {\n\n\t\t\t\t\t\t\t\t\tif ( ( ofType ?\n\t\t\t\t\t\t\t\t\t\tnode.nodeName.toLowerCase() === name :\n\t\t\t\t\t\t\t\t\t\tnode.nodeType === 1 ) &&\n\t\t\t\t\t\t\t\t\t\t++diff ) {\n\n\t\t\t\t\t\t\t\t\t\t// Cache the index of each encountered element\n\t\t\t\t\t\t\t\t\t\tif ( useCache ) {\n\t\t\t\t\t\t\t\t\t\t\touterCache = node[ expando ] || (node[ expando ] = {});\n\n\t\t\t\t\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t\t\t\t\t(outerCache[ node.uniqueID ] = {});\n\n\t\t\t\t\t\t\t\t\t\t\tuniqueCache[ type ] = [ dirruns, diff ];\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tif ( node === elem ) {\n\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Incorporate the offset, then check against cycle size\n\t\t\t\t\t\tdiff -= last;\n\t\t\t\t\t\treturn diff === first || ( diff % first === 0 && diff / first >= 0 );\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t},\n\n\t\t\"PSEUDO\": function( pseudo, argument ) {\n\t\t\t// pseudo-class names are case-insensitive\n\t\t\t// http://www.w3.org/TR/selectors/#pseudo-classes\n\t\t\t// Prioritize by case sensitivity in case custom pseudos are added with uppercase letters\n\t\t\t// Remember that setFilters inherits from pseudos\n\t\t\tvar args,\n\t\t\t\tfn = Expr.pseudos[ pseudo ] || Expr.setFilters[ pseudo.toLowerCase() ] ||\n\t\t\t\t\tSizzle.error( \"unsupported pseudo: \" + pseudo );\n\n\t\t\t// The user may use createPseudo to indicate that\n\t\t\t// arguments are needed to create the filter function\n\t\t\t// just as Sizzle does\n\t\t\tif ( fn[ expando ] ) {\n\t\t\t\treturn fn( argument );\n\t\t\t}\n\n\t\t\t// But maintain support for old signatures\n\t\t\tif ( fn.length > 1 ) {\n\t\t\t\targs = [ pseudo, pseudo, \"\", argument ];\n\t\t\t\treturn Expr.setFilters.hasOwnProperty( pseudo.toLowerCase() ) ?\n\t\t\t\t\tmarkFunction(function( seed, matches ) {\n\t\t\t\t\t\tvar idx,\n\t\t\t\t\t\t\tmatched = fn( seed, argument ),\n\t\t\t\t\t\t\ti = matched.length;\n\t\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\t\tidx = indexOf( seed, matched[i] );\n\t\t\t\t\t\t\tseed[ idx ] = !( matches[ idx ] = matched[i] );\n\t\t\t\t\t\t}\n\t\t\t\t\t}) :\n\t\t\t\t\tfunction( elem ) {\n\t\t\t\t\t\treturn fn( elem, 0, args );\n\t\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn fn;\n\t\t}\n\t},\n\n\tpseudos: {\n\t\t// Potentially complex pseudos\n\t\t\"not\": markFunction(function( selector ) {\n\t\t\t// Trim the selector passed to compile\n\t\t\t// to avoid treating leading and trailing\n\t\t\t// spaces as combinators\n\t\t\tvar input = [],\n\t\t\t\tresults = [],\n\t\t\t\tmatcher = compile( selector.replace( rtrim, \"$1\" ) );\n\n\t\t\treturn matcher[ expando ] ?\n\t\t\t\tmarkFunction(function( seed, matches, context, xml ) {\n\t\t\t\t\tvar elem,\n\t\t\t\t\t\tunmatched = matcher( seed, null, xml, [] ),\n\t\t\t\t\t\ti = seed.length;\n\n\t\t\t\t\t// Match elements unmatched by `matcher`\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tif ( (elem = unmatched[i]) ) {\n\t\t\t\t\t\t\tseed[i] = !(matches[i] = elem);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}) :\n\t\t\t\tfunction( elem, context, xml ) {\n\t\t\t\t\tinput[0] = elem;\n\t\t\t\t\tmatcher( input, null, xml, results );\n\t\t\t\t\t// Don't keep the element (issue #299)\n\t\t\t\t\tinput[0] = null;\n\t\t\t\t\treturn !results.pop();\n\t\t\t\t};\n\t\t}),\n\n\t\t\"has\": markFunction(function( selector ) {\n\t\t\treturn function( elem ) {\n\t\t\t\treturn Sizzle( selector, elem ).length > 0;\n\t\t\t};\n\t\t}),\n\n\t\t\"contains\": markFunction(function( text ) {\n\t\t\ttext = text.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\treturn ( elem.textContent || elem.innerText || getText( elem ) ).indexOf( text ) > -1;\n\t\t\t};\n\t\t}),\n\n\t\t// \"Whether an element is represented by a :lang() selector\n\t\t// is based solely on the element's language value\n\t\t// being equal to the identifier C,\n\t\t// or beginning with the identifier C immediately followed by \"-\".\n\t\t// The matching of C against the element's language value is performed case-insensitively.\n\t\t// The identifier C does not have to be a valid language name.\"\n\t\t// http://www.w3.org/TR/selectors/#lang-pseudo\n\t\t\"lang\": markFunction( function( lang ) {\n\t\t\t// lang value must be a valid identifier\n\t\t\tif ( !ridentifier.test(lang || \"\") ) {\n\t\t\t\tSizzle.error( \"unsupported lang: \" + lang );\n\t\t\t}\n\t\t\tlang = lang.replace( runescape, funescape ).toLowerCase();\n\t\t\treturn function( elem ) {\n\t\t\t\tvar elemLang;\n\t\t\t\tdo {\n\t\t\t\t\tif ( (elemLang = documentIsHTML ?\n\t\t\t\t\t\telem.lang :\n\t\t\t\t\t\telem.getAttribute(\"xml:lang\") || elem.getAttribute(\"lang\")) ) {\n\n\t\t\t\t\t\telemLang = elemLang.toLowerCase();\n\t\t\t\t\t\treturn elemLang === lang || elemLang.indexOf( lang + \"-\" ) === 0;\n\t\t\t\t\t}\n\t\t\t\t} while ( (elem = elem.parentNode) && elem.nodeType === 1 );\n\t\t\t\treturn false;\n\t\t\t};\n\t\t}),\n\n\t\t// Miscellaneous\n\t\t\"target\": function( elem ) {\n\t\t\tvar hash = window.location && window.location.hash;\n\t\t\treturn hash && hash.slice( 1 ) === elem.id;\n\t\t},\n\n\t\t\"root\": function( elem ) {\n\t\t\treturn elem === docElem;\n\t\t},\n\n\t\t\"focus\": function( elem ) {\n\t\t\treturn elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex);\n\t\t},\n\n\t\t// Boolean properties\n\t\t\"enabled\": function( elem ) {\n\t\t\treturn elem.disabled === false;\n\t\t},\n\n\t\t\"disabled\": function( elem ) {\n\t\t\treturn elem.disabled === true;\n\t\t},\n\n\t\t\"checked\": function( elem ) {\n\t\t\t// In CSS3, :checked should return both checked and selected elements\n\t\t\t// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked\n\t\t\tvar nodeName = elem.nodeName.toLowerCase();\n\t\t\treturn (nodeName === \"input\" && !!elem.checked) || (nodeName === \"option\" && !!elem.selected);\n\t\t},\n\n\t\t\"selected\": function( elem ) {\n\t\t\t// Accessing this property makes selected-by-default\n\t\t\t// options in Safari work properly\n\t\t\tif ( elem.parentNode ) {\n\t\t\t\telem.parentNode.selectedIndex;\n\t\t\t}\n\n\t\t\treturn elem.selected === true;\n\t\t},\n\n\t\t// Contents\n\t\t\"empty\": function( elem ) {\n\t\t\t// http://www.w3.org/TR/selectors/#empty-pseudo\n\t\t\t// :empty is negated by element (1) or content nodes (text: 3; cdata: 4; entity ref: 5),\n\t\t\t// but not by others (comment: 8; processing instruction: 7; etc.)\n\t\t\t// nodeType < 6 works because attributes (2) do not appear as children\n\t\t\tfor ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {\n\t\t\t\tif ( elem.nodeType < 6 ) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t},\n\n\t\t\"parent\": function( elem ) {\n\t\t\treturn !Expr.pseudos[\"empty\"]( elem );\n\t\t},\n\n\t\t// Element/input types\n\t\t\"header\": function( elem ) {\n\t\t\treturn rheader.test( elem.nodeName );\n\t\t},\n\n\t\t\"input\": function( elem ) {\n\t\t\treturn rinputs.test( elem.nodeName );\n\t\t},\n\n\t\t\"button\": function( elem ) {\n\t\t\tvar name = elem.nodeName.toLowerCase();\n\t\t\treturn name === \"input\" && elem.type === \"button\" || name === \"button\";\n\t\t},\n\n\t\t\"text\": function( elem ) {\n\t\t\tvar attr;\n\t\t\treturn elem.nodeName.toLowerCase() === \"input\" &&\n\t\t\t\telem.type === \"text\" &&\n\n\t\t\t\t// Support: IE<8\n\t\t\t\t// New HTML5 attribute values (e.g., \"search\") appear with elem.type === \"text\"\n\t\t\t\t( (attr = elem.getAttribute(\"type\")) == null || attr.toLowerCase() === \"text\" );\n\t\t},\n\n\t\t// Position-in-collection\n\t\t\"first\": createPositionalPseudo(function() {\n\t\t\treturn [ 0 ];\n\t\t}),\n\n\t\t\"last\": createPositionalPseudo(function( matchIndexes, length ) {\n\t\t\treturn [ length - 1 ];\n\t\t}),\n\n\t\t\"eq\": createPositionalPseudo(function( matchIndexes, length, argument ) {\n\t\t\treturn [ argument < 0 ? argument + length : argument ];\n\t\t}),\n\n\t\t\"even\": createPositionalPseudo(function( matchIndexes, length ) {\n\t\t\tvar i = 0;\n\t\t\tfor ( ; i < length; i += 2 ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t}),\n\n\t\t\"odd\": createPositionalPseudo(function( matchIndexes, length ) {\n\t\t\tvar i = 1;\n\t\t\tfor ( ; i < length; i += 2 ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t}),\n\n\t\t\"lt\": createPositionalPseudo(function( matchIndexes, length, argument ) {\n\t\t\tvar i = argument < 0 ? argument + length : argument;\n\t\t\tfor ( ; --i >= 0; ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t}),\n\n\t\t\"gt\": createPositionalPseudo(function( matchIndexes, length, argument ) {\n\t\t\tvar i = argument < 0 ? argument + length : argument;\n\t\t\tfor ( ; ++i < length; ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t})\n\t}\n};\n\nExpr.pseudos[\"nth\"] = Expr.pseudos[\"eq\"];\n\n// Add button/input type pseudos\nfor ( i in { radio: true, checkbox: true, file: true, password: true, image: true } ) {\n\tExpr.pseudos[ i ] = createInputPseudo( i );\n}\nfor ( i in { submit: true, reset: true } ) {\n\tExpr.pseudos[ i ] = createButtonPseudo( i );\n}\n\n// Easy API for creating new setFilters\nfunction setFilters() {}\nsetFilters.prototype = Expr.filters = Expr.pseudos;\nExpr.setFilters = new setFilters();\n\ntokenize = Sizzle.tokenize = function( selector, parseOnly ) {\n\tvar matched, match, tokens, type,\n\t\tsoFar, groups, preFilters,\n\t\tcached = tokenCache[ selector + \" \" ];\n\n\tif ( cached ) {\n\t\treturn parseOnly ? 0 : cached.slice( 0 );\n\t}\n\n\tsoFar = selector;\n\tgroups = [];\n\tpreFilters = Expr.preFilter;\n\n\twhile ( soFar ) {\n\n\t\t// Comma and first run\n\t\tif ( !matched || (match = rcomma.exec( soFar )) ) {\n\t\t\tif ( match ) {\n\t\t\t\t// Don't consume trailing commas as valid\n\t\t\t\tsoFar = soFar.slice( match[0].length ) || soFar;\n\t\t\t}\n\t\t\tgroups.push( (tokens = []) );\n\t\t}\n\n\t\tmatched = false;\n\n\t\t// Combinators\n\t\tif ( (match = rcombinators.exec( soFar )) ) {\n\t\t\tmatched = match.shift();\n\t\t\ttokens.push({\n\t\t\t\tvalue: matched,\n\t\t\t\t// Cast descendant combinators to space\n\t\t\t\ttype: match[0].replace( rtrim, \" \" )\n\t\t\t});\n\t\t\tsoFar = soFar.slice( matched.length );\n\t\t}\n\n\t\t// Filters\n\t\tfor ( type in Expr.filter ) {\n\t\t\tif ( (match = matchExpr[ type ].exec( soFar )) && (!preFilters[ type ] ||\n\t\t\t\t(match = preFilters[ type ]( match ))) ) {\n\t\t\t\tmatched = match.shift();\n\t\t\t\ttokens.push({\n\t\t\t\t\tvalue: matched,\n\t\t\t\t\ttype: type,\n\t\t\t\t\tmatches: match\n\t\t\t\t});\n\t\t\t\tsoFar = soFar.slice( matched.length );\n\t\t\t}\n\t\t}\n\n\t\tif ( !matched ) {\n\t\t\tbreak;\n\t\t}\n\t}\n\n\t// Return the length of the invalid excess\n\t// if we're just parsing\n\t// Otherwise, throw an error or return tokens\n\treturn parseOnly ?\n\t\tsoFar.length :\n\t\tsoFar ?\n\t\t\tSizzle.error( selector ) :\n\t\t\t// Cache the tokens\n\t\t\ttokenCache( selector, groups ).slice( 0 );\n};\n\nfunction toSelector( tokens ) {\n\tvar i = 0,\n\t\tlen = tokens.length,\n\t\tselector = \"\";\n\tfor ( ; i < len; i++ ) {\n\t\tselector += tokens[i].value;\n\t}\n\treturn selector;\n}\n\nfunction addCombinator( matcher, combinator, base ) {\n\tvar dir = combinator.dir,\n\t\tcheckNonElements = base && dir === \"parentNode\",\n\t\tdoneName = done++;\n\n\treturn combinator.first ?\n\t\t// Check against closest ancestor/preceding element\n\t\tfunction( elem, context, xml ) {\n\t\t\twhile ( (elem = elem[ dir ]) ) {\n\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\treturn matcher( elem, context, xml );\n\t\t\t\t}\n\t\t\t}\n\t\t} :\n\n\t\t// Check against all ancestor/preceding elements\n\t\tfunction( elem, context, xml ) {\n\t\t\tvar oldCache, uniqueCache, outerCache,\n\t\t\t\tnewCache = [ dirruns, doneName ];\n\n\t\t\t// We can't set arbitrary data on XML nodes, so they don't benefit from combinator caching\n\t\t\tif ( xml ) {\n\t\t\t\twhile ( (elem = elem[ dir ]) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\t\tif ( matcher( elem, context, xml ) ) {\n\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\twhile ( (elem = elem[ dir ]) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\t\touterCache = elem[ expando ] || (elem[ expando ] = {});\n\n\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\tuniqueCache = outerCache[ elem.uniqueID ] || (outerCache[ elem.uniqueID ] = {});\n\n\t\t\t\t\t\tif ( (oldCache = uniqueCache[ dir ]) &&\n\t\t\t\t\t\t\toldCache[ 0 ] === dirruns && oldCache[ 1 ] === doneName ) {\n\n\t\t\t\t\t\t\t// Assign to newCache so results back-propagate to previous elements\n\t\t\t\t\t\t\treturn (newCache[ 2 ] = oldCache[ 2 ]);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// Reuse newcache so results back-propagate to previous elements\n\t\t\t\t\t\t\tuniqueCache[ dir ] = newCache;\n\n\t\t\t\t\t\t\t// A match means we're done; a fail means we have to keep checking\n\t\t\t\t\t\t\tif ( (newCache[ 2 ] = matcher( elem, context, xml )) ) {\n\t\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n}\n\nfunction elementMatcher( matchers ) {\n\treturn matchers.length > 1 ?\n\t\tfunction( elem, context, xml ) {\n\t\t\tvar i = matchers.length;\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( !matchers[i]( elem, context, xml ) ) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t} :\n\t\tmatchers[0];\n}\n\nfunction multipleContexts( selector, contexts, results ) {\n\tvar i = 0,\n\t\tlen = contexts.length;\n\tfor ( ; i < len; i++ ) {\n\t\tSizzle( selector, contexts[i], results );\n\t}\n\treturn results;\n}\n\nfunction condense( unmatched, map, filter, context, xml ) {\n\tvar elem,\n\t\tnewUnmatched = [],\n\t\ti = 0,\n\t\tlen = unmatched.length,\n\t\tmapped = map != null;\n\n\tfor ( ; i < len; i++ ) {\n\t\tif ( (elem = unmatched[i]) ) {\n\t\t\tif ( !filter || filter( elem, context, xml ) ) {\n\t\t\t\tnewUnmatched.push( elem );\n\t\t\t\tif ( mapped ) {\n\t\t\t\t\tmap.push( i );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn newUnmatched;\n}\n\nfunction setMatcher( preFilter, selector, matcher, postFilter, postFinder, postSelector ) {\n\tif ( postFilter && !postFilter[ expando ] ) {\n\t\tpostFilter = setMatcher( postFilter );\n\t}\n\tif ( postFinder && !postFinder[ expando ] ) {\n\t\tpostFinder = setMatcher( postFinder, postSelector );\n\t}\n\treturn markFunction(function( seed, results, context, xml ) {\n\t\tvar temp, i, elem,\n\t\t\tpreMap = [],\n\t\t\tpostMap = [],\n\t\t\tpreexisting = results.length,\n\n\t\t\t// Get initial elements from seed or context\n\t\t\telems = seed || multipleContexts( selector || \"*\", context.nodeType ? [ context ] : context, [] ),\n\n\t\t\t// Prefilter to get matcher input, preserving a map for seed-results synchronization\n\t\t\tmatcherIn = preFilter && ( seed || !selector ) ?\n\t\t\t\tcondense( elems, preMap, preFilter, context, xml ) :\n\t\t\t\telems,\n\n\t\t\tmatcherOut = matcher ?\n\t\t\t\t// If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results,\n\t\t\t\tpostFinder || ( seed ? preFilter : preexisting || postFilter ) ?\n\n\t\t\t\t\t// ...intermediate processing is necessary\n\t\t\t\t\t[] :\n\n\t\t\t\t\t// ...otherwise use results directly\n\t\t\t\t\tresults :\n\t\t\t\tmatcherIn;\n\n\t\t// Find primary matches\n\t\tif ( matcher ) {\n\t\t\tmatcher( matcherIn, matcherOut, context, xml );\n\t\t}\n\n\t\t// Apply postFilter\n\t\tif ( postFilter ) {\n\t\t\ttemp = condense( matcherOut, postMap );\n\t\t\tpostFilter( temp, [], context, xml );\n\n\t\t\t// Un-match failing elements by moving them back to matcherIn\n\t\t\ti = temp.length;\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( (elem = temp[i]) ) {\n\t\t\t\t\tmatcherOut[ postMap[i] ] = !(matcherIn[ postMap[i] ] = elem);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif ( seed ) {\n\t\t\tif ( postFinder || preFilter ) {\n\t\t\t\tif ( postFinder ) {\n\t\t\t\t\t// Get the final matcherOut by condensing this intermediate into postFinder contexts\n\t\t\t\t\ttemp = [];\n\t\t\t\t\ti = matcherOut.length;\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tif ( (elem = matcherOut[i]) ) {\n\t\t\t\t\t\t\t// Restore matcherIn since elem is not yet a final match\n\t\t\t\t\t\t\ttemp.push( (matcherIn[i] = elem) );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tpostFinder( null, (matcherOut = []), temp, xml );\n\t\t\t\t}\n\n\t\t\t\t// Move matched elements from seed to results to keep them synchronized\n\t\t\t\ti = matcherOut.length;\n\t\t\t\twhile ( i-- ) {\n\t\t\t\t\tif ( (elem = matcherOut[i]) &&\n\t\t\t\t\t\t(temp = postFinder ? indexOf( seed, elem ) : preMap[i]) > -1 ) {\n\n\t\t\t\t\t\tseed[temp] = !(results[temp] = elem);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Add elements to results, through postFinder if defined\n\t\t} else {\n\t\t\tmatcherOut = condense(\n\t\t\t\tmatcherOut === results ?\n\t\t\t\t\tmatcherOut.splice( preexisting, matcherOut.length ) :\n\t\t\t\t\tmatcherOut\n\t\t\t);\n\t\t\tif ( postFinder ) {\n\t\t\t\tpostFinder( null, results, matcherOut, xml );\n\t\t\t} else {\n\t\t\t\tpush.apply( results, matcherOut );\n\t\t\t}\n\t\t}\n\t});\n}\n\nfunction matcherFromTokens( tokens ) {\n\tvar checkContext, matcher, j,\n\t\tlen = tokens.length,\n\t\tleadingRelative = Expr.relative[ tokens[0].type ],\n\t\timplicitRelative = leadingRelative || Expr.relative[\" \"],\n\t\ti = leadingRelative ? 1 : 0,\n\n\t\t// The foundational matcher ensures that elements are reachable from top-level context(s)\n\t\tmatchContext = addCombinator( function( elem ) {\n\t\t\treturn elem === checkContext;\n\t\t}, implicitRelative, true ),\n\t\tmatchAnyContext = addCombinator( function( elem ) {\n\t\t\treturn indexOf( checkContext, elem ) > -1;\n\t\t}, implicitRelative, true ),\n\t\tmatchers = [ function( elem, context, xml ) {\n\t\t\tvar ret = ( !leadingRelative && ( xml || context !== outermostContext ) ) || (\n\t\t\t\t(checkContext = context).nodeType ?\n\t\t\t\t\tmatchContext( elem, context, xml ) :\n\t\t\t\t\tmatchAnyContext( elem, context, xml ) );\n\t\t\t// Avoid hanging onto element (issue #299)\n\t\t\tcheckContext = null;\n\t\t\treturn ret;\n\t\t} ];\n\n\tfor ( ; i < len; i++ ) {\n\t\tif ( (matcher = Expr.relative[ tokens[i].type ]) ) {\n\t\t\tmatchers = [ addCombinator(elementMatcher( matchers ), matcher) ];\n\t\t} else {\n\t\t\tmatcher = Expr.filter[ tokens[i].type ].apply( null, tokens[i].matches );\n\n\t\t\t// Return special upon seeing a positional matcher\n\t\t\tif ( matcher[ expando ] ) {\n\t\t\t\t// Find the next relative operator (if any) for proper handling\n\t\t\t\tj = ++i;\n\t\t\t\tfor ( ; j < len; j++ ) {\n\t\t\t\t\tif ( Expr.relative[ tokens[j].type ] ) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn setMatcher(\n\t\t\t\t\ti > 1 && elementMatcher( matchers ),\n\t\t\t\t\ti > 1 && toSelector(\n\t\t\t\t\t\t// If the preceding token was a descendant combinator, insert an implicit any-element `*`\n\t\t\t\t\t\ttokens.slice( 0, i - 1 ).concat({ value: tokens[ i - 2 ].type === \" \" ? \"*\" : \"\" })\n\t\t\t\t\t).replace( rtrim, \"$1\" ),\n\t\t\t\t\tmatcher,\n\t\t\t\t\ti < j && matcherFromTokens( tokens.slice( i, j ) ),\n\t\t\t\t\tj < len && matcherFromTokens( (tokens = tokens.slice( j )) ),\n\t\t\t\t\tj < len && toSelector( tokens )\n\t\t\t\t);\n\t\t\t}\n\t\t\tmatchers.push( matcher );\n\t\t}\n\t}\n\n\treturn elementMatcher( matchers );\n}\n\nfunction matcherFromGroupMatchers( elementMatchers, setMatchers ) {\n\tvar bySet = setMatchers.length > 0,\n\t\tbyElement = elementMatchers.length > 0,\n\t\tsuperMatcher = function( seed, context, xml, results, outermost ) {\n\t\t\tvar elem, j, matcher,\n\t\t\t\tmatchedCount = 0,\n\t\t\t\ti = \"0\",\n\t\t\t\tunmatched = seed && [],\n\t\t\t\tsetMatched = [],\n\t\t\t\tcontextBackup = outermostContext,\n\t\t\t\t// We must always have either seed elements or outermost context\n\t\t\t\telems = seed || byElement && Expr.find[\"TAG\"]( \"*\", outermost ),\n\t\t\t\t// Use integer dirruns iff this is the outermost matcher\n\t\t\t\tdirrunsUnique = (dirruns += contextBackup == null ? 1 : Math.random() || 0.1),\n\t\t\t\tlen = elems.length;\n\n\t\t\tif ( outermost ) {\n\t\t\t\toutermostContext = context === document || context || outermost;\n\t\t\t}\n\n\t\t\t// Add elements passing elementMatchers directly to results\n\t\t\t// Support: IE<9, Safari\n\t\t\t// Tolerate NodeList properties (IE: \"length\"; Safari: <number>) matching elements by id\n\t\t\tfor ( ; i !== len && (elem = elems[i]) != null; i++ ) {\n\t\t\t\tif ( byElement && elem ) {\n\t\t\t\t\tj = 0;\n\t\t\t\t\tif ( !context && elem.ownerDocument !== document ) {\n\t\t\t\t\t\tsetDocument( elem );\n\t\t\t\t\t\txml = !documentIsHTML;\n\t\t\t\t\t}\n\t\t\t\t\twhile ( (matcher = elementMatchers[j++]) ) {\n\t\t\t\t\t\tif ( matcher( elem, context || document, xml) ) {\n\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif ( outermost ) {\n\t\t\t\t\t\tdirruns = dirrunsUnique;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Track unmatched elements for set filters\n\t\t\t\tif ( bySet ) {\n\t\t\t\t\t// They will have gone through all possible matchers\n\t\t\t\t\tif ( (elem = !matcher && elem) ) {\n\t\t\t\t\t\tmatchedCount--;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Lengthen the array for every element, matched or not\n\t\t\t\t\tif ( seed ) {\n\t\t\t\t\t\tunmatched.push( elem );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// `i` is now the count of elements visited above, and adding it to `matchedCount`\n\t\t\t// makes the latter nonnegative.\n\t\t\tmatchedCount += i;\n\n\t\t\t// Apply set filters to unmatched elements\n\t\t\t// NOTE: This can be skipped if there are no unmatched elements (i.e., `matchedCount`\n\t\t\t// equals `i`), unless we didn't visit _any_ elements in the above loop because we have\n\t\t\t// no element matchers and no seed.\n\t\t\t// Incrementing an initially-string \"0\" `i` allows `i` to remain a string only in that\n\t\t\t// case, which will result in a \"00\" `matchedCount` that differs from `i` but is also\n\t\t\t// numerically zero.\n\t\t\tif ( bySet && i !== matchedCount ) {\n\t\t\t\tj = 0;\n\t\t\t\twhile ( (matcher = setMatchers[j++]) ) {\n\t\t\t\t\tmatcher( unmatched, setMatched, context, xml );\n\t\t\t\t}\n\n\t\t\t\tif ( seed ) {\n\t\t\t\t\t// Reintegrate element matches to eliminate the need for sorting\n\t\t\t\t\tif ( matchedCount > 0 ) {\n\t\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\t\tif ( !(unmatched[i] || setMatched[i]) ) {\n\t\t\t\t\t\t\t\tsetMatched[i] = pop.call( results );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Discard index placeholder values to get only actual matches\n\t\t\t\t\tsetMatched = condense( setMatched );\n\t\t\t\t}\n\n\t\t\t\t// Add matches to results\n\t\t\t\tpush.apply( results, setMatched );\n\n\t\t\t\t// Seedless set matches succeeding multiple successful matchers stipulate sorting\n\t\t\t\tif ( outermost && !seed && setMatched.length > 0 &&\n\t\t\t\t\t( matchedCount + setMatchers.length ) > 1 ) {\n\n\t\t\t\t\tSizzle.uniqueSort( results );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Override manipulation of globals by nested matchers\n\t\t\tif ( outermost ) {\n\t\t\t\tdirruns = dirrunsUnique;\n\t\t\t\toutermostContext = contextBackup;\n\t\t\t}\n\n\t\t\treturn unmatched;\n\t\t};\n\n\treturn bySet ?\n\t\tmarkFunction( superMatcher ) :\n\t\tsuperMatcher;\n}\n\ncompile = Sizzle.compile = function( selector, match /* Internal Use Only */ ) {\n\tvar i,\n\t\tsetMatchers = [],\n\t\telementMatchers = [],\n\t\tcached = compilerCache[ selector + \" \" ];\n\n\tif ( !cached ) {\n\t\t// Generate a function of recursive functions that can be used to check each element\n\t\tif ( !match ) {\n\t\t\tmatch = tokenize( selector );\n\t\t}\n\t\ti = match.length;\n\t\twhile ( i-- ) {\n\t\t\tcached = matcherFromTokens( match[i] );\n\t\t\tif ( cached[ expando ] ) {\n\t\t\t\tsetMatchers.push( cached );\n\t\t\t} else {\n\t\t\t\telementMatchers.push( cached );\n\t\t\t}\n\t\t}\n\n\t\t// Cache the compiled function\n\t\tcached = compilerCache( selector, matcherFromGroupMatchers( elementMatchers, setMatchers ) );\n\n\t\t// Save selector and tokenization\n\t\tcached.selector = selector;\n\t}\n\treturn cached;\n};\n\n/**\n * A low-level selection function that works with Sizzle's compiled\n * selector functions\n * @param {String|Function} selector A selector or a pre-compiled\n * selector function built with Sizzle.compile\n * @param {Element} context\n * @param {Array} [results]\n * @param {Array} [seed] A set of elements to match against\n */\nselect = Sizzle.select = function( selector, context, results, seed ) {\n\tvar i, tokens, token, type, find,\n\t\tcompiled = typeof selector === \"function\" && selector,\n\t\tmatch = !seed && tokenize( (selector = compiled.selector || selector) );\n\n\tresults = results || [];\n\n\t// Try to minimize operations if there is only one selector in the list and no seed\n\t// (the latter of which guarantees us context)\n\tif ( match.length === 1 ) {\n\n\t\t// Reduce context if the leading compound selector is an ID\n\t\ttokens = match[0] = match[0].slice( 0 );\n\t\tif ( tokens.length > 2 && (token = tokens[0]).type === \"ID\" &&\n\t\t\t\tsupport.getById && context.nodeType === 9 && documentIsHTML &&\n\t\t\t\tExpr.relative[ tokens[1].type ] ) {\n\n\t\t\tcontext = ( Expr.find[\"ID\"]( token.matches[0].replace(runescape, funescape), context ) || [] )[0];\n\t\t\tif ( !context ) {\n\t\t\t\treturn results;\n\n\t\t\t// Precompiled matchers will still verify ancestry, so step up a level\n\t\t\t} else if ( compiled ) {\n\t\t\t\tcontext = context.parentNode;\n\t\t\t}\n\n\t\t\tselector = selector.slice( tokens.shift().value.length );\n\t\t}\n\n\t\t// Fetch a seed set for right-to-left matching\n\t\ti = matchExpr[\"needsContext\"].test( selector ) ? 0 : tokens.length;\n\t\twhile ( i-- ) {\n\t\t\ttoken = tokens[i];\n\n\t\t\t// Abort if we hit a combinator\n\t\t\tif ( Expr.relative[ (type = token.type) ] ) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif ( (find = Expr.find[ type ]) ) {\n\t\t\t\t// Search, expanding context for leading sibling combinators\n\t\t\t\tif ( (seed = find(\n\t\t\t\t\ttoken.matches[0].replace( runescape, funescape ),\n\t\t\t\t\trsibling.test( tokens[0].type ) && testContext( context.parentNode ) || context\n\t\t\t\t)) ) {\n\n\t\t\t\t\t// If seed is empty or no tokens remain, we can return early\n\t\t\t\t\ttokens.splice( i, 1 );\n\t\t\t\t\tselector = seed.length && toSelector( tokens );\n\t\t\t\t\tif ( !selector ) {\n\t\t\t\t\t\tpush.apply( results, seed );\n\t\t\t\t\t\treturn results;\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Compile and execute a filtering function if one is not provided\n\t// Provide `match` to avoid retokenization if we modified the selector above\n\t( compiled || compile( selector, match ) )(\n\t\tseed,\n\t\tcontext,\n\t\t!documentIsHTML,\n\t\tresults,\n\t\t!context || rsibling.test( selector ) && testContext( context.parentNode ) || context\n\t);\n\treturn results;\n};\n\n// One-time assignments\n\n// Sort stability\nsupport.sortStable = expando.split(\"\").sort( sortOrder ).join(\"\") === expando;\n\n// Support: Chrome 14-35+\n// Always assume duplicates if they aren't passed to the comparison function\nsupport.detectDuplicates = !!hasDuplicate;\n\n// Initialize against the default document\nsetDocument();\n\n// Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27)\n// Detached nodes confoundingly follow *each other*\nsupport.sortDetached = assert(function( div1 ) {\n\t// Should return 1, but returns 4 (following)\n\treturn div1.compareDocumentPosition( document.createElement(\"div\") ) & 1;\n});\n\n// Support: IE<8\n// Prevent attribute/property \"interpolation\"\n// http://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx\nif ( !assert(function( div ) {\n\tdiv.innerHTML = \"<a href='#'></a>\";\n\treturn div.firstChild.getAttribute(\"href\") === \"#\" ;\n}) ) {\n\taddHandle( \"type|href|height|width\", function( elem, name, isXML ) {\n\t\tif ( !isXML ) {\n\t\t\treturn elem.getAttribute( name, name.toLowerCase() === \"type\" ? 1 : 2 );\n\t\t}\n\t});\n}\n\n// Support: IE<9\n// Use defaultValue in place of getAttribute(\"value\")\nif ( !support.attributes || !assert(function( div ) {\n\tdiv.innerHTML = \"<input/>\";\n\tdiv.firstChild.setAttribute( \"value\", \"\" );\n\treturn div.firstChild.getAttribute( \"value\" ) === \"\";\n}) ) {\n\taddHandle( \"value\", function( elem, name, isXML ) {\n\t\tif ( !isXML && elem.nodeName.toLowerCase() === \"input\" ) {\n\t\t\treturn elem.defaultValue;\n\t\t}\n\t});\n}\n\n// Support: IE<9\n// Use getAttributeNode to fetch booleans when getAttribute lies\nif ( !assert(function( div ) {\n\treturn div.getAttribute(\"disabled\") == null;\n}) ) {\n\taddHandle( booleans, function( elem, name, isXML ) {\n\t\tvar val;\n\t\tif ( !isXML ) {\n\t\t\treturn elem[ name ] === true ? name.toLowerCase() :\n\t\t\t\t\t(val = elem.getAttributeNode( name )) && val.specified ?\n\t\t\t\t\tval.value :\n\t\t\t\tnull;\n\t\t}\n\t});\n}\n\nreturn Sizzle;\n\n})( window );\n\n\n\njQuery.find = Sizzle;\njQuery.expr = Sizzle.selectors;\njQuery.expr[ \":\" ] = jQuery.expr.pseudos;\njQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort;\njQuery.text = Sizzle.getText;\njQuery.isXMLDoc = Sizzle.isXML;\njQuery.contains = Sizzle.contains;\n\n\n\nvar dir = function( elem, dir, until ) {\n\tvar matched = [],\n\t\ttruncate = until !== undefined;\n\n\twhile ( ( elem = elem[ dir ] ) && elem.nodeType !== 9 ) {\n\t\tif ( elem.nodeType === 1 ) {\n\t\t\tif ( truncate && jQuery( elem ).is( until ) ) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tmatched.push( elem );\n\t\t}\n\t}\n\treturn matched;\n};\n\n\nvar siblings = function( n, elem ) {\n\tvar matched = [];\n\n\tfor ( ; n; n = n.nextSibling ) {\n\t\tif ( n.nodeType === 1 && n !== elem ) {\n\t\t\tmatched.push( n );\n\t\t}\n\t}\n\n\treturn matched;\n};\n\n\nvar rneedsContext = jQuery.expr.match.needsContext;\n\nvar rsingleTag = ( /^<([\\w-]+)\\s*\\/?>(?:<\\/\\1>|)$/ );\n\n\n\nvar risSimple = /^.[^:#\\[\\.,]*$/;\n\n// Implement the identical functionality for filter and not\nfunction winnow( elements, qualifier, not ) {\n\tif ( jQuery.isFunction( qualifier ) ) {\n\t\treturn jQuery.grep( elements, function( elem, i ) {\n\t\t\t/* jshint -W018 */\n\t\t\treturn !!qualifier.call( elem, i, elem ) !== not;\n\t\t} );\n\n\t}\n\n\tif ( qualifier.nodeType ) {\n\t\treturn jQuery.grep( elements, function( elem ) {\n\t\t\treturn ( elem === qualifier ) !== not;\n\t\t} );\n\n\t}\n\n\tif ( typeof qualifier === \"string\" ) {\n\t\tif ( risSimple.test( qualifier ) ) {\n\t\t\treturn jQuery.filter( qualifier, elements, not );\n\t\t}\n\n\t\tqualifier = jQuery.filter( qualifier, elements );\n\t}\n\n\treturn jQuery.grep( elements, function( elem ) {\n\t\treturn ( indexOf.call( qualifier, elem ) > -1 ) !== not;\n\t} );\n}\n\njQuery.filter = function( expr, elems, not ) {\n\tvar elem = elems[ 0 ];\n\n\tif ( not ) {\n\t\texpr = \":not(\" + expr + \")\";\n\t}\n\n\treturn elems.length === 1 && elem.nodeType === 1 ?\n\t\tjQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [] :\n\t\tjQuery.find.matches( expr, jQuery.grep( elems, function( elem ) {\n\t\t\treturn elem.nodeType === 1;\n\t\t} ) );\n};\n\njQuery.fn.extend( {\n\tfind: function( selector ) {\n\t\tvar i,\n\t\t\tlen = this.length,\n\t\t\tret = [],\n\t\t\tself = this;\n\n\t\tif ( typeof selector !== \"string\" ) {\n\t\t\treturn this.pushStack( jQuery( selector ).filter( function() {\n\t\t\t\tfor ( i = 0; i < len; i++ ) {\n\t\t\t\t\tif ( jQuery.contains( self[ i ], this ) ) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} ) );\n\t\t}\n\n\t\tfor ( i = 0; i < len; i++ ) {\n\t\t\tjQuery.find( selector, self[ i ], ret );\n\t\t}\n\n\t\t// Needed because $( selector, context ) becomes $( context ).find( selector )\n\t\tret = this.pushStack( len > 1 ? jQuery.unique( ret ) : ret );\n\t\tret.selector = this.selector ? this.selector + \" \" + selector : selector;\n\t\treturn ret;\n\t},\n\tfilter: function( selector ) {\n\t\treturn this.pushStack( winnow( this, selector || [], false ) );\n\t},\n\tnot: function( selector ) {\n\t\treturn this.pushStack( winnow( this, selector || [], true ) );\n\t},\n\tis: function( selector ) {\n\t\treturn !!winnow(\n\t\t\tthis,\n\n\t\t\t// If this is a positional/relative selector, check membership in the returned set\n\t\t\t// so $(\"p:first\").is(\"p:last\") won't return true for a doc with two \"p\".\n\t\t\ttypeof selector === \"string\" && rneedsContext.test( selector ) ?\n\t\t\t\tjQuery( selector ) :\n\t\t\t\tselector || [],\n\t\t\tfalse\n\t\t).length;\n\t}\n} );\n\n\n// Initialize a jQuery object\n\n\n// A central reference to the root jQuery(document)\nvar rootjQuery,\n\n\t// A simple way to check for HTML strings\n\t// Prioritize #id over <tag> to avoid XSS via location.hash (#9521)\n\t// Strict HTML recognition (#11290: must start with <)\n\trquickExpr = /^(?:\\s*(<[\\w\\W]+>)[^>]*|#([\\w-]*))$/,\n\n\tinit = jQuery.fn.init = function( selector, context, root ) {\n\t\tvar match, elem;\n\n\t\t// HANDLE: $(\"\"), $(null), $(undefined), $(false)\n\t\tif ( !selector ) {\n\t\t\treturn this;\n\t\t}\n\n\t\t// Method init() accepts an alternate rootjQuery\n\t\t// so migrate can support jQuery.sub (gh-2101)\n\t\troot = root || rootjQuery;\n\n\t\t// Handle HTML strings\n\t\tif ( typeof selector === \"string\" ) {\n\t\t\tif ( selector[ 0 ] === \"<\" &&\n\t\t\t\tselector[ selector.length - 1 ] === \">\" &&\n\t\t\t\tselector.length >= 3 ) {\n\n\t\t\t\t// Assume that strings that start and end with <> are HTML and skip the regex check\n\t\t\t\tmatch = [ null, selector, null ];\n\n\t\t\t} else {\n\t\t\t\tmatch = rquickExpr.exec( selector );\n\t\t\t}\n\n\t\t\t// Match html or make sure no context is specified for #id\n\t\t\tif ( match && ( match[ 1 ] || !context ) ) {\n\n\t\t\t\t// HANDLE: $(html) -> $(array)\n\t\t\t\tif ( match[ 1 ] ) {\n\t\t\t\t\tcontext = context instanceof jQuery ? context[ 0 ] : context;\n\n\t\t\t\t\t// Option to run scripts is true for back-compat\n\t\t\t\t\t// Intentionally let the error be thrown if parseHTML is not present\n\t\t\t\t\tjQuery.merge( this, jQuery.parseHTML(\n\t\t\t\t\t\tmatch[ 1 ],\n\t\t\t\t\t\tcontext && context.nodeType ? context.ownerDocument || context : document,\n\t\t\t\t\t\ttrue\n\t\t\t\t\t) );\n\n\t\t\t\t\t// HANDLE: $(html, props)\n\t\t\t\t\tif ( rsingleTag.test( match[ 1 ] ) && jQuery.isPlainObject( context ) ) {\n\t\t\t\t\t\tfor ( match in context ) {\n\n\t\t\t\t\t\t\t// Properties of context are called as methods if possible\n\t\t\t\t\t\t\tif ( jQuery.isFunction( this[ match ] ) ) {\n\t\t\t\t\t\t\t\tthis[ match ]( context[ match ] );\n\n\t\t\t\t\t\t\t// ...and otherwise set as attributes\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tthis.attr( match, context[ match ] );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\treturn this;\n\n\t\t\t\t// HANDLE: $(#id)\n\t\t\t\t} else {\n\t\t\t\t\telem = document.getElementById( match[ 2 ] );\n\n\t\t\t\t\t// Support: Blackberry 4.6\n\t\t\t\t\t// gEBID returns nodes no longer in the document (#6963)\n\t\t\t\t\tif ( elem && elem.parentNode ) {\n\n\t\t\t\t\t\t// Inject the element directly into the jQuery object\n\t\t\t\t\t\tthis.length = 1;\n\t\t\t\t\t\tthis[ 0 ] = elem;\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.context = document;\n\t\t\t\t\tthis.selector = selector;\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\n\t\t\t// HANDLE: $(expr, $(...))\n\t\t\t} else if ( !context || context.jquery ) {\n\t\t\t\treturn ( context || root ).find( selector );\n\n\t\t\t// HANDLE: $(expr, context)\n\t\t\t// (which is just equivalent to: $(context).find(expr)\n\t\t\t} else {\n\t\t\t\treturn this.constructor( context ).find( selector );\n\t\t\t}\n\n\t\t// HANDLE: $(DOMElement)\n\t\t} else if ( selector.nodeType ) {\n\t\t\tthis.context = this[ 0 ] = selector;\n\t\t\tthis.length = 1;\n\t\t\treturn this;\n\n\t\t// HANDLE: $(function)\n\t\t// Shortcut for document ready\n\t\t} else if ( jQuery.isFunction( selector ) ) {\n\t\t\treturn root.ready !== undefined ?\n\t\t\t\troot.ready( selector ) :\n\n\t\t\t\t// Execute immediately if ready is not present\n\t\t\t\tselector( jQuery );\n\t\t}\n\n\t\tif ( selector.selector !== undefined ) {\n\t\t\tthis.selector = selector.selector;\n\t\t\tthis.context = selector.context;\n\t\t}\n\n\t\treturn jQuery.makeArray( selector, this );\n\t};\n\n// Give the init function the jQuery prototype for later instantiation\ninit.prototype = jQuery.fn;\n\n// Initialize central reference\nrootjQuery = jQuery( document );\n\n\nvar rparentsprev = /^(?:parents|prev(?:Until|All))/,\n\n\t// Methods guaranteed to produce a unique set when starting from a unique set\n\tguaranteedUnique = {\n\t\tchildren: true,\n\t\tcontents: true,\n\t\tnext: true,\n\t\tprev: true\n\t};\n\njQuery.fn.extend( {\n\thas: function( target ) {\n\t\tvar targets = jQuery( target, this ),\n\t\t\tl = targets.length;\n\n\t\treturn this.filter( function() {\n\t\t\tvar i = 0;\n\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\tif ( jQuery.contains( this, targets[ i ] ) ) {\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t},\n\n\tclosest: function( selectors, context ) {\n\t\tvar cur,\n\t\t\ti = 0,\n\t\t\tl = this.length,\n\t\t\tmatched = [],\n\t\t\tpos = rneedsContext.test( selectors ) || typeof selectors !== \"string\" ?\n\t\t\t\tjQuery( selectors, context || this.context ) :\n\t\t\t\t0;\n\n\t\tfor ( ; i < l; i++ ) {\n\t\t\tfor ( cur = this[ i ]; cur && cur !== context; cur = cur.parentNode ) {\n\n\t\t\t\t// Always skip document fragments\n\t\t\t\tif ( cur.nodeType < 11 && ( pos ?\n\t\t\t\t\tpos.index( cur ) > -1 :\n\n\t\t\t\t\t// Don't pass non-elements to Sizzle\n\t\t\t\t\tcur.nodeType === 1 &&\n\t\t\t\t\t\tjQuery.find.matchesSelector( cur, selectors ) ) ) {\n\n\t\t\t\t\tmatched.push( cur );\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this.pushStack( matched.length > 1 ? jQuery.uniqueSort( matched ) : matched );\n\t},\n\n\t// Determine the position of an element within the set\n\tindex: function( elem ) {\n\n\t\t// No argument, return index in parent\n\t\tif ( !elem ) {\n\t\t\treturn ( this[ 0 ] && this[ 0 ].parentNode ) ? this.first().prevAll().length : -1;\n\t\t}\n\n\t\t// Index in selector\n\t\tif ( typeof elem === \"string\" ) {\n\t\t\treturn indexOf.call( jQuery( elem ), this[ 0 ] );\n\t\t}\n\n\t\t// Locate the position of the desired element\n\t\treturn indexOf.call( this,\n\n\t\t\t// If it receives a jQuery object, the first element is used\n\t\t\telem.jquery ? elem[ 0 ] : elem\n\t\t);\n\t},\n\n\tadd: function( selector, context ) {\n\t\treturn this.pushStack(\n\t\t\tjQuery.uniqueSort(\n\t\t\t\tjQuery.merge( this.get(), jQuery( selector, context ) )\n\t\t\t)\n\t\t);\n\t},\n\n\taddBack: function( selector ) {\n\t\treturn this.add( selector == null ?\n\t\t\tthis.prevObject : this.prevObject.filter( selector )\n\t\t);\n\t}\n} );\n\nfunction sibling( cur, dir ) {\n\twhile ( ( cur = cur[ dir ] ) && cur.nodeType !== 1 ) {}\n\treturn cur;\n}\n\njQuery.each( {\n\tparent: function( elem ) {\n\t\tvar parent = elem.parentNode;\n\t\treturn parent && parent.nodeType !== 11 ? parent : null;\n\t},\n\tparents: function( elem ) {\n\t\treturn dir( elem, \"parentNode\" );\n\t},\n\tparentsUntil: function( elem, i, until ) {\n\t\treturn dir( elem, \"parentNode\", until );\n\t},\n\tnext: function( elem ) {\n\t\treturn sibling( elem, \"nextSibling\" );\n\t},\n\tprev: function( elem ) {\n\t\treturn sibling( elem, \"previousSibling\" );\n\t},\n\tnextAll: function( elem ) {\n\t\treturn dir( elem, \"nextSibling\" );\n\t},\n\tprevAll: function( elem ) {\n\t\treturn dir( elem, \"previousSibling\" );\n\t},\n\tnextUntil: function( elem, i, until ) {\n\t\treturn dir( elem, \"nextSibling\", until );\n\t},\n\tprevUntil: function( elem, i, until ) {\n\t\treturn dir( elem, \"previousSibling\", until );\n\t},\n\tsiblings: function( elem ) {\n\t\treturn siblings( ( elem.parentNode || {} ).firstChild, elem );\n\t},\n\tchildren: function( elem ) {\n\t\treturn siblings( elem.firstChild );\n\t},\n\tcontents: function( elem ) {\n\t\treturn elem.contentDocument || jQuery.merge( [], elem.childNodes );\n\t}\n}, function( name, fn ) {\n\tjQuery.fn[ name ] = function( until, selector ) {\n\t\tvar matched = jQuery.map( this, fn, until );\n\n\t\tif ( name.slice( -5 ) !== \"Until\" ) {\n\t\t\tselector = until;\n\t\t}\n\n\t\tif ( selector && typeof selector === \"string\" ) {\n\t\t\tmatched = jQuery.filter( selector, matched );\n\t\t}\n\n\t\tif ( this.length > 1 ) {\n\n\t\t\t// Remove duplicates\n\t\t\tif ( !guaranteedUnique[ name ] ) {\n\t\t\t\tjQuery.uniqueSort( matched );\n\t\t\t}\n\n\t\t\t// Reverse order for parents* and prev-derivatives\n\t\t\tif ( rparentsprev.test( name ) ) {\n\t\t\t\tmatched.reverse();\n\t\t\t}\n\t\t}\n\n\t\treturn this.pushStack( matched );\n\t};\n} );\nvar rnotwhite = ( /\\S+/g );\n\n\n\n// Convert String-formatted options into Object-formatted ones\nfunction createOptions( options ) {\n\tvar object = {};\n\tjQuery.each( options.match( rnotwhite ) || [], function( _, flag ) {\n\t\tobject[ flag ] = true;\n\t} );\n\treturn object;\n}\n\n/*\n * Create a callback list using the following parameters:\n *\n *\toptions: an optional list of space-separated options that will change how\n *\t\t\tthe callback list behaves or a more traditional option object\n *\n * By default a callback list will act like an event callback list and can be\n * \"fired\" multiple times.\n *\n * Possible options:\n *\n *\tonce:\t\t\twill ensure the callback list can only be fired once (like a Deferred)\n *\n *\tmemory:\t\t\twill keep track of previous values and will call any callback added\n *\t\t\t\t\tafter the list has been fired right away with the latest \"memorized\"\n *\t\t\t\t\tvalues (like a Deferred)\n *\n *\tunique:\t\t\twill ensure a callback can only be added once (no duplicate in the list)\n *\n *\tstopOnFalse:\tinterrupt callings when a callback returns false\n *\n */\njQuery.Callbacks = function( options ) {\n\n\t// Convert options from String-formatted to Object-formatted if needed\n\t// (we check in cache first)\n\toptions = typeof options === \"string\" ?\n\t\tcreateOptions( options ) :\n\t\tjQuery.extend( {}, options );\n\n\tvar // Flag to know if list is currently firing\n\t\tfiring,\n\n\t\t// Last fire value for non-forgettable lists\n\t\tmemory,\n\n\t\t// Flag to know if list was already fired\n\t\tfired,\n\n\t\t// Flag to prevent firing\n\t\tlocked,\n\n\t\t// Actual callback list\n\t\tlist = [],\n\n\t\t// Queue of execution data for repeatable lists\n\t\tqueue = [],\n\n\t\t// Index of currently firing callback (modified by add/remove as needed)\n\t\tfiringIndex = -1,\n\n\t\t// Fire callbacks\n\t\tfire = function() {\n\n\t\t\t// Enforce single-firing\n\t\t\tlocked = options.once;\n\n\t\t\t// Execute callbacks for all pending executions,\n\t\t\t// respecting firingIndex overrides and runtime changes\n\t\t\tfired = firing = true;\n\t\t\tfor ( ; queue.length; firingIndex = -1 ) {\n\t\t\t\tmemory = queue.shift();\n\t\t\t\twhile ( ++firingIndex < list.length ) {\n\n\t\t\t\t\t// Run callback and check for early termination\n\t\t\t\t\tif ( list[ firingIndex ].apply( memory[ 0 ], memory[ 1 ] ) === false &&\n\t\t\t\t\t\toptions.stopOnFalse ) {\n\n\t\t\t\t\t\t// Jump to end and forget the data so .add doesn't re-fire\n\t\t\t\t\t\tfiringIndex = list.length;\n\t\t\t\t\t\tmemory = false;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Forget the data if we're done with it\n\t\t\tif ( !options.memory ) {\n\t\t\t\tmemory = false;\n\t\t\t}\n\n\t\t\tfiring = false;\n\n\t\t\t// Clean up if we're done firing for good\n\t\t\tif ( locked ) {\n\n\t\t\t\t// Keep an empty list if we have data for future add calls\n\t\t\t\tif ( memory ) {\n\t\t\t\t\tlist = [];\n\n\t\t\t\t// Otherwise, this object is spent\n\t\t\t\t} else {\n\t\t\t\t\tlist = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\t// Actual Callbacks object\n\t\tself = {\n\n\t\t\t// Add a callback or a collection of callbacks to the list\n\t\t\tadd: function() {\n\t\t\t\tif ( list ) {\n\n\t\t\t\t\t// If we have memory from a past run, we should fire after adding\n\t\t\t\t\tif ( memory && !firing ) {\n\t\t\t\t\t\tfiringIndex = list.length - 1;\n\t\t\t\t\t\tqueue.push( memory );\n\t\t\t\t\t}\n\n\t\t\t\t\t( function add( args ) {\n\t\t\t\t\t\tjQuery.each( args, function( _, arg ) {\n\t\t\t\t\t\t\tif ( jQuery.isFunction( arg ) ) {\n\t\t\t\t\t\t\t\tif ( !options.unique || !self.has( arg ) ) {\n\t\t\t\t\t\t\t\t\tlist.push( arg );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if ( arg && arg.length && jQuery.type( arg ) !== \"string\" ) {\n\n\t\t\t\t\t\t\t\t// Inspect recursively\n\t\t\t\t\t\t\t\tadd( arg );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} );\n\t\t\t\t\t} )( arguments );\n\n\t\t\t\t\tif ( memory && !firing ) {\n\t\t\t\t\t\tfire();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Remove a callback from the list\n\t\t\tremove: function() {\n\t\t\t\tjQuery.each( arguments, function( _, arg ) {\n\t\t\t\t\tvar index;\n\t\t\t\t\twhile ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) {\n\t\t\t\t\t\tlist.splice( index, 1 );\n\n\t\t\t\t\t\t// Handle firing indexes\n\t\t\t\t\t\tif ( index <= firingIndex ) {\n\t\t\t\t\t\t\tfiringIndex--;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Check if a given callback is in the list.\n\t\t\t// If no argument is given, return whether or not list has callbacks attached.\n\t\t\thas: function( fn ) {\n\t\t\t\treturn fn ?\n\t\t\t\t\tjQuery.inArray( fn, list ) > -1 :\n\t\t\t\t\tlist.length > 0;\n\t\t\t},\n\n\t\t\t// Remove all callbacks from the list\n\t\t\tempty: function() {\n\t\t\t\tif ( list ) {\n\t\t\t\t\tlist = [];\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Disable .fire and .add\n\t\t\t// Abort any current/pending executions\n\t\t\t// Clear all callbacks and values\n\t\t\tdisable: function() {\n\t\t\t\tlocked = queue = [];\n\t\t\t\tlist = memory = \"\";\n\t\t\t\treturn this;\n\t\t\t},\n\t\t\tdisabled: function() {\n\t\t\t\treturn !list;\n\t\t\t},\n\n\t\t\t// Disable .fire\n\t\t\t// Also disable .add unless we have memory (since it would have no effect)\n\t\t\t// Abort any pending executions\n\t\t\tlock: function() {\n\t\t\t\tlocked = queue = [];\n\t\t\t\tif ( !memory ) {\n\t\t\t\t\tlist = memory = \"\";\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\t\t\tlocked: function() {\n\t\t\t\treturn !!locked;\n\t\t\t},\n\n\t\t\t// Call all callbacks with the given context and arguments\n\t\t\tfireWith: function( context, args ) {\n\t\t\t\tif ( !locked ) {\n\t\t\t\t\targs = args || [];\n\t\t\t\t\targs = [ context, args.slice ? args.slice() : args ];\n\t\t\t\t\tqueue.push( args );\n\t\t\t\t\tif ( !firing ) {\n\t\t\t\t\t\tfire();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Call all the callbacks with the given arguments\n\t\t\tfire: function() {\n\t\t\t\tself.fireWith( this, arguments );\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// To know if the callbacks have already been called at least once\n\t\t\tfired: function() {\n\t\t\t\treturn !!fired;\n\t\t\t}\n\t\t};\n\n\treturn self;\n};\n\n\njQuery.extend( {\n\n\tDeferred: function( func ) {\n\t\tvar tuples = [\n\n\t\t\t\t// action, add listener, listener list, final state\n\t\t\t\t[ \"resolve\", \"done\", jQuery.Callbacks( \"once memory\" ), \"resolved\" ],\n\t\t\t\t[ \"reject\", \"fail\", jQuery.Callbacks( \"once memory\" ), \"rejected\" ],\n\t\t\t\t[ \"notify\", \"progress\", jQuery.Callbacks( \"memory\" ) ]\n\t\t\t],\n\t\t\tstate = \"pending\",\n\t\t\tpromise = {\n\t\t\t\tstate: function() {\n\t\t\t\t\treturn state;\n\t\t\t\t},\n\t\t\t\talways: function() {\n\t\t\t\t\tdeferred.done( arguments ).fail( arguments );\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\t\t\t\tthen: function( /* fnDone, fnFail, fnProgress */ ) {\n\t\t\t\t\tvar fns = arguments;\n\t\t\t\t\treturn jQuery.Deferred( function( newDefer ) {\n\t\t\t\t\t\tjQuery.each( tuples, function( i, tuple ) {\n\t\t\t\t\t\t\tvar fn = jQuery.isFunction( fns[ i ] ) && fns[ i ];\n\n\t\t\t\t\t\t\t// deferred[ done | fail | progress ] for forwarding actions to newDefer\n\t\t\t\t\t\t\tdeferred[ tuple[ 1 ] ]( function() {\n\t\t\t\t\t\t\t\tvar returned = fn && fn.apply( this, arguments );\n\t\t\t\t\t\t\t\tif ( returned && jQuery.isFunction( returned.promise ) ) {\n\t\t\t\t\t\t\t\t\treturned.promise()\n\t\t\t\t\t\t\t\t\t\t.progress( newDefer.notify )\n\t\t\t\t\t\t\t\t\t\t.done( newDefer.resolve )\n\t\t\t\t\t\t\t\t\t\t.fail( newDefer.reject );\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tnewDefer[ tuple[ 0 ] + \"With\" ](\n\t\t\t\t\t\t\t\t\t\tthis === promise ? newDefer.promise() : this,\n\t\t\t\t\t\t\t\t\t\tfn ? [ returned ] : arguments\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t} );\n\t\t\t\t\t\tfns = null;\n\t\t\t\t\t} ).promise();\n\t\t\t\t},\n\n\t\t\t\t// Get a promise for this deferred\n\t\t\t\t// If obj is provided, the promise aspect is added to the object\n\t\t\t\tpromise: function( obj ) {\n\t\t\t\t\treturn obj != null ? jQuery.extend( obj, promise ) : promise;\n\t\t\t\t}\n\t\t\t},\n\t\t\tdeferred = {};\n\n\t\t// Keep pipe for back-compat\n\t\tpromise.pipe = promise.then;\n\n\t\t// Add list-specific methods\n\t\tjQuery.each( tuples, function( i, tuple ) {\n\t\t\tvar list = tuple[ 2 ],\n\t\t\t\tstateString = tuple[ 3 ];\n\n\t\t\t// promise[ done | fail | progress ] = list.add\n\t\t\tpromise[ tuple[ 1 ] ] = list.add;\n\n\t\t\t// Handle state\n\t\t\tif ( stateString ) {\n\t\t\t\tlist.add( function() {\n\n\t\t\t\t\t// state = [ resolved | rejected ]\n\t\t\t\t\tstate = stateString;\n\n\t\t\t\t// [ reject_list | resolve_list ].disable; progress_list.lock\n\t\t\t\t}, tuples[ i ^ 1 ][ 2 ].disable, tuples[ 2 ][ 2 ].lock );\n\t\t\t}\n\n\t\t\t// deferred[ resolve | reject | notify ]\n\t\t\tdeferred[ tuple[ 0 ] ] = function() {\n\t\t\t\tdeferred[ tuple[ 0 ] + \"With\" ]( this === deferred ? promise : this, arguments );\n\t\t\t\treturn this;\n\t\t\t};\n\t\t\tdeferred[ tuple[ 0 ] + \"With\" ] = list.fireWith;\n\t\t} );\n\n\t\t// Make the deferred a promise\n\t\tpromise.promise( deferred );\n\n\t\t// Call given func if any\n\t\tif ( func ) {\n\t\t\tfunc.call( deferred, deferred );\n\t\t}\n\n\t\t// All done!\n\t\treturn deferred;\n\t},\n\n\t// Deferred helper\n\twhen: function( subordinate /* , ..., subordinateN */ ) {\n\t\tvar i = 0,\n\t\t\tresolveValues = slice.call( arguments ),\n\t\t\tlength = resolveValues.length,\n\n\t\t\t// the count of uncompleted subordinates\n\t\t\tremaining = length !== 1 ||\n\t\t\t\t( subordinate && jQuery.isFunction( subordinate.promise ) ) ? length : 0,\n\n\t\t\t// the master Deferred.\n\t\t\t// If resolveValues consist of only a single Deferred, just use that.\n\t\t\tdeferred = remaining === 1 ? subordinate : jQuery.Deferred(),\n\n\t\t\t// Update function for both resolve and progress values\n\t\t\tupdateFunc = function( i, contexts, values ) {\n\t\t\t\treturn function( value ) {\n\t\t\t\t\tcontexts[ i ] = this;\n\t\t\t\t\tvalues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value;\n\t\t\t\t\tif ( values === progressValues ) {\n\t\t\t\t\t\tdeferred.notifyWith( contexts, values );\n\t\t\t\t\t} else if ( !( --remaining ) ) {\n\t\t\t\t\t\tdeferred.resolveWith( contexts, values );\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t},\n\n\t\t\tprogressValues, progressContexts, resolveContexts;\n\n\t\t// Add listeners to Deferred subordinates; treat others as resolved\n\t\tif ( length > 1 ) {\n\t\t\tprogressValues = new Array( length );\n\t\t\tprogressContexts = new Array( length );\n\t\t\tresolveContexts = new Array( length );\n\t\t\tfor ( ; i < length; i++ ) {\n\t\t\t\tif ( resolveValues[ i ] && jQuery.isFunction( resolveValues[ i ].promise ) ) {\n\t\t\t\t\tresolveValues[ i ].promise()\n\t\t\t\t\t\t.progress( updateFunc( i, progressContexts, progressValues ) )\n\t\t\t\t\t\t.done( updateFunc( i, resolveContexts, resolveValues ) )\n\t\t\t\t\t\t.fail( deferred.reject );\n\t\t\t\t} else {\n\t\t\t\t\t--remaining;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// If we're not waiting on anything, resolve the master\n\t\tif ( !remaining ) {\n\t\t\tdeferred.resolveWith( resolveContexts, resolveValues );\n\t\t}\n\n\t\treturn deferred.promise();\n\t}\n} );\n\n\n// The deferred used on DOM ready\nvar readyList;\n\njQuery.fn.ready = function( fn ) {\n\n\t// Add the callback\n\tjQuery.ready.promise().done( fn );\n\n\treturn this;\n};\n\njQuery.extend( {\n\n\t// Is the DOM ready to be used? Set to true once it occurs.\n\tisReady: false,\n\n\t// A counter to track how many items to wait for before\n\t// the ready event fires. See #6781\n\treadyWait: 1,\n\n\t// Hold (or release) the ready event\n\tholdReady: function( hold ) {\n\t\tif ( hold ) {\n\t\t\tjQuery.readyWait++;\n\t\t} else {\n\t\t\tjQuery.ready( true );\n\t\t}\n\t},\n\n\t// Handle when the DOM is ready\n\tready: function( wait ) {\n\n\t\t// Abort if there are pending holds or we're already ready\n\t\tif ( wait === true ? --jQuery.readyWait : jQuery.isReady ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Remember that the DOM is ready\n\t\tjQuery.isReady = true;\n\n\t\t// If a normal DOM Ready event fired, decrement, and wait if need be\n\t\tif ( wait !== true && --jQuery.readyWait > 0 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// If there are functions bound, to execute\n\t\treadyList.resolveWith( document, [ jQuery ] );\n\n\t\t// Trigger any bound ready events\n\t\tif ( jQuery.fn.triggerHandler ) {\n\t\t\tjQuery( document ).triggerHandler( \"ready\" );\n\t\t\tjQuery( document ).off( \"ready\" );\n\t\t}\n\t}\n} );\n\n/**\n * The ready event handler and self cleanup method\n */\nfunction completed() {\n\tdocument.removeEventListener( \"DOMContentLoaded\", completed );\n\twindow.removeEventListener( \"load\", completed );\n\tjQuery.ready();\n}\n\njQuery.ready.promise = function( obj ) {\n\tif ( !readyList ) {\n\n\t\treadyList = jQuery.Deferred();\n\n\t\t// Catch cases where $(document).ready() is called\n\t\t// after the browser event has already occurred.\n\t\t// Support: IE9-10 only\n\t\t// Older IE sometimes signals \"interactive\" too soon\n\t\tif ( document.readyState === \"complete\" ||\n\t\t\t( document.readyState !== \"loading\" && !document.documentElement.doScroll ) ) {\n\n\t\t\t// Handle it asynchronously to allow scripts the opportunity to delay ready\n\t\t\twindow.setTimeout( jQuery.ready );\n\n\t\t} else {\n\n\t\t\t// Use the handy event callback\n\t\t\tdocument.addEventListener( \"DOMContentLoaded\", completed );\n\n\t\t\t// A fallback to window.onload, that will always work\n\t\t\twindow.addEventListener( \"load\", completed );\n\t\t}\n\t}\n\treturn readyList.promise( obj );\n};\n\n// Kick off the DOM ready check even if the user does not\njQuery.ready.promise();\n\n\n\n\n// Multifunctional method to get and set values of a collection\n// The value/s can optionally be executed if it's a function\nvar access = function( elems, fn, key, value, chainable, emptyGet, raw ) {\n\tvar i = 0,\n\t\tlen = elems.length,\n\t\tbulk = key == null;\n\n\t// Sets many values\n\tif ( jQuery.type( key ) === \"object\" ) {\n\t\tchainable = true;\n\t\tfor ( i in key ) {\n\t\t\taccess( elems, fn, i, key[ i ], true, emptyGet, raw );\n\t\t}\n\n\t// Sets one value\n\t} else if ( value !== undefined ) {\n\t\tchainable = true;\n\n\t\tif ( !jQuery.isFunction( value ) ) {\n\t\t\traw = true;\n\t\t}\n\n\t\tif ( bulk ) {\n\n\t\t\t// Bulk operations run against the entire set\n\t\t\tif ( raw ) {\n\t\t\t\tfn.call( elems, value );\n\t\t\t\tfn = null;\n\n\t\t\t// ...except when executing function values\n\t\t\t} else {\n\t\t\t\tbulk = fn;\n\t\t\t\tfn = function( elem, key, value ) {\n\t\t\t\t\treturn bulk.call( jQuery( elem ), value );\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\n\t\tif ( fn ) {\n\t\t\tfor ( ; i < len; i++ ) {\n\t\t\t\tfn(\n\t\t\t\t\telems[ i ], key, raw ?\n\t\t\t\t\tvalue :\n\t\t\t\t\tvalue.call( elems[ i ], i, fn( elems[ i ], key ) )\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn chainable ?\n\t\telems :\n\n\t\t// Gets\n\t\tbulk ?\n\t\t\tfn.call( elems ) :\n\t\t\tlen ? fn( elems[ 0 ], key ) : emptyGet;\n};\nvar acceptData = function( owner ) {\n\n\t// Accepts only:\n\t// - Node\n\t// - Node.ELEMENT_NODE\n\t// - Node.DOCUMENT_NODE\n\t// - Object\n\t// - Any\n\t/* jshint -W018 */\n\treturn owner.nodeType === 1 || owner.nodeType === 9 || !( +owner.nodeType );\n};\n\n\n\n\nfunction Data() {\n\tthis.expando = jQuery.expando + Data.uid++;\n}\n\nData.uid = 1;\n\nData.prototype = {\n\n\tregister: function( owner, initial ) {\n\t\tvar value = initial || {};\n\n\t\t// If it is a node unlikely to be stringify-ed or looped over\n\t\t// use plain assignment\n\t\tif ( owner.nodeType ) {\n\t\t\towner[ this.expando ] = value;\n\n\t\t// Otherwise secure it in a non-enumerable, non-writable property\n\t\t// configurability must be true to allow the property to be\n\t\t// deleted with the delete operator\n\t\t} else {\n\t\t\tObject.defineProperty( owner, this.expando, {\n\t\t\t\tvalue: value,\n\t\t\t\twritable: true,\n\t\t\t\tconfigurable: true\n\t\t\t} );\n\t\t}\n\t\treturn owner[ this.expando ];\n\t},\n\tcache: function( owner ) {\n\n\t\t// We can accept data for non-element nodes in modern browsers,\n\t\t// but we should not, see #8335.\n\t\t// Always return an empty object.\n\t\tif ( !acceptData( owner ) ) {\n\t\t\treturn {};\n\t\t}\n\n\t\t// Check if the owner object already has a cache\n\t\tvar value = owner[ this.expando ];\n\n\t\t// If not, create one\n\t\tif ( !value ) {\n\t\t\tvalue = {};\n\n\t\t\t// We can accept data for non-element nodes in modern browsers,\n\t\t\t// but we should not, see #8335.\n\t\t\t// Always return an empty object.\n\t\t\tif ( acceptData( owner ) ) {\n\n\t\t\t\t// If it is a node unlikely to be stringify-ed or looped over\n\t\t\t\t// use plain assignment\n\t\t\t\tif ( owner.nodeType ) {\n\t\t\t\t\towner[ this.expando ] = value;\n\n\t\t\t\t// Otherwise secure it in a non-enumerable property\n\t\t\t\t// configurable must be true to allow the property to be\n\t\t\t\t// deleted when data is removed\n\t\t\t\t} else {\n\t\t\t\t\tObject.defineProperty( owner, this.expando, {\n\t\t\t\t\t\tvalue: value,\n\t\t\t\t\t\tconfigurable: true\n\t\t\t\t\t} );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn value;\n\t},\n\tset: function( owner, data, value ) {\n\t\tvar prop,\n\t\t\tcache = this.cache( owner );\n\n\t\t// Handle: [ owner, key, value ] args\n\t\tif ( typeof data === \"string\" ) {\n\t\t\tcache[ data ] = value;\n\n\t\t// Handle: [ owner, { properties } ] args\n\t\t} else {\n\n\t\t\t// Copy the properties one-by-one to the cache object\n\t\t\tfor ( prop in data ) {\n\t\t\t\tcache[ prop ] = data[ prop ];\n\t\t\t}\n\t\t}\n\t\treturn cache;\n\t},\n\tget: function( owner, key ) {\n\t\treturn key === undefined ?\n\t\t\tthis.cache( owner ) :\n\t\t\towner[ this.expando ] && owner[ this.expando ][ key ];\n\t},\n\taccess: function( owner, key, value ) {\n\t\tvar stored;\n\n\t\t// In cases where either:\n\t\t//\n\t\t// 1. No key was specified\n\t\t// 2. A string key was specified, but no value provided\n\t\t//\n\t\t// Take the \"read\" path and allow the get method to determine\n\t\t// which value to return, respectively either:\n\t\t//\n\t\t// 1. The entire cache object\n\t\t// 2. The data stored at the key\n\t\t//\n\t\tif ( key === undefined ||\n\t\t\t\t( ( key && typeof key === \"string\" ) && value === undefined ) ) {\n\n\t\t\tstored = this.get( owner, key );\n\n\t\t\treturn stored !== undefined ?\n\t\t\t\tstored : this.get( owner, jQuery.camelCase( key ) );\n\t\t}\n\n\t\t// When the key is not a string, or both a key and value\n\t\t// are specified, set or extend (existing objects) with either:\n\t\t//\n\t\t// 1. An object of properties\n\t\t// 2. A key and value\n\t\t//\n\t\tthis.set( owner, key, value );\n\n\t\t// Since the \"set\" path can have two possible entry points\n\t\t// return the expected data based on which path was taken[*]\n\t\treturn value !== undefined ? value : key;\n\t},\n\tremove: function( owner, key ) {\n\t\tvar i, name, camel,\n\t\t\tcache = owner[ this.expando ];\n\n\t\tif ( cache === undefined ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( key === undefined ) {\n\t\t\tthis.register( owner );\n\n\t\t} else {\n\n\t\t\t// Support array or space separated string of keys\n\t\t\tif ( jQuery.isArray( key ) ) {\n\n\t\t\t\t// If \"name\" is an array of keys...\n\t\t\t\t// When data is initially created, via (\"key\", \"val\") signature,\n\t\t\t\t// keys will be converted to camelCase.\n\t\t\t\t// Since there is no way to tell _how_ a key was added, remove\n\t\t\t\t// both plain key and camelCase key. #12786\n\t\t\t\t// This will only penalize the array argument path.\n\t\t\t\tname = key.concat( key.map( jQuery.camelCase ) );\n\t\t\t} else {\n\t\t\t\tcamel = jQuery.camelCase( key );\n\n\t\t\t\t// Try the string as a key before any manipulation\n\t\t\t\tif ( key in cache ) {\n\t\t\t\t\tname = [ key, camel ];\n\t\t\t\t} else {\n\n\t\t\t\t\t// If a key with the spaces exists, use it.\n\t\t\t\t\t// Otherwise, create an array by matching non-whitespace\n\t\t\t\t\tname = camel;\n\t\t\t\t\tname = name in cache ?\n\t\t\t\t\t\t[ name ] : ( name.match( rnotwhite ) || [] );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\ti = name.length;\n\n\t\t\twhile ( i-- ) {\n\t\t\t\tdelete cache[ name[ i ] ];\n\t\t\t}\n\t\t}\n\n\t\t// Remove the expando if there's no more data\n\t\tif ( key === undefined || jQuery.isEmptyObject( cache ) ) {\n\n\t\t\t// Support: Chrome <= 35-45+\n\t\t\t// Webkit & Blink performance suffers when deleting properties\n\t\t\t// from DOM nodes, so set to undefined instead\n\t\t\t// https://code.google.com/p/chromium/issues/detail?id=378607\n\t\t\tif ( owner.nodeType ) {\n\t\t\t\towner[ this.expando ] = undefined;\n\t\t\t} else {\n\t\t\t\tdelete owner[ this.expando ];\n\t\t\t}\n\t\t}\n\t},\n\thasData: function( owner ) {\n\t\tvar cache = owner[ this.expando ];\n\t\treturn cache !== undefined && !jQuery.isEmptyObject( cache );\n\t}\n};\nvar dataPriv = new Data();\n\nvar dataUser = new Data();\n\n\n\n//\tImplementation Summary\n//\n//\t1. Enforce API surface and semantic compatibility with 1.9.x branch\n//\t2. Improve the module's maintainability by reducing the storage\n//\t\tpaths to a single mechanism.\n//\t3. Use the same single mechanism to support \"private\" and \"user\" data.\n//\t4. _Never_ expose \"private\" data to user code (TODO: Drop _data, _removeData)\n//\t5. Avoid exposing implementation details on user objects (eg. expando properties)\n//\t6. Provide a clear path for implementation upgrade to WeakMap in 2014\n\nvar rbrace = /^(?:\\{[\\w\\W]*\\}|\\[[\\w\\W]*\\])$/,\n\trmultiDash = /[A-Z]/g;\n\nfunction dataAttr( elem, key, data ) {\n\tvar name;\n\n\t// If nothing was found internally, try to fetch any\n\t// data from the HTML5 data-* attribute\n\tif ( data === undefined && elem.nodeType === 1 ) {\n\t\tname = \"data-\" + key.replace( rmultiDash, \"-$&\" ).toLowerCase();\n\t\tdata = elem.getAttribute( name );\n\n\t\tif ( typeof data === \"string\" ) {\n\t\t\ttry {\n\t\t\t\tdata = data === \"true\" ? true :\n\t\t\t\t\tdata === \"false\" ? false :\n\t\t\t\t\tdata === \"null\" ? null :\n\n\t\t\t\t\t// Only convert to a number if it doesn't change the string\n\t\t\t\t\t+data + \"\" === data ? +data :\n\t\t\t\t\trbrace.test( data ) ? jQuery.parseJSON( data ) :\n\t\t\t\t\tdata;\n\t\t\t} catch ( e ) {}\n\n\t\t\t// Make sure we set the data so it isn't changed later\n\t\t\tdataUser.set( elem, key, data );\n\t\t} else {\n\t\t\tdata = undefined;\n\t\t}\n\t}\n\treturn data;\n}\n\njQuery.extend( {\n\thasData: function( elem ) {\n\t\treturn dataUser.hasData( elem ) || dataPriv.hasData( elem );\n\t},\n\n\tdata: function( elem, name, data ) {\n\t\treturn dataUser.access( elem, name, data );\n\t},\n\n\tremoveData: function( elem, name ) {\n\t\tdataUser.remove( elem, name );\n\t},\n\n\t// TODO: Now that all calls to _data and _removeData have been replaced\n\t// with direct calls to dataPriv methods, these can be deprecated.\n\t_data: function( elem, name, data ) {\n\t\treturn dataPriv.access( elem, name, data );\n\t},\n\n\t_removeData: function( elem, name ) {\n\t\tdataPriv.remove( elem, name );\n\t}\n} );\n\njQuery.fn.extend( {\n\tdata: function( key, value ) {\n\t\tvar i, name, data,\n\t\t\telem = this[ 0 ],\n\t\t\tattrs = elem && elem.attributes;\n\n\t\t// Gets all values\n\t\tif ( key === undefined ) {\n\t\t\tif ( this.length ) {\n\t\t\t\tdata = dataUser.get( elem );\n\n\t\t\t\tif ( elem.nodeType === 1 && !dataPriv.get( elem, \"hasDataAttrs\" ) ) {\n\t\t\t\t\ti = attrs.length;\n\t\t\t\t\twhile ( i-- ) {\n\n\t\t\t\t\t\t// Support: IE11+\n\t\t\t\t\t\t// The attrs elements can be null (#14894)\n\t\t\t\t\t\tif ( attrs[ i ] ) {\n\t\t\t\t\t\t\tname = attrs[ i ].name;\n\t\t\t\t\t\t\tif ( name.indexOf( \"data-\" ) === 0 ) {\n\t\t\t\t\t\t\t\tname = jQuery.camelCase( name.slice( 5 ) );\n\t\t\t\t\t\t\t\tdataAttr( elem, name, data[ name ] );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tdataPriv.set( elem, \"hasDataAttrs\", true );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn data;\n\t\t}\n\n\t\t// Sets multiple values\n\t\tif ( typeof key === \"object\" ) {\n\t\t\treturn this.each( function() {\n\t\t\t\tdataUser.set( this, key );\n\t\t\t} );\n\t\t}\n\n\t\treturn access( this, function( value ) {\n\t\t\tvar data, camelKey;\n\n\t\t\t// The calling jQuery object (element matches) is not empty\n\t\t\t// (and therefore has an element appears at this[ 0 ]) and the\n\t\t\t// `value` parameter was not undefined. An empty jQuery object\n\t\t\t// will result in `undefined` for elem = this[ 0 ] which will\n\t\t\t// throw an exception if an attempt to read a data cache is made.\n\t\t\tif ( elem && value === undefined ) {\n\n\t\t\t\t// Attempt to get data from the cache\n\t\t\t\t// with the key as-is\n\t\t\t\tdata = dataUser.get( elem, key ) ||\n\n\t\t\t\t\t// Try to find dashed key if it exists (gh-2779)\n\t\t\t\t\t// This is for 2.2.x only\n\t\t\t\t\tdataUser.get( elem, key.replace( rmultiDash, \"-$&\" ).toLowerCase() );\n\n\t\t\t\tif ( data !== undefined ) {\n\t\t\t\t\treturn data;\n\t\t\t\t}\n\n\t\t\t\tcamelKey = jQuery.camelCase( key );\n\n\t\t\t\t// Attempt to get data from the cache\n\t\t\t\t// with the key camelized\n\t\t\t\tdata = dataUser.get( elem, camelKey );\n\t\t\t\tif ( data !== undefined ) {\n\t\t\t\t\treturn data;\n\t\t\t\t}\n\n\t\t\t\t// Attempt to \"discover\" the data in\n\t\t\t\t// HTML5 custom data-* attrs\n\t\t\t\tdata = dataAttr( elem, camelKey, undefined );\n\t\t\t\tif ( data !== undefined ) {\n\t\t\t\t\treturn data;\n\t\t\t\t}\n\n\t\t\t\t// We tried really hard, but the data doesn't exist.\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Set the data...\n\t\t\tcamelKey = jQuery.camelCase( key );\n\t\t\tthis.each( function() {\n\n\t\t\t\t// First, attempt to store a copy or reference of any\n\t\t\t\t// data that might've been store with a camelCased key.\n\t\t\t\tvar data = dataUser.get( this, camelKey );\n\n\t\t\t\t// For HTML5 data-* attribute interop, we have to\n\t\t\t\t// store property names with dashes in a camelCase form.\n\t\t\t\t// This might not apply to all properties...*\n\t\t\t\tdataUser.set( this, camelKey, value );\n\n\t\t\t\t// *... In the case of properties that might _actually_\n\t\t\t\t// have dashes, we need to also store a copy of that\n\t\t\t\t// unchanged property.\n\t\t\t\tif ( key.indexOf( \"-\" ) > -1 && data !== undefined ) {\n\t\t\t\t\tdataUser.set( this, key, value );\n\t\t\t\t}\n\t\t\t} );\n\t\t}, null, value, arguments.length > 1, null, true );\n\t},\n\n\tremoveData: function( key ) {\n\t\treturn this.each( function() {\n\t\t\tdataUser.remove( this, key );\n\t\t} );\n\t}\n} );\n\n\njQuery.extend( {\n\tqueue: function( elem, type, data ) {\n\t\tvar queue;\n\n\t\tif ( elem ) {\n\t\t\ttype = ( type || \"fx\" ) + \"queue\";\n\t\t\tqueue = dataPriv.get( elem, type );\n\n\t\t\t// Speed up dequeue by getting out quickly if this is just a lookup\n\t\t\tif ( data ) {\n\t\t\t\tif ( !queue || jQuery.isArray( data ) ) {\n\t\t\t\t\tqueue = dataPriv.access( elem, type, jQuery.makeArray( data ) );\n\t\t\t\t} else {\n\t\t\t\t\tqueue.push( data );\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn queue || [];\n\t\t}\n\t},\n\n\tdequeue: function( elem, type ) {\n\t\ttype = type || \"fx\";\n\n\t\tvar queue = jQuery.queue( elem, type ),\n\t\t\tstartLength = queue.length,\n\t\t\tfn = queue.shift(),\n\t\t\thooks = jQuery._queueHooks( elem, type ),\n\t\t\tnext = function() {\n\t\t\t\tjQuery.dequeue( elem, type );\n\t\t\t};\n\n\t\t// If the fx queue is dequeued, always remove the progress sentinel\n\t\tif ( fn === \"inprogress\" ) {\n\t\t\tfn = queue.shift();\n\t\t\tstartLength--;\n\t\t}\n\n\t\tif ( fn ) {\n\n\t\t\t// Add a progress sentinel to prevent the fx queue from being\n\t\t\t// automatically dequeued\n\t\t\tif ( type === \"fx\" ) {\n\t\t\t\tqueue.unshift( \"inprogress\" );\n\t\t\t}\n\n\t\t\t// Clear up the last queue stop function\n\t\t\tdelete hooks.stop;\n\t\t\tfn.call( elem, next, hooks );\n\t\t}\n\n\t\tif ( !startLength && hooks ) {\n\t\t\thooks.empty.fire();\n\t\t}\n\t},\n\n\t// Not public - generate a queueHooks object, or return the current one\n\t_queueHooks: function( elem, type ) {\n\t\tvar key = type + \"queueHooks\";\n\t\treturn dataPriv.get( elem, key ) || dataPriv.access( elem, key, {\n\t\t\tempty: jQuery.Callbacks( \"once memory\" ).add( function() {\n\t\t\t\tdataPriv.remove( elem, [ type + \"queue\", key ] );\n\t\t\t} )\n\t\t} );\n\t}\n} );\n\njQuery.fn.extend( {\n\tqueue: function( type, data ) {\n\t\tvar setter = 2;\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tdata = type;\n\t\t\ttype = \"fx\";\n\t\t\tsetter--;\n\t\t}\n\n\t\tif ( arguments.length < setter ) {\n\t\t\treturn jQuery.queue( this[ 0 ], type );\n\t\t}\n\n\t\treturn data === undefined ?\n\t\t\tthis :\n\t\t\tthis.each( function() {\n\t\t\t\tvar queue = jQuery.queue( this, type, data );\n\n\t\t\t\t// Ensure a hooks for this queue\n\t\t\t\tjQuery._queueHooks( this, type );\n\n\t\t\t\tif ( type === \"fx\" && queue[ 0 ] !== \"inprogress\" ) {\n\t\t\t\t\tjQuery.dequeue( this, type );\n\t\t\t\t}\n\t\t\t} );\n\t},\n\tdequeue: function( type ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.dequeue( this, type );\n\t\t} );\n\t},\n\tclearQueue: function( type ) {\n\t\treturn this.queue( type || \"fx\", [] );\n\t},\n\n\t// Get a promise resolved when queues of a certain type\n\t// are emptied (fx is the type by default)\n\tpromise: function( type, obj ) {\n\t\tvar tmp,\n\t\t\tcount = 1,\n\t\t\tdefer = jQuery.Deferred(),\n\t\t\telements = this,\n\t\t\ti = this.length,\n\t\t\tresolve = function() {\n\t\t\t\tif ( !( --count ) ) {\n\t\t\t\t\tdefer.resolveWith( elements, [ elements ] );\n\t\t\t\t}\n\t\t\t};\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tobj = type;\n\t\t\ttype = undefined;\n\t\t}\n\t\ttype = type || \"fx\";\n\n\t\twhile ( i-- ) {\n\t\t\ttmp = dataPriv.get( elements[ i ], type + \"queueHooks\" );\n\t\t\tif ( tmp && tmp.empty ) {\n\t\t\t\tcount++;\n\t\t\t\ttmp.empty.add( resolve );\n\t\t\t}\n\t\t}\n\t\tresolve();\n\t\treturn defer.promise( obj );\n\t}\n} );\nvar pnum = ( /[+-]?(?:\\d*\\.|)\\d+(?:[eE][+-]?\\d+|)/ ).source;\n\nvar rcssNum = new RegExp( \"^(?:([+-])=|)(\" + pnum + \")([a-z%]*)$\", \"i\" );\n\n\nvar cssExpand = [ \"Top\", \"Right\", \"Bottom\", \"Left\" ];\n\nvar isHidden = function( elem, el ) {\n\n\t\t// isHidden might be called from jQuery#filter function;\n\t\t// in that case, element will be second argument\n\t\telem = el || elem;\n\t\treturn jQuery.css( elem, \"display\" ) === \"none\" ||\n\t\t\t!jQuery.contains( elem.ownerDocument, elem );\n\t};\n\n\n\nfunction adjustCSS( elem, prop, valueParts, tween ) {\n\tvar adjusted,\n\t\tscale = 1,\n\t\tmaxIterations = 20,\n\t\tcurrentValue = tween ?\n\t\t\tfunction() { return tween.cur(); } :\n\t\t\tfunction() { return jQuery.css( elem, prop, \"\" ); },\n\t\tinitial = currentValue(),\n\t\tunit = valueParts && valueParts[ 3 ] || ( jQuery.cssNumber[ prop ] ? \"\" : \"px\" ),\n\n\t\t// Starting value computation is required for potential unit mismatches\n\t\tinitialInUnit = ( jQuery.cssNumber[ prop ] || unit !== \"px\" && +initial ) &&\n\t\t\trcssNum.exec( jQuery.css( elem, prop ) );\n\n\tif ( initialInUnit && initialInUnit[ 3 ] !== unit ) {\n\n\t\t// Trust units reported by jQuery.css\n\t\tunit = unit || initialInUnit[ 3 ];\n\n\t\t// Make sure we update the tween properties later on\n\t\tvalueParts = valueParts || [];\n\n\t\t// Iteratively approximate from a nonzero starting point\n\t\tinitialInUnit = +initial || 1;\n\n\t\tdo {\n\n\t\t\t// If previous iteration zeroed out, double until we get *something*.\n\t\t\t// Use string for doubling so we don't accidentally see scale as unchanged below\n\t\t\tscale = scale || \".5\";\n\n\t\t\t// Adjust and apply\n\t\t\tinitialInUnit = initialInUnit / scale;\n\t\t\tjQuery.style( elem, prop, initialInUnit + unit );\n\n\t\t// Update scale, tolerating zero or NaN from tween.cur()\n\t\t// Break the loop if scale is unchanged or perfect, or if we've just had enough.\n\t\t} while (\n\t\t\tscale !== ( scale = currentValue() / initial ) && scale !== 1 && --maxIterations\n\t\t);\n\t}\n\n\tif ( valueParts ) {\n\t\tinitialInUnit = +initialInUnit || +initial || 0;\n\n\t\t// Apply relative offset (+=/-=) if specified\n\t\tadjusted = valueParts[ 1 ] ?\n\t\t\tinitialInUnit + ( valueParts[ 1 ] + 1 ) * valueParts[ 2 ] :\n\t\t\t+valueParts[ 2 ];\n\t\tif ( tween ) {\n\t\t\ttween.unit = unit;\n\t\t\ttween.start = initialInUnit;\n\t\t\ttween.end = adjusted;\n\t\t}\n\t}\n\treturn adjusted;\n}\nvar rcheckableType = ( /^(?:checkbox|radio)$/i );\n\nvar rtagName = ( /<([\\w:-]+)/ );\n\nvar rscriptType = ( /^$|\\/(?:java|ecma)script/i );\n\n\n\n// We have to close these tags to support XHTML (#13200)\nvar wrapMap = {\n\n\t// Support: IE9\n\toption: [ 1, \"<select multiple='multiple'>\", \"</select>\" ],\n\n\t// XHTML parsers do not magically insert elements in the\n\t// same way that tag soup parsers do. So we cannot shorten\n\t// this by omitting <tbody> or other required elements.\n\tthead: [ 1, \"<table>\", \"</table>\" ],\n\tcol: [ 2, \"<table><colgroup>\", \"</colgroup></table>\" ],\n\ttr: [ 2, \"<table><tbody>\", \"</tbody></table>\" ],\n\ttd: [ 3, \"<table><tbody><tr>\", \"</tr></tbody></table>\" ],\n\n\t_default: [ 0, \"\", \"\" ]\n};\n\n// Support: IE9\nwrapMap.optgroup = wrapMap.option;\n\nwrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead;\nwrapMap.th = wrapMap.td;\n\n\nfunction getAll( context, tag ) {\n\n\t// Support: IE9-11+\n\t// Use typeof to avoid zero-argument method invocation on host objects (#15151)\n\tvar ret = typeof context.getElementsByTagName !== \"undefined\" ?\n\t\t\tcontext.getElementsByTagName( tag || \"*\" ) :\n\t\t\ttypeof context.querySelectorAll !== \"undefined\" ?\n\t\t\t\tcontext.querySelectorAll( tag || \"*\" ) :\n\t\t\t[];\n\n\treturn tag === undefined || tag && jQuery.nodeName( context, tag ) ?\n\t\tjQuery.merge( [ context ], ret ) :\n\t\tret;\n}\n\n\n// Mark scripts as having already been evaluated\nfunction setGlobalEval( elems, refElements ) {\n\tvar i = 0,\n\t\tl = elems.length;\n\n\tfor ( ; i < l; i++ ) {\n\t\tdataPriv.set(\n\t\t\telems[ i ],\n\t\t\t\"globalEval\",\n\t\t\t!refElements || dataPriv.get( refElements[ i ], \"globalEval\" )\n\t\t);\n\t}\n}\n\n\nvar rhtml = /<|&#?\\w+;/;\n\nfunction buildFragment( elems, context, scripts, selection, ignored ) {\n\tvar elem, tmp, tag, wrap, contains, j,\n\t\tfragment = context.createDocumentFragment(),\n\t\tnodes = [],\n\t\ti = 0,\n\t\tl = elems.length;\n\n\tfor ( ; i < l; i++ ) {\n\t\telem = elems[ i ];\n\n\t\tif ( elem || elem === 0 ) {\n\n\t\t\t// Add nodes directly\n\t\t\tif ( jQuery.type( elem ) === \"object\" ) {\n\n\t\t\t\t// Support: Android<4.1, PhantomJS<2\n\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\tjQuery.merge( nodes, elem.nodeType ? [ elem ] : elem );\n\n\t\t\t// Convert non-html into a text node\n\t\t\t} else if ( !rhtml.test( elem ) ) {\n\t\t\t\tnodes.push( context.createTextNode( elem ) );\n\n\t\t\t// Convert html into DOM nodes\n\t\t\t} else {\n\t\t\t\ttmp = tmp || fragment.appendChild( context.createElement( \"div\" ) );\n\n\t\t\t\t// Deserialize a standard representation\n\t\t\t\ttag = ( rtagName.exec( elem ) || [ \"\", \"\" ] )[ 1 ].toLowerCase();\n\t\t\t\twrap = wrapMap[ tag ] || wrapMap._default;\n\t\t\t\ttmp.innerHTML = wrap[ 1 ] + jQuery.htmlPrefilter( elem ) + wrap[ 2 ];\n\n\t\t\t\t// Descend through wrappers to the right content\n\t\t\t\tj = wrap[ 0 ];\n\t\t\t\twhile ( j-- ) {\n\t\t\t\t\ttmp = tmp.lastChild;\n\t\t\t\t}\n\n\t\t\t\t// Support: Android<4.1, PhantomJS<2\n\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\tjQuery.merge( nodes, tmp.childNodes );\n\n\t\t\t\t// Remember the top-level container\n\t\t\t\ttmp = fragment.firstChild;\n\n\t\t\t\t// Ensure the created nodes are orphaned (#12392)\n\t\t\t\ttmp.textContent = \"\";\n\t\t\t}\n\t\t}\n\t}\n\n\t// Remove wrapper from fragment\n\tfragment.textContent = \"\";\n\n\ti = 0;\n\twhile ( ( elem = nodes[ i++ ] ) ) {\n\n\t\t// Skip elements already in the context collection (trac-4087)\n\t\tif ( selection && jQuery.inArray( elem, selection ) > -1 ) {\n\t\t\tif ( ignored ) {\n\t\t\t\tignored.push( elem );\n\t\t\t}\n\t\t\tcontinue;\n\t\t}\n\n\t\tcontains = jQuery.contains( elem.ownerDocument, elem );\n\n\t\t// Append to fragment\n\t\ttmp = getAll( fragment.appendChild( elem ), \"script\" );\n\n\t\t// Preserve script evaluation history\n\t\tif ( contains ) {\n\t\t\tsetGlobalEval( tmp );\n\t\t}\n\n\t\t// Capture executables\n\t\tif ( scripts ) {\n\t\t\tj = 0;\n\t\t\twhile ( ( elem = tmp[ j++ ] ) ) {\n\t\t\t\tif ( rscriptType.test( elem.type || \"\" ) ) {\n\t\t\t\t\tscripts.push( elem );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn fragment;\n}\n\n\n( function() {\n\tvar fragment = document.createDocumentFragment(),\n\t\tdiv = fragment.appendChild( document.createElement( \"div\" ) ),\n\t\tinput = document.createElement( \"input\" );\n\n\t// Support: Android 4.0-4.3, Safari<=5.1\n\t// Check state lost if the name is set (#11217)\n\t// Support: Windows Web Apps (WWA)\n\t// `name` and `type` must use .setAttribute for WWA (#14901)\n\tinput.setAttribute( \"type\", \"radio\" );\n\tinput.setAttribute( \"checked\", \"checked\" );\n\tinput.setAttribute( \"name\", \"t\" );\n\n\tdiv.appendChild( input );\n\n\t// Support: Safari<=5.1, Android<4.2\n\t// Older WebKit doesn't clone checked state correctly in fragments\n\tsupport.checkClone = div.cloneNode( true ).cloneNode( true ).lastChild.checked;\n\n\t// Support: IE<=11+\n\t// Make sure textarea (and checkbox) defaultValue is properly cloned\n\tdiv.innerHTML = \"<textarea>x</textarea>\";\n\tsupport.noCloneChecked = !!div.cloneNode( true ).lastChild.defaultValue;\n} )();\n\n\nvar\n\trkeyEvent = /^key/,\n\trmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/,\n\trtypenamespace = /^([^.]*)(?:\\.(.+)|)/;\n\nfunction returnTrue() {\n\treturn true;\n}\n\nfunction returnFalse() {\n\treturn false;\n}\n\n// Support: IE9\n// See #13393 for more info\nfunction safeActiveElement() {\n\ttry {\n\t\treturn document.activeElement;\n\t} catch ( err ) { }\n}\n\nfunction on( elem, types, selector, data, fn, one ) {\n\tvar origFn, type;\n\n\t// Types can be a map of types/handlers\n\tif ( typeof types === \"object\" ) {\n\n\t\t// ( types-Object, selector, data )\n\t\tif ( typeof selector !== \"string\" ) {\n\n\t\t\t// ( types-Object, data )\n\t\t\tdata = data || selector;\n\t\t\tselector = undefined;\n\t\t}\n\t\tfor ( type in types ) {\n\t\t\ton( elem, type, selector, data, types[ type ], one );\n\t\t}\n\t\treturn elem;\n\t}\n\n\tif ( data == null && fn == null ) {\n\n\t\t// ( types, fn )\n\t\tfn = selector;\n\t\tdata = selector = undefined;\n\t} else if ( fn == null ) {\n\t\tif ( typeof selector === \"string\" ) {\n\n\t\t\t// ( types, selector, fn )\n\t\t\tfn = data;\n\t\t\tdata = undefined;\n\t\t} else {\n\n\t\t\t// ( types, data, fn )\n\t\t\tfn = data;\n\t\t\tdata = selector;\n\t\t\tselector = undefined;\n\t\t}\n\t}\n\tif ( fn === false ) {\n\t\tfn = returnFalse;\n\t} else if ( !fn ) {\n\t\treturn elem;\n\t}\n\n\tif ( one === 1 ) {\n\t\torigFn = fn;\n\t\tfn = function( event ) {\n\n\t\t\t// Can use an empty set, since event contains the info\n\t\t\tjQuery().off( event );\n\t\t\treturn origFn.apply( this, arguments );\n\t\t};\n\n\t\t// Use same guid so caller can remove using origFn\n\t\tfn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ );\n\t}\n\treturn elem.each( function() {\n\t\tjQuery.event.add( this, types, fn, data, selector );\n\t} );\n}\n\n/*\n * Helper functions for managing events -- not part of the public interface.\n * Props to Dean Edwards' addEvent library for many of the ideas.\n */\njQuery.event = {\n\n\tglobal: {},\n\n\tadd: function( elem, types, handler, data, selector ) {\n\n\t\tvar handleObjIn, eventHandle, tmp,\n\t\t\tevents, t, handleObj,\n\t\t\tspecial, handlers, type, namespaces, origType,\n\t\t\telemData = dataPriv.get( elem );\n\n\t\t// Don't attach events to noData or text/comment nodes (but allow plain objects)\n\t\tif ( !elemData ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Caller can pass in an object of custom data in lieu of the handler\n\t\tif ( handler.handler ) {\n\t\t\thandleObjIn = handler;\n\t\t\thandler = handleObjIn.handler;\n\t\t\tselector = handleObjIn.selector;\n\t\t}\n\n\t\t// Make sure that the handler has a unique ID, used to find/remove it later\n\t\tif ( !handler.guid ) {\n\t\t\thandler.guid = jQuery.guid++;\n\t\t}\n\n\t\t// Init the element's event structure and main handler, if this is the first\n\t\tif ( !( events = elemData.events ) ) {\n\t\t\tevents = elemData.events = {};\n\t\t}\n\t\tif ( !( eventHandle = elemData.handle ) ) {\n\t\t\teventHandle = elemData.handle = function( e ) {\n\n\t\t\t\t// Discard the second event of a jQuery.event.trigger() and\n\t\t\t\t// when an event is called after a page has unloaded\n\t\t\t\treturn typeof jQuery !== \"undefined\" && jQuery.event.triggered !== e.type ?\n\t\t\t\t\tjQuery.event.dispatch.apply( elem, arguments ) : undefined;\n\t\t\t};\n\t\t}\n\n\t\t// Handle multiple events separated by a space\n\t\ttypes = ( types || \"\" ).match( rnotwhite ) || [ \"\" ];\n\t\tt = types.length;\n\t\twhile ( t-- ) {\n\t\t\ttmp = rtypenamespace.exec( types[ t ] ) || [];\n\t\t\ttype = origType = tmp[ 1 ];\n\t\t\tnamespaces = ( tmp[ 2 ] || \"\" ).split( \".\" ).sort();\n\n\t\t\t// There *must* be a type, no attaching namespace-only handlers\n\t\t\tif ( !type ) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// If event changes its type, use the special event handlers for the changed type\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\n\t\t\t// If selector defined, determine special event api type, otherwise given type\n\t\t\ttype = ( selector ? special.delegateType : special.bindType ) || type;\n\n\t\t\t// Update special based on newly reset type\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\n\t\t\t// handleObj is passed to all event handlers\n\t\t\thandleObj = jQuery.extend( {\n\t\t\t\ttype: type,\n\t\t\t\torigType: origType,\n\t\t\t\tdata: data,\n\t\t\t\thandler: handler,\n\t\t\t\tguid: handler.guid,\n\t\t\t\tselector: selector,\n\t\t\t\tneedsContext: selector && jQuery.expr.match.needsContext.test( selector ),\n\t\t\t\tnamespace: namespaces.join( \".\" )\n\t\t\t}, handleObjIn );\n\n\t\t\t// Init the event handler queue if we're the first\n\t\t\tif ( !( handlers = events[ type ] ) ) {\n\t\t\t\thandlers = events[ type ] = [];\n\t\t\t\thandlers.delegateCount = 0;\n\n\t\t\t\t// Only use addEventListener if the special events handler returns false\n\t\t\t\tif ( !special.setup ||\n\t\t\t\t\tspecial.setup.call( elem, data, namespaces, eventHandle ) === false ) {\n\n\t\t\t\t\tif ( elem.addEventListener ) {\n\t\t\t\t\t\telem.addEventListener( type, eventHandle );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif ( special.add ) {\n\t\t\t\tspecial.add.call( elem, handleObj );\n\n\t\t\t\tif ( !handleObj.handler.guid ) {\n\t\t\t\t\thandleObj.handler.guid = handler.guid;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add to the element's handler list, delegates in front\n\t\t\tif ( selector ) {\n\t\t\t\thandlers.splice( handlers.delegateCount++, 0, handleObj );\n\t\t\t} else {\n\t\t\t\thandlers.push( handleObj );\n\t\t\t}\n\n\t\t\t// Keep track of which events have ever been used, for event optimization\n\t\t\tjQuery.event.global[ type ] = true;\n\t\t}\n\n\t},\n\n\t// Detach an event or set of events from an element\n\tremove: function( elem, types, handler, selector, mappedTypes ) {\n\n\t\tvar j, origCount, tmp,\n\t\t\tevents, t, handleObj,\n\t\t\tspecial, handlers, type, namespaces, origType,\n\t\t\telemData = dataPriv.hasData( elem ) && dataPriv.get( elem );\n\n\t\tif ( !elemData || !( events = elemData.events ) ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Once for each type.namespace in types; type may be omitted\n\t\ttypes = ( types || \"\" ).match( rnotwhite ) || [ \"\" ];\n\t\tt = types.length;\n\t\twhile ( t-- ) {\n\t\t\ttmp = rtypenamespace.exec( types[ t ] ) || [];\n\t\t\ttype = origType = tmp[ 1 ];\n\t\t\tnamespaces = ( tmp[ 2 ] || \"\" ).split( \".\" ).sort();\n\n\t\t\t// Unbind all events (on this namespace, if provided) for the element\n\t\t\tif ( !type ) {\n\t\t\t\tfor ( type in events ) {\n\t\t\t\t\tjQuery.event.remove( elem, type + types[ t ], handler, selector, true );\n\t\t\t\t}\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\t\t\ttype = ( selector ? special.delegateType : special.bindType ) || type;\n\t\t\thandlers = events[ type ] || [];\n\t\t\ttmp = tmp[ 2 ] &&\n\t\t\t\tnew RegExp( \"(^|\\\\.)\" + namespaces.join( \"\\\\.(?:.*\\\\.|)\" ) + \"(\\\\.|$)\" );\n\n\t\t\t// Remove matching events\n\t\t\torigCount = j = handlers.length;\n\t\t\twhile ( j-- ) {\n\t\t\t\thandleObj = handlers[ j ];\n\n\t\t\t\tif ( ( mappedTypes || origType === handleObj.origType ) &&\n\t\t\t\t\t( !handler || handler.guid === handleObj.guid ) &&\n\t\t\t\t\t( !tmp || tmp.test( handleObj.namespace ) ) &&\n\t\t\t\t\t( !selector || selector === handleObj.selector ||\n\t\t\t\t\t\tselector === \"**\" && handleObj.selector ) ) {\n\t\t\t\t\thandlers.splice( j, 1 );\n\n\t\t\t\t\tif ( handleObj.selector ) {\n\t\t\t\t\t\thandlers.delegateCount--;\n\t\t\t\t\t}\n\t\t\t\t\tif ( special.remove ) {\n\t\t\t\t\t\tspecial.remove.call( elem, handleObj );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Remove generic event handler if we removed something and no more handlers exist\n\t\t\t// (avoids potential for endless recursion during removal of special event handlers)\n\t\t\tif ( origCount && !handlers.length ) {\n\t\t\t\tif ( !special.teardown ||\n\t\t\t\t\tspecial.teardown.call( elem, namespaces, elemData.handle ) === false ) {\n\n\t\t\t\t\tjQuery.removeEvent( elem, type, elemData.handle );\n\t\t\t\t}\n\n\t\t\t\tdelete events[ type ];\n\t\t\t}\n\t\t}\n\n\t\t// Remove data and the expando if it's no longer used\n\t\tif ( jQuery.isEmptyObject( events ) ) {\n\t\t\tdataPriv.remove( elem, \"handle events\" );\n\t\t}\n\t},\n\n\tdispatch: function( event ) {\n\n\t\t// Make a writable jQuery.Event from the native event object\n\t\tevent = jQuery.event.fix( event );\n\n\t\tvar i, j, ret, matched, handleObj,\n\t\t\thandlerQueue = [],\n\t\t\targs = slice.call( arguments ),\n\t\t\thandlers = ( dataPriv.get( this, \"events\" ) || {} )[ event.type ] || [],\n\t\t\tspecial = jQuery.event.special[ event.type ] || {};\n\n\t\t// Use the fix-ed jQuery.Event rather than the (read-only) native event\n\t\targs[ 0 ] = event;\n\t\tevent.delegateTarget = this;\n\n\t\t// Call the preDispatch hook for the mapped type, and let it bail if desired\n\t\tif ( special.preDispatch && special.preDispatch.call( this, event ) === false ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Determine handlers\n\t\thandlerQueue = jQuery.event.handlers.call( this, event, handlers );\n\n\t\t// Run delegates first; they may want to stop propagation beneath us\n\t\ti = 0;\n\t\twhile ( ( matched = handlerQueue[ i++ ] ) && !event.isPropagationStopped() ) {\n\t\t\tevent.currentTarget = matched.elem;\n\n\t\t\tj = 0;\n\t\t\twhile ( ( handleObj = matched.handlers[ j++ ] ) &&\n\t\t\t\t!event.isImmediatePropagationStopped() ) {\n\n\t\t\t\t// Triggered event must either 1) have no namespace, or 2) have namespace(s)\n\t\t\t\t// a subset or equal to those in the bound event (both can have no namespace).\n\t\t\t\tif ( !event.rnamespace || event.rnamespace.test( handleObj.namespace ) ) {\n\n\t\t\t\t\tevent.handleObj = handleObj;\n\t\t\t\t\tevent.data = handleObj.data;\n\n\t\t\t\t\tret = ( ( jQuery.event.special[ handleObj.origType ] || {} ).handle ||\n\t\t\t\t\t\thandleObj.handler ).apply( matched.elem, args );\n\n\t\t\t\t\tif ( ret !== undefined ) {\n\t\t\t\t\t\tif ( ( event.result = ret ) === false ) {\n\t\t\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Call the postDispatch hook for the mapped type\n\t\tif ( special.postDispatch ) {\n\t\t\tspecial.postDispatch.call( this, event );\n\t\t}\n\n\t\treturn event.result;\n\t},\n\n\thandlers: function( event, handlers ) {\n\t\tvar i, matches, sel, handleObj,\n\t\t\thandlerQueue = [],\n\t\t\tdelegateCount = handlers.delegateCount,\n\t\t\tcur = event.target;\n\n\t\t// Support (at least): Chrome, IE9\n\t\t// Find delegate handlers\n\t\t// Black-hole SVG <use> instance trees (#13180)\n\t\t//\n\t\t// Support: Firefox<=42+\n\t\t// Avoid non-left-click in FF but don't block IE radio events (#3861, gh-2343)\n\t\tif ( delegateCount && cur.nodeType &&\n\t\t\t( event.type !== \"click\" || isNaN( event.button ) || event.button < 1 ) ) {\n\n\t\t\tfor ( ; cur !== this; cur = cur.parentNode || this ) {\n\n\t\t\t\t// Don't check non-elements (#13208)\n\t\t\t\t// Don't process clicks on disabled elements (#6911, #8165, #11382, #11764)\n\t\t\t\tif ( cur.nodeType === 1 && ( cur.disabled !== true || event.type !== \"click\" ) ) {\n\t\t\t\t\tmatches = [];\n\t\t\t\t\tfor ( i = 0; i < delegateCount; i++ ) {\n\t\t\t\t\t\thandleObj = handlers[ i ];\n\n\t\t\t\t\t\t// Don't conflict with Object.prototype properties (#13203)\n\t\t\t\t\t\tsel = handleObj.selector + \" \";\n\n\t\t\t\t\t\tif ( matches[ sel ] === undefined ) {\n\t\t\t\t\t\t\tmatches[ sel ] = handleObj.needsContext ?\n\t\t\t\t\t\t\t\tjQuery( sel, this ).index( cur ) > -1 :\n\t\t\t\t\t\t\t\tjQuery.find( sel, this, null, [ cur ] ).length;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif ( matches[ sel ] ) {\n\t\t\t\t\t\t\tmatches.push( handleObj );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif ( matches.length ) {\n\t\t\t\t\t\thandlerQueue.push( { elem: cur, handlers: matches } );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Add the remaining (directly-bound) handlers\n\t\tif ( delegateCount < handlers.length ) {\n\t\t\thandlerQueue.push( { elem: this, handlers: handlers.slice( delegateCount ) } );\n\t\t}\n\n\t\treturn handlerQueue;\n\t},\n\n\t// Includes some event props shared by KeyEvent and MouseEvent\n\tprops: ( \"altKey bubbles cancelable ctrlKey currentTarget detail eventPhase \" +\n\t\t\"metaKey relatedTarget shiftKey target timeStamp view which\" ).split( \" \" ),\n\n\tfixHooks: {},\n\n\tkeyHooks: {\n\t\tprops: \"char charCode key keyCode\".split( \" \" ),\n\t\tfilter: function( event, original ) {\n\n\t\t\t// Add which for key events\n\t\t\tif ( event.which == null ) {\n\t\t\t\tevent.which = original.charCode != null ? original.charCode : original.keyCode;\n\t\t\t}\n\n\t\t\treturn event;\n\t\t}\n\t},\n\n\tmouseHooks: {\n\t\tprops: ( \"button buttons clientX clientY offsetX offsetY pageX pageY \" +\n\t\t\t\"screenX screenY toElement\" ).split( \" \" ),\n\t\tfilter: function( event, original ) {\n\t\t\tvar eventDoc, doc, body,\n\t\t\t\tbutton = original.button;\n\n\t\t\t// Calculate pageX/Y if missing and clientX/Y available\n\t\t\tif ( event.pageX == null && original.clientX != null ) {\n\t\t\t\teventDoc = event.target.ownerDocument || document;\n\t\t\t\tdoc = eventDoc.documentElement;\n\t\t\t\tbody = eventDoc.body;\n\n\t\t\t\tevent.pageX = original.clientX +\n\t\t\t\t\t( doc && doc.scrollLeft || body && body.scrollLeft || 0 ) -\n\t\t\t\t\t( doc && doc.clientLeft || body && body.clientLeft || 0 );\n\t\t\t\tevent.pageY = original.clientY +\n\t\t\t\t\t( doc && doc.scrollTop || body && body.scrollTop || 0 ) -\n\t\t\t\t\t( doc && doc.clientTop || body && body.clientTop || 0 );\n\t\t\t}\n\n\t\t\t// Add which for click: 1 === left; 2 === middle; 3 === right\n\t\t\t// Note: button is not normalized, so don't use it\n\t\t\tif ( !event.which && button !== undefined ) {\n\t\t\t\tevent.which = ( button & 1 ? 1 : ( button & 2 ? 3 : ( button & 4 ? 2 : 0 ) ) );\n\t\t\t}\n\n\t\t\treturn event;\n\t\t}\n\t},\n\n\tfix: function( event ) {\n\t\tif ( event[ jQuery.expando ] ) {\n\t\t\treturn event;\n\t\t}\n\n\t\t// Create a writable copy of the event object and normalize some properties\n\t\tvar i, prop, copy,\n\t\t\ttype = event.type,\n\t\t\toriginalEvent = event,\n\t\t\tfixHook = this.fixHooks[ type ];\n\n\t\tif ( !fixHook ) {\n\t\t\tthis.fixHooks[ type ] = fixHook =\n\t\t\t\trmouseEvent.test( type ) ? this.mouseHooks :\n\t\t\t\trkeyEvent.test( type ) ? this.keyHooks :\n\t\t\t\t{};\n\t\t}\n\t\tcopy = fixHook.props ? this.props.concat( fixHook.props ) : this.props;\n\n\t\tevent = new jQuery.Event( originalEvent );\n\n\t\ti = copy.length;\n\t\twhile ( i-- ) {\n\t\t\tprop = copy[ i ];\n\t\t\tevent[ prop ] = originalEvent[ prop ];\n\t\t}\n\n\t\t// Support: Cordova 2.5 (WebKit) (#13255)\n\t\t// All events should have a target; Cordova deviceready doesn't\n\t\tif ( !event.target ) {\n\t\t\tevent.target = document;\n\t\t}\n\n\t\t// Support: Safari 6.0+, Chrome<28\n\t\t// Target should not be a text node (#504, #13143)\n\t\tif ( event.target.nodeType === 3 ) {\n\t\t\tevent.target = event.target.parentNode;\n\t\t}\n\n\t\treturn fixHook.filter ? fixHook.filter( event, originalEvent ) : event;\n\t},\n\n\tspecial: {\n\t\tload: {\n\n\t\t\t// Prevent triggered image.load events from bubbling to window.load\n\t\t\tnoBubble: true\n\t\t},\n\t\tfocus: {\n\n\t\t\t// Fire native event if possible so blur/focus sequence is correct\n\t\t\ttrigger: function() {\n\t\t\t\tif ( this !== safeActiveElement() && this.focus ) {\n\t\t\t\t\tthis.focus();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t},\n\t\t\tdelegateType: \"focusin\"\n\t\t},\n\t\tblur: {\n\t\t\ttrigger: function() {\n\t\t\t\tif ( this === safeActiveElement() && this.blur ) {\n\t\t\t\t\tthis.blur();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t},\n\t\t\tdelegateType: \"focusout\"\n\t\t},\n\t\tclick: {\n\n\t\t\t// For checkbox, fire native event so checked state will be right\n\t\t\ttrigger: function() {\n\t\t\t\tif ( this.type === \"checkbox\" && this.click && jQuery.nodeName( this, \"input\" ) ) {\n\t\t\t\t\tthis.click();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t},\n\n\t\t\t// For cross-browser consistency, don't fire native .click() on links\n\t\t\t_default: function( event ) {\n\t\t\t\treturn jQuery.nodeName( event.target, \"a\" );\n\t\t\t}\n\t\t},\n\n\t\tbeforeunload: {\n\t\t\tpostDispatch: function( event ) {\n\n\t\t\t\t// Support: Firefox 20+\n\t\t\t\t// Firefox doesn't alert if the returnValue field is not set.\n\t\t\t\tif ( event.result !== undefined && event.originalEvent ) {\n\t\t\t\t\tevent.originalEvent.returnValue = event.result;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n};\n\njQuery.removeEvent = function( elem, type, handle ) {\n\n\t// This \"if\" is needed for plain objects\n\tif ( elem.removeEventListener ) {\n\t\telem.removeEventListener( type, handle );\n\t}\n};\n\njQuery.Event = function( src, props ) {\n\n\t// Allow instantiation without the 'new' keyword\n\tif ( !( this instanceof jQuery.Event ) ) {\n\t\treturn new jQuery.Event( src, props );\n\t}\n\n\t// Event object\n\tif ( src && src.type ) {\n\t\tthis.originalEvent = src;\n\t\tthis.type = src.type;\n\n\t\t// Events bubbling up the document may have been marked as prevented\n\t\t// by a handler lower down the tree; reflect the correct value.\n\t\tthis.isDefaultPrevented = src.defaultPrevented ||\n\t\t\t\tsrc.defaultPrevented === undefined &&\n\n\t\t\t\t// Support: Android<4.0\n\t\t\t\tsrc.returnValue === false ?\n\t\t\treturnTrue :\n\t\t\treturnFalse;\n\n\t// Event type\n\t} else {\n\t\tthis.type = src;\n\t}\n\n\t// Put explicitly provided properties onto the event object\n\tif ( props ) {\n\t\tjQuery.extend( this, props );\n\t}\n\n\t// Create a timestamp if incoming event doesn't have one\n\tthis.timeStamp = src && src.timeStamp || jQuery.now();\n\n\t// Mark it as fixed\n\tthis[ jQuery.expando ] = true;\n};\n\n// jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding\n// http://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html\njQuery.Event.prototype = {\n\tconstructor: jQuery.Event,\n\tisDefaultPrevented: returnFalse,\n\tisPropagationStopped: returnFalse,\n\tisImmediatePropagationStopped: returnFalse,\n\tisSimulated: false,\n\n\tpreventDefault: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isDefaultPrevented = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.preventDefault();\n\t\t}\n\t},\n\tstopPropagation: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isPropagationStopped = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.stopPropagation();\n\t\t}\n\t},\n\tstopImmediatePropagation: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isImmediatePropagationStopped = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.stopImmediatePropagation();\n\t\t}\n\n\t\tthis.stopPropagation();\n\t}\n};\n\n// Create mouseenter/leave events using mouseover/out and event-time checks\n// so that event delegation works in jQuery.\n// Do the same for pointerenter/pointerleave and pointerover/pointerout\n//\n// Support: Safari 7 only\n// Safari sends mouseenter too often; see:\n// https://code.google.com/p/chromium/issues/detail?id=470258\n// for the description of the bug (it existed in older Chrome versions as well).\njQuery.each( {\n\tmouseenter: \"mouseover\",\n\tmouseleave: \"mouseout\",\n\tpointerenter: \"pointerover\",\n\tpointerleave: \"pointerout\"\n}, function( orig, fix ) {\n\tjQuery.event.special[ orig ] = {\n\t\tdelegateType: fix,\n\t\tbindType: fix,\n\n\t\thandle: function( event ) {\n\t\t\tvar ret,\n\t\t\t\ttarget = this,\n\t\t\t\trelated = event.relatedTarget,\n\t\t\t\thandleObj = event.handleObj;\n\n\t\t\t// For mouseenter/leave call the handler if related is outside the target.\n\t\t\t// NB: No relatedTarget if the mouse left/entered the browser window\n\t\t\tif ( !related || ( related !== target && !jQuery.contains( target, related ) ) ) {\n\t\t\t\tevent.type = handleObj.origType;\n\t\t\t\tret = handleObj.handler.apply( this, arguments );\n\t\t\t\tevent.type = fix;\n\t\t\t}\n\t\t\treturn ret;\n\t\t}\n\t};\n} );\n\njQuery.fn.extend( {\n\ton: function( types, selector, data, fn ) {\n\t\treturn on( this, types, selector, data, fn );\n\t},\n\tone: function( types, selector, data, fn ) {\n\t\treturn on( this, types, selector, data, fn, 1 );\n\t},\n\toff: function( types, selector, fn ) {\n\t\tvar handleObj, type;\n\t\tif ( types && types.preventDefault && types.handleObj ) {\n\n\t\t\t// ( event ) dispatched jQuery.Event\n\t\t\thandleObj = types.handleObj;\n\t\t\tjQuery( types.delegateTarget ).off(\n\t\t\t\thandleObj.namespace ?\n\t\t\t\t\thandleObj.origType + \".\" + handleObj.namespace :\n\t\t\t\t\thandleObj.origType,\n\t\t\t\thandleObj.selector,\n\t\t\t\thandleObj.handler\n\t\t\t);\n\t\t\treturn this;\n\t\t}\n\t\tif ( typeof types === \"object\" ) {\n\n\t\t\t// ( types-object [, selector] )\n\t\t\tfor ( type in types ) {\n\t\t\t\tthis.off( type, selector, types[ type ] );\n\t\t\t}\n\t\t\treturn this;\n\t\t}\n\t\tif ( selector === false || typeof selector === \"function\" ) {\n\n\t\t\t// ( types [, fn] )\n\t\t\tfn = selector;\n\t\t\tselector = undefined;\n\t\t}\n\t\tif ( fn === false ) {\n\t\t\tfn = returnFalse;\n\t\t}\n\t\treturn this.each( function() {\n\t\t\tjQuery.event.remove( this, types, fn, selector );\n\t\t} );\n\t}\n} );\n\n\nvar\n\trxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\\w:-]+)[^>]*)\\/>/gi,\n\n\t// Support: IE 10-11, Edge 10240+\n\t// In IE/Edge using regex groups here causes severe slowdowns.\n\t// See https://connect.microsoft.com/IE/feedback/details/1736512/\n\trnoInnerhtml = /<script|<style|<link/i,\n\n\t// checked=\"checked\" or checked\n\trchecked = /checked\\s*(?:[^=]|=\\s*.checked.)/i,\n\trscriptTypeMasked = /^true\\/(.*)/,\n\trcleanScript = /^\\s*<!(?:\\[CDATA\\[|--)|(?:\\]\\]|--)>\\s*$/g;\n\n// Manipulating tables requires a tbody\nfunction manipulationTarget( elem, content ) {\n\treturn jQuery.nodeName( elem, \"table\" ) &&\n\t\tjQuery.nodeName( content.nodeType !== 11 ? content : content.firstChild, \"tr\" ) ?\n\n\t\telem.getElementsByTagName( \"tbody\" )[ 0 ] ||\n\t\t\telem.appendChild( elem.ownerDocument.createElement( \"tbody\" ) ) :\n\t\telem;\n}\n\n// Replace/restore the type attribute of script elements for safe DOM manipulation\nfunction disableScript( elem ) {\n\telem.type = ( elem.getAttribute( \"type\" ) !== null ) + \"/\" + elem.type;\n\treturn elem;\n}\nfunction restoreScript( elem ) {\n\tvar match = rscriptTypeMasked.exec( elem.type );\n\n\tif ( match ) {\n\t\telem.type = match[ 1 ];\n\t} else {\n\t\telem.removeAttribute( \"type\" );\n\t}\n\n\treturn elem;\n}\n\nfunction cloneCopyEvent( src, dest ) {\n\tvar i, l, type, pdataOld, pdataCur, udataOld, udataCur, events;\n\n\tif ( dest.nodeType !== 1 ) {\n\t\treturn;\n\t}\n\n\t// 1. Copy private data: events, handlers, etc.\n\tif ( dataPriv.hasData( src ) ) {\n\t\tpdataOld = dataPriv.access( src );\n\t\tpdataCur = dataPriv.set( dest, pdataOld );\n\t\tevents = pdataOld.events;\n\n\t\tif ( events ) {\n\t\t\tdelete pdataCur.handle;\n\t\t\tpdataCur.events = {};\n\n\t\t\tfor ( type in events ) {\n\t\t\t\tfor ( i = 0, l = events[ type ].length; i < l; i++ ) {\n\t\t\t\t\tjQuery.event.add( dest, type, events[ type ][ i ] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// 2. Copy user data\n\tif ( dataUser.hasData( src ) ) {\n\t\tudataOld = dataUser.access( src );\n\t\tudataCur = jQuery.extend( {}, udataOld );\n\n\t\tdataUser.set( dest, udataCur );\n\t}\n}\n\n// Fix IE bugs, see support tests\nfunction fixInput( src, dest ) {\n\tvar nodeName = dest.nodeName.toLowerCase();\n\n\t// Fails to persist the checked state of a cloned checkbox or radio button.\n\tif ( nodeName === \"input\" && rcheckableType.test( src.type ) ) {\n\t\tdest.checked = src.checked;\n\n\t// Fails to return the selected option to the default selected state when cloning options\n\t} else if ( nodeName === \"input\" || nodeName === \"textarea\" ) {\n\t\tdest.defaultValue = src.defaultValue;\n\t}\n}\n\nfunction domManip( collection, args, callback, ignored ) {\n\n\t// Flatten any nested arrays\n\targs = concat.apply( [], args );\n\n\tvar fragment, first, scripts, hasScripts, node, doc,\n\t\ti = 0,\n\t\tl = collection.length,\n\t\tiNoClone = l - 1,\n\t\tvalue = args[ 0 ],\n\t\tisFunction = jQuery.isFunction( value );\n\n\t// We can't cloneNode fragments that contain checked, in WebKit\n\tif ( isFunction ||\n\t\t\t( l > 1 && typeof value === \"string\" &&\n\t\t\t\t!support.checkClone && rchecked.test( value ) ) ) {\n\t\treturn collection.each( function( index ) {\n\t\t\tvar self = collection.eq( index );\n\t\t\tif ( isFunction ) {\n\t\t\t\targs[ 0 ] = value.call( this, index, self.html() );\n\t\t\t}\n\t\t\tdomManip( self, args, callback, ignored );\n\t\t} );\n\t}\n\n\tif ( l ) {\n\t\tfragment = buildFragment( args, collection[ 0 ].ownerDocument, false, collection, ignored );\n\t\tfirst = fragment.firstChild;\n\n\t\tif ( fragment.childNodes.length === 1 ) {\n\t\t\tfragment = first;\n\t\t}\n\n\t\t// Require either new content or an interest in ignored elements to invoke the callback\n\t\tif ( first || ignored ) {\n\t\t\tscripts = jQuery.map( getAll( fragment, \"script\" ), disableScript );\n\t\t\thasScripts = scripts.length;\n\n\t\t\t// Use the original fragment for the last item\n\t\t\t// instead of the first because it can end up\n\t\t\t// being emptied incorrectly in certain situations (#8070).\n\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\tnode = fragment;\n\n\t\t\t\tif ( i !== iNoClone ) {\n\t\t\t\t\tnode = jQuery.clone( node, true, true );\n\n\t\t\t\t\t// Keep references to cloned scripts for later restoration\n\t\t\t\t\tif ( hasScripts ) {\n\n\t\t\t\t\t\t// Support: Android<4.1, PhantomJS<2\n\t\t\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\t\t\tjQuery.merge( scripts, getAll( node, \"script\" ) );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tcallback.call( collection[ i ], node, i );\n\t\t\t}\n\n\t\t\tif ( hasScripts ) {\n\t\t\t\tdoc = scripts[ scripts.length - 1 ].ownerDocument;\n\n\t\t\t\t// Reenable scripts\n\t\t\t\tjQuery.map( scripts, restoreScript );\n\n\t\t\t\t// Evaluate executable scripts on first document insertion\n\t\t\t\tfor ( i = 0; i < hasScripts; i++ ) {\n\t\t\t\t\tnode = scripts[ i ];\n\t\t\t\t\tif ( rscriptType.test( node.type || \"\" ) &&\n\t\t\t\t\t\t!dataPriv.access( node, \"globalEval\" ) &&\n\t\t\t\t\t\tjQuery.contains( doc, node ) ) {\n\n\t\t\t\t\t\tif ( node.src ) {\n\n\t\t\t\t\t\t\t// Optional AJAX dependency, but won't run scripts if not present\n\t\t\t\t\t\t\tif ( jQuery._evalUrl ) {\n\t\t\t\t\t\t\t\tjQuery._evalUrl( node.src );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tjQuery.globalEval( node.textContent.replace( rcleanScript, \"\" ) );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn collection;\n}\n\nfunction remove( elem, selector, keepData ) {\n\tvar node,\n\t\tnodes = selector ? jQuery.filter( selector, elem ) : elem,\n\t\ti = 0;\n\n\tfor ( ; ( node = nodes[ i ] ) != null; i++ ) {\n\t\tif ( !keepData && node.nodeType === 1 ) {\n\t\t\tjQuery.cleanData( getAll( node ) );\n\t\t}\n\n\t\tif ( node.parentNode ) {\n\t\t\tif ( keepData && jQuery.contains( node.ownerDocument, node ) ) {\n\t\t\t\tsetGlobalEval( getAll( node, \"script\" ) );\n\t\t\t}\n\t\t\tnode.parentNode.removeChild( node );\n\t\t}\n\t}\n\n\treturn elem;\n}\n\njQuery.extend( {\n\thtmlPrefilter: function( html ) {\n\t\treturn html.replace( rxhtmlTag, \"<$1></$2>\" );\n\t},\n\n\tclone: function( elem, dataAndEvents, deepDataAndEvents ) {\n\t\tvar i, l, srcElements, destElements,\n\t\t\tclone = elem.cloneNode( true ),\n\t\t\tinPage = jQuery.contains( elem.ownerDocument, elem );\n\n\t\t// Fix IE cloning issues\n\t\tif ( !support.noCloneChecked && ( elem.nodeType === 1 || elem.nodeType === 11 ) &&\n\t\t\t\t!jQuery.isXMLDoc( elem ) ) {\n\n\t\t\t// We eschew Sizzle here for performance reasons: http://jsperf.com/getall-vs-sizzle/2\n\t\t\tdestElements = getAll( clone );\n\t\t\tsrcElements = getAll( elem );\n\n\t\t\tfor ( i = 0, l = srcElements.length; i < l; i++ ) {\n\t\t\t\tfixInput( srcElements[ i ], destElements[ i ] );\n\t\t\t}\n\t\t}\n\n\t\t// Copy the events from the original to the clone\n\t\tif ( dataAndEvents ) {\n\t\t\tif ( deepDataAndEvents ) {\n\t\t\t\tsrcElements = srcElements || getAll( elem );\n\t\t\t\tdestElements = destElements || getAll( clone );\n\n\t\t\t\tfor ( i = 0, l = srcElements.length; i < l; i++ ) {\n\t\t\t\t\tcloneCopyEvent( srcElements[ i ], destElements[ i ] );\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tcloneCopyEvent( elem, clone );\n\t\t\t}\n\t\t}\n\n\t\t// Preserve script evaluation history\n\t\tdestElements = getAll( clone, \"script\" );\n\t\tif ( destElements.length > 0 ) {\n\t\t\tsetGlobalEval( destElements, !inPage && getAll( elem, \"script\" ) );\n\t\t}\n\n\t\t// Return the cloned set\n\t\treturn clone;\n\t},\n\n\tcleanData: function( elems ) {\n\t\tvar data, elem, type,\n\t\t\tspecial = jQuery.event.special,\n\t\t\ti = 0;\n\n\t\tfor ( ; ( elem = elems[ i ] ) !== undefined; i++ ) {\n\t\t\tif ( acceptData( elem ) ) {\n\t\t\t\tif ( ( data = elem[ dataPriv.expando ] ) ) {\n\t\t\t\t\tif ( data.events ) {\n\t\t\t\t\t\tfor ( type in data.events ) {\n\t\t\t\t\t\t\tif ( special[ type ] ) {\n\t\t\t\t\t\t\t\tjQuery.event.remove( elem, type );\n\n\t\t\t\t\t\t\t// This is a shortcut to avoid jQuery.event.remove's overhead\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tjQuery.removeEvent( elem, type, data.handle );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Support: Chrome <= 35-45+\n\t\t\t\t\t// Assign undefined instead of using delete, see Data#remove\n\t\t\t\t\telem[ dataPriv.expando ] = undefined;\n\t\t\t\t}\n\t\t\t\tif ( elem[ dataUser.expando ] ) {\n\n\t\t\t\t\t// Support: Chrome <= 35-45+\n\t\t\t\t\t// Assign undefined instead of using delete, see Data#remove\n\t\t\t\t\telem[ dataUser.expando ] = undefined;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n} );\n\njQuery.fn.extend( {\n\n\t// Keep domManip exposed until 3.0 (gh-2225)\n\tdomManip: domManip,\n\n\tdetach: function( selector ) {\n\t\treturn remove( this, selector, true );\n\t},\n\n\tremove: function( selector ) {\n\t\treturn remove( this, selector );\n\t},\n\n\ttext: function( value ) {\n\t\treturn access( this, function( value ) {\n\t\t\treturn value === undefined ?\n\t\t\t\tjQuery.text( this ) :\n\t\t\t\tthis.empty().each( function() {\n\t\t\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\t\t\tthis.textContent = value;\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t}, null, value, arguments.length );\n\t},\n\n\tappend: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\tvar target = manipulationTarget( this, elem );\n\t\t\t\ttarget.appendChild( elem );\n\t\t\t}\n\t\t} );\n\t},\n\n\tprepend: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\tvar target = manipulationTarget( this, elem );\n\t\t\t\ttarget.insertBefore( elem, target.firstChild );\n\t\t\t}\n\t\t} );\n\t},\n\n\tbefore: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.parentNode ) {\n\t\t\t\tthis.parentNode.insertBefore( elem, this );\n\t\t\t}\n\t\t} );\n\t},\n\n\tafter: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.parentNode ) {\n\t\t\t\tthis.parentNode.insertBefore( elem, this.nextSibling );\n\t\t\t}\n\t\t} );\n\t},\n\n\tempty: function() {\n\t\tvar elem,\n\t\t\ti = 0;\n\n\t\tfor ( ; ( elem = this[ i ] ) != null; i++ ) {\n\t\t\tif ( elem.nodeType === 1 ) {\n\n\t\t\t\t// Prevent memory leaks\n\t\t\t\tjQuery.cleanData( getAll( elem, false ) );\n\n\t\t\t\t// Remove any remaining nodes\n\t\t\t\telem.textContent = \"\";\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\tclone: function( dataAndEvents, deepDataAndEvents ) {\n\t\tdataAndEvents = dataAndEvents == null ? false : dataAndEvents;\n\t\tdeepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents;\n\n\t\treturn this.map( function() {\n\t\t\treturn jQuery.clone( this, dataAndEvents, deepDataAndEvents );\n\t\t} );\n\t},\n\n\thtml: function( value ) {\n\t\treturn access( this, function( value ) {\n\t\t\tvar elem = this[ 0 ] || {},\n\t\t\t\ti = 0,\n\t\t\t\tl = this.length;\n\n\t\t\tif ( value === undefined && elem.nodeType === 1 ) {\n\t\t\t\treturn elem.innerHTML;\n\t\t\t}\n\n\t\t\t// See if we can take a shortcut and just use innerHTML\n\t\t\tif ( typeof value === \"string\" && !rnoInnerhtml.test( value ) &&\n\t\t\t\t!wrapMap[ ( rtagName.exec( value ) || [ \"\", \"\" ] )[ 1 ].toLowerCase() ] ) {\n\n\t\t\t\tvalue = jQuery.htmlPrefilter( value );\n\n\t\t\t\ttry {\n\t\t\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\t\t\telem = this[ i ] || {};\n\n\t\t\t\t\t\t// Remove element nodes and prevent memory leaks\n\t\t\t\t\t\tif ( elem.nodeType === 1 ) {\n\t\t\t\t\t\t\tjQuery.cleanData( getAll( elem, false ) );\n\t\t\t\t\t\t\telem.innerHTML = value;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\telem = 0;\n\n\t\t\t\t// If using innerHTML throws an exception, use the fallback method\n\t\t\t\t} catch ( e ) {}\n\t\t\t}\n\n\t\t\tif ( elem ) {\n\t\t\t\tthis.empty().append( value );\n\t\t\t}\n\t\t}, null, value, arguments.length );\n\t},\n\n\treplaceWith: function() {\n\t\tvar ignored = [];\n\n\t\t// Make the changes, replacing each non-ignored context element with the new content\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tvar parent = this.parentNode;\n\n\t\t\tif ( jQuery.inArray( this, ignored ) < 0 ) {\n\t\t\t\tjQuery.cleanData( getAll( this ) );\n\t\t\t\tif ( parent ) {\n\t\t\t\t\tparent.replaceChild( elem, this );\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Force callback invocation\n\t\t}, ignored );\n\t}\n} );\n\njQuery.each( {\n\tappendTo: \"append\",\n\tprependTo: \"prepend\",\n\tinsertBefore: \"before\",\n\tinsertAfter: \"after\",\n\treplaceAll: \"replaceWith\"\n}, function( name, original ) {\n\tjQuery.fn[ name ] = function( selector ) {\n\t\tvar elems,\n\t\t\tret = [],\n\t\t\tinsert = jQuery( selector ),\n\t\t\tlast = insert.length - 1,\n\t\t\ti = 0;\n\n\t\tfor ( ; i <= last; i++ ) {\n\t\t\telems = i === last ? this : this.clone( true );\n\t\t\tjQuery( insert[ i ] )[ original ]( elems );\n\n\t\t\t// Support: QtWebKit\n\t\t\t// .get() because push.apply(_, arraylike) throws\n\t\t\tpush.apply( ret, elems.get() );\n\t\t}\n\n\t\treturn this.pushStack( ret );\n\t};\n} );\n\n\nvar iframe,\n\telemdisplay = {\n\n\t\t// Support: Firefox\n\t\t// We have to pre-define these values for FF (#10227)\n\t\tHTML: \"block\",\n\t\tBODY: \"block\"\n\t};\n\n/**\n * Retrieve the actual display of a element\n * @param {String} name nodeName of the element\n * @param {Object} doc Document object\n */\n\n// Called only from within defaultDisplay\nfunction actualDisplay( name, doc ) {\n\tvar elem = jQuery( doc.createElement( name ) ).appendTo( doc.body ),\n\n\t\tdisplay = jQuery.css( elem[ 0 ], \"display\" );\n\n\t// We don't have any data stored on the element,\n\t// so use \"detach\" method as fast way to get rid of the element\n\telem.detach();\n\n\treturn display;\n}\n\n/**\n * Try to determine the default display value of an element\n * @param {String} nodeName\n */\nfunction defaultDisplay( nodeName ) {\n\tvar doc = document,\n\t\tdisplay = elemdisplay[ nodeName ];\n\n\tif ( !display ) {\n\t\tdisplay = actualDisplay( nodeName, doc );\n\n\t\t// If the simple way fails, read from inside an iframe\n\t\tif ( display === \"none\" || !display ) {\n\n\t\t\t// Use the already-created iframe if possible\n\t\t\tiframe = ( iframe || jQuery( \"<iframe frameborder='0' width='0' height='0'/>\" ) )\n\t\t\t\t.appendTo( doc.documentElement );\n\n\t\t\t// Always write a new HTML skeleton so Webkit and Firefox don't choke on reuse\n\t\t\tdoc = iframe[ 0 ].contentDocument;\n\n\t\t\t// Support: IE\n\t\t\tdoc.write();\n\t\t\tdoc.close();\n\n\t\t\tdisplay = actualDisplay( nodeName, doc );\n\t\t\tiframe.detach();\n\t\t}\n\n\t\t// Store the correct default display\n\t\telemdisplay[ nodeName ] = display;\n\t}\n\n\treturn display;\n}\nvar rmargin = ( /^margin/ );\n\nvar rnumnonpx = new RegExp( \"^(\" + pnum + \")(?!px)[a-z%]+$\", \"i\" );\n\nvar getStyles = function( elem ) {\n\n\t\t// Support: IE<=11+, Firefox<=30+ (#15098, #14150)\n\t\t// IE throws on elements created in popups\n\t\t// FF meanwhile throws on frame elements through \"defaultView.getComputedStyle\"\n\t\tvar view = elem.ownerDocument.defaultView;\n\n\t\tif ( !view || !view.opener ) {\n\t\t\tview = window;\n\t\t}\n\n\t\treturn view.getComputedStyle( elem );\n\t};\n\nvar swap = function( elem, options, callback, args ) {\n\tvar ret, name,\n\t\told = {};\n\n\t// Remember the old values, and insert the new ones\n\tfor ( name in options ) {\n\t\told[ name ] = elem.style[ name ];\n\t\telem.style[ name ] = options[ name ];\n\t}\n\n\tret = callback.apply( elem, args || [] );\n\n\t// Revert the old values\n\tfor ( name in options ) {\n\t\telem.style[ name ] = old[ name ];\n\t}\n\n\treturn ret;\n};\n\n\nvar documentElement = document.documentElement;\n\n\n\n( function() {\n\tvar pixelPositionVal, boxSizingReliableVal, pixelMarginRightVal, reliableMarginLeftVal,\n\t\tcontainer = document.createElement( \"div\" ),\n\t\tdiv = document.createElement( \"div\" );\n\n\t// Finish early in limited (non-browser) environments\n\tif ( !div.style ) {\n\t\treturn;\n\t}\n\n\t// Support: IE9-11+\n\t// Style of cloned element affects source element cloned (#8908)\n\tdiv.style.backgroundClip = \"content-box\";\n\tdiv.cloneNode( true ).style.backgroundClip = \"\";\n\tsupport.clearCloneStyle = div.style.backgroundClip === \"content-box\";\n\n\tcontainer.style.cssText = \"border:0;width:8px;height:0;top:0;left:-9999px;\" +\n\t\t\"padding:0;margin-top:1px;position:absolute\";\n\tcontainer.appendChild( div );\n\n\t// Executing both pixelPosition & boxSizingReliable tests require only one layout\n\t// so they're executed at the same time to save the second computation.\n\tfunction computeStyleTests() {\n\t\tdiv.style.cssText =\n\n\t\t\t// Support: Firefox<29, Android 2.3\n\t\t\t// Vendor-prefix box-sizing\n\t\t\t\"-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;\" +\n\t\t\t\"position:relative;display:block;\" +\n\t\t\t\"margin:auto;border:1px;padding:1px;\" +\n\t\t\t\"top:1%;width:50%\";\n\t\tdiv.innerHTML = \"\";\n\t\tdocumentElement.appendChild( container );\n\n\t\tvar divStyle = window.getComputedStyle( div );\n\t\tpixelPositionVal = divStyle.top !== \"1%\";\n\t\treliableMarginLeftVal = divStyle.marginLeft === \"2px\";\n\t\tboxSizingReliableVal = divStyle.width === \"4px\";\n\n\t\t// Support: Android 4.0 - 4.3 only\n\t\t// Some styles come back with percentage values, even though they shouldn't\n\t\tdiv.style.marginRight = \"50%\";\n\t\tpixelMarginRightVal = divStyle.marginRight === \"4px\";\n\n\t\tdocumentElement.removeChild( container );\n\t}\n\n\tjQuery.extend( support, {\n\t\tpixelPosition: function() {\n\n\t\t\t// This test is executed only once but we still do memoizing\n\t\t\t// since we can use the boxSizingReliable pre-computing.\n\t\t\t// No need to check if the test was already performed, though.\n\t\t\tcomputeStyleTests();\n\t\t\treturn pixelPositionVal;\n\t\t},\n\t\tboxSizingReliable: function() {\n\t\t\tif ( boxSizingReliableVal == null ) {\n\t\t\t\tcomputeStyleTests();\n\t\t\t}\n\t\t\treturn boxSizingReliableVal;\n\t\t},\n\t\tpixelMarginRight: function() {\n\n\t\t\t// Support: Android 4.0-4.3\n\t\t\t// We're checking for boxSizingReliableVal here instead of pixelMarginRightVal\n\t\t\t// since that compresses better and they're computed together anyway.\n\t\t\tif ( boxSizingReliableVal == null ) {\n\t\t\t\tcomputeStyleTests();\n\t\t\t}\n\t\t\treturn pixelMarginRightVal;\n\t\t},\n\t\treliableMarginLeft: function() {\n\n\t\t\t// Support: IE <=8 only, Android 4.0 - 4.3 only, Firefox <=3 - 37\n\t\t\tif ( boxSizingReliableVal == null ) {\n\t\t\t\tcomputeStyleTests();\n\t\t\t}\n\t\t\treturn reliableMarginLeftVal;\n\t\t},\n\t\treliableMarginRight: function() {\n\n\t\t\t// Support: Android 2.3\n\t\t\t// Check if div with explicit width and no margin-right incorrectly\n\t\t\t// gets computed margin-right based on width of container. (#3333)\n\t\t\t// WebKit Bug 13343 - getComputedStyle returns wrong value for margin-right\n\t\t\t// This support function is only executed once so no memoizing is needed.\n\t\t\tvar ret,\n\t\t\t\tmarginDiv = div.appendChild( document.createElement( \"div\" ) );\n\n\t\t\t// Reset CSS: box-sizing; display; margin; border; padding\n\t\t\tmarginDiv.style.cssText = div.style.cssText =\n\n\t\t\t\t// Support: Android 2.3\n\t\t\t\t// Vendor-prefix box-sizing\n\t\t\t\t\"-webkit-box-sizing:content-box;box-sizing:content-box;\" +\n\t\t\t\t\"display:block;margin:0;border:0;padding:0\";\n\t\t\tmarginDiv.style.marginRight = marginDiv.style.width = \"0\";\n\t\t\tdiv.style.width = \"1px\";\n\t\t\tdocumentElement.appendChild( container );\n\n\t\t\tret = !parseFloat( window.getComputedStyle( marginDiv ).marginRight );\n\n\t\t\tdocumentElement.removeChild( container );\n\t\t\tdiv.removeChild( marginDiv );\n\n\t\t\treturn ret;\n\t\t}\n\t} );\n} )();\n\n\nfunction curCSS( elem, name, computed ) {\n\tvar width, minWidth, maxWidth, ret,\n\t\tstyle = elem.style;\n\n\tcomputed = computed || getStyles( elem );\n\tret = computed ? computed.getPropertyValue( name ) || computed[ name ] : undefined;\n\n\t// Support: Opera 12.1x only\n\t// Fall back to style even without computed\n\t// computed is undefined for elems on document fragments\n\tif ( ( ret === \"\" || ret === undefined ) && !jQuery.contains( elem.ownerDocument, elem ) ) {\n\t\tret = jQuery.style( elem, name );\n\t}\n\n\t// Support: IE9\n\t// getPropertyValue is only needed for .css('filter') (#12537)\n\tif ( computed ) {\n\n\t\t// A tribute to the \"awesome hack by Dean Edwards\"\n\t\t// Android Browser returns percentage for some values,\n\t\t// but width seems to be reliably pixels.\n\t\t// This is against the CSSOM draft spec:\n\t\t// http://dev.w3.org/csswg/cssom/#resolved-values\n\t\tif ( !support.pixelMarginRight() && rnumnonpx.test( ret ) && rmargin.test( name ) ) {\n\n\t\t\t// Remember the original values\n\t\t\twidth = style.width;\n\t\t\tminWidth = style.minWidth;\n\t\t\tmaxWidth = style.maxWidth;\n\n\t\t\t// Put in the new values to get a computed value out\n\t\t\tstyle.minWidth = style.maxWidth = style.width = ret;\n\t\t\tret = computed.width;\n\n\t\t\t// Revert the changed values\n\t\t\tstyle.width = width;\n\t\t\tstyle.minWidth = minWidth;\n\t\t\tstyle.maxWidth = maxWidth;\n\t\t}\n\t}\n\n\treturn ret !== undefined ?\n\n\t\t// Support: IE9-11+\n\t\t// IE returns zIndex value as an integer.\n\t\tret + \"\" :\n\t\tret;\n}\n\n\nfunction addGetHookIf( conditionFn, hookFn ) {\n\n\t// Define the hook, we'll check on the first run if it's really needed.\n\treturn {\n\t\tget: function() {\n\t\t\tif ( conditionFn() ) {\n\n\t\t\t\t// Hook not needed (or it's not possible to use it due\n\t\t\t\t// to missing dependency), remove it.\n\t\t\t\tdelete this.get;\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Hook needed; redefine it so that the support test is not executed again.\n\t\t\treturn ( this.get = hookFn ).apply( this, arguments );\n\t\t}\n\t};\n}\n\n\nvar\n\n\t// Swappable if display is none or starts with table\n\t// except \"table\", \"table-cell\", or \"table-caption\"\n\t// See here for display values: https://developer.mozilla.org/en-US/docs/CSS/display\n\trdisplayswap = /^(none|table(?!-c[ea]).+)/,\n\n\tcssShow = { position: \"absolute\", visibility: \"hidden\", display: \"block\" },\n\tcssNormalTransform = {\n\t\tletterSpacing: \"0\",\n\t\tfontWeight: \"400\"\n\t},\n\n\tcssPrefixes = [ \"Webkit\", \"O\", \"Moz\", \"ms\" ],\n\temptyStyle = document.createElement( \"div\" ).style;\n\n// Return a css property mapped to a potentially vendor prefixed property\nfunction vendorPropName( name ) {\n\n\t// Shortcut for names that are not vendor prefixed\n\tif ( name in emptyStyle ) {\n\t\treturn name;\n\t}\n\n\t// Check for vendor prefixed names\n\tvar capName = name[ 0 ].toUpperCase() + name.slice( 1 ),\n\t\ti = cssPrefixes.length;\n\n\twhile ( i-- ) {\n\t\tname = cssPrefixes[ i ] + capName;\n\t\tif ( name in emptyStyle ) {\n\t\t\treturn name;\n\t\t}\n\t}\n}\n\nfunction setPositiveNumber( elem, value, subtract ) {\n\n\t// Any relative (+/-) values have already been\n\t// normalized at this point\n\tvar matches = rcssNum.exec( value );\n\treturn matches ?\n\n\t\t// Guard against undefined \"subtract\", e.g., when used as in cssHooks\n\t\tMath.max( 0, matches[ 2 ] - ( subtract || 0 ) ) + ( matches[ 3 ] || \"px\" ) :\n\t\tvalue;\n}\n\nfunction augmentWidthOrHeight( elem, name, extra, isBorderBox, styles ) {\n\tvar i = extra === ( isBorderBox ? \"border\" : \"content\" ) ?\n\n\t\t// If we already have the right measurement, avoid augmentation\n\t\t4 :\n\n\t\t// Otherwise initialize for horizontal or vertical properties\n\t\tname === \"width\" ? 1 : 0,\n\n\t\tval = 0;\n\n\tfor ( ; i < 4; i += 2 ) {\n\n\t\t// Both box models exclude margin, so add it if we want it\n\t\tif ( extra === \"margin\" ) {\n\t\t\tval += jQuery.css( elem, extra + cssExpand[ i ], true, styles );\n\t\t}\n\n\t\tif ( isBorderBox ) {\n\n\t\t\t// border-box includes padding, so remove it if we want content\n\t\t\tif ( extra === \"content\" ) {\n\t\t\t\tval -= jQuery.css( elem, \"padding\" + cssExpand[ i ], true, styles );\n\t\t\t}\n\n\t\t\t// At this point, extra isn't border nor margin, so remove border\n\t\t\tif ( extra !== \"margin\" ) {\n\t\t\t\tval -= jQuery.css( elem, \"border\" + cssExpand[ i ] + \"Width\", true, styles );\n\t\t\t}\n\t\t} else {\n\n\t\t\t// At this point, extra isn't content, so add padding\n\t\t\tval += jQuery.css( elem, \"padding\" + cssExpand[ i ], true, styles );\n\n\t\t\t// At this point, extra isn't content nor padding, so add border\n\t\t\tif ( extra !== \"padding\" ) {\n\t\t\t\tval += jQuery.css( elem, \"border\" + cssExpand[ i ] + \"Width\", true, styles );\n\t\t\t}\n\t\t}\n\t}\n\n\treturn val;\n}\n\nfunction getWidthOrHeight( elem, name, extra ) {\n\n\t// Start with offset property, which is equivalent to the border-box value\n\tvar valueIsBorderBox = true,\n\t\tval = name === \"width\" ? elem.offsetWidth : elem.offsetHeight,\n\t\tstyles = getStyles( elem ),\n\t\tisBorderBox = jQuery.css( elem, \"boxSizing\", false, styles ) === \"border-box\";\n\n\t// Some non-html elements return undefined for offsetWidth, so check for null/undefined\n\t// svg - https://bugzilla.mozilla.org/show_bug.cgi?id=649285\n\t// MathML - https://bugzilla.mozilla.org/show_bug.cgi?id=491668\n\tif ( val <= 0 || val == null ) {\n\n\t\t// Fall back to computed then uncomputed css if necessary\n\t\tval = curCSS( elem, name, styles );\n\t\tif ( val < 0 || val == null ) {\n\t\t\tval = elem.style[ name ];\n\t\t}\n\n\t\t// Computed unit is not pixels. Stop here and return.\n\t\tif ( rnumnonpx.test( val ) ) {\n\t\t\treturn val;\n\t\t}\n\n\t\t// Check for style in case a browser which returns unreliable values\n\t\t// for getComputedStyle silently falls back to the reliable elem.style\n\t\tvalueIsBorderBox = isBorderBox &&\n\t\t\t( support.boxSizingReliable() || val === elem.style[ name ] );\n\n\t\t// Normalize \"\", auto, and prepare for extra\n\t\tval = parseFloat( val ) || 0;\n\t}\n\n\t// Use the active box-sizing model to add/subtract irrelevant styles\n\treturn ( val +\n\t\taugmentWidthOrHeight(\n\t\t\telem,\n\t\t\tname,\n\t\t\textra || ( isBorderBox ? \"border\" : \"content\" ),\n\t\t\tvalueIsBorderBox,\n\t\t\tstyles\n\t\t)\n\t) + \"px\";\n}\n\nfunction showHide( elements, show ) {\n\tvar display, elem, hidden,\n\t\tvalues = [],\n\t\tindex = 0,\n\t\tlength = elements.length;\n\n\tfor ( ; index < length; index++ ) {\n\t\telem = elements[ index ];\n\t\tif ( !elem.style ) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tvalues[ index ] = dataPriv.get( elem, \"olddisplay\" );\n\t\tdisplay = elem.style.display;\n\t\tif ( show ) {\n\n\t\t\t// Reset the inline display of this element to learn if it is\n\t\t\t// being hidden by cascaded rules or not\n\t\t\tif ( !values[ index ] && display === \"none\" ) {\n\t\t\t\telem.style.display = \"\";\n\t\t\t}\n\n\t\t\t// Set elements which have been overridden with display: none\n\t\t\t// in a stylesheet to whatever the default browser style is\n\t\t\t// for such an element\n\t\t\tif ( elem.style.display === \"\" && isHidden( elem ) ) {\n\t\t\t\tvalues[ index ] = dataPriv.access(\n\t\t\t\t\telem,\n\t\t\t\t\t\"olddisplay\",\n\t\t\t\t\tdefaultDisplay( elem.nodeName )\n\t\t\t\t);\n\t\t\t}\n\t\t} else {\n\t\t\thidden = isHidden( elem );\n\n\t\t\tif ( display !== \"none\" || !hidden ) {\n\t\t\t\tdataPriv.set(\n\t\t\t\t\telem,\n\t\t\t\t\t\"olddisplay\",\n\t\t\t\t\thidden ? display : jQuery.css( elem, \"display\" )\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\n\t// Set the display of most of the elements in a second loop\n\t// to avoid the constant reflow\n\tfor ( index = 0; index < length; index++ ) {\n\t\telem = elements[ index ];\n\t\tif ( !elem.style ) {\n\t\t\tcontinue;\n\t\t}\n\t\tif ( !show || elem.style.display === \"none\" || elem.style.display === \"\" ) {\n\t\t\telem.style.display = show ? values[ index ] || \"\" : \"none\";\n\t\t}\n\t}\n\n\treturn elements;\n}\n\njQuery.extend( {\n\n\t// Add in style property hooks for overriding the default\n\t// behavior of getting and setting a style property\n\tcssHooks: {\n\t\topacity: {\n\t\t\tget: function( elem, computed ) {\n\t\t\t\tif ( computed ) {\n\n\t\t\t\t\t// We should always get a number back from opacity\n\t\t\t\t\tvar ret = curCSS( elem, \"opacity\" );\n\t\t\t\t\treturn ret === \"\" ? \"1\" : ret;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\t// Don't automatically add \"px\" to these possibly-unitless properties\n\tcssNumber: {\n\t\t\"animationIterationCount\": true,\n\t\t\"columnCount\": true,\n\t\t\"fillOpacity\": true,\n\t\t\"flexGrow\": true,\n\t\t\"flexShrink\": true,\n\t\t\"fontWeight\": true,\n\t\t\"lineHeight\": true,\n\t\t\"opacity\": true,\n\t\t\"order\": true,\n\t\t\"orphans\": true,\n\t\t\"widows\": true,\n\t\t\"zIndex\": true,\n\t\t\"zoom\": true\n\t},\n\n\t// Add in properties whose names you wish to fix before\n\t// setting or getting the value\n\tcssProps: {\n\t\t\"float\": \"cssFloat\"\n\t},\n\n\t// Get and set the style property on a DOM Node\n\tstyle: function( elem, name, value, extra ) {\n\n\t\t// Don't set styles on text and comment nodes\n\t\tif ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Make sure that we're working with the right name\n\t\tvar ret, type, hooks,\n\t\t\torigName = jQuery.camelCase( name ),\n\t\t\tstyle = elem.style;\n\n\t\tname = jQuery.cssProps[ origName ] ||\n\t\t\t( jQuery.cssProps[ origName ] = vendorPropName( origName ) || origName );\n\n\t\t// Gets hook for the prefixed version, then unprefixed version\n\t\thooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];\n\n\t\t// Check if we're setting a value\n\t\tif ( value !== undefined ) {\n\t\t\ttype = typeof value;\n\n\t\t\t// Convert \"+=\" or \"-=\" to relative numbers (#7345)\n\t\t\tif ( type === \"string\" && ( ret = rcssNum.exec( value ) ) && ret[ 1 ] ) {\n\t\t\t\tvalue = adjustCSS( elem, name, ret );\n\n\t\t\t\t// Fixes bug #9237\n\t\t\t\ttype = \"number\";\n\t\t\t}\n\n\t\t\t// Make sure that null and NaN values aren't set (#7116)\n\t\t\tif ( value == null || value !== value ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// If a number was passed in, add the unit (except for certain CSS properties)\n\t\t\tif ( type === \"number\" ) {\n\t\t\t\tvalue += ret && ret[ 3 ] || ( jQuery.cssNumber[ origName ] ? \"\" : \"px\" );\n\t\t\t}\n\n\t\t\t// Support: IE9-11+\n\t\t\t// background-* props affect original clone's values\n\t\t\tif ( !support.clearCloneStyle && value === \"\" && name.indexOf( \"background\" ) === 0 ) {\n\t\t\t\tstyle[ name ] = \"inherit\";\n\t\t\t}\n\n\t\t\t// If a hook was provided, use that value, otherwise just set the specified value\n\t\t\tif ( !hooks || !( \"set\" in hooks ) ||\n\t\t\t\t( value = hooks.set( elem, value, extra ) ) !== undefined ) {\n\n\t\t\t\tstyle[ name ] = value;\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t// If a hook was provided get the non-computed value from there\n\t\t\tif ( hooks && \"get\" in hooks &&\n\t\t\t\t( ret = hooks.get( elem, false, extra ) ) !== undefined ) {\n\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\t// Otherwise just get the value from the style object\n\t\t\treturn style[ name ];\n\t\t}\n\t},\n\n\tcss: function( elem, name, extra, styles ) {\n\t\tvar val, num, hooks,\n\t\t\torigName = jQuery.camelCase( name );\n\n\t\t// Make sure that we're working with the right name\n\t\tname = jQuery.cssProps[ origName ] ||\n\t\t\t( jQuery.cssProps[ origName ] = vendorPropName( origName ) || origName );\n\n\t\t// Try prefixed name followed by the unprefixed name\n\t\thooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];\n\n\t\t// If a hook was provided get the computed value from there\n\t\tif ( hooks && \"get\" in hooks ) {\n\t\t\tval = hooks.get( elem, true, extra );\n\t\t}\n\n\t\t// Otherwise, if a way to get the computed value exists, use that\n\t\tif ( val === undefined ) {\n\t\t\tval = curCSS( elem, name, styles );\n\t\t}\n\n\t\t// Convert \"normal\" to computed value\n\t\tif ( val === \"normal\" && name in cssNormalTransform ) {\n\t\t\tval = cssNormalTransform[ name ];\n\t\t}\n\n\t\t// Make numeric if forced or a qualifier was provided and val looks numeric\n\t\tif ( extra === \"\" || extra ) {\n\t\t\tnum = parseFloat( val );\n\t\t\treturn extra === true || isFinite( num ) ? num || 0 : val;\n\t\t}\n\t\treturn val;\n\t}\n} );\n\njQuery.each( [ \"height\", \"width\" ], function( i, name ) {\n\tjQuery.cssHooks[ name ] = {\n\t\tget: function( elem, computed, extra ) {\n\t\t\tif ( computed ) {\n\n\t\t\t\t// Certain elements can have dimension info if we invisibly show them\n\t\t\t\t// but it must have a current display style that would benefit\n\t\t\t\treturn rdisplayswap.test( jQuery.css( elem, \"display\" ) ) &&\n\t\t\t\t\telem.offsetWidth === 0 ?\n\t\t\t\t\t\tswap( elem, cssShow, function() {\n\t\t\t\t\t\t\treturn getWidthOrHeight( elem, name, extra );\n\t\t\t\t\t\t} ) :\n\t\t\t\t\t\tgetWidthOrHeight( elem, name, extra );\n\t\t\t}\n\t\t},\n\n\t\tset: function( elem, value, extra ) {\n\t\t\tvar matches,\n\t\t\t\tstyles = extra && getStyles( elem ),\n\t\t\t\tsubtract = extra && augmentWidthOrHeight(\n\t\t\t\t\telem,\n\t\t\t\t\tname,\n\t\t\t\t\textra,\n\t\t\t\t\tjQuery.css( elem, \"boxSizing\", false, styles ) === \"border-box\",\n\t\t\t\t\tstyles\n\t\t\t\t);\n\n\t\t\t// Convert to pixels if value adjustment is needed\n\t\t\tif ( subtract && ( matches = rcssNum.exec( value ) ) &&\n\t\t\t\t( matches[ 3 ] || \"px\" ) !== \"px\" ) {\n\n\t\t\t\telem.style[ name ] = value;\n\t\t\t\tvalue = jQuery.css( elem, name );\n\t\t\t}\n\n\t\t\treturn setPositiveNumber( elem, value, subtract );\n\t\t}\n\t};\n} );\n\njQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft,\n\tfunction( elem, computed ) {\n\t\tif ( computed ) {\n\t\t\treturn ( parseFloat( curCSS( elem, \"marginLeft\" ) ) ||\n\t\t\t\telem.getBoundingClientRect().left -\n\t\t\t\t\tswap( elem, { marginLeft: 0 }, function() {\n\t\t\t\t\t\treturn elem.getBoundingClientRect().left;\n\t\t\t\t\t} )\n\t\t\t\t) + \"px\";\n\t\t}\n\t}\n);\n\n// Support: Android 2.3\njQuery.cssHooks.marginRight = addGetHookIf( support.reliableMarginRight,\n\tfunction( elem, computed ) {\n\t\tif ( computed ) {\n\t\t\treturn swap( elem, { \"display\": \"inline-block\" },\n\t\t\t\tcurCSS, [ elem, \"marginRight\" ] );\n\t\t}\n\t}\n);\n\n// These hooks are used by animate to expand properties\njQuery.each( {\n\tmargin: \"\",\n\tpadding: \"\",\n\tborder: \"Width\"\n}, function( prefix, suffix ) {\n\tjQuery.cssHooks[ prefix + suffix ] = {\n\t\texpand: function( value ) {\n\t\t\tvar i = 0,\n\t\t\t\texpanded = {},\n\n\t\t\t\t// Assumes a single number if not a string\n\t\t\t\tparts = typeof value === \"string\" ? value.split( \" \" ) : [ value ];\n\n\t\t\tfor ( ; i < 4; i++ ) {\n\t\t\t\texpanded[ prefix + cssExpand[ i ] + suffix ] =\n\t\t\t\t\tparts[ i ] || parts[ i - 2 ] || parts[ 0 ];\n\t\t\t}\n\n\t\t\treturn expanded;\n\t\t}\n\t};\n\n\tif ( !rmargin.test( prefix ) ) {\n\t\tjQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber;\n\t}\n} );\n\njQuery.fn.extend( {\n\tcss: function( name, value ) {\n\t\treturn access( this, function( elem, name, value ) {\n\t\t\tvar styles, len,\n\t\t\t\tmap = {},\n\t\t\t\ti = 0;\n\n\t\t\tif ( jQuery.isArray( name ) ) {\n\t\t\t\tstyles = getStyles( elem );\n\t\t\t\tlen = name.length;\n\n\t\t\t\tfor ( ; i < len; i++ ) {\n\t\t\t\t\tmap[ name[ i ] ] = jQuery.css( elem, name[ i ], false, styles );\n\t\t\t\t}\n\n\t\t\t\treturn map;\n\t\t\t}\n\n\t\t\treturn value !== undefined ?\n\t\t\t\tjQuery.style( elem, name, value ) :\n\t\t\t\tjQuery.css( elem, name );\n\t\t}, name, value, arguments.length > 1 );\n\t},\n\tshow: function() {\n\t\treturn showHide( this, true );\n\t},\n\thide: function() {\n\t\treturn showHide( this );\n\t},\n\ttoggle: function( state ) {\n\t\tif ( typeof state === \"boolean\" ) {\n\t\t\treturn state ? this.show() : this.hide();\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tif ( isHidden( this ) ) {\n\t\t\t\tjQuery( this ).show();\n\t\t\t} else {\n\t\t\t\tjQuery( this ).hide();\n\t\t\t}\n\t\t} );\n\t}\n} );\n\n\nfunction Tween( elem, options, prop, end, easing ) {\n\treturn new Tween.prototype.init( elem, options, prop, end, easing );\n}\njQuery.Tween = Tween;\n\nTween.prototype = {\n\tconstructor: Tween,\n\tinit: function( elem, options, prop, end, easing, unit ) {\n\t\tthis.elem = elem;\n\t\tthis.prop = prop;\n\t\tthis.easing = easing || jQuery.easing._default;\n\t\tthis.options = options;\n\t\tthis.start = this.now = this.cur();\n\t\tthis.end = end;\n\t\tthis.unit = unit || ( jQuery.cssNumber[ prop ] ? \"\" : \"px\" );\n\t},\n\tcur: function() {\n\t\tvar hooks = Tween.propHooks[ this.prop ];\n\n\t\treturn hooks && hooks.get ?\n\t\t\thooks.get( this ) :\n\t\t\tTween.propHooks._default.get( this );\n\t},\n\trun: function( percent ) {\n\t\tvar eased,\n\t\t\thooks = Tween.propHooks[ this.prop ];\n\n\t\tif ( this.options.duration ) {\n\t\t\tthis.pos = eased = jQuery.easing[ this.easing ](\n\t\t\t\tpercent, this.options.duration * percent, 0, 1, this.options.duration\n\t\t\t);\n\t\t} else {\n\t\t\tthis.pos = eased = percent;\n\t\t}\n\t\tthis.now = ( this.end - this.start ) * eased + this.start;\n\n\t\tif ( this.options.step ) {\n\t\t\tthis.options.step.call( this.elem, this.now, this );\n\t\t}\n\n\t\tif ( hooks && hooks.set ) {\n\t\t\thooks.set( this );\n\t\t} else {\n\t\t\tTween.propHooks._default.set( this );\n\t\t}\n\t\treturn this;\n\t}\n};\n\nTween.prototype.init.prototype = Tween.prototype;\n\nTween.propHooks = {\n\t_default: {\n\t\tget: function( tween ) {\n\t\t\tvar result;\n\n\t\t\t// Use a property on the element directly when it is not a DOM element,\n\t\t\t// or when there is no matching style property that exists.\n\t\t\tif ( tween.elem.nodeType !== 1 ||\n\t\t\t\ttween.elem[ tween.prop ] != null && tween.elem.style[ tween.prop ] == null ) {\n\t\t\t\treturn tween.elem[ tween.prop ];\n\t\t\t}\n\n\t\t\t// Passing an empty string as a 3rd parameter to .css will automatically\n\t\t\t// attempt a parseFloat and fallback to a string if the parse fails.\n\t\t\t// Simple values such as \"10px\" are parsed to Float;\n\t\t\t// complex values such as \"rotate(1rad)\" are returned as-is.\n\t\t\tresult = jQuery.css( tween.elem, tween.prop, \"\" );\n\n\t\t\t// Empty strings, null, undefined and \"auto\" are converted to 0.\n\t\t\treturn !result || result === \"auto\" ? 0 : result;\n\t\t},\n\t\tset: function( tween ) {\n\n\t\t\t// Use step hook for back compat.\n\t\t\t// Use cssHook if its there.\n\t\t\t// Use .style if available and use plain properties where available.\n\t\t\tif ( jQuery.fx.step[ tween.prop ] ) {\n\t\t\t\tjQuery.fx.step[ tween.prop ]( tween );\n\t\t\t} else if ( tween.elem.nodeType === 1 &&\n\t\t\t\t( tween.elem.style[ jQuery.cssProps[ tween.prop ] ] != null ||\n\t\t\t\t\tjQuery.cssHooks[ tween.prop ] ) ) {\n\t\t\t\tjQuery.style( tween.elem, tween.prop, tween.now + tween.unit );\n\t\t\t} else {\n\t\t\t\ttween.elem[ tween.prop ] = tween.now;\n\t\t\t}\n\t\t}\n\t}\n};\n\n// Support: IE9\n// Panic based approach to setting things on disconnected nodes\nTween.propHooks.scrollTop = Tween.propHooks.scrollLeft = {\n\tset: function( tween ) {\n\t\tif ( tween.elem.nodeType && tween.elem.parentNode ) {\n\t\t\ttween.elem[ tween.prop ] = tween.now;\n\t\t}\n\t}\n};\n\njQuery.easing = {\n\tlinear: function( p ) {\n\t\treturn p;\n\t},\n\tswing: function( p ) {\n\t\treturn 0.5 - Math.cos( p * Math.PI ) / 2;\n\t},\n\t_default: \"swing\"\n};\n\njQuery.fx = Tween.prototype.init;\n\n// Back Compat <1.8 extension point\njQuery.fx.step = {};\n\n\n\n\nvar\n\tfxNow, timerId,\n\trfxtypes = /^(?:toggle|show|hide)$/,\n\trrun = /queueHooks$/;\n\n// Animations created synchronously will run synchronously\nfunction createFxNow() {\n\twindow.setTimeout( function() {\n\t\tfxNow = undefined;\n\t} );\n\treturn ( fxNow = jQuery.now() );\n}\n\n// Generate parameters to create a standard animation\nfunction genFx( type, includeWidth ) {\n\tvar which,\n\t\ti = 0,\n\t\tattrs = { height: type };\n\n\t// If we include width, step value is 1 to do all cssExpand values,\n\t// otherwise step value is 2 to skip over Left and Right\n\tincludeWidth = includeWidth ? 1 : 0;\n\tfor ( ; i < 4 ; i += 2 - includeWidth ) {\n\t\twhich = cssExpand[ i ];\n\t\tattrs[ \"margin\" + which ] = attrs[ \"padding\" + which ] = type;\n\t}\n\n\tif ( includeWidth ) {\n\t\tattrs.opacity = attrs.width = type;\n\t}\n\n\treturn attrs;\n}\n\nfunction createTween( value, prop, animation ) {\n\tvar tween,\n\t\tcollection = ( Animation.tweeners[ prop ] || [] ).concat( Animation.tweeners[ \"*\" ] ),\n\t\tindex = 0,\n\t\tlength = collection.length;\n\tfor ( ; index < length; index++ ) {\n\t\tif ( ( tween = collection[ index ].call( animation, prop, value ) ) ) {\n\n\t\t\t// We're done with this property\n\t\t\treturn tween;\n\t\t}\n\t}\n}\n\nfunction defaultPrefilter( elem, props, opts ) {\n\t/* jshint validthis: true */\n\tvar prop, value, toggle, tween, hooks, oldfire, display, checkDisplay,\n\t\tanim = this,\n\t\torig = {},\n\t\tstyle = elem.style,\n\t\thidden = elem.nodeType && isHidden( elem ),\n\t\tdataShow = dataPriv.get( elem, \"fxshow\" );\n\n\t// Handle queue: false promises\n\tif ( !opts.queue ) {\n\t\thooks = jQuery._queueHooks( elem, \"fx\" );\n\t\tif ( hooks.unqueued == null ) {\n\t\t\thooks.unqueued = 0;\n\t\t\toldfire = hooks.empty.fire;\n\t\t\thooks.empty.fire = function() {\n\t\t\t\tif ( !hooks.unqueued ) {\n\t\t\t\t\toldfire();\n\t\t\t\t}\n\t\t\t};\n\t\t}\n\t\thooks.unqueued++;\n\n\t\tanim.always( function() {\n\n\t\t\t// Ensure the complete handler is called before this completes\n\t\t\tanim.always( function() {\n\t\t\t\thooks.unqueued--;\n\t\t\t\tif ( !jQuery.queue( elem, \"fx\" ).length ) {\n\t\t\t\t\thooks.empty.fire();\n\t\t\t\t}\n\t\t\t} );\n\t\t} );\n\t}\n\n\t// Height/width overflow pass\n\tif ( elem.nodeType === 1 && ( \"height\" in props || \"width\" in props ) ) {\n\n\t\t// Make sure that nothing sneaks out\n\t\t// Record all 3 overflow attributes because IE9-10 do not\n\t\t// change the overflow attribute when overflowX and\n\t\t// overflowY are set to the same value\n\t\topts.overflow = [ style.overflow, style.overflowX, style.overflowY ];\n\n\t\t// Set display property to inline-block for height/width\n\t\t// animations on inline elements that are having width/height animated\n\t\tdisplay = jQuery.css( elem, \"display\" );\n\n\t\t// Test default display if display is currently \"none\"\n\t\tcheckDisplay = display === \"none\" ?\n\t\t\tdataPriv.get( elem, \"olddisplay\" ) || defaultDisplay( elem.nodeName ) : display;\n\n\t\tif ( checkDisplay === \"inline\" && jQuery.css( elem, \"float\" ) === \"none\" ) {\n\t\t\tstyle.display = \"inline-block\";\n\t\t}\n\t}\n\n\tif ( opts.overflow ) {\n\t\tstyle.overflow = \"hidden\";\n\t\tanim.always( function() {\n\t\t\tstyle.overflow = opts.overflow[ 0 ];\n\t\t\tstyle.overflowX = opts.overflow[ 1 ];\n\t\t\tstyle.overflowY = opts.overflow[ 2 ];\n\t\t} );\n\t}\n\n\t// show/hide pass\n\tfor ( prop in props ) {\n\t\tvalue = props[ prop ];\n\t\tif ( rfxtypes.exec( value ) ) {\n\t\t\tdelete props[ prop ];\n\t\t\ttoggle = toggle || value === \"toggle\";\n\t\t\tif ( value === ( hidden ? \"hide\" : \"show\" ) ) {\n\n\t\t\t\t// If there is dataShow left over from a stopped hide or show\n\t\t\t\t// and we are going to proceed with show, we should pretend to be hidden\n\t\t\t\tif ( value === \"show\" && dataShow && dataShow[ prop ] !== undefined ) {\n\t\t\t\t\thidden = true;\n\t\t\t\t} else {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t}\n\t\t\torig[ prop ] = dataShow && dataShow[ prop ] || jQuery.style( elem, prop );\n\n\t\t// Any non-fx value stops us from restoring the original display value\n\t\t} else {\n\t\t\tdisplay = undefined;\n\t\t}\n\t}\n\n\tif ( !jQuery.isEmptyObject( orig ) ) {\n\t\tif ( dataShow ) {\n\t\t\tif ( \"hidden\" in dataShow ) {\n\t\t\t\thidden = dataShow.hidden;\n\t\t\t}\n\t\t} else {\n\t\t\tdataShow = dataPriv.access( elem, \"fxshow\", {} );\n\t\t}\n\n\t\t// Store state if its toggle - enables .stop().toggle() to \"reverse\"\n\t\tif ( toggle ) {\n\t\t\tdataShow.hidden = !hidden;\n\t\t}\n\t\tif ( hidden ) {\n\t\t\tjQuery( elem ).show();\n\t\t} else {\n\t\t\tanim.done( function() {\n\t\t\t\tjQuery( elem ).hide();\n\t\t\t} );\n\t\t}\n\t\tanim.done( function() {\n\t\t\tvar prop;\n\n\t\t\tdataPriv.remove( elem, \"fxshow\" );\n\t\t\tfor ( prop in orig ) {\n\t\t\t\tjQuery.style( elem, prop, orig[ prop ] );\n\t\t\t}\n\t\t} );\n\t\tfor ( prop in orig ) {\n\t\t\ttween = createTween( hidden ? dataShow[ prop ] : 0, prop, anim );\n\n\t\t\tif ( !( prop in dataShow ) ) {\n\t\t\t\tdataShow[ prop ] = tween.start;\n\t\t\t\tif ( hidden ) {\n\t\t\t\t\ttween.end = tween.start;\n\t\t\t\t\ttween.start = prop === \"width\" || prop === \"height\" ? 1 : 0;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t// If this is a noop like .hide().hide(), restore an overwritten display value\n\t} else if ( ( display === \"none\" ? defaultDisplay( elem.nodeName ) : display ) === \"inline\" ) {\n\t\tstyle.display = display;\n\t}\n}\n\nfunction propFilter( props, specialEasing ) {\n\tvar index, name, easing, value, hooks;\n\n\t// camelCase, specialEasing and expand cssHook pass\n\tfor ( index in props ) {\n\t\tname = jQuery.camelCase( index );\n\t\teasing = specialEasing[ name ];\n\t\tvalue = props[ index ];\n\t\tif ( jQuery.isArray( value ) ) {\n\t\t\teasing = value[ 1 ];\n\t\t\tvalue = props[ index ] = value[ 0 ];\n\t\t}\n\n\t\tif ( index !== name ) {\n\t\t\tprops[ name ] = value;\n\t\t\tdelete props[ index ];\n\t\t}\n\n\t\thooks = jQuery.cssHooks[ name ];\n\t\tif ( hooks && \"expand\" in hooks ) {\n\t\t\tvalue = hooks.expand( value );\n\t\t\tdelete props[ name ];\n\n\t\t\t// Not quite $.extend, this won't overwrite existing keys.\n\t\t\t// Reusing 'index' because we have the correct \"name\"\n\t\t\tfor ( index in value ) {\n\t\t\t\tif ( !( index in props ) ) {\n\t\t\t\t\tprops[ index ] = value[ index ];\n\t\t\t\t\tspecialEasing[ index ] = easing;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tspecialEasing[ name ] = easing;\n\t\t}\n\t}\n}\n\nfunction Animation( elem, properties, options ) {\n\tvar result,\n\t\tstopped,\n\t\tindex = 0,\n\t\tlength = Animation.prefilters.length,\n\t\tdeferred = jQuery.Deferred().always( function() {\n\n\t\t\t// Don't match elem in the :animated selector\n\t\t\tdelete tick.elem;\n\t\t} ),\n\t\ttick = function() {\n\t\t\tif ( stopped ) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tvar currentTime = fxNow || createFxNow(),\n\t\t\t\tremaining = Math.max( 0, animation.startTime + animation.duration - currentTime ),\n\n\t\t\t\t// Support: Android 2.3\n\t\t\t\t// Archaic crash bug won't allow us to use `1 - ( 0.5 || 0 )` (#12497)\n\t\t\t\ttemp = remaining / animation.duration || 0,\n\t\t\t\tpercent = 1 - temp,\n\t\t\t\tindex = 0,\n\t\t\t\tlength = animation.tweens.length;\n\n\t\t\tfor ( ; index < length ; index++ ) {\n\t\t\t\tanimation.tweens[ index ].run( percent );\n\t\t\t}\n\n\t\t\tdeferred.notifyWith( elem, [ animation, percent, remaining ] );\n\n\t\t\tif ( percent < 1 && length ) {\n\t\t\t\treturn remaining;\n\t\t\t} else {\n\t\t\t\tdeferred.resolveWith( elem, [ animation ] );\n\t\t\t\treturn false;\n\t\t\t}\n\t\t},\n\t\tanimation = deferred.promise( {\n\t\t\telem: elem,\n\t\t\tprops: jQuery.extend( {}, properties ),\n\t\t\topts: jQuery.extend( true, {\n\t\t\t\tspecialEasing: {},\n\t\t\t\teasing: jQuery.easing._default\n\t\t\t}, options ),\n\t\t\toriginalProperties: properties,\n\t\t\toriginalOptions: options,\n\t\t\tstartTime: fxNow || createFxNow(),\n\t\t\tduration: options.duration,\n\t\t\ttweens: [],\n\t\t\tcreateTween: function( prop, end ) {\n\t\t\t\tvar tween = jQuery.Tween( elem, animation.opts, prop, end,\n\t\t\t\t\t\tanimation.opts.specialEasing[ prop ] || animation.opts.easing );\n\t\t\t\tanimation.tweens.push( tween );\n\t\t\t\treturn tween;\n\t\t\t},\n\t\t\tstop: function( gotoEnd ) {\n\t\t\t\tvar index = 0,\n\n\t\t\t\t\t// If we are going to the end, we want to run all the tweens\n\t\t\t\t\t// otherwise we skip this part\n\t\t\t\t\tlength = gotoEnd ? animation.tweens.length : 0;\n\t\t\t\tif ( stopped ) {\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t\tstopped = true;\n\t\t\t\tfor ( ; index < length ; index++ ) {\n\t\t\t\t\tanimation.tweens[ index ].run( 1 );\n\t\t\t\t}\n\n\t\t\t\t// Resolve when we played the last frame; otherwise, reject\n\t\t\t\tif ( gotoEnd ) {\n\t\t\t\t\tdeferred.notifyWith( elem, [ animation, 1, 0 ] );\n\t\t\t\t\tdeferred.resolveWith( elem, [ animation, gotoEnd ] );\n\t\t\t\t} else {\n\t\t\t\t\tdeferred.rejectWith( elem, [ animation, gotoEnd ] );\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t}\n\t\t} ),\n\t\tprops = animation.props;\n\n\tpropFilter( props, animation.opts.specialEasing );\n\n\tfor ( ; index < length ; index++ ) {\n\t\tresult = Animation.prefilters[ index ].call( animation, elem, props, animation.opts );\n\t\tif ( result ) {\n\t\t\tif ( jQuery.isFunction( result.stop ) ) {\n\t\t\t\tjQuery._queueHooks( animation.elem, animation.opts.queue ).stop =\n\t\t\t\t\tjQuery.proxy( result.stop, result );\n\t\t\t}\n\t\t\treturn result;\n\t\t}\n\t}\n\n\tjQuery.map( props, createTween, animation );\n\n\tif ( jQuery.isFunction( animation.opts.start ) ) {\n\t\tanimation.opts.start.call( elem, animation );\n\t}\n\n\tjQuery.fx.timer(\n\t\tjQuery.extend( tick, {\n\t\t\telem: elem,\n\t\t\tanim: animation,\n\t\t\tqueue: animation.opts.queue\n\t\t} )\n\t);\n\n\t// attach callbacks from options\n\treturn animation.progress( animation.opts.progress )\n\t\t.done( animation.opts.done, animation.opts.complete )\n\t\t.fail( animation.opts.fail )\n\t\t.always( animation.opts.always );\n}\n\njQuery.Animation = jQuery.extend( Animation, {\n\ttweeners: {\n\t\t\"*\": [ function( prop, value ) {\n\t\t\tvar tween = this.createTween( prop, value );\n\t\t\tadjustCSS( tween.elem, prop, rcssNum.exec( value ), tween );\n\t\t\treturn tween;\n\t\t} ]\n\t},\n\n\ttweener: function( props, callback ) {\n\t\tif ( jQuery.isFunction( props ) ) {\n\t\t\tcallback = props;\n\t\t\tprops = [ \"*\" ];\n\t\t} else {\n\t\t\tprops = props.match( rnotwhite );\n\t\t}\n\n\t\tvar prop,\n\t\t\tindex = 0,\n\t\t\tlength = props.length;\n\n\t\tfor ( ; index < length ; index++ ) {\n\t\t\tprop = props[ index ];\n\t\t\tAnimation.tweeners[ prop ] = Animation.tweeners[ prop ] || [];\n\t\t\tAnimation.tweeners[ prop ].unshift( callback );\n\t\t}\n\t},\n\n\tprefilters: [ defaultPrefilter ],\n\n\tprefilter: function( callback, prepend ) {\n\t\tif ( prepend ) {\n\t\t\tAnimation.prefilters.unshift( callback );\n\t\t} else {\n\t\t\tAnimation.prefilters.push( callback );\n\t\t}\n\t}\n} );\n\njQuery.speed = function( speed, easing, fn ) {\n\tvar opt = speed && typeof speed === \"object\" ? jQuery.extend( {}, speed ) : {\n\t\tcomplete: fn || !fn && easing ||\n\t\t\tjQuery.isFunction( speed ) && speed,\n\t\tduration: speed,\n\t\teasing: fn && easing || easing && !jQuery.isFunction( easing ) && easing\n\t};\n\n\topt.duration = jQuery.fx.off ? 0 : typeof opt.duration === \"number\" ?\n\t\topt.duration : opt.duration in jQuery.fx.speeds ?\n\t\t\tjQuery.fx.speeds[ opt.duration ] : jQuery.fx.speeds._default;\n\n\t// Normalize opt.queue - true/undefined/null -> \"fx\"\n\tif ( opt.queue == null || opt.queue === true ) {\n\t\topt.queue = \"fx\";\n\t}\n\n\t// Queueing\n\topt.old = opt.complete;\n\n\topt.complete = function() {\n\t\tif ( jQuery.isFunction( opt.old ) ) {\n\t\t\topt.old.call( this );\n\t\t}\n\n\t\tif ( opt.queue ) {\n\t\t\tjQuery.dequeue( this, opt.queue );\n\t\t}\n\t};\n\n\treturn opt;\n};\n\njQuery.fn.extend( {\n\tfadeTo: function( speed, to, easing, callback ) {\n\n\t\t// Show any hidden elements after setting opacity to 0\n\t\treturn this.filter( isHidden ).css( \"opacity\", 0 ).show()\n\n\t\t\t// Animate to the value specified\n\t\t\t.end().animate( { opacity: to }, speed, easing, callback );\n\t},\n\tanimate: function( prop, speed, easing, callback ) {\n\t\tvar empty = jQuery.isEmptyObject( prop ),\n\t\t\toptall = jQuery.speed( speed, easing, callback ),\n\t\t\tdoAnimation = function() {\n\n\t\t\t\t// Operate on a copy of prop so per-property easing won't be lost\n\t\t\t\tvar anim = Animation( this, jQuery.extend( {}, prop ), optall );\n\n\t\t\t\t// Empty animations, or finishing resolves immediately\n\t\t\t\tif ( empty || dataPriv.get( this, \"finish\" ) ) {\n\t\t\t\t\tanim.stop( true );\n\t\t\t\t}\n\t\t\t};\n\t\t\tdoAnimation.finish = doAnimation;\n\n\t\treturn empty || optall.queue === false ?\n\t\t\tthis.each( doAnimation ) :\n\t\t\tthis.queue( optall.queue, doAnimation );\n\t},\n\tstop: function( type, clearQueue, gotoEnd ) {\n\t\tvar stopQueue = function( hooks ) {\n\t\t\tvar stop = hooks.stop;\n\t\t\tdelete hooks.stop;\n\t\t\tstop( gotoEnd );\n\t\t};\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tgotoEnd = clearQueue;\n\t\t\tclearQueue = type;\n\t\t\ttype = undefined;\n\t\t}\n\t\tif ( clearQueue && type !== false ) {\n\t\t\tthis.queue( type || \"fx\", [] );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar dequeue = true,\n\t\t\t\tindex = type != null && type + \"queueHooks\",\n\t\t\t\ttimers = jQuery.timers,\n\t\t\t\tdata = dataPriv.get( this );\n\n\t\t\tif ( index ) {\n\t\t\t\tif ( data[ index ] && data[ index ].stop ) {\n\t\t\t\t\tstopQueue( data[ index ] );\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tfor ( index in data ) {\n\t\t\t\t\tif ( data[ index ] && data[ index ].stop && rrun.test( index ) ) {\n\t\t\t\t\t\tstopQueue( data[ index ] );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfor ( index = timers.length; index--; ) {\n\t\t\t\tif ( timers[ index ].elem === this &&\n\t\t\t\t\t( type == null || timers[ index ].queue === type ) ) {\n\n\t\t\t\t\ttimers[ index ].anim.stop( gotoEnd );\n\t\t\t\t\tdequeue = false;\n\t\t\t\t\ttimers.splice( index, 1 );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Start the next in the queue if the last step wasn't forced.\n\t\t\t// Timers currently will call their complete callbacks, which\n\t\t\t// will dequeue but only if they were gotoEnd.\n\t\t\tif ( dequeue || !gotoEnd ) {\n\t\t\t\tjQuery.dequeue( this, type );\n\t\t\t}\n\t\t} );\n\t},\n\tfinish: function( type ) {\n\t\tif ( type !== false ) {\n\t\t\ttype = type || \"fx\";\n\t\t}\n\t\treturn this.each( function() {\n\t\t\tvar index,\n\t\t\t\tdata = dataPriv.get( this ),\n\t\t\t\tqueue = data[ type + \"queue\" ],\n\t\t\t\thooks = data[ type + \"queueHooks\" ],\n\t\t\t\ttimers = jQuery.timers,\n\t\t\t\tlength = queue ? queue.length : 0;\n\n\t\t\t// Enable finishing flag on private data\n\t\t\tdata.finish = true;\n\n\t\t\t// Empty the queue first\n\t\t\tjQuery.queue( this, type, [] );\n\n\t\t\tif ( hooks && hooks.stop ) {\n\t\t\t\thooks.stop.call( this, true );\n\t\t\t}\n\n\t\t\t// Look for any active animations, and finish them\n\t\t\tfor ( index = timers.length; index--; ) {\n\t\t\t\tif ( timers[ index ].elem === this && timers[ index ].queue === type ) {\n\t\t\t\t\ttimers[ index ].anim.stop( true );\n\t\t\t\t\ttimers.splice( index, 1 );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Look for any animations in the old queue and finish them\n\t\t\tfor ( index = 0; index < length; index++ ) {\n\t\t\t\tif ( queue[ index ] && queue[ index ].finish ) {\n\t\t\t\t\tqueue[ index ].finish.call( this );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Turn off finishing flag\n\t\t\tdelete data.finish;\n\t\t} );\n\t}\n} );\n\njQuery.each( [ \"toggle\", \"show\", \"hide\" ], function( i, name ) {\n\tvar cssFn = jQuery.fn[ name ];\n\tjQuery.fn[ name ] = function( speed, easing, callback ) {\n\t\treturn speed == null || typeof speed === \"boolean\" ?\n\t\t\tcssFn.apply( this, arguments ) :\n\t\t\tthis.animate( genFx( name, true ), speed, easing, callback );\n\t};\n} );\n\n// Generate shortcuts for custom animations\njQuery.each( {\n\tslideDown: genFx( \"show\" ),\n\tslideUp: genFx( \"hide\" ),\n\tslideToggle: genFx( \"toggle\" ),\n\tfadeIn: { opacity: \"show\" },\n\tfadeOut: { opacity: \"hide\" },\n\tfadeToggle: { opacity: \"toggle\" }\n}, function( name, props ) {\n\tjQuery.fn[ name ] = function( speed, easing, callback ) {\n\t\treturn this.animate( props, speed, easing, callback );\n\t};\n} );\n\njQuery.timers = [];\njQuery.fx.tick = function() {\n\tvar timer,\n\t\ti = 0,\n\t\ttimers = jQuery.timers;\n\n\tfxNow = jQuery.now();\n\n\tfor ( ; i < timers.length; i++ ) {\n\t\ttimer = timers[ i ];\n\n\t\t// Checks the timer has not already been removed\n\t\tif ( !timer() && timers[ i ] === timer ) {\n\t\t\ttimers.splice( i--, 1 );\n\t\t}\n\t}\n\n\tif ( !timers.length ) {\n\t\tjQuery.fx.stop();\n\t}\n\tfxNow = undefined;\n};\n\njQuery.fx.timer = function( timer ) {\n\tjQuery.timers.push( timer );\n\tif ( timer() ) {\n\t\tjQuery.fx.start();\n\t} else {\n\t\tjQuery.timers.pop();\n\t}\n};\n\njQuery.fx.interval = 13;\njQuery.fx.start = function() {\n\tif ( !timerId ) {\n\t\ttimerId = window.setInterval( jQuery.fx.tick, jQuery.fx.interval );\n\t}\n};\n\njQuery.fx.stop = function() {\n\twindow.clearInterval( timerId );\n\n\ttimerId = null;\n};\n\njQuery.fx.speeds = {\n\tslow: 600,\n\tfast: 200,\n\n\t// Default speed\n\t_default: 400\n};\n\n\n// Based off of the plugin by Clint Helfers, with permission.\n// http://web.archive.org/web/20100324014747/http://blindsignals.com/index.php/2009/07/jquery-delay/\njQuery.fn.delay = function( time, type ) {\n\ttime = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time;\n\ttype = type || \"fx\";\n\n\treturn this.queue( type, function( next, hooks ) {\n\t\tvar timeout = window.setTimeout( next, time );\n\t\thooks.stop = function() {\n\t\t\twindow.clearTimeout( timeout );\n\t\t};\n\t} );\n};\n\n\n( function() {\n\tvar input = document.createElement( \"input\" ),\n\t\tselect = document.createElement( \"select\" ),\n\t\topt = select.appendChild( document.createElement( \"option\" ) );\n\n\tinput.type = \"checkbox\";\n\n\t// Support: iOS<=5.1, Android<=4.2+\n\t// Default value for a checkbox should be \"on\"\n\tsupport.checkOn = input.value !== \"\";\n\n\t// Support: IE<=11+\n\t// Must access selectedIndex to make default options select\n\tsupport.optSelected = opt.selected;\n\n\t// Support: Android<=2.3\n\t// Options inside disabled selects are incorrectly marked as disabled\n\tselect.disabled = true;\n\tsupport.optDisabled = !opt.disabled;\n\n\t// Support: IE<=11+\n\t// An input loses its value after becoming a radio\n\tinput = document.createElement( \"input\" );\n\tinput.value = \"t\";\n\tinput.type = \"radio\";\n\tsupport.radioValue = input.value === \"t\";\n} )();\n\n\nvar boolHook,\n\tattrHandle = jQuery.expr.attrHandle;\n\njQuery.fn.extend( {\n\tattr: function( name, value ) {\n\t\treturn access( this, jQuery.attr, name, value, arguments.length > 1 );\n\t},\n\n\tremoveAttr: function( name ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.removeAttr( this, name );\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tattr: function( elem, name, value ) {\n\t\tvar ret, hooks,\n\t\t\tnType = elem.nodeType;\n\n\t\t// Don't get/set attributes on text, comment and attribute nodes\n\t\tif ( nType === 3 || nType === 8 || nType === 2 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Fallback to prop when attributes are not supported\n\t\tif ( typeof elem.getAttribute === \"undefined\" ) {\n\t\t\treturn jQuery.prop( elem, name, value );\n\t\t}\n\n\t\t// All attributes are lowercase\n\t\t// Grab necessary hook if one is defined\n\t\tif ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {\n\t\t\tname = name.toLowerCase();\n\t\t\thooks = jQuery.attrHooks[ name ] ||\n\t\t\t\t( jQuery.expr.match.bool.test( name ) ? boolHook : undefined );\n\t\t}\n\n\t\tif ( value !== undefined ) {\n\t\t\tif ( value === null ) {\n\t\t\t\tjQuery.removeAttr( elem, name );\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif ( hooks && \"set\" in hooks &&\n\t\t\t\t( ret = hooks.set( elem, value, name ) ) !== undefined ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\telem.setAttribute( name, value + \"\" );\n\t\t\treturn value;\n\t\t}\n\n\t\tif ( hooks && \"get\" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {\n\t\t\treturn ret;\n\t\t}\n\n\t\tret = jQuery.find.attr( elem, name );\n\n\t\t// Non-existent attributes return null, we normalize to undefined\n\t\treturn ret == null ? undefined : ret;\n\t},\n\n\tattrHooks: {\n\t\ttype: {\n\t\t\tset: function( elem, value ) {\n\t\t\t\tif ( !support.radioValue && value === \"radio\" &&\n\t\t\t\t\tjQuery.nodeName( elem, \"input\" ) ) {\n\t\t\t\t\tvar val = elem.value;\n\t\t\t\t\telem.setAttribute( \"type\", value );\n\t\t\t\t\tif ( val ) {\n\t\t\t\t\t\telem.value = val;\n\t\t\t\t\t}\n\t\t\t\t\treturn value;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\tremoveAttr: function( elem, value ) {\n\t\tvar name, propName,\n\t\t\ti = 0,\n\t\t\tattrNames = value && value.match( rnotwhite );\n\n\t\tif ( attrNames && elem.nodeType === 1 ) {\n\t\t\twhile ( ( name = attrNames[ i++ ] ) ) {\n\t\t\t\tpropName = jQuery.propFix[ name ] || name;\n\n\t\t\t\t// Boolean attributes get special treatment (#10870)\n\t\t\t\tif ( jQuery.expr.match.bool.test( name ) ) {\n\n\t\t\t\t\t// Set corresponding property to false\n\t\t\t\t\telem[ propName ] = false;\n\t\t\t\t}\n\n\t\t\t\telem.removeAttribute( name );\n\t\t\t}\n\t\t}\n\t}\n} );\n\n// Hooks for boolean attributes\nboolHook = {\n\tset: function( elem, value, name ) {\n\t\tif ( value === false ) {\n\n\t\t\t// Remove boolean attributes when set to false\n\t\t\tjQuery.removeAttr( elem, name );\n\t\t} else {\n\t\t\telem.setAttribute( name, name );\n\t\t}\n\t\treturn name;\n\t}\n};\njQuery.each( jQuery.expr.match.bool.source.match( /\\w+/g ), function( i, name ) {\n\tvar getter = attrHandle[ name ] || jQuery.find.attr;\n\n\tattrHandle[ name ] = function( elem, name, isXML ) {\n\t\tvar ret, handle;\n\t\tif ( !isXML ) {\n\n\t\t\t// Avoid an infinite loop by temporarily removing this function from the getter\n\t\t\thandle = attrHandle[ name ];\n\t\t\tattrHandle[ name ] = ret;\n\t\t\tret = getter( elem, name, isXML ) != null ?\n\t\t\t\tname.toLowerCase() :\n\t\t\t\tnull;\n\t\t\tattrHandle[ name ] = handle;\n\t\t}\n\t\treturn ret;\n\t};\n} );\n\n\n\n\nvar rfocusable = /^(?:input|select|textarea|button)$/i,\n\trclickable = /^(?:a|area)$/i;\n\njQuery.fn.extend( {\n\tprop: function( name, value ) {\n\t\treturn access( this, jQuery.prop, name, value, arguments.length > 1 );\n\t},\n\n\tremoveProp: function( name ) {\n\t\treturn this.each( function() {\n\t\t\tdelete this[ jQuery.propFix[ name ] || name ];\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tprop: function( elem, name, value ) {\n\t\tvar ret, hooks,\n\t\t\tnType = elem.nodeType;\n\n\t\t// Don't get/set properties on text, comment and attribute nodes\n\t\tif ( nType === 3 || nType === 8 || nType === 2 ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {\n\n\t\t\t// Fix name and attach hooks\n\t\t\tname = jQuery.propFix[ name ] || name;\n\t\t\thooks = jQuery.propHooks[ name ];\n\t\t}\n\n\t\tif ( value !== undefined ) {\n\t\t\tif ( hooks && \"set\" in hooks &&\n\t\t\t\t( ret = hooks.set( elem, value, name ) ) !== undefined ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\treturn ( elem[ name ] = value );\n\t\t}\n\n\t\tif ( hooks && \"get\" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {\n\t\t\treturn ret;\n\t\t}\n\n\t\treturn elem[ name ];\n\t},\n\n\tpropHooks: {\n\t\ttabIndex: {\n\t\t\tget: function( elem ) {\n\n\t\t\t\t// elem.tabIndex doesn't always return the\n\t\t\t\t// correct value when it hasn't been explicitly set\n\t\t\t\t// http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/\n\t\t\t\t// Use proper attribute retrieval(#12072)\n\t\t\t\tvar tabindex = jQuery.find.attr( elem, \"tabindex\" );\n\n\t\t\t\treturn tabindex ?\n\t\t\t\t\tparseInt( tabindex, 10 ) :\n\t\t\t\t\trfocusable.test( elem.nodeName ) ||\n\t\t\t\t\t\trclickable.test( elem.nodeName ) && elem.href ?\n\t\t\t\t\t\t\t0 :\n\t\t\t\t\t\t\t-1;\n\t\t\t}\n\t\t}\n\t},\n\n\tpropFix: {\n\t\t\"for\": \"htmlFor\",\n\t\t\"class\": \"className\"\n\t}\n} );\n\n// Support: IE <=11 only\n// Accessing the selectedIndex property\n// forces the browser to respect setting selected\n// on the option\n// The getter ensures a default option is selected\n// when in an optgroup\nif ( !support.optSelected ) {\n\tjQuery.propHooks.selected = {\n\t\tget: function( elem ) {\n\t\t\tvar parent = elem.parentNode;\n\t\t\tif ( parent && parent.parentNode ) {\n\t\t\t\tparent.parentNode.selectedIndex;\n\t\t\t}\n\t\t\treturn null;\n\t\t},\n\t\tset: function( elem ) {\n\t\t\tvar parent = elem.parentNode;\n\t\t\tif ( parent ) {\n\t\t\t\tparent.selectedIndex;\n\n\t\t\t\tif ( parent.parentNode ) {\n\t\t\t\t\tparent.parentNode.selectedIndex;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n}\n\njQuery.each( [\n\t\"tabIndex\",\n\t\"readOnly\",\n\t\"maxLength\",\n\t\"cellSpacing\",\n\t\"cellPadding\",\n\t\"rowSpan\",\n\t\"colSpan\",\n\t\"useMap\",\n\t\"frameBorder\",\n\t\"contentEditable\"\n], function() {\n\tjQuery.propFix[ this.toLowerCase() ] = this;\n} );\n\n\n\n\nvar rclass = /[\\t\\r\\n\\f]/g;\n\nfunction getClass( elem ) {\n\treturn elem.getAttribute && elem.getAttribute( \"class\" ) || \"\";\n}\n\njQuery.fn.extend( {\n\taddClass: function( value ) {\n\t\tvar classes, elem, cur, curValue, clazz, j, finalValue,\n\t\t\ti = 0;\n\n\t\tif ( jQuery.isFunction( value ) ) {\n\t\t\treturn this.each( function( j ) {\n\t\t\t\tjQuery( this ).addClass( value.call( this, j, getClass( this ) ) );\n\t\t\t} );\n\t\t}\n\n\t\tif ( typeof value === \"string\" && value ) {\n\t\t\tclasses = value.match( rnotwhite ) || [];\n\n\t\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\t\tcurValue = getClass( elem );\n\t\t\t\tcur = elem.nodeType === 1 &&\n\t\t\t\t\t( \" \" + curValue + \" \" ).replace( rclass, \" \" );\n\n\t\t\t\tif ( cur ) {\n\t\t\t\t\tj = 0;\n\t\t\t\t\twhile ( ( clazz = classes[ j++ ] ) ) {\n\t\t\t\t\t\tif ( cur.indexOf( \" \" + clazz + \" \" ) < 0 ) {\n\t\t\t\t\t\t\tcur += clazz + \" \";\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Only assign if different to avoid unneeded rendering.\n\t\t\t\t\tfinalValue = jQuery.trim( cur );\n\t\t\t\t\tif ( curValue !== finalValue ) {\n\t\t\t\t\t\telem.setAttribute( \"class\", finalValue );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\tremoveClass: function( value ) {\n\t\tvar classes, elem, cur, curValue, clazz, j, finalValue,\n\t\t\ti = 0;\n\n\t\tif ( jQuery.isFunction( value ) ) {\n\t\t\treturn this.each( function( j ) {\n\t\t\t\tjQuery( this ).removeClass( value.call( this, j, getClass( this ) ) );\n\t\t\t} );\n\t\t}\n\n\t\tif ( !arguments.length ) {\n\t\t\treturn this.attr( \"class\", \"\" );\n\t\t}\n\n\t\tif ( typeof value === \"string\" && value ) {\n\t\t\tclasses = value.match( rnotwhite ) || [];\n\n\t\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\t\tcurValue = getClass( elem );\n\n\t\t\t\t// This expression is here for better compressibility (see addClass)\n\t\t\t\tcur = elem.nodeType === 1 &&\n\t\t\t\t\t( \" \" + curValue + \" \" ).replace( rclass, \" \" );\n\n\t\t\t\tif ( cur ) {\n\t\t\t\t\tj = 0;\n\t\t\t\t\twhile ( ( clazz = classes[ j++ ] ) ) {\n\n\t\t\t\t\t\t// Remove *all* instances\n\t\t\t\t\t\twhile ( cur.indexOf( \" \" + clazz + \" \" ) > -1 ) {\n\t\t\t\t\t\t\tcur = cur.replace( \" \" + clazz + \" \", \" \" );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Only assign if different to avoid unneeded rendering.\n\t\t\t\t\tfinalValue = jQuery.trim( cur );\n\t\t\t\t\tif ( curValue !== finalValue ) {\n\t\t\t\t\t\telem.setAttribute( \"class\", finalValue );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\ttoggleClass: function( value, stateVal ) {\n\t\tvar type = typeof value;\n\n\t\tif ( typeof stateVal === \"boolean\" && type === \"string\" ) {\n\t\t\treturn stateVal ? this.addClass( value ) : this.removeClass( value );\n\t\t}\n\n\t\tif ( jQuery.isFunction( value ) ) {\n\t\t\treturn this.each( function( i ) {\n\t\t\t\tjQuery( this ).toggleClass(\n\t\t\t\t\tvalue.call( this, i, getClass( this ), stateVal ),\n\t\t\t\t\tstateVal\n\t\t\t\t);\n\t\t\t} );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar className, i, self, classNames;\n\n\t\t\tif ( type === \"string\" ) {\n\n\t\t\t\t// Toggle individual class names\n\t\t\t\ti = 0;\n\t\t\t\tself = jQuery( this );\n\t\t\t\tclassNames = value.match( rnotwhite ) || [];\n\n\t\t\t\twhile ( ( className = classNames[ i++ ] ) ) {\n\n\t\t\t\t\t// Check each className given, space separated list\n\t\t\t\t\tif ( self.hasClass( className ) ) {\n\t\t\t\t\t\tself.removeClass( className );\n\t\t\t\t\t} else {\n\t\t\t\t\t\tself.addClass( className );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t// Toggle whole class name\n\t\t\t} else if ( value === undefined || type === \"boolean\" ) {\n\t\t\t\tclassName = getClass( this );\n\t\t\t\tif ( className ) {\n\n\t\t\t\t\t// Store className if set\n\t\t\t\t\tdataPriv.set( this, \"__className__\", className );\n\t\t\t\t}\n\n\t\t\t\t// If the element has a class name or if we're passed `false`,\n\t\t\t\t// then remove the whole classname (if there was one, the above saved it).\n\t\t\t\t// Otherwise bring back whatever was previously saved (if anything),\n\t\t\t\t// falling back to the empty string if nothing was stored.\n\t\t\t\tif ( this.setAttribute ) {\n\t\t\t\t\tthis.setAttribute( \"class\",\n\t\t\t\t\t\tclassName || value === false ?\n\t\t\t\t\t\t\"\" :\n\t\t\t\t\t\tdataPriv.get( this, \"__className__\" ) || \"\"\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t},\n\n\thasClass: function( selector ) {\n\t\tvar className, elem,\n\t\t\ti = 0;\n\n\t\tclassName = \" \" + selector + \" \";\n\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\tif ( elem.nodeType === 1 &&\n\t\t\t\t( \" \" + getClass( elem ) + \" \" ).replace( rclass, \" \" )\n\t\t\t\t\t.indexOf( className ) > -1\n\t\t\t) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n} );\n\n\n\n\nvar rreturn = /\\r/g,\n\trspaces = /[\\x20\\t\\r\\n\\f]+/g;\n\njQuery.fn.extend( {\n\tval: function( value ) {\n\t\tvar hooks, ret, isFunction,\n\t\t\telem = this[ 0 ];\n\n\t\tif ( !arguments.length ) {\n\t\t\tif ( elem ) {\n\t\t\t\thooks = jQuery.valHooks[ elem.type ] ||\n\t\t\t\t\tjQuery.valHooks[ elem.nodeName.toLowerCase() ];\n\n\t\t\t\tif ( hooks &&\n\t\t\t\t\t\"get\" in hooks &&\n\t\t\t\t\t( ret = hooks.get( elem, \"value\" ) ) !== undefined\n\t\t\t\t) {\n\t\t\t\t\treturn ret;\n\t\t\t\t}\n\n\t\t\t\tret = elem.value;\n\n\t\t\t\treturn typeof ret === \"string\" ?\n\n\t\t\t\t\t// Handle most common string cases\n\t\t\t\t\tret.replace( rreturn, \"\" ) :\n\n\t\t\t\t\t// Handle cases where value is null/undef or number\n\t\t\t\t\tret == null ? \"\" : ret;\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tisFunction = jQuery.isFunction( value );\n\n\t\treturn this.each( function( i ) {\n\t\t\tvar val;\n\n\t\t\tif ( this.nodeType !== 1 ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif ( isFunction ) {\n\t\t\t\tval = value.call( this, i, jQuery( this ).val() );\n\t\t\t} else {\n\t\t\t\tval = value;\n\t\t\t}\n\n\t\t\t// Treat null/undefined as \"\"; convert numbers to string\n\t\t\tif ( val == null ) {\n\t\t\t\tval = \"\";\n\n\t\t\t} else if ( typeof val === \"number\" ) {\n\t\t\t\tval += \"\";\n\n\t\t\t} else if ( jQuery.isArray( val ) ) {\n\t\t\t\tval = jQuery.map( val, function( value ) {\n\t\t\t\t\treturn value == null ? \"\" : value + \"\";\n\t\t\t\t} );\n\t\t\t}\n\n\t\t\thooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ];\n\n\t\t\t// If set returns undefined, fall back to normal setting\n\t\t\tif ( !hooks || !( \"set\" in hooks ) || hooks.set( this, val, \"value\" ) === undefined ) {\n\t\t\t\tthis.value = val;\n\t\t\t}\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tvalHooks: {\n\t\toption: {\n\t\t\tget: function( elem ) {\n\n\t\t\t\tvar val = jQuery.find.attr( elem, \"value\" );\n\t\t\t\treturn val != null ?\n\t\t\t\t\tval :\n\n\t\t\t\t\t// Support: IE10-11+\n\t\t\t\t\t// option.text throws exceptions (#14686, #14858)\n\t\t\t\t\t// Strip and collapse whitespace\n\t\t\t\t\t// https://html.spec.whatwg.org/#strip-and-collapse-whitespace\n\t\t\t\t\tjQuery.trim( jQuery.text( elem ) ).replace( rspaces, \" \" );\n\t\t\t}\n\t\t},\n\t\tselect: {\n\t\t\tget: function( elem ) {\n\t\t\t\tvar value, option,\n\t\t\t\t\toptions = elem.options,\n\t\t\t\t\tindex = elem.selectedIndex,\n\t\t\t\t\tone = elem.type === \"select-one\" || index < 0,\n\t\t\t\t\tvalues = one ? null : [],\n\t\t\t\t\tmax = one ? index + 1 : options.length,\n\t\t\t\t\ti = index < 0 ?\n\t\t\t\t\t\tmax :\n\t\t\t\t\t\tone ? index : 0;\n\n\t\t\t\t// Loop through all the selected options\n\t\t\t\tfor ( ; i < max; i++ ) {\n\t\t\t\t\toption = options[ i ];\n\n\t\t\t\t\t// IE8-9 doesn't update selected after form reset (#2551)\n\t\t\t\t\tif ( ( option.selected || i === index ) &&\n\n\t\t\t\t\t\t\t// Don't return options that are disabled or in a disabled optgroup\n\t\t\t\t\t\t\t( support.optDisabled ?\n\t\t\t\t\t\t\t\t!option.disabled : option.getAttribute( \"disabled\" ) === null ) &&\n\t\t\t\t\t\t\t( !option.parentNode.disabled ||\n\t\t\t\t\t\t\t\t!jQuery.nodeName( option.parentNode, \"optgroup\" ) ) ) {\n\n\t\t\t\t\t\t// Get the specific value for the option\n\t\t\t\t\t\tvalue = jQuery( option ).val();\n\n\t\t\t\t\t\t// We don't need an array for one selects\n\t\t\t\t\t\tif ( one ) {\n\t\t\t\t\t\t\treturn value;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Multi-Selects return an array\n\t\t\t\t\t\tvalues.push( value );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn values;\n\t\t\t},\n\n\t\t\tset: function( elem, value ) {\n\t\t\t\tvar optionSet, option,\n\t\t\t\t\toptions = elem.options,\n\t\t\t\t\tvalues = jQuery.makeArray( value ),\n\t\t\t\t\ti = options.length;\n\n\t\t\t\twhile ( i-- ) {\n\t\t\t\t\toption = options[ i ];\n\t\t\t\t\tif ( option.selected =\n\t\t\t\t\t\tjQuery.inArray( jQuery.valHooks.option.get( option ), values ) > -1\n\t\t\t\t\t) {\n\t\t\t\t\t\toptionSet = true;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Force browsers to behave consistently when non-matching value is set\n\t\t\t\tif ( !optionSet ) {\n\t\t\t\t\telem.selectedIndex = -1;\n\t\t\t\t}\n\t\t\t\treturn values;\n\t\t\t}\n\t\t}\n\t}\n} );\n\n// Radios and checkboxes getter/setter\njQuery.each( [ \"radio\", \"checkbox\" ], function() {\n\tjQuery.valHooks[ this ] = {\n\t\tset: function( elem, value ) {\n\t\t\tif ( jQuery.isArray( value ) ) {\n\t\t\t\treturn ( elem.checked = jQuery.inArray( jQuery( elem ).val(), value ) > -1 );\n\t\t\t}\n\t\t}\n\t};\n\tif ( !support.checkOn ) {\n\t\tjQuery.valHooks[ this ].get = function( elem ) {\n\t\t\treturn elem.getAttribute( \"value\" ) === null ? \"on\" : elem.value;\n\t\t};\n\t}\n} );\n\n\n\n\n// Return jQuery for attributes-only inclusion\n\n\nvar rfocusMorph = /^(?:focusinfocus|focusoutblur)$/;\n\njQuery.extend( jQuery.event, {\n\n\ttrigger: function( event, data, elem, onlyHandlers ) {\n\n\t\tvar i, cur, tmp, bubbleType, ontype, handle, special,\n\t\t\teventPath = [ elem || document ],\n\t\t\ttype = hasOwn.call( event, \"type\" ) ? event.type : event,\n\t\t\tnamespaces = hasOwn.call( event, \"namespace\" ) ? event.namespace.split( \".\" ) : [];\n\n\t\tcur = tmp = elem = elem || document;\n\n\t\t// Don't do events on text and comment nodes\n\t\tif ( elem.nodeType === 3 || elem.nodeType === 8 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// focus/blur morphs to focusin/out; ensure we're not firing them right now\n\t\tif ( rfocusMorph.test( type + jQuery.event.triggered ) ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( type.indexOf( \".\" ) > -1 ) {\n\n\t\t\t// Namespaced trigger; create a regexp to match event type in handle()\n\t\t\tnamespaces = type.split( \".\" );\n\t\t\ttype = namespaces.shift();\n\t\t\tnamespaces.sort();\n\t\t}\n\t\tontype = type.indexOf( \":\" ) < 0 && \"on\" + type;\n\n\t\t// Caller can pass in a jQuery.Event object, Object, or just an event type string\n\t\tevent = event[ jQuery.expando ] ?\n\t\t\tevent :\n\t\t\tnew jQuery.Event( type, typeof event === \"object\" && event );\n\n\t\t// Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true)\n\t\tevent.isTrigger = onlyHandlers ? 2 : 3;\n\t\tevent.namespace = namespaces.join( \".\" );\n\t\tevent.rnamespace = event.namespace ?\n\t\t\tnew RegExp( \"(^|\\\\.)\" + namespaces.join( \"\\\\.(?:.*\\\\.|)\" ) + \"(\\\\.|$)\" ) :\n\t\t\tnull;\n\n\t\t// Clean up the event in case it is being reused\n\t\tevent.result = undefined;\n\t\tif ( !event.target ) {\n\t\t\tevent.target = elem;\n\t\t}\n\n\t\t// Clone any incoming data and prepend the event, creating the handler arg list\n\t\tdata = data == null ?\n\t\t\t[ event ] :\n\t\t\tjQuery.makeArray( data, [ event ] );\n\n\t\t// Allow special events to draw outside the lines\n\t\tspecial = jQuery.event.special[ type ] || {};\n\t\tif ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Determine event propagation path in advance, per W3C events spec (#9951)\n\t\t// Bubble up to document, then to window; watch for a global ownerDocument var (#9724)\n\t\tif ( !onlyHandlers && !special.noBubble && !jQuery.isWindow( elem ) ) {\n\n\t\t\tbubbleType = special.delegateType || type;\n\t\t\tif ( !rfocusMorph.test( bubbleType + type ) ) {\n\t\t\t\tcur = cur.parentNode;\n\t\t\t}\n\t\t\tfor ( ; cur; cur = cur.parentNode ) {\n\t\t\t\teventPath.push( cur );\n\t\t\t\ttmp = cur;\n\t\t\t}\n\n\t\t\t// Only add window if we got to document (e.g., not plain obj or detached DOM)\n\t\t\tif ( tmp === ( elem.ownerDocument || document ) ) {\n\t\t\t\teventPath.push( tmp.defaultView || tmp.parentWindow || window );\n\t\t\t}\n\t\t}\n\n\t\t// Fire handlers on the event path\n\t\ti = 0;\n\t\twhile ( ( cur = eventPath[ i++ ] ) && !event.isPropagationStopped() ) {\n\n\t\t\tevent.type = i > 1 ?\n\t\t\t\tbubbleType :\n\t\t\t\tspecial.bindType || type;\n\n\t\t\t// jQuery handler\n\t\t\thandle = ( dataPriv.get( cur, \"events\" ) || {} )[ event.type ] &&\n\t\t\t\tdataPriv.get( cur, \"handle\" );\n\t\t\tif ( handle ) {\n\t\t\t\thandle.apply( cur, data );\n\t\t\t}\n\n\t\t\t// Native handler\n\t\t\thandle = ontype && cur[ ontype ];\n\t\t\tif ( handle && handle.apply && acceptData( cur ) ) {\n\t\t\t\tevent.result = handle.apply( cur, data );\n\t\t\t\tif ( event.result === false ) {\n\t\t\t\t\tevent.preventDefault();\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tevent.type = type;\n\n\t\t// If nobody prevented the default action, do it now\n\t\tif ( !onlyHandlers && !event.isDefaultPrevented() ) {\n\n\t\t\tif ( ( !special._default ||\n\t\t\t\tspecial._default.apply( eventPath.pop(), data ) === false ) &&\n\t\t\t\tacceptData( elem ) ) {\n\n\t\t\t\t// Call a native DOM method on the target with the same name name as the event.\n\t\t\t\t// Don't do default actions on window, that's where global variables be (#6170)\n\t\t\t\tif ( ontype && jQuery.isFunction( elem[ type ] ) && !jQuery.isWindow( elem ) ) {\n\n\t\t\t\t\t// Don't re-trigger an onFOO event when we call its FOO() method\n\t\t\t\t\ttmp = elem[ ontype ];\n\n\t\t\t\t\tif ( tmp ) {\n\t\t\t\t\t\telem[ ontype ] = null;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Prevent re-triggering of the same event, since we already bubbled it above\n\t\t\t\t\tjQuery.event.triggered = type;\n\t\t\t\t\telem[ type ]();\n\t\t\t\t\tjQuery.event.triggered = undefined;\n\n\t\t\t\t\tif ( tmp ) {\n\t\t\t\t\t\telem[ ontype ] = tmp;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn event.result;\n\t},\n\n\t// Piggyback on a donor event to simulate a different one\n\t// Used only for `focus(in | out)` events\n\tsimulate: function( type, elem, event ) {\n\t\tvar e = jQuery.extend(\n\t\t\tnew jQuery.Event(),\n\t\t\tevent,\n\t\t\t{\n\t\t\t\ttype: type,\n\t\t\t\tisSimulated: true\n\t\t\t}\n\t\t);\n\n\t\tjQuery.event.trigger( e, null, elem );\n\t}\n\n} );\n\njQuery.fn.extend( {\n\n\ttrigger: function( type, data ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.event.trigger( type, data, this );\n\t\t} );\n\t},\n\ttriggerHandler: function( type, data ) {\n\t\tvar elem = this[ 0 ];\n\t\tif ( elem ) {\n\t\t\treturn jQuery.event.trigger( type, data, elem, true );\n\t\t}\n\t}\n} );\n\n\njQuery.each( ( \"blur focus focusin focusout load resize scroll unload click dblclick \" +\n\t\"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave \" +\n\t\"change select submit keydown keypress keyup error contextmenu\" ).split( \" \" ),\n\tfunction( i, name ) {\n\n\t// Handle event binding\n\tjQuery.fn[ name ] = function( data, fn ) {\n\t\treturn arguments.length > 0 ?\n\t\t\tthis.on( name, null, data, fn ) :\n\t\t\tthis.trigger( name );\n\t};\n} );\n\njQuery.fn.extend( {\n\thover: function( fnOver, fnOut ) {\n\t\treturn this.mouseenter( fnOver ).mouseleave( fnOut || fnOver );\n\t}\n} );\n\n\n\n\nsupport.focusin = \"onfocusin\" in window;\n\n\n// Support: Firefox\n// Firefox doesn't have focus(in | out) events\n// Related ticket - https://bugzilla.mozilla.org/show_bug.cgi?id=687787\n//\n// Support: Chrome, Safari\n// focus(in | out) events fire after focus & blur events,\n// which is spec violation - http://www.w3.org/TR/DOM-Level-3-Events/#events-focusevent-event-order\n// Related ticket - https://code.google.com/p/chromium/issues/detail?id=449857\nif ( !support.focusin ) {\n\tjQuery.each( { focus: \"focusin\", blur: \"focusout\" }, function( orig, fix ) {\n\n\t\t// Attach a single capturing handler on the document while someone wants focusin/focusout\n\t\tvar handler = function( event ) {\n\t\t\tjQuery.event.simulate( fix, event.target, jQuery.event.fix( event ) );\n\t\t};\n\n\t\tjQuery.event.special[ fix ] = {\n\t\t\tsetup: function() {\n\t\t\t\tvar doc = this.ownerDocument || this,\n\t\t\t\t\tattaches = dataPriv.access( doc, fix );\n\n\t\t\t\tif ( !attaches ) {\n\t\t\t\t\tdoc.addEventListener( orig, handler, true );\n\t\t\t\t}\n\t\t\t\tdataPriv.access( doc, fix, ( attaches || 0 ) + 1 );\n\t\t\t},\n\t\t\tteardown: function() {\n\t\t\t\tvar doc = this.ownerDocument || this,\n\t\t\t\t\tattaches = dataPriv.access( doc, fix ) - 1;\n\n\t\t\t\tif ( !attaches ) {\n\t\t\t\t\tdoc.removeEventListener( orig, handler, true );\n\t\t\t\t\tdataPriv.remove( doc, fix );\n\n\t\t\t\t} else {\n\t\t\t\t\tdataPriv.access( doc, fix, attaches );\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t} );\n}\nvar location = window.location;\n\nvar nonce = jQuery.now();\n\nvar rquery = ( /\\?/ );\n\n\n\n// Support: Android 2.3\n// Workaround failure to string-cast null input\njQuery.parseJSON = function( data ) {\n\treturn JSON.parse( data + \"\" );\n};\n\n\n// Cross-browser xml parsing\njQuery.parseXML = function( data ) {\n\tvar xml;\n\tif ( !data || typeof data !== \"string\" ) {\n\t\treturn null;\n\t}\n\n\t// Support: IE9\n\ttry {\n\t\txml = ( new window.DOMParser() ).parseFromString( data, \"text/xml\" );\n\t} catch ( e ) {\n\t\txml = undefined;\n\t}\n\n\tif ( !xml || xml.getElementsByTagName( \"parsererror\" ).length ) {\n\t\tjQuery.error( \"Invalid XML: \" + data );\n\t}\n\treturn xml;\n};\n\n\nvar\n\trhash = /#.*$/,\n\trts = /([?&])_=[^&]*/,\n\trheaders = /^(.*?):[ \\t]*([^\\r\\n]*)$/mg,\n\n\t// #7653, #8125, #8152: local protocol detection\n\trlocalProtocol = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/,\n\trnoContent = /^(?:GET|HEAD)$/,\n\trprotocol = /^\\/\\//,\n\n\t/* Prefilters\n\t * 1) They are useful to introduce custom dataTypes (see ajax/jsonp.js for an example)\n\t * 2) These are called:\n\t * - BEFORE asking for a transport\n\t * - AFTER param serialization (s.data is a string if s.processData is true)\n\t * 3) key is the dataType\n\t * 4) the catchall symbol \"*\" can be used\n\t * 5) execution will start with transport dataType and THEN continue down to \"*\" if needed\n\t */\n\tprefilters = {},\n\n\t/* Transports bindings\n\t * 1) key is the dataType\n\t * 2) the catchall symbol \"*\" can be used\n\t * 3) selection will start with transport dataType and THEN go to \"*\" if needed\n\t */\n\ttransports = {},\n\n\t// Avoid comment-prolog char sequence (#10098); must appease lint and evade compression\n\tallTypes = \"*/\".concat( \"*\" ),\n\n\t// Anchor tag for parsing the document origin\n\toriginAnchor = document.createElement( \"a\" );\n\toriginAnchor.href = location.href;\n\n// Base \"constructor\" for jQuery.ajaxPrefilter and jQuery.ajaxTransport\nfunction addToPrefiltersOrTransports( structure ) {\n\n\t// dataTypeExpression is optional and defaults to \"*\"\n\treturn function( dataTypeExpression, func ) {\n\n\t\tif ( typeof dataTypeExpression !== \"string\" ) {\n\t\t\tfunc = dataTypeExpression;\n\t\t\tdataTypeExpression = \"*\";\n\t\t}\n\n\t\tvar dataType,\n\t\t\ti = 0,\n\t\t\tdataTypes = dataTypeExpression.toLowerCase().match( rnotwhite ) || [];\n\n\t\tif ( jQuery.isFunction( func ) ) {\n\n\t\t\t// For each dataType in the dataTypeExpression\n\t\t\twhile ( ( dataType = dataTypes[ i++ ] ) ) {\n\n\t\t\t\t// Prepend if requested\n\t\t\t\tif ( dataType[ 0 ] === \"+\" ) {\n\t\t\t\t\tdataType = dataType.slice( 1 ) || \"*\";\n\t\t\t\t\t( structure[ dataType ] = structure[ dataType ] || [] ).unshift( func );\n\n\t\t\t\t// Otherwise append\n\t\t\t\t} else {\n\t\t\t\t\t( structure[ dataType ] = structure[ dataType ] || [] ).push( func );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n}\n\n// Base inspection function for prefilters and transports\nfunction inspectPrefiltersOrTransports( structure, options, originalOptions, jqXHR ) {\n\n\tvar inspected = {},\n\t\tseekingTransport = ( structure === transports );\n\n\tfunction inspect( dataType ) {\n\t\tvar selected;\n\t\tinspected[ dataType ] = true;\n\t\tjQuery.each( structure[ dataType ] || [], function( _, prefilterOrFactory ) {\n\t\t\tvar dataTypeOrTransport = prefilterOrFactory( options, originalOptions, jqXHR );\n\t\t\tif ( typeof dataTypeOrTransport === \"string\" &&\n\t\t\t\t!seekingTransport && !inspected[ dataTypeOrTransport ] ) {\n\n\t\t\t\toptions.dataTypes.unshift( dataTypeOrTransport );\n\t\t\t\tinspect( dataTypeOrTransport );\n\t\t\t\treturn false;\n\t\t\t} else if ( seekingTransport ) {\n\t\t\t\treturn !( selected = dataTypeOrTransport );\n\t\t\t}\n\t\t} );\n\t\treturn selected;\n\t}\n\n\treturn inspect( options.dataTypes[ 0 ] ) || !inspected[ \"*\" ] && inspect( \"*\" );\n}\n\n// A special extend for ajax options\n// that takes \"flat\" options (not to be deep extended)\n// Fixes #9887\nfunction ajaxExtend( target, src ) {\n\tvar key, deep,\n\t\tflatOptions = jQuery.ajaxSettings.flatOptions || {};\n\n\tfor ( key in src ) {\n\t\tif ( src[ key ] !== undefined ) {\n\t\t\t( flatOptions[ key ] ? target : ( deep || ( deep = {} ) ) )[ key ] = src[ key ];\n\t\t}\n\t}\n\tif ( deep ) {\n\t\tjQuery.extend( true, target, deep );\n\t}\n\n\treturn target;\n}\n\n/* Handles responses to an ajax request:\n * - finds the right dataType (mediates between content-type and expected dataType)\n * - returns the corresponding response\n */\nfunction ajaxHandleResponses( s, jqXHR, responses ) {\n\n\tvar ct, type, finalDataType, firstDataType,\n\t\tcontents = s.contents,\n\t\tdataTypes = s.dataTypes;\n\n\t// Remove auto dataType and get content-type in the process\n\twhile ( dataTypes[ 0 ] === \"*\" ) {\n\t\tdataTypes.shift();\n\t\tif ( ct === undefined ) {\n\t\t\tct = s.mimeType || jqXHR.getResponseHeader( \"Content-Type\" );\n\t\t}\n\t}\n\n\t// Check if we're dealing with a known content-type\n\tif ( ct ) {\n\t\tfor ( type in contents ) {\n\t\t\tif ( contents[ type ] && contents[ type ].test( ct ) ) {\n\t\t\t\tdataTypes.unshift( type );\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\t// Check to see if we have a response for the expected dataType\n\tif ( dataTypes[ 0 ] in responses ) {\n\t\tfinalDataType = dataTypes[ 0 ];\n\t} else {\n\n\t\t// Try convertible dataTypes\n\t\tfor ( type in responses ) {\n\t\t\tif ( !dataTypes[ 0 ] || s.converters[ type + \" \" + dataTypes[ 0 ] ] ) {\n\t\t\t\tfinalDataType = type;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif ( !firstDataType ) {\n\t\t\t\tfirstDataType = type;\n\t\t\t}\n\t\t}\n\n\t\t// Or just use first one\n\t\tfinalDataType = finalDataType || firstDataType;\n\t}\n\n\t// If we found a dataType\n\t// We add the dataType to the list if needed\n\t// and return the corresponding response\n\tif ( finalDataType ) {\n\t\tif ( finalDataType !== dataTypes[ 0 ] ) {\n\t\t\tdataTypes.unshift( finalDataType );\n\t\t}\n\t\treturn responses[ finalDataType ];\n\t}\n}\n\n/* Chain conversions given the request and the original response\n * Also sets the responseXXX fields on the jqXHR instance\n */\nfunction ajaxConvert( s, response, jqXHR, isSuccess ) {\n\tvar conv2, current, conv, tmp, prev,\n\t\tconverters = {},\n\n\t\t// Work with a copy of dataTypes in case we need to modify it for conversion\n\t\tdataTypes = s.dataTypes.slice();\n\n\t// Create converters map with lowercased keys\n\tif ( dataTypes[ 1 ] ) {\n\t\tfor ( conv in s.converters ) {\n\t\t\tconverters[ conv.toLowerCase() ] = s.converters[ conv ];\n\t\t}\n\t}\n\n\tcurrent = dataTypes.shift();\n\n\t// Convert to each sequential dataType\n\twhile ( current ) {\n\n\t\tif ( s.responseFields[ current ] ) {\n\t\t\tjqXHR[ s.responseFields[ current ] ] = response;\n\t\t}\n\n\t\t// Apply the dataFilter if provided\n\t\tif ( !prev && isSuccess && s.dataFilter ) {\n\t\t\tresponse = s.dataFilter( response, s.dataType );\n\t\t}\n\n\t\tprev = current;\n\t\tcurrent = dataTypes.shift();\n\n\t\tif ( current ) {\n\n\t\t// There's only work to do if current dataType is non-auto\n\t\t\tif ( current === \"*\" ) {\n\n\t\t\t\tcurrent = prev;\n\n\t\t\t// Convert response if prev dataType is non-auto and differs from current\n\t\t\t} else if ( prev !== \"*\" && prev !== current ) {\n\n\t\t\t\t// Seek a direct converter\n\t\t\t\tconv = converters[ prev + \" \" + current ] || converters[ \"* \" + current ];\n\n\t\t\t\t// If none found, seek a pair\n\t\t\t\tif ( !conv ) {\n\t\t\t\t\tfor ( conv2 in converters ) {\n\n\t\t\t\t\t\t// If conv2 outputs current\n\t\t\t\t\t\ttmp = conv2.split( \" \" );\n\t\t\t\t\t\tif ( tmp[ 1 ] === current ) {\n\n\t\t\t\t\t\t\t// If prev can be converted to accepted input\n\t\t\t\t\t\t\tconv = converters[ prev + \" \" + tmp[ 0 ] ] ||\n\t\t\t\t\t\t\t\tconverters[ \"* \" + tmp[ 0 ] ];\n\t\t\t\t\t\t\tif ( conv ) {\n\n\t\t\t\t\t\t\t\t// Condense equivalence converters\n\t\t\t\t\t\t\t\tif ( conv === true ) {\n\t\t\t\t\t\t\t\t\tconv = converters[ conv2 ];\n\n\t\t\t\t\t\t\t\t// Otherwise, insert the intermediate dataType\n\t\t\t\t\t\t\t\t} else if ( converters[ conv2 ] !== true ) {\n\t\t\t\t\t\t\t\t\tcurrent = tmp[ 0 ];\n\t\t\t\t\t\t\t\t\tdataTypes.unshift( tmp[ 1 ] );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Apply converter (if not an equivalence)\n\t\t\t\tif ( conv !== true ) {\n\n\t\t\t\t\t// Unless errors are allowed to bubble, catch and return them\n\t\t\t\t\tif ( conv && s.throws ) {\n\t\t\t\t\t\tresponse = conv( response );\n\t\t\t\t\t} else {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tresponse = conv( response );\n\t\t\t\t\t\t} catch ( e ) {\n\t\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\t\tstate: \"parsererror\",\n\t\t\t\t\t\t\t\terror: conv ? e : \"No conversion from \" + prev + \" to \" + current\n\t\t\t\t\t\t\t};\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn { state: \"success\", data: response };\n}\n\njQuery.extend( {\n\n\t// Counter for holding the number of active queries\n\tactive: 0,\n\n\t// Last-Modified header cache for next request\n\tlastModified: {},\n\tetag: {},\n\n\tajaxSettings: {\n\t\turl: location.href,\n\t\ttype: \"GET\",\n\t\tisLocal: rlocalProtocol.test( location.protocol ),\n\t\tglobal: true,\n\t\tprocessData: true,\n\t\tasync: true,\n\t\tcontentType: \"application/x-www-form-urlencoded; charset=UTF-8\",\n\t\t/*\n\t\ttimeout: 0,\n\t\tdata: null,\n\t\tdataType: null,\n\t\tusername: null,\n\t\tpassword: null,\n\t\tcache: null,\n\t\tthrows: false,\n\t\ttraditional: false,\n\t\theaders: {},\n\t\t*/\n\n\t\taccepts: {\n\t\t\t\"*\": allTypes,\n\t\t\ttext: \"text/plain\",\n\t\t\thtml: \"text/html\",\n\t\t\txml: \"application/xml, text/xml\",\n\t\t\tjson: \"application/json, text/javascript\"\n\t\t},\n\n\t\tcontents: {\n\t\t\txml: /\\bxml\\b/,\n\t\t\thtml: /\\bhtml/,\n\t\t\tjson: /\\bjson\\b/\n\t\t},\n\n\t\tresponseFields: {\n\t\t\txml: \"responseXML\",\n\t\t\ttext: \"responseText\",\n\t\t\tjson: \"responseJSON\"\n\t\t},\n\n\t\t// Data converters\n\t\t// Keys separate source (or catchall \"*\") and destination types with a single space\n\t\tconverters: {\n\n\t\t\t// Convert anything to text\n\t\t\t\"* text\": String,\n\n\t\t\t// Text to html (true = no transformation)\n\t\t\t\"text html\": true,\n\n\t\t\t// Evaluate text as a json expression\n\t\t\t\"text json\": jQuery.parseJSON,\n\n\t\t\t// Parse text as xml\n\t\t\t\"text xml\": jQuery.parseXML\n\t\t},\n\n\t\t// For options that shouldn't be deep extended:\n\t\t// you can add your own custom options here if\n\t\t// and when you create one that shouldn't be\n\t\t// deep extended (see ajaxExtend)\n\t\tflatOptions: {\n\t\t\turl: true,\n\t\t\tcontext: true\n\t\t}\n\t},\n\n\t// Creates a full fledged settings object into target\n\t// with both ajaxSettings and settings fields.\n\t// If target is omitted, writes into ajaxSettings.\n\tajaxSetup: function( target, settings ) {\n\t\treturn settings ?\n\n\t\t\t// Building a settings object\n\t\t\tajaxExtend( ajaxExtend( target, jQuery.ajaxSettings ), settings ) :\n\n\t\t\t// Extending ajaxSettings\n\t\t\tajaxExtend( jQuery.ajaxSettings, target );\n\t},\n\n\tajaxPrefilter: addToPrefiltersOrTransports( prefilters ),\n\tajaxTransport: addToPrefiltersOrTransports( transports ),\n\n\t// Main method\n\tajax: function( url, options ) {\n\n\t\t// If url is an object, simulate pre-1.5 signature\n\t\tif ( typeof url === \"object\" ) {\n\t\t\toptions = url;\n\t\t\turl = undefined;\n\t\t}\n\n\t\t// Force options to be an object\n\t\toptions = options || {};\n\n\t\tvar transport,\n\n\t\t\t// URL without anti-cache param\n\t\t\tcacheURL,\n\n\t\t\t// Response headers\n\t\t\tresponseHeadersString,\n\t\t\tresponseHeaders,\n\n\t\t\t// timeout handle\n\t\t\ttimeoutTimer,\n\n\t\t\t// Url cleanup var\n\t\t\turlAnchor,\n\n\t\t\t// To know if global events are to be dispatched\n\t\t\tfireGlobals,\n\n\t\t\t// Loop variable\n\t\t\ti,\n\n\t\t\t// Create the final options object\n\t\t\ts = jQuery.ajaxSetup( {}, options ),\n\n\t\t\t// Callbacks context\n\t\t\tcallbackContext = s.context || s,\n\n\t\t\t// Context for global events is callbackContext if it is a DOM node or jQuery collection\n\t\t\tglobalEventContext = s.context &&\n\t\t\t\t( callbackContext.nodeType || callbackContext.jquery ) ?\n\t\t\t\t\tjQuery( callbackContext ) :\n\t\t\t\t\tjQuery.event,\n\n\t\t\t// Deferreds\n\t\t\tdeferred = jQuery.Deferred(),\n\t\t\tcompleteDeferred = jQuery.Callbacks( \"once memory\" ),\n\n\t\t\t// Status-dependent callbacks\n\t\t\tstatusCode = s.statusCode || {},\n\n\t\t\t// Headers (they are sent all at once)\n\t\t\trequestHeaders = {},\n\t\t\trequestHeadersNames = {},\n\n\t\t\t// The jqXHR state\n\t\t\tstate = 0,\n\n\t\t\t// Default abort message\n\t\t\tstrAbort = \"canceled\",\n\n\t\t\t// Fake xhr\n\t\t\tjqXHR = {\n\t\t\t\treadyState: 0,\n\n\t\t\t\t// Builds headers hashtable if needed\n\t\t\t\tgetResponseHeader: function( key ) {\n\t\t\t\t\tvar match;\n\t\t\t\t\tif ( state === 2 ) {\n\t\t\t\t\t\tif ( !responseHeaders ) {\n\t\t\t\t\t\t\tresponseHeaders = {};\n\t\t\t\t\t\t\twhile ( ( match = rheaders.exec( responseHeadersString ) ) ) {\n\t\t\t\t\t\t\t\tresponseHeaders[ match[ 1 ].toLowerCase() ] = match[ 2 ];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tmatch = responseHeaders[ key.toLowerCase() ];\n\t\t\t\t\t}\n\t\t\t\t\treturn match == null ? null : match;\n\t\t\t\t},\n\n\t\t\t\t// Raw string\n\t\t\t\tgetAllResponseHeaders: function() {\n\t\t\t\t\treturn state === 2 ? responseHeadersString : null;\n\t\t\t\t},\n\n\t\t\t\t// Caches the header\n\t\t\t\tsetRequestHeader: function( name, value ) {\n\t\t\t\t\tvar lname = name.toLowerCase();\n\t\t\t\t\tif ( !state ) {\n\t\t\t\t\t\tname = requestHeadersNames[ lname ] = requestHeadersNames[ lname ] || name;\n\t\t\t\t\t\trequestHeaders[ name ] = value;\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Overrides response content-type header\n\t\t\t\toverrideMimeType: function( type ) {\n\t\t\t\t\tif ( !state ) {\n\t\t\t\t\t\ts.mimeType = type;\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Status-dependent callbacks\n\t\t\t\tstatusCode: function( map ) {\n\t\t\t\t\tvar code;\n\t\t\t\t\tif ( map ) {\n\t\t\t\t\t\tif ( state < 2 ) {\n\t\t\t\t\t\t\tfor ( code in map ) {\n\n\t\t\t\t\t\t\t\t// Lazy-add the new callback in a way that preserves old ones\n\t\t\t\t\t\t\t\tstatusCode[ code ] = [ statusCode[ code ], map[ code ] ];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t// Execute the appropriate callbacks\n\t\t\t\t\t\t\tjqXHR.always( map[ jqXHR.status ] );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Cancel the request\n\t\t\t\tabort: function( statusText ) {\n\t\t\t\t\tvar finalText = statusText || strAbort;\n\t\t\t\t\tif ( transport ) {\n\t\t\t\t\t\ttransport.abort( finalText );\n\t\t\t\t\t}\n\t\t\t\t\tdone( 0, finalText );\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t};\n\n\t\t// Attach deferreds\n\t\tdeferred.promise( jqXHR ).complete = completeDeferred.add;\n\t\tjqXHR.success = jqXHR.done;\n\t\tjqXHR.error = jqXHR.fail;\n\n\t\t// Remove hash character (#7531: and string promotion)\n\t\t// Add protocol if not provided (prefilters might expect it)\n\t\t// Handle falsy url in the settings object (#10093: consistency with old signature)\n\t\t// We also use the url parameter if available\n\t\ts.url = ( ( url || s.url || location.href ) + \"\" ).replace( rhash, \"\" )\n\t\t\t.replace( rprotocol, location.protocol + \"//\" );\n\n\t\t// Alias method option to type as per ticket #12004\n\t\ts.type = options.method || options.type || s.method || s.type;\n\n\t\t// Extract dataTypes list\n\t\ts.dataTypes = jQuery.trim( s.dataType || \"*\" ).toLowerCase().match( rnotwhite ) || [ \"\" ];\n\n\t\t// A cross-domain request is in order when the origin doesn't match the current origin.\n\t\tif ( s.crossDomain == null ) {\n\t\t\turlAnchor = document.createElement( \"a\" );\n\n\t\t\t// Support: IE8-11+\n\t\t\t// IE throws exception if url is malformed, e.g. http://example.com:80x/\n\t\t\ttry {\n\t\t\t\turlAnchor.href = s.url;\n\n\t\t\t\t// Support: IE8-11+\n\t\t\t\t// Anchor's host property isn't correctly set when s.url is relative\n\t\t\t\turlAnchor.href = urlAnchor.href;\n\t\t\t\ts.crossDomain = originAnchor.protocol + \"//\" + originAnchor.host !==\n\t\t\t\t\turlAnchor.protocol + \"//\" + urlAnchor.host;\n\t\t\t} catch ( e ) {\n\n\t\t\t\t// If there is an error parsing the URL, assume it is crossDomain,\n\t\t\t\t// it can be rejected by the transport if it is invalid\n\t\t\t\ts.crossDomain = true;\n\t\t\t}\n\t\t}\n\n\t\t// Convert data if not already a string\n\t\tif ( s.data && s.processData && typeof s.data !== \"string\" ) {\n\t\t\ts.data = jQuery.param( s.data, s.traditional );\n\t\t}\n\n\t\t// Apply prefilters\n\t\tinspectPrefiltersOrTransports( prefilters, s, options, jqXHR );\n\n\t\t// If request was aborted inside a prefilter, stop there\n\t\tif ( state === 2 ) {\n\t\t\treturn jqXHR;\n\t\t}\n\n\t\t// We can fire global events as of now if asked to\n\t\t// Don't fire events if jQuery.event is undefined in an AMD-usage scenario (#15118)\n\t\tfireGlobals = jQuery.event && s.global;\n\n\t\t// Watch for a new set of requests\n\t\tif ( fireGlobals && jQuery.active++ === 0 ) {\n\t\t\tjQuery.event.trigger( \"ajaxStart\" );\n\t\t}\n\n\t\t// Uppercase the type\n\t\ts.type = s.type.toUpperCase();\n\n\t\t// Determine if request has content\n\t\ts.hasContent = !rnoContent.test( s.type );\n\n\t\t// Save the URL in case we're toying with the If-Modified-Since\n\t\t// and/or If-None-Match header later on\n\t\tcacheURL = s.url;\n\n\t\t// More options handling for requests with no content\n\t\tif ( !s.hasContent ) {\n\n\t\t\t// If data is available, append data to url\n\t\t\tif ( s.data ) {\n\t\t\t\tcacheURL = ( s.url += ( rquery.test( cacheURL ) ? \"&\" : \"?\" ) + s.data );\n\n\t\t\t\t// #9682: remove data so that it's not used in an eventual retry\n\t\t\t\tdelete s.data;\n\t\t\t}\n\n\t\t\t// Add anti-cache in url if needed\n\t\t\tif ( s.cache === false ) {\n\t\t\t\ts.url = rts.test( cacheURL ) ?\n\n\t\t\t\t\t// If there is already a '_' parameter, set its value\n\t\t\t\t\tcacheURL.replace( rts, \"$1_=\" + nonce++ ) :\n\n\t\t\t\t\t// Otherwise add one to the end\n\t\t\t\t\tcacheURL + ( rquery.test( cacheURL ) ? \"&\" : \"?\" ) + \"_=\" + nonce++;\n\t\t\t}\n\t\t}\n\n\t\t// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.\n\t\tif ( s.ifModified ) {\n\t\t\tif ( jQuery.lastModified[ cacheURL ] ) {\n\t\t\t\tjqXHR.setRequestHeader( \"If-Modified-Since\", jQuery.lastModified[ cacheURL ] );\n\t\t\t}\n\t\t\tif ( jQuery.etag[ cacheURL ] ) {\n\t\t\t\tjqXHR.setRequestHeader( \"If-None-Match\", jQuery.etag[ cacheURL ] );\n\t\t\t}\n\t\t}\n\n\t\t// Set the correct header, if data is being sent\n\t\tif ( s.data && s.hasContent && s.contentType !== false || options.contentType ) {\n\t\t\tjqXHR.setRequestHeader( \"Content-Type\", s.contentType );\n\t\t}\n\n\t\t// Set the Accepts header for the server, depending on the dataType\n\t\tjqXHR.setRequestHeader(\n\t\t\t\"Accept\",\n\t\t\ts.dataTypes[ 0 ] && s.accepts[ s.dataTypes[ 0 ] ] ?\n\t\t\t\ts.accepts[ s.dataTypes[ 0 ] ] +\n\t\t\t\t\t( s.dataTypes[ 0 ] !== \"*\" ? \", \" + allTypes + \"; q=0.01\" : \"\" ) :\n\t\t\t\ts.accepts[ \"*\" ]\n\t\t);\n\n\t\t// Check for headers option\n\t\tfor ( i in s.headers ) {\n\t\t\tjqXHR.setRequestHeader( i, s.headers[ i ] );\n\t\t}\n\n\t\t// Allow custom headers/mimetypes and early abort\n\t\tif ( s.beforeSend &&\n\t\t\t( s.beforeSend.call( callbackContext, jqXHR, s ) === false || state === 2 ) ) {\n\n\t\t\t// Abort if not done already and return\n\t\t\treturn jqXHR.abort();\n\t\t}\n\n\t\t// Aborting is no longer a cancellation\n\t\tstrAbort = \"abort\";\n\n\t\t// Install callbacks on deferreds\n\t\tfor ( i in { success: 1, error: 1, complete: 1 } ) {\n\t\t\tjqXHR[ i ]( s[ i ] );\n\t\t}\n\n\t\t// Get transport\n\t\ttransport = inspectPrefiltersOrTransports( transports, s, options, jqXHR );\n\n\t\t// If no transport, we auto-abort\n\t\tif ( !transport ) {\n\t\t\tdone( -1, \"No Transport\" );\n\t\t} else {\n\t\t\tjqXHR.readyState = 1;\n\n\t\t\t// Send global event\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( \"ajaxSend\", [ jqXHR, s ] );\n\t\t\t}\n\n\t\t\t// If request was aborted inside ajaxSend, stop there\n\t\t\tif ( state === 2 ) {\n\t\t\t\treturn jqXHR;\n\t\t\t}\n\n\t\t\t// Timeout\n\t\t\tif ( s.async && s.timeout > 0 ) {\n\t\t\t\ttimeoutTimer = window.setTimeout( function() {\n\t\t\t\t\tjqXHR.abort( \"timeout\" );\n\t\t\t\t}, s.timeout );\n\t\t\t}\n\n\t\t\ttry {\n\t\t\t\tstate = 1;\n\t\t\t\ttransport.send( requestHeaders, done );\n\t\t\t} catch ( e ) {\n\n\t\t\t\t// Propagate exception as error if not done\n\t\t\t\tif ( state < 2 ) {\n\t\t\t\t\tdone( -1, e );\n\n\t\t\t\t// Simply rethrow otherwise\n\t\t\t\t} else {\n\t\t\t\t\tthrow e;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Callback for when everything is done\n\t\tfunction done( status, nativeStatusText, responses, headers ) {\n\t\t\tvar isSuccess, success, error, response, modified,\n\t\t\t\tstatusText = nativeStatusText;\n\n\t\t\t// Called once\n\t\t\tif ( state === 2 ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// State is \"done\" now\n\t\t\tstate = 2;\n\n\t\t\t// Clear timeout if it exists\n\t\t\tif ( timeoutTimer ) {\n\t\t\t\twindow.clearTimeout( timeoutTimer );\n\t\t\t}\n\n\t\t\t// Dereference transport for early garbage collection\n\t\t\t// (no matter how long the jqXHR object will be used)\n\t\t\ttransport = undefined;\n\n\t\t\t// Cache response headers\n\t\t\tresponseHeadersString = headers || \"\";\n\n\t\t\t// Set readyState\n\t\t\tjqXHR.readyState = status > 0 ? 4 : 0;\n\n\t\t\t// Determine if successful\n\t\t\tisSuccess = status >= 200 && status < 300 || status === 304;\n\n\t\t\t// Get response data\n\t\t\tif ( responses ) {\n\t\t\t\tresponse = ajaxHandleResponses( s, jqXHR, responses );\n\t\t\t}\n\n\t\t\t// Convert no matter what (that way responseXXX fields are always set)\n\t\t\tresponse = ajaxConvert( s, response, jqXHR, isSuccess );\n\n\t\t\t// If successful, handle type chaining\n\t\t\tif ( isSuccess ) {\n\n\t\t\t\t// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.\n\t\t\t\tif ( s.ifModified ) {\n\t\t\t\t\tmodified = jqXHR.getResponseHeader( \"Last-Modified\" );\n\t\t\t\t\tif ( modified ) {\n\t\t\t\t\t\tjQuery.lastModified[ cacheURL ] = modified;\n\t\t\t\t\t}\n\t\t\t\t\tmodified = jqXHR.getResponseHeader( \"etag\" );\n\t\t\t\t\tif ( modified ) {\n\t\t\t\t\t\tjQuery.etag[ cacheURL ] = modified;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// if no content\n\t\t\t\tif ( status === 204 || s.type === \"HEAD\" ) {\n\t\t\t\t\tstatusText = \"nocontent\";\n\n\t\t\t\t// if not modified\n\t\t\t\t} else if ( status === 304 ) {\n\t\t\t\t\tstatusText = \"notmodified\";\n\n\t\t\t\t// If we have data, let's convert it\n\t\t\t\t} else {\n\t\t\t\t\tstatusText = response.state;\n\t\t\t\t\tsuccess = response.data;\n\t\t\t\t\terror = response.error;\n\t\t\t\t\tisSuccess = !error;\n\t\t\t\t}\n\t\t\t} else {\n\n\t\t\t\t// Extract error from statusText and normalize for non-aborts\n\t\t\t\terror = statusText;\n\t\t\t\tif ( status || !statusText ) {\n\t\t\t\t\tstatusText = \"error\";\n\t\t\t\t\tif ( status < 0 ) {\n\t\t\t\t\t\tstatus = 0;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Set data for the fake xhr object\n\t\t\tjqXHR.status = status;\n\t\t\tjqXHR.statusText = ( nativeStatusText || statusText ) + \"\";\n\n\t\t\t// Success/Error\n\t\t\tif ( isSuccess ) {\n\t\t\t\tdeferred.resolveWith( callbackContext, [ success, statusText, jqXHR ] );\n\t\t\t} else {\n\t\t\t\tdeferred.rejectWith( callbackContext, [ jqXHR, statusText, error ] );\n\t\t\t}\n\n\t\t\t// Status-dependent callbacks\n\t\t\tjqXHR.statusCode( statusCode );\n\t\t\tstatusCode = undefined;\n\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( isSuccess ? \"ajaxSuccess\" : \"ajaxError\",\n\t\t\t\t\t[ jqXHR, s, isSuccess ? success : error ] );\n\t\t\t}\n\n\t\t\t// Complete\n\t\t\tcompleteDeferred.fireWith( callbackContext, [ jqXHR, statusText ] );\n\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( \"ajaxComplete\", [ jqXHR, s ] );\n\n\t\t\t\t// Handle the global AJAX counter\n\t\t\t\tif ( !( --jQuery.active ) ) {\n\t\t\t\t\tjQuery.event.trigger( \"ajaxStop\" );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn jqXHR;\n\t},\n\n\tgetJSON: function( url, data, callback ) {\n\t\treturn jQuery.get( url, data, callback, \"json\" );\n\t},\n\n\tgetScript: function( url, callback ) {\n\t\treturn jQuery.get( url, undefined, callback, \"script\" );\n\t}\n} );\n\njQuery.each( [ \"get\", \"post\" ], function( i, method ) {\n\tjQuery[ method ] = function( url, data, callback, type ) {\n\n\t\t// Shift arguments if data argument was omitted\n\t\tif ( jQuery.isFunction( data ) ) {\n\t\t\ttype = type || callback;\n\t\t\tcallback = data;\n\t\t\tdata = undefined;\n\t\t}\n\n\t\t// The url can be an options object (which then must have .url)\n\t\treturn jQuery.ajax( jQuery.extend( {\n\t\t\turl: url,\n\t\t\ttype: method,\n\t\t\tdataType: type,\n\t\t\tdata: data,\n\t\t\tsuccess: callback\n\t\t}, jQuery.isPlainObject( url ) && url ) );\n\t};\n} );\n\n\njQuery._evalUrl = function( url ) {\n\treturn jQuery.ajax( {\n\t\turl: url,\n\n\t\t// Make this explicit, since user can override this through ajaxSetup (#11264)\n\t\ttype: \"GET\",\n\t\tdataType: \"script\",\n\t\tasync: false,\n\t\tglobal: false,\n\t\t\"throws\": true\n\t} );\n};\n\n\njQuery.fn.extend( {\n\twrapAll: function( html ) {\n\t\tvar wrap;\n\n\t\tif ( jQuery.isFunction( html ) ) {\n\t\t\treturn this.each( function( i ) {\n\t\t\t\tjQuery( this ).wrapAll( html.call( this, i ) );\n\t\t\t} );\n\t\t}\n\n\t\tif ( this[ 0 ] ) {\n\n\t\t\t// The elements to wrap the target around\n\t\t\twrap = jQuery( html, this[ 0 ].ownerDocument ).eq( 0 ).clone( true );\n\n\t\t\tif ( this[ 0 ].parentNode ) {\n\t\t\t\twrap.insertBefore( this[ 0 ] );\n\t\t\t}\n\n\t\t\twrap.map( function() {\n\t\t\t\tvar elem = this;\n\n\t\t\t\twhile ( elem.firstElementChild ) {\n\t\t\t\t\telem = elem.firstElementChild;\n\t\t\t\t}\n\n\t\t\t\treturn elem;\n\t\t\t} ).append( this );\n\t\t}\n\n\t\treturn this;\n\t},\n\n\twrapInner: function( html ) {\n\t\tif ( jQuery.isFunction( html ) ) {\n\t\t\treturn this.each( function( i ) {\n\t\t\t\tjQuery( this ).wrapInner( html.call( this, i ) );\n\t\t\t} );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar self = jQuery( this ),\n\t\t\t\tcontents = self.contents();\n\n\t\t\tif ( contents.length ) {\n\t\t\t\tcontents.wrapAll( html );\n\n\t\t\t} else {\n\t\t\t\tself.append( html );\n\t\t\t}\n\t\t} );\n\t},\n\n\twrap: function( html ) {\n\t\tvar isFunction = jQuery.isFunction( html );\n\n\t\treturn this.each( function( i ) {\n\t\t\tjQuery( this ).wrapAll( isFunction ? html.call( this, i ) : html );\n\t\t} );\n\t},\n\n\tunwrap: function() {\n\t\treturn this.parent().each( function() {\n\t\t\tif ( !jQuery.nodeName( this, \"body\" ) ) {\n\t\t\t\tjQuery( this ).replaceWith( this.childNodes );\n\t\t\t}\n\t\t} ).end();\n\t}\n} );\n\n\njQuery.expr.filters.hidden = function( elem ) {\n\treturn !jQuery.expr.filters.visible( elem );\n};\njQuery.expr.filters.visible = function( elem ) {\n\n\t// Support: Opera <= 12.12\n\t// Opera reports offsetWidths and offsetHeights less than zero on some elements\n\t// Use OR instead of AND as the element is not visible if either is true\n\t// See tickets #10406 and #13132\n\treturn elem.offsetWidth > 0 || elem.offsetHeight > 0 || elem.getClientRects().length > 0;\n};\n\n\n\n\nvar r20 = /%20/g,\n\trbracket = /\\[\\]$/,\n\trCRLF = /\\r?\\n/g,\n\trsubmitterTypes = /^(?:submit|button|image|reset|file)$/i,\n\trsubmittable = /^(?:input|select|textarea|keygen)/i;\n\nfunction buildParams( prefix, obj, traditional, add ) {\n\tvar name;\n\n\tif ( jQuery.isArray( obj ) ) {\n\n\t\t// Serialize array item.\n\t\tjQuery.each( obj, function( i, v ) {\n\t\t\tif ( traditional || rbracket.test( prefix ) ) {\n\n\t\t\t\t// Treat each array item as a scalar.\n\t\t\t\tadd( prefix, v );\n\n\t\t\t} else {\n\n\t\t\t\t// Item is non-scalar (array or object), encode its numeric index.\n\t\t\t\tbuildParams(\n\t\t\t\t\tprefix + \"[\" + ( typeof v === \"object\" && v != null ? i : \"\" ) + \"]\",\n\t\t\t\t\tv,\n\t\t\t\t\ttraditional,\n\t\t\t\t\tadd\n\t\t\t\t);\n\t\t\t}\n\t\t} );\n\n\t} else if ( !traditional && jQuery.type( obj ) === \"object\" ) {\n\n\t\t// Serialize object item.\n\t\tfor ( name in obj ) {\n\t\t\tbuildParams( prefix + \"[\" + name + \"]\", obj[ name ], traditional, add );\n\t\t}\n\n\t} else {\n\n\t\t// Serialize scalar item.\n\t\tadd( prefix, obj );\n\t}\n}\n\n// Serialize an array of form elements or a set of\n// key/values into a query string\njQuery.param = function( a, traditional ) {\n\tvar prefix,\n\t\ts = [],\n\t\tadd = function( key, value ) {\n\n\t\t\t// If value is a function, invoke it and return its value\n\t\t\tvalue = jQuery.isFunction( value ) ? value() : ( value == null ? \"\" : value );\n\t\t\ts[ s.length ] = encodeURIComponent( key ) + \"=\" + encodeURIComponent( value );\n\t\t};\n\n\t// Set traditional to true for jQuery <= 1.3.2 behavior.\n\tif ( traditional === undefined ) {\n\t\ttraditional = jQuery.ajaxSettings && jQuery.ajaxSettings.traditional;\n\t}\n\n\t// If an array was passed in, assume that it is an array of form elements.\n\tif ( jQuery.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) {\n\n\t\t// Serialize the form elements\n\t\tjQuery.each( a, function() {\n\t\t\tadd( this.name, this.value );\n\t\t} );\n\n\t} else {\n\n\t\t// If traditional, encode the \"old\" way (the way 1.3.2 or older\n\t\t// did it), otherwise encode params recursively.\n\t\tfor ( prefix in a ) {\n\t\t\tbuildParams( prefix, a[ prefix ], traditional, add );\n\t\t}\n\t}\n\n\t// Return the resulting serialization\n\treturn s.join( \"&\" ).replace( r20, \"+\" );\n};\n\njQuery.fn.extend( {\n\tserialize: function() {\n\t\treturn jQuery.param( this.serializeArray() );\n\t},\n\tserializeArray: function() {\n\t\treturn this.map( function() {\n\n\t\t\t// Can add propHook for \"elements\" to filter or add form elements\n\t\t\tvar elements = jQuery.prop( this, \"elements\" );\n\t\t\treturn elements ? jQuery.makeArray( elements ) : this;\n\t\t} )\n\t\t.filter( function() {\n\t\t\tvar type = this.type;\n\n\t\t\t// Use .is( \":disabled\" ) so that fieldset[disabled] works\n\t\t\treturn this.name && !jQuery( this ).is( \":disabled\" ) &&\n\t\t\t\trsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) &&\n\t\t\t\t( this.checked || !rcheckableType.test( type ) );\n\t\t} )\n\t\t.map( function( i, elem ) {\n\t\t\tvar val = jQuery( this ).val();\n\n\t\t\treturn val == null ?\n\t\t\t\tnull :\n\t\t\t\tjQuery.isArray( val ) ?\n\t\t\t\t\tjQuery.map( val, function( val ) {\n\t\t\t\t\t\treturn { name: elem.name, value: val.replace( rCRLF, \"\\r\\n\" ) };\n\t\t\t\t\t} ) :\n\t\t\t\t\t{ name: elem.name, value: val.replace( rCRLF, \"\\r\\n\" ) };\n\t\t} ).get();\n\t}\n} );\n\n\njQuery.ajaxSettings.xhr = function() {\n\ttry {\n\t\treturn new window.XMLHttpRequest();\n\t} catch ( e ) {}\n};\n\nvar xhrSuccessStatus = {\n\n\t\t// File protocol always yields status code 0, assume 200\n\t\t0: 200,\n\n\t\t// Support: IE9\n\t\t// #1450: sometimes IE returns 1223 when it should be 204\n\t\t1223: 204\n\t},\n\txhrSupported = jQuery.ajaxSettings.xhr();\n\nsupport.cors = !!xhrSupported && ( \"withCredentials\" in xhrSupported );\nsupport.ajax = xhrSupported = !!xhrSupported;\n\njQuery.ajaxTransport( function( options ) {\n\tvar callback, errorCallback;\n\n\t// Cross domain only allowed if supported through XMLHttpRequest\n\tif ( support.cors || xhrSupported && !options.crossDomain ) {\n\t\treturn {\n\t\t\tsend: function( headers, complete ) {\n\t\t\t\tvar i,\n\t\t\t\t\txhr = options.xhr();\n\n\t\t\t\txhr.open(\n\t\t\t\t\toptions.type,\n\t\t\t\t\toptions.url,\n\t\t\t\t\toptions.async,\n\t\t\t\t\toptions.username,\n\t\t\t\t\toptions.password\n\t\t\t\t);\n\n\t\t\t\t// Apply custom fields if provided\n\t\t\t\tif ( options.xhrFields ) {\n\t\t\t\t\tfor ( i in options.xhrFields ) {\n\t\t\t\t\t\txhr[ i ] = options.xhrFields[ i ];\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Override mime type if needed\n\t\t\t\tif ( options.mimeType && xhr.overrideMimeType ) {\n\t\t\t\t\txhr.overrideMimeType( options.mimeType );\n\t\t\t\t}\n\n\t\t\t\t// X-Requested-With header\n\t\t\t\t// For cross-domain requests, seeing as conditions for a preflight are\n\t\t\t\t// akin to a jigsaw puzzle, we simply never set it to be sure.\n\t\t\t\t// (it can always be set on a per-request basis or even using ajaxSetup)\n\t\t\t\t// For same-domain requests, won't change header if already provided.\n\t\t\t\tif ( !options.crossDomain && !headers[ \"X-Requested-With\" ] ) {\n\t\t\t\t\theaders[ \"X-Requested-With\" ] = \"XMLHttpRequest\";\n\t\t\t\t}\n\n\t\t\t\t// Set headers\n\t\t\t\tfor ( i in headers ) {\n\t\t\t\t\txhr.setRequestHeader( i, headers[ i ] );\n\t\t\t\t}\n\n\t\t\t\t// Callback\n\t\t\t\tcallback = function( type ) {\n\t\t\t\t\treturn function() {\n\t\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\t\tcallback = errorCallback = xhr.onload =\n\t\t\t\t\t\t\t\txhr.onerror = xhr.onabort = xhr.onreadystatechange = null;\n\n\t\t\t\t\t\t\tif ( type === \"abort\" ) {\n\t\t\t\t\t\t\t\txhr.abort();\n\t\t\t\t\t\t\t} else if ( type === \"error\" ) {\n\n\t\t\t\t\t\t\t\t// Support: IE9\n\t\t\t\t\t\t\t\t// On a manual native abort, IE9 throws\n\t\t\t\t\t\t\t\t// errors on any property access that is not readyState\n\t\t\t\t\t\t\t\tif ( typeof xhr.status !== \"number\" ) {\n\t\t\t\t\t\t\t\t\tcomplete( 0, \"error\" );\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tcomplete(\n\n\t\t\t\t\t\t\t\t\t\t// File: protocol always yields status 0; see #8605, #14207\n\t\t\t\t\t\t\t\t\t\txhr.status,\n\t\t\t\t\t\t\t\t\t\txhr.statusText\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tcomplete(\n\t\t\t\t\t\t\t\t\txhrSuccessStatus[ xhr.status ] || xhr.status,\n\t\t\t\t\t\t\t\t\txhr.statusText,\n\n\t\t\t\t\t\t\t\t\t// Support: IE9 only\n\t\t\t\t\t\t\t\t\t// IE9 has no XHR2 but throws on binary (trac-11426)\n\t\t\t\t\t\t\t\t\t// For XHR2 non-text, let the caller handle it (gh-2498)\n\t\t\t\t\t\t\t\t\t( xhr.responseType || \"text\" ) !== \"text\" ||\n\t\t\t\t\t\t\t\t\ttypeof xhr.responseText !== \"string\" ?\n\t\t\t\t\t\t\t\t\t\t{ binary: xhr.response } :\n\t\t\t\t\t\t\t\t\t\t{ text: xhr.responseText },\n\t\t\t\t\t\t\t\t\txhr.getAllResponseHeaders()\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t};\n\n\t\t\t\t// Listen to events\n\t\t\t\txhr.onload = callback();\n\t\t\t\terrorCallback = xhr.onerror = callback( \"error\" );\n\n\t\t\t\t// Support: IE9\n\t\t\t\t// Use onreadystatechange to replace onabort\n\t\t\t\t// to handle uncaught aborts\n\t\t\t\tif ( xhr.onabort !== undefined ) {\n\t\t\t\t\txhr.onabort = errorCallback;\n\t\t\t\t} else {\n\t\t\t\t\txhr.onreadystatechange = function() {\n\n\t\t\t\t\t\t// Check readyState before timeout as it changes\n\t\t\t\t\t\tif ( xhr.readyState === 4 ) {\n\n\t\t\t\t\t\t\t// Allow onerror to be called first,\n\t\t\t\t\t\t\t// but that will not handle a native abort\n\t\t\t\t\t\t\t// Also, save errorCallback to a variable\n\t\t\t\t\t\t\t// as xhr.onerror cannot be accessed\n\t\t\t\t\t\t\twindow.setTimeout( function() {\n\t\t\t\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\t\t\t\terrorCallback();\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t}\n\n\t\t\t\t// Create the abort callback\n\t\t\t\tcallback = callback( \"abort\" );\n\n\t\t\t\ttry {\n\n\t\t\t\t\t// Do send the request (this may raise an exception)\n\t\t\t\t\txhr.send( options.hasContent && options.data || null );\n\t\t\t\t} catch ( e ) {\n\n\t\t\t\t\t// #14683: Only rethrow if this hasn't been notified as an error yet\n\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\tthrow e;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\n\t\t\tabort: function() {\n\t\t\t\tif ( callback ) {\n\t\t\t\t\tcallback();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n} );\n\n\n\n\n// Install script dataType\njQuery.ajaxSetup( {\n\taccepts: {\n\t\tscript: \"text/javascript, application/javascript, \" +\n\t\t\t\"application/ecmascript, application/x-ecmascript\"\n\t},\n\tcontents: {\n\t\tscript: /\\b(?:java|ecma)script\\b/\n\t},\n\tconverters: {\n\t\t\"text script\": function( text ) {\n\t\t\tjQuery.globalEval( text );\n\t\t\treturn text;\n\t\t}\n\t}\n} );\n\n// Handle cache's special case and crossDomain\njQuery.ajaxPrefilter( \"script\", function( s ) {\n\tif ( s.cache === undefined ) {\n\t\ts.cache = false;\n\t}\n\tif ( s.crossDomain ) {\n\t\ts.type = \"GET\";\n\t}\n} );\n\n// Bind script tag hack transport\njQuery.ajaxTransport( \"script\", function( s ) {\n\n\t// This transport only deals with cross domain requests\n\tif ( s.crossDomain ) {\n\t\tvar script, callback;\n\t\treturn {\n\t\t\tsend: function( _, complete ) {\n\t\t\t\tscript = jQuery( \"<script>\" ).prop( {\n\t\t\t\t\tcharset: s.scriptCharset,\n\t\t\t\t\tsrc: s.url\n\t\t\t\t} ).on(\n\t\t\t\t\t\"load error\",\n\t\t\t\t\tcallback = function( evt ) {\n\t\t\t\t\t\tscript.remove();\n\t\t\t\t\t\tcallback = null;\n\t\t\t\t\t\tif ( evt ) {\n\t\t\t\t\t\t\tcomplete( evt.type === \"error\" ? 404 : 200, evt.type );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t);\n\n\t\t\t\t// Use native DOM manipulation to avoid our domManip AJAX trickery\n\t\t\t\tdocument.head.appendChild( script[ 0 ] );\n\t\t\t},\n\t\t\tabort: function() {\n\t\t\t\tif ( callback ) {\n\t\t\t\t\tcallback();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n} );\n\n\n\n\nvar oldCallbacks = [],\n\trjsonp = /(=)\\?(?=&|$)|\\?\\?/;\n\n// Default jsonp settings\njQuery.ajaxSetup( {\n\tjsonp: \"callback\",\n\tjsonpCallback: function() {\n\t\tvar callback = oldCallbacks.pop() || ( jQuery.expando + \"_\" + ( nonce++ ) );\n\t\tthis[ callback ] = true;\n\t\treturn callback;\n\t}\n} );\n\n// Detect, normalize options and install callbacks for jsonp requests\njQuery.ajaxPrefilter( \"json jsonp\", function( s, originalSettings, jqXHR ) {\n\n\tvar callbackName, overwritten, responseContainer,\n\t\tjsonProp = s.jsonp !== false && ( rjsonp.test( s.url ) ?\n\t\t\t\"url\" :\n\t\t\ttypeof s.data === \"string\" &&\n\t\t\t\t( s.contentType || \"\" )\n\t\t\t\t\t.indexOf( \"application/x-www-form-urlencoded\" ) === 0 &&\n\t\t\t\trjsonp.test( s.data ) && \"data\"\n\t\t);\n\n\t// Handle iff the expected data type is \"jsonp\" or we have a parameter to set\n\tif ( jsonProp || s.dataTypes[ 0 ] === \"jsonp\" ) {\n\n\t\t// Get callback name, remembering preexisting value associated with it\n\t\tcallbackName = s.jsonpCallback = jQuery.isFunction( s.jsonpCallback ) ?\n\t\t\ts.jsonpCallback() :\n\t\t\ts.jsonpCallback;\n\n\t\t// Insert callback into url or form data\n\t\tif ( jsonProp ) {\n\t\t\ts[ jsonProp ] = s[ jsonProp ].replace( rjsonp, \"$1\" + callbackName );\n\t\t} else if ( s.jsonp !== false ) {\n\t\t\ts.url += ( rquery.test( s.url ) ? \"&\" : \"?\" ) + s.jsonp + \"=\" + callbackName;\n\t\t}\n\n\t\t// Use data converter to retrieve json after script execution\n\t\ts.converters[ \"script json\" ] = function() {\n\t\t\tif ( !responseContainer ) {\n\t\t\t\tjQuery.error( callbackName + \" was not called\" );\n\t\t\t}\n\t\t\treturn responseContainer[ 0 ];\n\t\t};\n\n\t\t// Force json dataType\n\t\ts.dataTypes[ 0 ] = \"json\";\n\n\t\t// Install callback\n\t\toverwritten = window[ callbackName ];\n\t\twindow[ callbackName ] = function() {\n\t\t\tresponseContainer = arguments;\n\t\t};\n\n\t\t// Clean-up function (fires after converters)\n\t\tjqXHR.always( function() {\n\n\t\t\t// If previous value didn't exist - remove it\n\t\t\tif ( overwritten === undefined ) {\n\t\t\t\tjQuery( window ).removeProp( callbackName );\n\n\t\t\t// Otherwise restore preexisting value\n\t\t\t} else {\n\t\t\t\twindow[ callbackName ] = overwritten;\n\t\t\t}\n\n\t\t\t// Save back as free\n\t\t\tif ( s[ callbackName ] ) {\n\n\t\t\t\t// Make sure that re-using the options doesn't screw things around\n\t\t\t\ts.jsonpCallback = originalSettings.jsonpCallback;\n\n\t\t\t\t// Save the callback name for future use\n\t\t\t\toldCallbacks.push( callbackName );\n\t\t\t}\n\n\t\t\t// Call if it was a function and we have a response\n\t\t\tif ( responseContainer && jQuery.isFunction( overwritten ) ) {\n\t\t\t\toverwritten( responseContainer[ 0 ] );\n\t\t\t}\n\n\t\t\tresponseContainer = overwritten = undefined;\n\t\t} );\n\n\t\t// Delegate to script\n\t\treturn \"script\";\n\t}\n} );\n\n\n\n\n// Argument \"data\" should be string of html\n// context (optional): If specified, the fragment will be created in this context,\n// defaults to document\n// keepScripts (optional): If true, will include scripts passed in the html string\njQuery.parseHTML = function( data, context, keepScripts ) {\n\tif ( !data || typeof data !== \"string\" ) {\n\t\treturn null;\n\t}\n\tif ( typeof context === \"boolean\" ) {\n\t\tkeepScripts = context;\n\t\tcontext = false;\n\t}\n\tcontext = context || document;\n\n\tvar parsed = rsingleTag.exec( data ),\n\t\tscripts = !keepScripts && [];\n\n\t// Single tag\n\tif ( parsed ) {\n\t\treturn [ context.createElement( parsed[ 1 ] ) ];\n\t}\n\n\tparsed = buildFragment( [ data ], context, scripts );\n\n\tif ( scripts && scripts.length ) {\n\t\tjQuery( scripts ).remove();\n\t}\n\n\treturn jQuery.merge( [], parsed.childNodes );\n};\n\n\n// Keep a copy of the old load method\nvar _load = jQuery.fn.load;\n\n/**\n * Load a url into a page\n */\njQuery.fn.load = function( url, params, callback ) {\n\tif ( typeof url !== \"string\" && _load ) {\n\t\treturn _load.apply( this, arguments );\n\t}\n\n\tvar selector, type, response,\n\t\tself = this,\n\t\toff = url.indexOf( \" \" );\n\n\tif ( off > -1 ) {\n\t\tselector = jQuery.trim( url.slice( off ) );\n\t\turl = url.slice( 0, off );\n\t}\n\n\t// If it's a function\n\tif ( jQuery.isFunction( params ) ) {\n\n\t\t// We assume that it's the callback\n\t\tcallback = params;\n\t\tparams = undefined;\n\n\t// Otherwise, build a param string\n\t} else if ( params && typeof params === \"object\" ) {\n\t\ttype = \"POST\";\n\t}\n\n\t// If we have elements to modify, make the request\n\tif ( self.length > 0 ) {\n\t\tjQuery.ajax( {\n\t\t\turl: url,\n\n\t\t\t// If \"type\" variable is undefined, then \"GET\" method will be used.\n\t\t\t// Make value of this field explicit since\n\t\t\t// user can override it through ajaxSetup method\n\t\t\ttype: type || \"GET\",\n\t\t\tdataType: \"html\",\n\t\t\tdata: params\n\t\t} ).done( function( responseText ) {\n\n\t\t\t// Save response for use in complete callback\n\t\t\tresponse = arguments;\n\n\t\t\tself.html( selector ?\n\n\t\t\t\t// If a selector was specified, locate the right elements in a dummy div\n\t\t\t\t// Exclude scripts to avoid IE 'Permission Denied' errors\n\t\t\t\tjQuery( \"<div>\" ).append( jQuery.parseHTML( responseText ) ).find( selector ) :\n\n\t\t\t\t// Otherwise use the full result\n\t\t\t\tresponseText );\n\n\t\t// If the request succeeds, this function gets \"data\", \"status\", \"jqXHR\"\n\t\t// but they are ignored because response was set above.\n\t\t// If it fails, this function gets \"jqXHR\", \"status\", \"error\"\n\t\t} ).always( callback && function( jqXHR, status ) {\n\t\t\tself.each( function() {\n\t\t\t\tcallback.apply( this, response || [ jqXHR.responseText, status, jqXHR ] );\n\t\t\t} );\n\t\t} );\n\t}\n\n\treturn this;\n};\n\n\n\n\n// Attach a bunch of functions for handling common AJAX events\njQuery.each( [\n\t\"ajaxStart\",\n\t\"ajaxStop\",\n\t\"ajaxComplete\",\n\t\"ajaxError\",\n\t\"ajaxSuccess\",\n\t\"ajaxSend\"\n], function( i, type ) {\n\tjQuery.fn[ type ] = function( fn ) {\n\t\treturn this.on( type, fn );\n\t};\n} );\n\n\n\n\njQuery.expr.filters.animated = function( elem ) {\n\treturn jQuery.grep( jQuery.timers, function( fn ) {\n\t\treturn elem === fn.elem;\n\t} ).length;\n};\n\n\n\n\n/**\n * Gets a window from an element\n */\nfunction getWindow( elem ) {\n\treturn jQuery.isWindow( elem ) ? elem : elem.nodeType === 9 && elem.defaultView;\n}\n\njQuery.offset = {\n\tsetOffset: function( elem, options, i ) {\n\t\tvar curPosition, curLeft, curCSSTop, curTop, curOffset, curCSSLeft, calculatePosition,\n\t\t\tposition = jQuery.css( elem, \"position\" ),\n\t\t\tcurElem = jQuery( elem ),\n\t\t\tprops = {};\n\n\t\t// Set position first, in-case top/left are set even on static elem\n\t\tif ( position === \"static\" ) {\n\t\t\telem.style.position = \"relative\";\n\t\t}\n\n\t\tcurOffset = curElem.offset();\n\t\tcurCSSTop = jQuery.css( elem, \"top\" );\n\t\tcurCSSLeft = jQuery.css( elem, \"left\" );\n\t\tcalculatePosition = ( position === \"absolute\" || position === \"fixed\" ) &&\n\t\t\t( curCSSTop + curCSSLeft ).indexOf( \"auto\" ) > -1;\n\n\t\t// Need to be able to calculate position if either\n\t\t// top or left is auto and position is either absolute or fixed\n\t\tif ( calculatePosition ) {\n\t\t\tcurPosition = curElem.position();\n\t\t\tcurTop = curPosition.top;\n\t\t\tcurLeft = curPosition.left;\n\n\t\t} else {\n\t\t\tcurTop = parseFloat( curCSSTop ) || 0;\n\t\t\tcurLeft = parseFloat( curCSSLeft ) || 0;\n\t\t}\n\n\t\tif ( jQuery.isFunction( options ) ) {\n\n\t\t\t// Use jQuery.extend here to allow modification of coordinates argument (gh-1848)\n\t\t\toptions = options.call( elem, i, jQuery.extend( {}, curOffset ) );\n\t\t}\n\n\t\tif ( options.top != null ) {\n\t\t\tprops.top = ( options.top - curOffset.top ) + curTop;\n\t\t}\n\t\tif ( options.left != null ) {\n\t\t\tprops.left = ( options.left - curOffset.left ) + curLeft;\n\t\t}\n\n\t\tif ( \"using\" in options ) {\n\t\t\toptions.using.call( elem, props );\n\n\t\t} else {\n\t\t\tcurElem.css( props );\n\t\t}\n\t}\n};\n\njQuery.fn.extend( {\n\toffset: function( options ) {\n\t\tif ( arguments.length ) {\n\t\t\treturn options === undefined ?\n\t\t\t\tthis :\n\t\t\t\tthis.each( function( i ) {\n\t\t\t\t\tjQuery.offset.setOffset( this, options, i );\n\t\t\t\t} );\n\t\t}\n\n\t\tvar docElem, win,\n\t\t\telem = this[ 0 ],\n\t\t\tbox = { top: 0, left: 0 },\n\t\t\tdoc = elem && elem.ownerDocument;\n\n\t\tif ( !doc ) {\n\t\t\treturn;\n\t\t}\n\n\t\tdocElem = doc.documentElement;\n\n\t\t// Make sure it's not a disconnected DOM node\n\t\tif ( !jQuery.contains( docElem, elem ) ) {\n\t\t\treturn box;\n\t\t}\n\n\t\tbox = elem.getBoundingClientRect();\n\t\twin = getWindow( doc );\n\t\treturn {\n\t\t\ttop: box.top + win.pageYOffset - docElem.clientTop,\n\t\t\tleft: box.left + win.pageXOffset - docElem.clientLeft\n\t\t};\n\t},\n\n\tposition: function() {\n\t\tif ( !this[ 0 ] ) {\n\t\t\treturn;\n\t\t}\n\n\t\tvar offsetParent, offset,\n\t\t\telem = this[ 0 ],\n\t\t\tparentOffset = { top: 0, left: 0 };\n\n\t\t// Fixed elements are offset from window (parentOffset = {top:0, left: 0},\n\t\t// because it is its only offset parent\n\t\tif ( jQuery.css( elem, \"position\" ) === \"fixed\" ) {\n\n\t\t\t// Assume getBoundingClientRect is there when computed position is fixed\n\t\t\toffset = elem.getBoundingClientRect();\n\n\t\t} else {\n\n\t\t\t// Get *real* offsetParent\n\t\t\toffsetParent = this.offsetParent();\n\n\t\t\t// Get correct offsets\n\t\t\toffset = this.offset();\n\t\t\tif ( !jQuery.nodeName( offsetParent[ 0 ], \"html\" ) ) {\n\t\t\t\tparentOffset = offsetParent.offset();\n\t\t\t}\n\n\t\t\t// Add offsetParent borders\n\t\t\tparentOffset.top += jQuery.css( offsetParent[ 0 ], \"borderTopWidth\", true );\n\t\t\tparentOffset.left += jQuery.css( offsetParent[ 0 ], \"borderLeftWidth\", true );\n\t\t}\n\n\t\t// Subtract parent offsets and element margins\n\t\treturn {\n\t\t\ttop: offset.top - parentOffset.top - jQuery.css( elem, \"marginTop\", true ),\n\t\t\tleft: offset.left - parentOffset.left - jQuery.css( elem, \"marginLeft\", true )\n\t\t};\n\t},\n\n\t// This method will return documentElement in the following cases:\n\t// 1) For the element inside the iframe without offsetParent, this method will return\n\t// documentElement of the parent window\n\t// 2) For the hidden or detached element\n\t// 3) For body or html element, i.e. in case of the html node - it will return itself\n\t//\n\t// but those exceptions were never presented as a real life use-cases\n\t// and might be considered as more preferable results.\n\t//\n\t// This logic, however, is not guaranteed and can change at any point in the future\n\toffsetParent: function() {\n\t\treturn this.map( function() {\n\t\t\tvar offsetParent = this.offsetParent;\n\n\t\t\twhile ( offsetParent && jQuery.css( offsetParent, \"position\" ) === \"static\" ) {\n\t\t\t\toffsetParent = offsetParent.offsetParent;\n\t\t\t}\n\n\t\t\treturn offsetParent || documentElement;\n\t\t} );\n\t}\n} );\n\n// Create scrollLeft and scrollTop methods\njQuery.each( { scrollLeft: \"pageXOffset\", scrollTop: \"pageYOffset\" }, function( method, prop ) {\n\tvar top = \"pageYOffset\" === prop;\n\n\tjQuery.fn[ method ] = function( val ) {\n\t\treturn access( this, function( elem, method, val ) {\n\t\t\tvar win = getWindow( elem );\n\n\t\t\tif ( val === undefined ) {\n\t\t\t\treturn win ? win[ prop ] : elem[ method ];\n\t\t\t}\n\n\t\t\tif ( win ) {\n\t\t\t\twin.scrollTo(\n\t\t\t\t\t!top ? val : win.pageXOffset,\n\t\t\t\t\ttop ? val : win.pageYOffset\n\t\t\t\t);\n\n\t\t\t} else {\n\t\t\t\telem[ method ] = val;\n\t\t\t}\n\t\t}, method, val, arguments.length );\n\t};\n} );\n\n// Support: Safari<7-8+, Chrome<37-44+\n// Add the top/left cssHooks using jQuery.fn.position\n// Webkit bug: https://bugs.webkit.org/show_bug.cgi?id=29084\n// Blink bug: https://code.google.com/p/chromium/issues/detail?id=229280\n// getComputedStyle returns percent when specified for top/left/bottom/right;\n// rather than make the css module depend on the offset module, just check for it here\njQuery.each( [ \"top\", \"left\" ], function( i, prop ) {\n\tjQuery.cssHooks[ prop ] = addGetHookIf( support.pixelPosition,\n\t\tfunction( elem, computed ) {\n\t\t\tif ( computed ) {\n\t\t\t\tcomputed = curCSS( elem, prop );\n\n\t\t\t\t// If curCSS returns percentage, fallback to offset\n\t\t\t\treturn rnumnonpx.test( computed ) ?\n\t\t\t\t\tjQuery( elem ).position()[ prop ] + \"px\" :\n\t\t\t\t\tcomputed;\n\t\t\t}\n\t\t}\n\t);\n} );\n\n\n// Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods\njQuery.each( { Height: \"height\", Width: \"width\" }, function( name, type ) {\n\tjQuery.each( { padding: \"inner\" + name, content: type, \"\": \"outer\" + name },\n\t\tfunction( defaultExtra, funcName ) {\n\n\t\t// Margin is only for outerHeight, outerWidth\n\t\tjQuery.fn[ funcName ] = function( margin, value ) {\n\t\t\tvar chainable = arguments.length && ( defaultExtra || typeof margin !== \"boolean\" ),\n\t\t\t\textra = defaultExtra || ( margin === true || value === true ? \"margin\" : \"border\" );\n\n\t\t\treturn access( this, function( elem, type, value ) {\n\t\t\t\tvar doc;\n\n\t\t\t\tif ( jQuery.isWindow( elem ) ) {\n\n\t\t\t\t\t// As of 5/8/2012 this will yield incorrect results for Mobile Safari, but there\n\t\t\t\t\t// isn't a whole lot we can do. See pull request at this URL for discussion:\n\t\t\t\t\t// https://github.com/jquery/jquery/pull/764\n\t\t\t\t\treturn elem.document.documentElement[ \"client\" + name ];\n\t\t\t\t}\n\n\t\t\t\t// Get document width or height\n\t\t\t\tif ( elem.nodeType === 9 ) {\n\t\t\t\t\tdoc = elem.documentElement;\n\n\t\t\t\t\t// Either scroll[Width/Height] or offset[Width/Height] or client[Width/Height],\n\t\t\t\t\t// whichever is greatest\n\t\t\t\t\treturn Math.max(\n\t\t\t\t\t\telem.body[ \"scroll\" + name ], doc[ \"scroll\" + name ],\n\t\t\t\t\t\telem.body[ \"offset\" + name ], doc[ \"offset\" + name ],\n\t\t\t\t\t\tdoc[ \"client\" + name ]\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn value === undefined ?\n\n\t\t\t\t\t// Get width or height on the element, requesting but not forcing parseFloat\n\t\t\t\t\tjQuery.css( elem, type, extra ) :\n\n\t\t\t\t\t// Set width or height on the element\n\t\t\t\t\tjQuery.style( elem, type, value, extra );\n\t\t\t}, type, chainable ? margin : undefined, chainable, null );\n\t\t};\n\t} );\n} );\n\n\njQuery.fn.extend( {\n\n\tbind: function( types, data, fn ) {\n\t\treturn this.on( types, null, data, fn );\n\t},\n\tunbind: function( types, fn ) {\n\t\treturn this.off( types, null, fn );\n\t},\n\n\tdelegate: function( selector, types, data, fn ) {\n\t\treturn this.on( types, selector, data, fn );\n\t},\n\tundelegate: function( selector, types, fn ) {\n\n\t\t// ( namespace ) or ( selector, types [, fn] )\n\t\treturn arguments.length === 1 ?\n\t\t\tthis.off( selector, \"**\" ) :\n\t\t\tthis.off( types, selector || \"**\", fn );\n\t},\n\tsize: function() {\n\t\treturn this.length;\n\t}\n} );\n\njQuery.fn.andSelf = jQuery.fn.addBack;\n\n\n\n\n// Register as a named AMD module, since jQuery can be concatenated with other\n// files that may use define, but not via a proper concatenation script that\n// understands anonymous AMD modules. A named AMD is safest and most robust\n// way to register. Lowercase jquery is used because AMD module names are\n// derived from file names, and jQuery is normally delivered in a lowercase\n// file name. Do this after creating the global so that if an AMD module wants\n// to call noConflict to hide this version of jQuery, it will work.\n\n// Note that for maximum portability, libraries that are not jQuery should\n// declare themselves as anonymous modules, and avoid setting a global if an\n// AMD loader is present. jQuery is a special case. For more information, see\n// https://github.com/jrburke/requirejs/wiki/Updating-existing-libraries#wiki-anon\n\nif ( typeof define === \"function\" && define.amd ) {\n\tdefine( \"jquery\", [], function() {\n\t\treturn jQuery;\n\t} );\n}\n\n\n\nvar\n\n\t// Map over jQuery in case of overwrite\n\t_jQuery = window.jQuery,\n\n\t// Map over the $ in case of overwrite\n\t_$ = window.$;\n\njQuery.noConflict = function( deep ) {\n\tif ( window.$ === jQuery ) {\n\t\twindow.$ = _$;\n\t}\n\n\tif ( deep && window.jQuery === jQuery ) {\n\t\twindow.jQuery = _jQuery;\n\t}\n\n\treturn jQuery;\n};\n\n// Expose jQuery and $ identifiers, even in AMD\n// (#7102#comment:10, https://github.com/jquery/jquery/pull/557)\n// and CommonJS for browser emulators (#13566)\nif ( !noGlobal ) {\n\twindow.jQuery = window.$ = jQuery;\n}\n\nreturn jQuery;\n}));\n\n},{}],19:[function(require,module,exports){\n(function() {\n var callWithJQuery;\n\n callWithJQuery = function(pivotModule) {\n if (typeof exports === \"object\" && typeof module === \"object\") {\n return pivotModule(require(\"jquery\"), require(\"d3\"));\n } else if (typeof define === \"function\" && define.amd) {\n return define([\"jquery\", \"d3\"], pivotModule);\n } else {\n return pivotModule(jQuery, d3);\n }\n };\n\n callWithJQuery(function($, d3) {\n return $.pivotUtilities.d3_renderers = {\n Treemap: function(pivotData, opts) {\n var addToTree, color, defaults, height, i, len, ref, result, rowKey, tree, treemap, value, width;\n defaults = {\n localeStrings: {},\n d3: {\n width: function() {\n return $(window).width() / 1.4;\n },\n height: function() {\n return $(window).height() / 1.4;\n }\n }\n };\n opts = $.extend(defaults, opts);\n result = $(\"<div>\").css({\n width: \"100%\",\n height: \"100%\"\n });\n tree = {\n name: \"All\",\n children: []\n };\n addToTree = function(tree, path, value) {\n var child, i, len, newChild, ref, x;\n if (path.length === 0) {\n tree.value = value;\n return;\n }\n if (tree.children == null) {\n tree.children = [];\n }\n x = path.shift();\n ref = tree.children;\n for (i = 0, len = ref.length; i < len; i++) {\n child = ref[i];\n if (!(child.name === x)) {\n continue;\n }\n addToTree(child, path, value);\n return;\n }\n newChild = {\n name: x\n };\n addToTree(newChild, path, value);\n return tree.children.push(newChild);\n };\n ref = pivotData.getRowKeys();\n for (i = 0, len = ref.length; i < len; i++) {\n rowKey = ref[i];\n value = pivotData.getAggregator(rowKey, []).value();\n if (value != null) {\n addToTree(tree, rowKey, value);\n }\n }\n color = d3.scale.category10();\n width = opts.d3.width();\n height = opts.d3.height();\n treemap = d3.layout.treemap().size([width, height]).sticky(true).value(function(d) {\n return d.size;\n });\n d3.select(result[0]).append(\"div\").style(\"position\", \"relative\").style(\"width\", width + \"px\").style(\"height\", height + \"px\").datum(tree).selectAll(\".node\").data(treemap.padding([15, 0, 0, 0]).value(function(d) {\n return d.value;\n }).nodes).enter().append(\"div\").attr(\"class\", \"node\").style(\"background\", function(d) {\n if (d.children != null) {\n return \"lightgrey\";\n } else {\n return color(d.name);\n }\n }).text(function(d) {\n return d.name;\n }).call(function() {\n this.style(\"left\", function(d) {\n return d.x + \"px\";\n }).style(\"top\", function(d) {\n return d.y + \"px\";\n }).style(\"width\", function(d) {\n return Math.max(0, d.dx - 1) + \"px\";\n }).style(\"height\", function(d) {\n return Math.max(0, d.dy - 1) + \"px\";\n });\n });\n return result;\n }\n };\n });\n\n}).call(this);\n\n\n\n},{\"d3\":11,\"jquery\":18}],20:[function(require,module,exports){\n(function() {\n var callWithJQuery;\n\n callWithJQuery = function(pivotModule) {\n if (typeof exports === \"object\" && typeof module === \"object\") {\n return pivotModule(require(\"jquery\"));\n } else if (typeof define === \"function\" && define.amd) {\n return define([\"jquery\"], pivotModule);\n } else {\n return pivotModule(jQuery);\n }\n };\n\n callWithJQuery(function($) {\n var makeGoogleChart;\n makeGoogleChart = function(chartType, extraOptions) {\n return function(pivotData, opts) {\n var agg, base, base1, colKey, colKeys, dataArray, dataTable, defaults, fullAggName, groupByTitle, h, hAxisTitle, headers, i, j, len, len1, numCharsInHAxis, options, ref, result, row, rowKey, rowKeys, title, tree2, vAxisTitle, val, wrapper, x, y;\n defaults = {\n localeStrings: {\n vs: \"vs\",\n by: \"by\"\n },\n gchart: {}\n };\n opts = $.extend(true, defaults, opts);\n if ((base = opts.gchart).width == null) {\n base.width = window.innerWidth / 1.4;\n }\n if ((base1 = opts.gchart).height == null) {\n base1.height = window.innerHeight / 1.4;\n }\n rowKeys = pivotData.getRowKeys();\n if (rowKeys.length === 0) {\n rowKeys.push([]);\n }\n colKeys = pivotData.getColKeys();\n if (colKeys.length === 0) {\n colKeys.push([]);\n }\n fullAggName = pivotData.aggregatorName;\n if (pivotData.valAttrs.length) {\n fullAggName += \"(\" + (pivotData.valAttrs.join(\", \")) + \")\";\n }\n headers = (function() {\n var i, len, results;\n results = [];\n for (i = 0, len = rowKeys.length; i < len; i++) {\n h = rowKeys[i];\n results.push(h.join(\"-\"));\n }\n return results;\n })();\n headers.unshift(\"\");\n numCharsInHAxis = 0;\n if (chartType === \"ScatterChart\") {\n dataArray = [];\n ref = pivotData.tree;\n for (y in ref) {\n tree2 = ref[y];\n for (x in tree2) {\n agg = tree2[x];\n dataArray.push([parseFloat(x), parseFloat(y), fullAggName + \": \\n\" + agg.format(agg.value())]);\n }\n }\n dataTable = new google.visualization.DataTable();\n dataTable.addColumn('number', pivotData.colAttrs.join(\"-\"));\n dataTable.addColumn('number', pivotData.rowAttrs.join(\"-\"));\n dataTable.addColumn({\n type: \"string\",\n role: \"tooltip\"\n });\n dataTable.addRows(dataArray);\n hAxisTitle = pivotData.colAttrs.join(\"-\");\n vAxisTitle = pivotData.rowAttrs.join(\"-\");\n title = \"\";\n } else {\n dataArray = [headers];\n for (i = 0, len = colKeys.length; i < len; i++) {\n colKey = colKeys[i];\n row = [colKey.join(\"-\")];\n numCharsInHAxis += row[0].length;\n for (j = 0, len1 = rowKeys.length; j < len1; j++) {\n rowKey = rowKeys[j];\n agg = pivotData.getAggregator(rowKey, colKey);\n if (agg.value() != null) {\n val = agg.value();\n if ($.isNumeric(val)) {\n if (val < 1) {\n row.push(parseFloat(val.toPrecision(3)));\n } else {\n row.push(parseFloat(val.toFixed(3)));\n }\n } else {\n row.push(val);\n }\n } else {\n row.push(null);\n }\n }\n dataArray.push(row);\n }\n dataTable = google.visualization.arrayToDataTable(dataArray);\n title = vAxisTitle = fullAggName;\n hAxisTitle = pivotData.colAttrs.join(\"-\");\n if (hAxisTitle !== \"\") {\n title += \" \" + opts.localeStrings.vs + \" \" + hAxisTitle;\n }\n groupByTitle = pivotData.rowAttrs.join(\"-\");\n if (groupByTitle !== \"\") {\n title += \" \" + opts.localeStrings.by + \" \" + groupByTitle;\n }\n }\n options = {\n title: title,\n hAxis: {\n title: hAxisTitle,\n slantedText: numCharsInHAxis > 50\n },\n vAxis: {\n title: vAxisTitle\n },\n tooltip: {\n textStyle: {\n fontName: 'Arial',\n fontSize: 12\n }\n }\n };\n if (chartType === \"ColumnChart\") {\n options.vAxis.minValue = 0;\n }\n if (chartType === \"ScatterChart\") {\n options.legend = {\n position: \"none\"\n };\n options.chartArea = {\n 'width': '80%',\n 'height': '80%'\n };\n } else if (dataArray[0].length === 2 && dataArray[0][1] === \"\") {\n options.legend = {\n position: \"none\"\n };\n }\n $.extend(options, opts.gchart, extraOptions);\n result = $(\"<div>\").css({\n width: \"100%\",\n height: \"100%\"\n });\n wrapper = new google.visualization.ChartWrapper({\n dataTable: dataTable,\n chartType: chartType,\n options: options\n });\n wrapper.draw(result[0]);\n result.bind(\"dblclick\", function() {\n var editor;\n editor = new google.visualization.ChartEditor();\n google.visualization.events.addListener(editor, 'ok', function() {\n return editor.getChartWrapper().draw(result[0]);\n });\n return editor.openDialog(wrapper);\n });\n return result;\n };\n };\n return $.pivotUtilities.gchart_renderers = {\n \"Line Chart\": makeGoogleChart(\"LineChart\"),\n \"Bar Chart\": makeGoogleChart(\"ColumnChart\"),\n \"Stacked Bar Chart\": makeGoogleChart(\"ColumnChart\", {\n isStacked: true\n }),\n \"Area Chart\": makeGoogleChart(\"AreaChart\", {\n isStacked: true\n }),\n \"Scatter Chart\": makeGoogleChart(\"ScatterChart\")\n };\n });\n\n}).call(this);\n\n\n\n},{\"jquery\":18}],21:[function(require,module,exports){\n(function() {\n var callWithJQuery,\n indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; },\n slice = [].slice,\n bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n hasProp = {}.hasOwnProperty;\n\n callWithJQuery = function(pivotModule) {\n if (typeof exports === \"object\" && typeof module === \"object\") {\n return pivotModule(require(\"jquery\"));\n } else if (typeof define === \"function\" && define.amd) {\n return define([\"jquery\"], pivotModule);\n } else {\n return pivotModule(jQuery);\n }\n };\n\n callWithJQuery(function($) {\n\n /*\n Utilities\n */\n var PivotData, addSeparators, aggregatorTemplates, aggregators, dayNamesEn, derivers, getSort, locales, mthNamesEn, naturalSort, numberFormat, pivotTableRenderer, renderers, sortAs, usFmt, usFmtInt, usFmtPct, zeroPad;\n addSeparators = function(nStr, thousandsSep, decimalSep) {\n var rgx, x, x1, x2;\n nStr += '';\n x = nStr.split('.');\n x1 = x[0];\n x2 = x.length > 1 ? decimalSep + x[1] : '';\n rgx = /(\\d+)(\\d{3})/;\n while (rgx.test(x1)) {\n x1 = x1.replace(rgx, '$1' + thousandsSep + '$2');\n }\n return x1 + x2;\n };\n numberFormat = function(opts) {\n var defaults;\n defaults = {\n digitsAfterDecimal: 2,\n scaler: 1,\n thousandsSep: \",\",\n decimalSep: \".\",\n prefix: \"\",\n suffix: \"\",\n showZero: false\n };\n opts = $.extend(defaults, opts);\n return function(x) {\n var result;\n if (isNaN(x) || !isFinite(x)) {\n return \"\";\n }\n if (x === 0 && !opts.showZero) {\n return \"\";\n }\n result = addSeparators((opts.scaler * x).toFixed(opts.digitsAfterDecimal), opts.thousandsSep, opts.decimalSep);\n return \"\" + opts.prefix + result + opts.suffix;\n };\n };\n usFmt = numberFormat();\n usFmtInt = numberFormat({\n digitsAfterDecimal: 0\n });\n usFmtPct = numberFormat({\n digitsAfterDecimal: 1,\n scaler: 100,\n suffix: \"%\"\n });\n aggregatorTemplates = {\n count: function(formatter) {\n if (formatter == null) {\n formatter = usFmtInt;\n }\n return function() {\n return function(data, rowKey, colKey) {\n return {\n count: 0,\n push: function() {\n return this.count++;\n },\n value: function() {\n return this.count;\n },\n format: formatter\n };\n };\n };\n },\n countUnique: function(formatter) {\n if (formatter == null) {\n formatter = usFmtInt;\n }\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n uniq: [],\n push: function(record) {\n var ref;\n if (ref = record[attr], indexOf.call(this.uniq, ref) < 0) {\n return this.uniq.push(record[attr]);\n }\n },\n value: function() {\n return this.uniq.length;\n },\n format: formatter,\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n listUnique: function(sep) {\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n uniq: [],\n push: function(record) {\n var ref;\n if (ref = record[attr], indexOf.call(this.uniq, ref) < 0) {\n return this.uniq.push(record[attr]);\n }\n },\n value: function() {\n return this.uniq.join(sep);\n },\n format: function(x) {\n return x;\n },\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n sum: function(formatter) {\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n sum: 0,\n push: function(record) {\n if (!isNaN(parseFloat(record[attr]))) {\n return this.sum += parseFloat(record[attr]);\n }\n },\n value: function() {\n return this.sum;\n },\n format: formatter,\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n min: function(formatter) {\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n val: null,\n push: function(record) {\n var ref, x;\n x = parseFloat(record[attr]);\n if (!isNaN(x)) {\n return this.val = Math.min(x, (ref = this.val) != null ? ref : x);\n }\n },\n value: function() {\n return this.val;\n },\n format: formatter,\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n max: function(formatter) {\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n val: null,\n push: function(record) {\n var ref, x;\n x = parseFloat(record[attr]);\n if (!isNaN(x)) {\n return this.val = Math.max(x, (ref = this.val) != null ? ref : x);\n }\n },\n value: function() {\n return this.val;\n },\n format: formatter,\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n average: function(formatter) {\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n sum: 0,\n len: 0,\n push: function(record) {\n if (!isNaN(parseFloat(record[attr]))) {\n this.sum += parseFloat(record[attr]);\n return this.len++;\n }\n },\n value: function() {\n return this.sum / this.len;\n },\n format: formatter,\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n sumOverSum: function(formatter) {\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var denom, num;\n num = arg[0], denom = arg[1];\n return function(data, rowKey, colKey) {\n return {\n sumNum: 0,\n sumDenom: 0,\n push: function(record) {\n if (!isNaN(parseFloat(record[num]))) {\n this.sumNum += parseFloat(record[num]);\n }\n if (!isNaN(parseFloat(record[denom]))) {\n return this.sumDenom += parseFloat(record[denom]);\n }\n },\n value: function() {\n return this.sumNum / this.sumDenom;\n },\n format: formatter,\n numInputs: (num != null) && (denom != null) ? 0 : 2\n };\n };\n };\n },\n sumOverSumBound80: function(upper, formatter) {\n if (upper == null) {\n upper = true;\n }\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var denom, num;\n num = arg[0], denom = arg[1];\n return function(data, rowKey, colKey) {\n return {\n sumNum: 0,\n sumDenom: 0,\n push: function(record) {\n if (!isNaN(parseFloat(record[num]))) {\n this.sumNum += parseFloat(record[num]);\n }\n if (!isNaN(parseFloat(record[denom]))) {\n return this.sumDenom += parseFloat(record[denom]);\n }\n },\n value: function() {\n var sign;\n sign = upper ? 1 : -1;\n return (0.821187207574908 / this.sumDenom + this.sumNum / this.sumDenom + 1.2815515655446004 * sign * Math.sqrt(0.410593603787454 / (this.sumDenom * this.sumDenom) + (this.sumNum * (1 - this.sumNum / this.sumDenom)) / (this.sumDenom * this.sumDenom))) / (1 + 1.642374415149816 / this.sumDenom);\n },\n format: formatter,\n numInputs: (num != null) && (denom != null) ? 0 : 2\n };\n };\n };\n },\n fractionOf: function(wrapped, type, formatter) {\n if (type == null) {\n type = \"total\";\n }\n if (formatter == null) {\n formatter = usFmtPct;\n }\n return function() {\n var x;\n x = 1 <= arguments.length ? slice.call(arguments, 0) : [];\n return function(data, rowKey, colKey) {\n return {\n selector: {\n total: [[], []],\n row: [rowKey, []],\n col: [[], colKey]\n }[type],\n inner: wrapped.apply(null, x)(data, rowKey, colKey),\n push: function(record) {\n return this.inner.push(record);\n },\n format: formatter,\n value: function() {\n return this.inner.value() / data.getAggregator.apply(data, this.selector).inner.value();\n },\n numInputs: wrapped.apply(null, x)().numInputs\n };\n };\n };\n }\n };\n aggregators = (function(tpl) {\n return {\n \"Count\": tpl.count(usFmtInt),\n \"Count Unique Values\": tpl.countUnique(usFmtInt),\n \"List Unique Values\": tpl.listUnique(\", \"),\n \"Sum\": tpl.sum(usFmt),\n \"Integer Sum\": tpl.sum(usFmtInt),\n \"Average\": tpl.average(usFmt),\n \"Minimum\": tpl.min(usFmt),\n \"Maximum\": tpl.max(usFmt),\n \"Sum over Sum\": tpl.sumOverSum(usFmt),\n \"80% Upper Bound\": tpl.sumOverSumBound80(true, usFmt),\n \"80% Lower Bound\": tpl.sumOverSumBound80(false, usFmt),\n \"Sum as Fraction of Total\": tpl.fractionOf(tpl.sum(), \"total\", usFmtPct),\n \"Sum as Fraction of Rows\": tpl.fractionOf(tpl.sum(), \"row\", usFmtPct),\n \"Sum as Fraction of Columns\": tpl.fractionOf(tpl.sum(), \"col\", usFmtPct),\n \"Count as Fraction of Total\": tpl.fractionOf(tpl.count(), \"total\", usFmtPct),\n \"Count as Fraction of Rows\": tpl.fractionOf(tpl.count(), \"row\", usFmtPct),\n \"Count as Fraction of Columns\": tpl.fractionOf(tpl.count(), \"col\", usFmtPct)\n };\n })(aggregatorTemplates);\n renderers = {\n \"Table\": function(data, opts) {\n return pivotTableRenderer(data, opts);\n },\n \"Table Barchart\": function(data, opts) {\n return $(pivotTableRenderer(data, opts)).barchart();\n },\n \"Heatmap\": function(data, opts) {\n return $(pivotTableRenderer(data, opts)).heatmap(\"heatmap\", opts);\n },\n \"Row Heatmap\": function(data, opts) {\n return $(pivotTableRenderer(data, opts)).heatmap(\"rowheatmap\", opts);\n },\n \"Col Heatmap\": function(data, opts) {\n return $(pivotTableRenderer(data, opts)).heatmap(\"colheatmap\", opts);\n }\n };\n locales = {\n en: {\n aggregators: aggregators,\n renderers: renderers,\n localeStrings: {\n renderError: \"An error occurred rendering the PivotTable results.\",\n computeError: \"An error occurred computing the PivotTable results.\",\n uiRenderError: \"An error occurred rendering the PivotTable UI.\",\n selectAll: \"Select All\",\n selectNone: \"Select None\",\n tooMany: \"(too many to list)\",\n filterResults: \"Filter results\",\n totals: \"Totals\",\n vs: \"vs\",\n by: \"by\"\n }\n }\n };\n mthNamesEn = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\n dayNamesEn = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\n zeroPad = function(number) {\n return (\"0\" + number).substr(-2, 2);\n };\n derivers = {\n bin: function(col, binWidth) {\n return function(record) {\n return record[col] - record[col] % binWidth;\n };\n },\n dateFormat: function(col, formatString, utcOutput, mthNames, dayNames) {\n var utc;\n if (utcOutput == null) {\n utcOutput = false;\n }\n if (mthNames == null) {\n mthNames = mthNamesEn;\n }\n if (dayNames == null) {\n dayNames = dayNamesEn;\n }\n utc = utcOutput ? \"UTC\" : \"\";\n return function(record) {\n var date;\n date = new Date(Date.parse(record[col]));\n if (isNaN(date)) {\n return \"\";\n }\n return formatString.replace(/%(.)/g, function(m, p) {\n switch (p) {\n case \"y\":\n return date[\"get\" + utc + \"FullYear\"]();\n case \"m\":\n return zeroPad(date[\"get\" + utc + \"Month\"]() + 1);\n case \"n\":\n return mthNames[date[\"get\" + utc + \"Month\"]()];\n case \"d\":\n return zeroPad(date[\"get\" + utc + \"Date\"]());\n case \"w\":\n return dayNames[date[\"get\" + utc + \"Day\"]()];\n case \"x\":\n return date[\"get\" + utc + \"Day\"]();\n case \"H\":\n return zeroPad(date[\"get\" + utc + \"Hours\"]());\n case \"M\":\n return zeroPad(date[\"get\" + utc + \"Minutes\"]());\n case \"S\":\n return zeroPad(date[\"get\" + utc + \"Seconds\"]());\n default:\n return \"%\" + p;\n }\n });\n };\n }\n };\n naturalSort = (function(_this) {\n return function(as, bs) {\n var a, a1, b, b1, rd, rx, rz;\n rx = /(\\d+)|(\\D+)/g;\n rd = /\\d/;\n rz = /^0/;\n if (typeof as === \"number\" || typeof bs === \"number\") {\n if (isNaN(as)) {\n return 1;\n }\n if (isNaN(bs)) {\n return -1;\n }\n return as - bs;\n }\n a = String(as).toLowerCase();\n b = String(bs).toLowerCase();\n if (a === b) {\n return 0;\n }\n if (!(rd.test(a) && rd.test(b))) {\n return (a > b ? 1 : -1);\n }\n a = a.match(rx);\n b = b.match(rx);\n while (a.length && b.length) {\n a1 = a.shift();\n b1 = b.shift();\n if (a1 !== b1) {\n if (rd.test(a1) && rd.test(b1)) {\n return a1.replace(rz, \".0\") - b1.replace(rz, \".0\");\n } else {\n return (a1 > b1 ? 1 : -1);\n }\n }\n }\n return a.length - b.length;\n };\n })(this);\n sortAs = function(order) {\n var i, mapping, x;\n mapping = {};\n for (i in order) {\n x = order[i];\n mapping[x] = i;\n }\n return function(a, b) {\n if ((mapping[a] != null) && (mapping[b] != null)) {\n return mapping[a] - mapping[b];\n } else if (mapping[a] != null) {\n return -1;\n } else if (mapping[b] != null) {\n return 1;\n } else {\n return naturalSort(a, b);\n }\n };\n };\n getSort = function(sorters, attr) {\n var sort;\n sort = sorters(attr);\n if ($.isFunction(sort)) {\n return sort;\n } else {\n return naturalSort;\n }\n };\n\n /*\n Data Model class\n */\n PivotData = (function() {\n function PivotData(input, opts) {\n this.getAggregator = bind(this.getAggregator, this);\n this.getRowKeys = bind(this.getRowKeys, this);\n this.getColKeys = bind(this.getColKeys, this);\n this.sortKeys = bind(this.sortKeys, this);\n this.arrSort = bind(this.arrSort, this);\n this.aggregator = opts.aggregator;\n this.aggregatorName = opts.aggregatorName;\n this.colAttrs = opts.cols;\n this.rowAttrs = opts.rows;\n this.valAttrs = opts.vals;\n this.sorters = opts.sorters;\n this.tree = {};\n this.rowKeys = [];\n this.colKeys = [];\n this.rowTotals = {};\n this.colTotals = {};\n this.allTotal = this.aggregator(this, [], []);\n this.sorted = false;\n PivotData.forEachRecord(input, opts.derivedAttributes, (function(_this) {\n return function(record) {\n if (opts.filter(record)) {\n return _this.processRecord(record);\n }\n };\n })(this));\n }\n\n PivotData.forEachRecord = function(input, derivedAttributes, f) {\n var addRecord, compactRecord, i, j, k, l, len1, record, ref, results, results1, tblCols;\n if ($.isEmptyObject(derivedAttributes)) {\n addRecord = f;\n } else {\n addRecord = function(record) {\n var k, ref, v;\n for (k in derivedAttributes) {\n v = derivedAttributes[k];\n record[k] = (ref = v(record)) != null ? ref : record[k];\n }\n return f(record);\n };\n }\n if ($.isFunction(input)) {\n return input(addRecord);\n } else if ($.isArray(input)) {\n if ($.isArray(input[0])) {\n results = [];\n for (i in input) {\n if (!hasProp.call(input, i)) continue;\n compactRecord = input[i];\n if (!(i > 0)) {\n continue;\n }\n record = {};\n ref = input[0];\n for (j in ref) {\n if (!hasProp.call(ref, j)) continue;\n k = ref[j];\n record[k] = compactRecord[j];\n }\n results.push(addRecord(record));\n }\n return results;\n } else {\n results1 = [];\n for (l = 0, len1 = input.length; l < len1; l++) {\n record = input[l];\n results1.push(addRecord(record));\n }\n return results1;\n }\n } else if (input instanceof jQuery) {\n tblCols = [];\n $(\"thead > tr > th\", input).each(function(i) {\n return tblCols.push($(this).text());\n });\n return $(\"tbody > tr\", input).each(function(i) {\n record = {};\n $(\"td\", this).each(function(j) {\n return record[tblCols[j]] = $(this).text();\n });\n return addRecord(record);\n });\n } else {\n throw new Error(\"unknown input format\");\n }\n };\n\n PivotData.convertToArray = function(input) {\n var result;\n result = [];\n PivotData.forEachRecord(input, {}, function(record) {\n return result.push(record);\n });\n return result;\n };\n\n PivotData.prototype.arrSort = function(attrs) {\n var a, sortersArr;\n sortersArr = (function() {\n var l, len1, results;\n results = [];\n for (l = 0, len1 = attrs.length; l < len1; l++) {\n a = attrs[l];\n results.push(getSort(this.sorters, a));\n }\n return results;\n }).call(this);\n return function(a, b) {\n var comparison, i, sorter;\n for (i in sortersArr) {\n if (!hasProp.call(sortersArr, i)) continue;\n sorter = sortersArr[i];\n comparison = sorter(a[i], b[i]);\n if (comparison !== 0) {\n return comparison;\n }\n }\n return 0;\n };\n };\n\n PivotData.prototype.sortKeys = function() {\n if (!this.sorted) {\n this.sorted = true;\n this.rowKeys.sort(this.arrSort(this.rowAttrs));\n return this.colKeys.sort(this.arrSort(this.colAttrs));\n }\n };\n\n PivotData.prototype.getColKeys = function() {\n this.sortKeys();\n return this.colKeys;\n };\n\n PivotData.prototype.getRowKeys = function() {\n this.sortKeys();\n return this.rowKeys;\n };\n\n PivotData.prototype.processRecord = function(record) {\n var colKey, flatColKey, flatRowKey, l, len1, len2, n, ref, ref1, ref2, ref3, rowKey, x;\n colKey = [];\n rowKey = [];\n ref = this.colAttrs;\n for (l = 0, len1 = ref.length; l < len1; l++) {\n x = ref[l];\n colKey.push((ref1 = record[x]) != null ? ref1 : \"null\");\n }\n ref2 = this.rowAttrs;\n for (n = 0, len2 = ref2.length; n < len2; n++) {\n x = ref2[n];\n rowKey.push((ref3 = record[x]) != null ? ref3 : \"null\");\n }\n flatRowKey = rowKey.join(String.fromCharCode(0));\n flatColKey = colKey.join(String.fromCharCode(0));\n this.allTotal.push(record);\n if (rowKey.length !== 0) {\n if (!this.rowTotals[flatRowKey]) {\n this.rowKeys.push(rowKey);\n this.rowTotals[flatRowKey] = this.aggregator(this, rowKey, []);\n }\n this.rowTotals[flatRowKey].push(record);\n }\n if (colKey.length !== 0) {\n if (!this.colTotals[flatColKey]) {\n this.colKeys.push(colKey);\n this.colTotals[flatColKey] = this.aggregator(this, [], colKey);\n }\n this.colTotals[flatColKey].push(record);\n }\n if (colKey.length !== 0 && rowKey.length !== 0) {\n if (!this.tree[flatRowKey]) {\n this.tree[flatRowKey] = {};\n }\n if (!this.tree[flatRowKey][flatColKey]) {\n this.tree[flatRowKey][flatColKey] = this.aggregator(this, rowKey, colKey);\n }\n return this.tree[flatRowKey][flatColKey].push(record);\n }\n };\n\n PivotData.prototype.getAggregator = function(rowKey, colKey) {\n var agg, flatColKey, flatRowKey;\n flatRowKey = rowKey.join(String.fromCharCode(0));\n flatColKey = colKey.join(String.fromCharCode(0));\n if (rowKey.length === 0 && colKey.length === 0) {\n agg = this.allTotal;\n } else if (rowKey.length === 0) {\n agg = this.colTotals[flatColKey];\n } else if (colKey.length === 0) {\n agg = this.rowTotals[flatRowKey];\n } else {\n agg = this.tree[flatRowKey][flatColKey];\n }\n return agg != null ? agg : {\n value: (function() {\n return null;\n }),\n format: function() {\n return \"\";\n }\n };\n };\n\n return PivotData;\n\n })();\n $.pivotUtilities = {\n aggregatorTemplates: aggregatorTemplates,\n aggregators: aggregators,\n renderers: renderers,\n derivers: derivers,\n locales: locales,\n naturalSort: naturalSort,\n numberFormat: numberFormat,\n sortAs: sortAs,\n PivotData: PivotData\n };\n\n /*\n Default Renderer for hierarchical table layout\n */\n pivotTableRenderer = function(pivotData, opts) {\n var aggregator, c, colAttrs, colKey, colKeys, defaults, i, j, r, result, rowAttrs, rowKey, rowKeys, spanSize, tbody, td, th, thead, totalAggregator, tr, txt, val, x;\n defaults = {\n localeStrings: {\n totals: \"Totals\"\n }\n };\n opts = $.extend(defaults, opts);\n colAttrs = pivotData.colAttrs;\n rowAttrs = pivotData.rowAttrs;\n rowKeys = pivotData.getRowKeys();\n colKeys = pivotData.getColKeys();\n result = document.createElement(\"table\");\n result.className = \"pvtTable\";\n spanSize = function(arr, i, j) {\n var l, len, n, noDraw, ref, ref1, stop, x;\n if (i !== 0) {\n noDraw = true;\n for (x = l = 0, ref = j; 0 <= ref ? l <= ref : l >= ref; x = 0 <= ref ? ++l : --l) {\n if (arr[i - 1][x] !== arr[i][x]) {\n noDraw = false;\n }\n }\n if (noDraw) {\n return -1;\n }\n }\n len = 0;\n while (i + len < arr.length) {\n stop = false;\n for (x = n = 0, ref1 = j; 0 <= ref1 ? n <= ref1 : n >= ref1; x = 0 <= ref1 ? ++n : --n) {\n if (arr[i][x] !== arr[i + len][x]) {\n stop = true;\n }\n }\n if (stop) {\n break;\n }\n len++;\n }\n return len;\n };\n thead = document.createElement(\"thead\");\n for (j in colAttrs) {\n if (!hasProp.call(colAttrs, j)) continue;\n c = colAttrs[j];\n tr = document.createElement(\"tr\");\n if (parseInt(j) === 0 && rowAttrs.length !== 0) {\n th = document.createElement(\"th\");\n th.setAttribute(\"colspan\", rowAttrs.length);\n th.setAttribute(\"rowspan\", colAttrs.length);\n tr.appendChild(th);\n }\n th = document.createElement(\"th\");\n th.className = \"pvtAxisLabel\";\n th.textContent = c;\n tr.appendChild(th);\n for (i in colKeys) {\n if (!hasProp.call(colKeys, i)) continue;\n colKey = colKeys[i];\n x = spanSize(colKeys, parseInt(i), parseInt(j));\n if (x !== -1) {\n th = document.createElement(\"th\");\n th.className = \"pvtColLabel\";\n th.textContent = colKey[j];\n th.setAttribute(\"colspan\", x);\n if (parseInt(j) === colAttrs.length - 1 && rowAttrs.length !== 0) {\n th.setAttribute(\"rowspan\", 2);\n }\n tr.appendChild(th);\n }\n }\n if (parseInt(j) === 0) {\n th = document.createElement(\"th\");\n th.className = \"pvtTotalLabel\";\n th.innerHTML = opts.localeStrings.totals;\n th.setAttribute(\"rowspan\", colAttrs.length + (rowAttrs.length === 0 ? 0 : 1));\n tr.appendChild(th);\n }\n thead.appendChild(tr);\n }\n if (rowAttrs.length !== 0) {\n tr = document.createElement(\"tr\");\n for (i in rowAttrs) {\n if (!hasProp.call(rowAttrs, i)) continue;\n r = rowAttrs[i];\n th = document.createElement(\"th\");\n th.className = \"pvtAxisLabel\";\n th.textContent = r;\n tr.appendChild(th);\n }\n th = document.createElement(\"th\");\n if (colAttrs.length === 0) {\n th.className = \"pvtTotalLabel\";\n th.innerHTML = opts.localeStrings.totals;\n }\n tr.appendChild(th);\n thead.appendChild(tr);\n }\n result.appendChild(thead);\n tbody = document.createElement(\"tbody\");\n for (i in rowKeys) {\n if (!hasProp.call(rowKeys, i)) continue;\n rowKey = rowKeys[i];\n tr = document.createElement(\"tr\");\n for (j in rowKey) {\n if (!hasProp.call(rowKey, j)) continue;\n txt = rowKey[j];\n x = spanSize(rowKeys, parseInt(i), parseInt(j));\n if (x !== -1) {\n th = document.createElement(\"th\");\n th.className = \"pvtRowLabel\";\n th.textContent = txt;\n th.setAttribute(\"rowspan\", x);\n if (parseInt(j) === rowAttrs.length - 1 && colAttrs.length !== 0) {\n th.setAttribute(\"colspan\", 2);\n }\n tr.appendChild(th);\n }\n }\n for (j in colKeys) {\n if (!hasProp.call(colKeys, j)) continue;\n colKey = colKeys[j];\n aggregator = pivotData.getAggregator(rowKey, colKey);\n val = aggregator.value();\n td = document.createElement(\"td\");\n td.className = \"pvtVal row\" + i + \" col\" + j;\n td.textContent = aggregator.format(val);\n td.setAttribute(\"data-value\", val);\n tr.appendChild(td);\n }\n totalAggregator = pivotData.getAggregator(rowKey, []);\n val = totalAggregator.value();\n td = document.createElement(\"td\");\n td.className = \"pvtTotal rowTotal\";\n td.textContent = totalAggregator.format(val);\n td.setAttribute(\"data-value\", val);\n td.setAttribute(\"data-for\", \"row\" + i);\n tr.appendChild(td);\n tbody.appendChild(tr);\n }\n tr = document.createElement(\"tr\");\n th = document.createElement(\"th\");\n th.className = \"pvtTotalLabel\";\n th.innerHTML = opts.localeStrings.totals;\n th.setAttribute(\"colspan\", rowAttrs.length + (colAttrs.length === 0 ? 0 : 1));\n tr.appendChild(th);\n for (j in colKeys) {\n if (!hasProp.call(colKeys, j)) continue;\n colKey = colKeys[j];\n totalAggregator = pivotData.getAggregator([], colKey);\n val = totalAggregator.value();\n td = document.createElement(\"td\");\n td.className = \"pvtTotal colTotal\";\n td.textContent = totalAggregator.format(val);\n td.setAttribute(\"data-value\", val);\n td.setAttribute(\"data-for\", \"col\" + j);\n tr.appendChild(td);\n }\n totalAggregator = pivotData.getAggregator([], []);\n val = totalAggregator.value();\n td = document.createElement(\"td\");\n td.className = \"pvtGrandTotal\";\n td.textContent = totalAggregator.format(val);\n td.setAttribute(\"data-value\", val);\n tr.appendChild(td);\n tbody.appendChild(tr);\n result.appendChild(tbody);\n result.setAttribute(\"data-numrows\", rowKeys.length);\n result.setAttribute(\"data-numcols\", colKeys.length);\n return result;\n };\n\n /*\n Pivot Table core: create PivotData object and call Renderer on it\n */\n $.fn.pivot = function(input, opts) {\n var defaults, e, error, error1, pivotData, result, x;\n defaults = {\n cols: [],\n rows: [],\n vals: [],\n dataClass: PivotData,\n filter: function() {\n return true;\n },\n aggregator: aggregatorTemplates.count()(),\n aggregatorName: \"Count\",\n sorters: function() {},\n derivedAttributes: {},\n renderer: pivotTableRenderer,\n rendererOptions: null,\n localeStrings: locales.en.localeStrings\n };\n opts = $.extend(defaults, opts);\n result = null;\n try {\n pivotData = new opts.dataClass(input, opts);\n try {\n result = opts.renderer(pivotData, opts.rendererOptions);\n } catch (error) {\n e = error;\n if (typeof console !== \"undefined\" && console !== null) {\n console.error(e.stack);\n }\n result = $(\"<span>\").html(opts.localeStrings.renderError);\n }\n } catch (error1) {\n e = error1;\n if (typeof console !== \"undefined\" && console !== null) {\n console.error(e.stack);\n }\n result = $(\"<span>\").html(opts.localeStrings.computeError);\n }\n x = this[0];\n while (x.hasChildNodes()) {\n x.removeChild(x.lastChild);\n }\n return this.append(result);\n };\n\n /*\n Pivot Table UI: calls Pivot Table core above with options set by user\n */\n $.fn.pivotUI = function(input, inputOpts, overwrite, locale) {\n var a, aggregator, attrLength, axisValues, c, colList, defaults, e, error, existingOpts, fn, i, initialRender, k, l, len1, len2, len3, len4, n, o, opts, pivotTable, q, ref, ref1, ref2, ref3, ref4, refresh, refreshDelayed, renderer, rendererControl, shownAttributes, tblCols, tr1, tr2, uiTable, unusedAttrsVerticalAutoCutoff, unusedAttrsVerticalAutoOverride, x;\n if (overwrite == null) {\n overwrite = false;\n }\n if (locale == null) {\n locale = \"en\";\n }\n if (locales[locale] == null) {\n locale = \"en\";\n }\n defaults = {\n derivedAttributes: {},\n aggregators: locales[locale].aggregators,\n renderers: locales[locale].renderers,\n hiddenAttributes: [],\n menuLimit: 200,\n cols: [],\n rows: [],\n vals: [],\n dataClass: PivotData,\n exclusions: {},\n inclusions: {},\n unusedAttrsVertical: 85,\n autoSortUnusedAttrs: false,\n rendererOptions: {\n localeStrings: locales[locale].localeStrings\n },\n onRefresh: null,\n filter: function() {\n return true;\n },\n sorters: function() {},\n localeStrings: locales[locale].localeStrings\n };\n existingOpts = this.data(\"pivotUIOptions\");\n if ((existingOpts == null) || overwrite) {\n opts = $.extend(defaults, inputOpts);\n } else {\n opts = existingOpts;\n }\n try {\n input = PivotData.convertToArray(input);\n tblCols = (function() {\n var ref, results;\n ref = input[0];\n results = [];\n for (k in ref) {\n if (!hasProp.call(ref, k)) continue;\n results.push(k);\n }\n return results;\n })();\n ref = opts.derivedAttributes;\n for (c in ref) {\n if (!hasProp.call(ref, c)) continue;\n if ((indexOf.call(tblCols, c) < 0)) {\n tblCols.push(c);\n }\n }\n axisValues = {};\n for (l = 0, len1 = tblCols.length; l < len1; l++) {\n x = tblCols[l];\n axisValues[x] = {};\n }\n PivotData.forEachRecord(input, opts.derivedAttributes, function(record) {\n var base, results, v;\n results = [];\n for (k in record) {\n if (!hasProp.call(record, k)) continue;\n v = record[k];\n if (!(opts.filter(record))) {\n continue;\n }\n if (v == null) {\n v = \"null\";\n }\n if ((base = axisValues[k])[v] == null) {\n base[v] = 0;\n }\n results.push(axisValues[k][v]++);\n }\n return results;\n });\n uiTable = $(\"<table>\", {\n \"class\": \"pvtUi\"\n }).attr(\"cellpadding\", 5);\n rendererControl = $(\"<td>\");\n renderer = $(\"<select>\").addClass('pvtRenderer').appendTo(rendererControl).bind(\"change\", function() {\n return refresh();\n });\n ref1 = opts.renderers;\n for (x in ref1) {\n if (!hasProp.call(ref1, x)) continue;\n $(\"<option>\").val(x).html(x).appendTo(renderer);\n }\n colList = $(\"<td>\").addClass('pvtAxisContainer pvtUnused');\n shownAttributes = (function() {\n var len2, n, results;\n results = [];\n for (n = 0, len2 = tblCols.length; n < len2; n++) {\n c = tblCols[n];\n if (indexOf.call(opts.hiddenAttributes, c) < 0) {\n results.push(c);\n }\n }\n return results;\n })();\n unusedAttrsVerticalAutoOverride = false;\n if (opts.unusedAttrsVertical === \"auto\") {\n unusedAttrsVerticalAutoCutoff = 120;\n } else {\n unusedAttrsVerticalAutoCutoff = parseInt(opts.unusedAttrsVertical);\n }\n if (!isNaN(unusedAttrsVerticalAutoCutoff)) {\n attrLength = 0;\n for (n = 0, len2 = shownAttributes.length; n < len2; n++) {\n a = shownAttributes[n];\n attrLength += a.length;\n }\n unusedAttrsVerticalAutoOverride = attrLength > unusedAttrsVerticalAutoCutoff;\n }\n if (opts.unusedAttrsVertical === true || unusedAttrsVerticalAutoOverride) {\n colList.addClass('pvtVertList');\n } else {\n colList.addClass('pvtHorizList');\n }\n fn = function(c) {\n var attrElem, btns, checkContainer, filterItem, filterItemExcluded, hasExcludedItem, keys, len3, o, ref2, showFilterList, triangleLink, updateFilter, v, valueList;\n keys = (function() {\n var results;\n results = [];\n for (k in axisValues[c]) {\n results.push(k);\n }\n return results;\n })();\n hasExcludedItem = false;\n valueList = $(\"<div>\").addClass('pvtFilterBox').hide();\n valueList.append($(\"<h4>\").text(c + \" (\" + keys.length + \")\"));\n if (keys.length > opts.menuLimit) {\n valueList.append($(\"<p>\").html(opts.localeStrings.tooMany));\n } else {\n btns = $(\"<p>\").appendTo(valueList);\n btns.append($(\"<button>\", {\n type: \"button\"\n }).html(opts.localeStrings.selectAll).bind(\"click\", function() {\n return valueList.find(\"input:visible\").prop(\"checked\", true);\n }));\n btns.append($(\"<button>\", {\n type: \"button\"\n }).html(opts.localeStrings.selectNone).bind(\"click\", function() {\n return valueList.find(\"input:visible\").prop(\"checked\", false);\n }));\n btns.append($(\"<br>\"));\n btns.append($(\"<input>\", {\n type: \"text\",\n placeholder: opts.localeStrings.filterResults,\n \"class\": \"pvtSearch\"\n }).bind(\"keyup\", function() {\n var filter;\n filter = $(this).val().toLowerCase();\n return valueList.find('.pvtCheckContainer p').each(function() {\n var testString;\n testString = $(this).text().toLowerCase().indexOf(filter);\n if (testString !== -1) {\n return $(this).show();\n } else {\n return $(this).hide();\n }\n });\n }));\n checkContainer = $(\"<div>\").addClass(\"pvtCheckContainer\").appendTo(valueList);\n ref2 = keys.sort(getSort(opts.sorters, c));\n for (o = 0, len3 = ref2.length; o < len3; o++) {\n k = ref2[o];\n v = axisValues[c][k];\n filterItem = $(\"<label>\");\n filterItemExcluded = false;\n if (opts.inclusions[c]) {\n filterItemExcluded = (indexOf.call(opts.inclusions[c], k) < 0);\n } else if (opts.exclusions[c]) {\n filterItemExcluded = (indexOf.call(opts.exclusions[c], k) >= 0);\n }\n hasExcludedItem || (hasExcludedItem = filterItemExcluded);\n $(\"<input>\").attr(\"type\", \"checkbox\").addClass('pvtFilter').attr(\"checked\", !filterItemExcluded).data(\"filter\", [c, k]).appendTo(filterItem);\n filterItem.append($(\"<span>\").text(k));\n filterItem.append($(\"<span>\").text(\" (\" + v + \")\"));\n checkContainer.append($(\"<p>\").append(filterItem));\n }\n }\n updateFilter = function() {\n var unselectedCount;\n unselectedCount = valueList.find(\"[type='checkbox']\").length - valueList.find(\"[type='checkbox']:checked\").length;\n if (unselectedCount > 0) {\n attrElem.addClass(\"pvtFilteredAttribute\");\n } else {\n attrElem.removeClass(\"pvtFilteredAttribute\");\n }\n if (keys.length > opts.menuLimit) {\n return valueList.toggle();\n } else {\n return valueList.toggle(0, refresh);\n }\n };\n $(\"<p>\").appendTo(valueList).append($(\"<button>\", {\n type: \"button\"\n }).text(\"OK\").bind(\"click\", updateFilter));\n showFilterList = function(e) {\n var clickLeft, clickTop, ref3;\n ref3 = $(e.currentTarget).position(), clickLeft = ref3.left, clickTop = ref3.top;\n valueList.css({\n left: clickLeft + 10,\n top: clickTop + 10\n }).toggle();\n valueList.find('.pvtSearch').val('');\n return valueList.find('.pvtCheckContainer p').show();\n };\n triangleLink = $(\"<span>\").addClass('pvtTriangle').html(\" ▾\").bind(\"click\", showFilterList);\n attrElem = $(\"<li>\").addClass(\"axis_\" + i).append($(\"<span>\").addClass('pvtAttr').text(c).data(\"attrName\", c).append(triangleLink));\n if (hasExcludedItem) {\n attrElem.addClass('pvtFilteredAttribute');\n }\n colList.append(attrElem).append(valueList);\n return attrElem.bind(\"dblclick\", showFilterList);\n };\n for (i in shownAttributes) {\n if (!hasProp.call(shownAttributes, i)) continue;\n c = shownAttributes[i];\n fn(c);\n }\n tr1 = $(\"<tr>\").appendTo(uiTable);\n aggregator = $(\"<select>\").addClass('pvtAggregator').bind(\"change\", function() {\n return refresh();\n });\n ref2 = opts.aggregators;\n for (x in ref2) {\n if (!hasProp.call(ref2, x)) continue;\n aggregator.append($(\"<option>\").val(x).html(x));\n }\n $(\"<td>\").addClass('pvtVals').appendTo(tr1).append(aggregator).append($(\"<br>\"));\n $(\"<td>\").addClass('pvtAxisContainer pvtHorizList pvtCols').appendTo(tr1);\n tr2 = $(\"<tr>\").appendTo(uiTable);\n tr2.append($(\"<td>\").addClass('pvtAxisContainer pvtRows').attr(\"valign\", \"top\"));\n pivotTable = $(\"<td>\").attr(\"valign\", \"top\").addClass('pvtRendererArea').appendTo(tr2);\n if (opts.unusedAttrsVertical === true || unusedAttrsVerticalAutoOverride) {\n uiTable.find('tr:nth-child(1)').prepend(rendererControl);\n uiTable.find('tr:nth-child(2)').prepend(colList);\n } else {\n uiTable.prepend($(\"<tr>\").append(rendererControl).append(colList));\n }\n this.html(uiTable);\n ref3 = opts.cols;\n for (o = 0, len3 = ref3.length; o < len3; o++) {\n x = ref3[o];\n this.find(\".pvtCols\").append(this.find(\".axis_\" + ($.inArray(x, shownAttributes))));\n }\n ref4 = opts.rows;\n for (q = 0, len4 = ref4.length; q < len4; q++) {\n x = ref4[q];\n this.find(\".pvtRows\").append(this.find(\".axis_\" + ($.inArray(x, shownAttributes))));\n }\n if (opts.aggregatorName != null) {\n this.find(\".pvtAggregator\").val(opts.aggregatorName);\n }\n if (opts.rendererName != null) {\n this.find(\".pvtRenderer\").val(opts.rendererName);\n }\n initialRender = true;\n refreshDelayed = (function(_this) {\n return function() {\n var attr, exclusions, inclusions, len5, newDropdown, numInputsToProcess, pivotUIOptions, pvtVals, ref5, ref6, s, subopts, t, unusedAttrsContainer, vals;\n subopts = {\n derivedAttributes: opts.derivedAttributes,\n localeStrings: opts.localeStrings,\n rendererOptions: opts.rendererOptions,\n sorters: opts.sorters,\n cols: [],\n rows: [],\n dataClass: opts.dataClass\n };\n numInputsToProcess = (ref5 = opts.aggregators[aggregator.val()]([])().numInputs) != null ? ref5 : 0;\n vals = [];\n _this.find(\".pvtRows li span.pvtAttr\").each(function() {\n return subopts.rows.push($(this).data(\"attrName\"));\n });\n _this.find(\".pvtCols li span.pvtAttr\").each(function() {\n return subopts.cols.push($(this).data(\"attrName\"));\n });\n _this.find(\".pvtVals select.pvtAttrDropdown\").each(function() {\n if (numInputsToProcess === 0) {\n return $(this).remove();\n } else {\n numInputsToProcess--;\n if ($(this).val() !== \"\") {\n return vals.push($(this).val());\n }\n }\n });\n if (numInputsToProcess !== 0) {\n pvtVals = _this.find(\".pvtVals\");\n for (x = s = 0, ref6 = numInputsToProcess; 0 <= ref6 ? s < ref6 : s > ref6; x = 0 <= ref6 ? ++s : --s) {\n newDropdown = $(\"<select>\").addClass('pvtAttrDropdown').append($(\"<option>\")).bind(\"change\", function() {\n return refresh();\n });\n for (t = 0, len5 = shownAttributes.length; t < len5; t++) {\n attr = shownAttributes[t];\n newDropdown.append($(\"<option>\").val(attr).text(attr));\n }\n pvtVals.append(newDropdown);\n }\n }\n if (initialRender) {\n vals = opts.vals;\n i = 0;\n _this.find(\".pvtVals select.pvtAttrDropdown\").each(function() {\n $(this).val(vals[i]);\n return i++;\n });\n initialRender = false;\n }\n subopts.aggregatorName = aggregator.val();\n subopts.vals = vals;\n subopts.aggregator = opts.aggregators[aggregator.val()](vals);\n subopts.renderer = opts.renderers[renderer.val()];\n exclusions = {};\n _this.find('input.pvtFilter').not(':checked').each(function() {\n var filter;\n filter = $(this).data(\"filter\");\n if (exclusions[filter[0]] != null) {\n return exclusions[filter[0]].push(filter[1]);\n } else {\n return exclusions[filter[0]] = [filter[1]];\n }\n });\n inclusions = {};\n _this.find('input.pvtFilter:checked').each(function() {\n var filter;\n filter = $(this).data(\"filter\");\n if (exclusions[filter[0]] != null) {\n if (inclusions[filter[0]] != null) {\n return inclusions[filter[0]].push(filter[1]);\n } else {\n return inclusions[filter[0]] = [filter[1]];\n }\n }\n });\n subopts.filter = function(record) {\n var excludedItems, ref7;\n if (!opts.filter(record)) {\n return false;\n }\n for (k in exclusions) {\n excludedItems = exclusions[k];\n if (ref7 = \"\" + record[k], indexOf.call(excludedItems, ref7) >= 0) {\n return false;\n }\n }\n return true;\n };\n pivotTable.pivot(input, subopts);\n pivotUIOptions = $.extend(opts, {\n cols: subopts.cols,\n rows: subopts.rows,\n vals: vals,\n exclusions: exclusions,\n inclusions: inclusions,\n inclusionsInfo: inclusions,\n aggregatorName: aggregator.val(),\n rendererName: renderer.val()\n });\n _this.data(\"pivotUIOptions\", pivotUIOptions);\n if (opts.autoSortUnusedAttrs) {\n unusedAttrsContainer = _this.find(\"td.pvtUnused.pvtAxisContainer\");\n $(unusedAttrsContainer).children(\"li\").sort(function(a, b) {\n return naturalSort($(a).text(), $(b).text());\n }).appendTo(unusedAttrsContainer);\n }\n pivotTable.css(\"opacity\", 1);\n if (opts.onRefresh != null) {\n return opts.onRefresh(pivotUIOptions);\n }\n };\n })(this);\n refresh = (function(_this) {\n return function() {\n pivotTable.css(\"opacity\", 0.5);\n return setTimeout(refreshDelayed, 10);\n };\n })(this);\n refresh();\n this.find(\".pvtAxisContainer\").sortable({\n update: function(e, ui) {\n if (ui.sender == null) {\n return refresh();\n }\n },\n connectWith: this.find(\".pvtAxisContainer\"),\n items: 'li',\n placeholder: 'pvtPlaceholder'\n });\n } catch (error) {\n e = error;\n if (typeof console !== \"undefined\" && console !== null) {\n console.error(e.stack);\n }\n this.html(opts.localeStrings.uiRenderError);\n }\n return this;\n };\n\n /*\n Heatmap post-processing\n */\n $.fn.heatmap = function(scope, opts) {\n var colorScaleGenerator, heatmapper, i, j, l, n, numCols, numRows, ref, ref1, ref2;\n if (scope == null) {\n scope = \"heatmap\";\n }\n numRows = this.data(\"numrows\");\n numCols = this.data(\"numcols\");\n colorScaleGenerator = opts != null ? (ref = opts.heatmap) != null ? ref.colorScaleGenerator : void 0 : void 0;\n if (colorScaleGenerator == null) {\n colorScaleGenerator = function(values) {\n var max, min;\n min = Math.min.apply(Math, values);\n max = Math.max.apply(Math, values);\n return function(x) {\n var nonRed;\n nonRed = 255 - Math.round(255 * (x - min) / (max - min));\n return \"rgb(255,\" + nonRed + \",\" + nonRed + \")\";\n };\n };\n }\n heatmapper = (function(_this) {\n return function(scope) {\n var colorScale, forEachCell, values;\n forEachCell = function(f) {\n return _this.find(scope).each(function() {\n var x;\n x = $(this).data(\"value\");\n if ((x != null) && isFinite(x)) {\n return f(x, $(this));\n }\n });\n };\n values = [];\n forEachCell(function(x) {\n return values.push(x);\n });\n colorScale = colorScaleGenerator(values);\n return forEachCell(function(x, elem) {\n return elem.css(\"background-color\", colorScale(x));\n });\n };\n })(this);\n switch (scope) {\n case \"heatmap\":\n heatmapper(\".pvtVal\");\n break;\n case \"rowheatmap\":\n for (i = l = 0, ref1 = numRows; 0 <= ref1 ? l < ref1 : l > ref1; i = 0 <= ref1 ? ++l : --l) {\n heatmapper(\".pvtVal.row\" + i);\n }\n break;\n case \"colheatmap\":\n for (j = n = 0, ref2 = numCols; 0 <= ref2 ? n < ref2 : n > ref2; j = 0 <= ref2 ? ++n : --n) {\n heatmapper(\".pvtVal.col\" + j);\n }\n }\n heatmapper(\".pvtTotal.rowTotal\");\n heatmapper(\".pvtTotal.colTotal\");\n return this;\n };\n\n /*\n Barchart post-processing\n */\n return $.fn.barchart = function() {\n var barcharter, i, l, numCols, numRows, ref;\n numRows = this.data(\"numrows\");\n numCols = this.data(\"numcols\");\n barcharter = (function(_this) {\n return function(scope) {\n var forEachCell, max, scaler, values;\n forEachCell = function(f) {\n return _this.find(scope).each(function() {\n var x;\n x = $(this).data(\"value\");\n if ((x != null) && isFinite(x)) {\n return f(x, $(this));\n }\n });\n };\n values = [];\n forEachCell(function(x) {\n return values.push(x);\n });\n max = Math.max.apply(Math, values);\n scaler = function(x) {\n return 100 * x / (1.4 * max);\n };\n return forEachCell(function(x, elem) {\n var text, wrapper;\n text = elem.text();\n wrapper = $(\"<div>\").css({\n \"position\": \"relative\",\n \"height\": \"55px\"\n });\n wrapper.append($(\"<div>\").css({\n \"position\": \"absolute\",\n \"bottom\": 0,\n \"left\": 0,\n \"right\": 0,\n \"height\": scaler(x) + \"%\",\n \"background-color\": \"gray\"\n }));\n wrapper.append($(\"<div>\").text(text).css({\n \"position\": \"relative\",\n \"padding-left\": \"5px\",\n \"padding-right\": \"5px\"\n }));\n return elem.css({\n \"padding\": 0,\n \"padding-top\": \"5px\",\n \"text-align\": \"center\"\n }).html(wrapper);\n });\n };\n })(this);\n for (i = l = 0, ref = numRows; 0 <= ref ? l < ref : l > ref; i = 0 <= ref ? ++l : --l) {\n barcharter(\".pvtVal.row\" + i);\n }\n barcharter(\".pvtTotal.colTotal\");\n return this;\n };\n });\n\n}).call(this);\n\n\n\n},{\"jquery\":18}],22:[function(require,module,exports){\n(function (global){\n\"use strict\"\n// Module export pattern from\n// https://github.com/umdjs/umd/blob/master/returnExports.js\n;(function (root, factory) {\n if (typeof define === 'function' && define.amd) {\n // AMD. Register as an anonymous module.\n define([], factory);\n } else if (typeof exports === 'object') {\n // Node. Does not work with strict CommonJS, but\n // only CommonJS-like environments that support module.exports,\n // like Node.\n module.exports = factory();\n } else {\n // Browser globals (root is window)\n root.store = factory();\n }\n}(this, function () {\n\t\n\t// Store.js\n\tvar store = {},\n\t\twin = (typeof window != 'undefined' ? window : global),\n\t\tdoc = win.document,\n\t\tlocalStorageName = 'localStorage',\n\t\tscriptTag = 'script',\n\t\tstorage\n\n\tstore.disabled = false\n\tstore.version = '1.3.20'\n\tstore.set = function(key, value) {}\n\tstore.get = function(key, defaultVal) {}\n\tstore.has = function(key) { return store.get(key) !== undefined }\n\tstore.remove = function(key) {}\n\tstore.clear = function() {}\n\tstore.transact = function(key, defaultVal, transactionFn) {\n\t\tif (transactionFn == null) {\n\t\t\ttransactionFn = defaultVal\n\t\t\tdefaultVal = null\n\t\t}\n\t\tif (defaultVal == null) {\n\t\t\tdefaultVal = {}\n\t\t}\n\t\tvar val = store.get(key, defaultVal)\n\t\ttransactionFn(val)\n\t\tstore.set(key, val)\n\t}\n\tstore.getAll = function() {}\n\tstore.forEach = function() {}\n\n\tstore.serialize = function(value) {\n\t\treturn JSON.stringify(value)\n\t}\n\tstore.deserialize = function(value) {\n\t\tif (typeof value != 'string') { return undefined }\n\t\ttry { return JSON.parse(value) }\n\t\tcatch(e) { return value || undefined }\n\t}\n\n\t// Functions to encapsulate questionable FireFox 3.6.13 behavior\n\t// when about.config::dom.storage.enabled === false\n\t// See https://github.com/marcuswestin/store.js/issues#issue/13\n\tfunction isLocalStorageNameSupported() {\n\t\ttry { return (localStorageName in win && win[localStorageName]) }\n\t\tcatch(err) { return false }\n\t}\n\n\tif (isLocalStorageNameSupported()) {\n\t\tstorage = win[localStorageName]\n\t\tstore.set = function(key, val) {\n\t\t\tif (val === undefined) { return store.remove(key) }\n\t\t\tstorage.setItem(key, store.serialize(val))\n\t\t\treturn val\n\t\t}\n\t\tstore.get = function(key, defaultVal) {\n\t\t\tvar val = store.deserialize(storage.getItem(key))\n\t\t\treturn (val === undefined ? defaultVal : val)\n\t\t}\n\t\tstore.remove = function(key) { storage.removeItem(key) }\n\t\tstore.clear = function() { storage.clear() }\n\t\tstore.getAll = function() {\n\t\t\tvar ret = {}\n\t\t\tstore.forEach(function(key, val) {\n\t\t\t\tret[key] = val\n\t\t\t})\n\t\t\treturn ret\n\t\t}\n\t\tstore.forEach = function(callback) {\n\t\t\tfor (var i=0; i<storage.length; i++) {\n\t\t\t\tvar key = storage.key(i)\n\t\t\t\tcallback(key, store.get(key))\n\t\t\t}\n\t\t}\n\t} else if (doc && doc.documentElement.addBehavior) {\n\t\tvar storageOwner,\n\t\t\tstorageContainer\n\t\t// Since #userData storage applies only to specific paths, we need to\n\t\t// somehow link our data to a specific path. We choose /favicon.ico\n\t\t// as a pretty safe option, since all browsers already make a request to\n\t\t// this URL anyway and being a 404 will not hurt us here. We wrap an\n\t\t// iframe pointing to the favicon in an ActiveXObject(htmlfile) object\n\t\t// (see: http://msdn.microsoft.com/en-us/library/aa752574(v=VS.85).aspx)\n\t\t// since the iframe access rules appear to allow direct access and\n\t\t// manipulation of the document element, even for a 404 page. This\n\t\t// document can be used instead of the current document (which would\n\t\t// have been limited to the current path) to perform #userData storage.\n\t\ttry {\n\t\t\tstorageContainer = new ActiveXObject('htmlfile')\n\t\t\tstorageContainer.open()\n\t\t\tstorageContainer.write('<'+scriptTag+'>document.w=window</'+scriptTag+'><iframe src=\"/favicon.ico\"></iframe>')\n\t\t\tstorageContainer.close()\n\t\t\tstorageOwner = storageContainer.w.frames[0].document\n\t\t\tstorage = storageOwner.createElement('div')\n\t\t} catch(e) {\n\t\t\t// somehow ActiveXObject instantiation failed (perhaps some special\n\t\t\t// security settings or otherwse), fall back to per-path storage\n\t\t\tstorage = doc.createElement('div')\n\t\t\tstorageOwner = doc.body\n\t\t}\n\t\tvar withIEStorage = function(storeFunction) {\n\t\t\treturn function() {\n\t\t\t\tvar args = Array.prototype.slice.call(arguments, 0)\n\t\t\t\targs.unshift(storage)\n\t\t\t\t// See http://msdn.microsoft.com/en-us/library/ms531081(v=VS.85).aspx\n\t\t\t\t// and http://msdn.microsoft.com/en-us/library/ms531424(v=VS.85).aspx\n\t\t\t\tstorageOwner.appendChild(storage)\n\t\t\t\tstorage.addBehavior('#default#userData')\n\t\t\t\tstorage.load(localStorageName)\n\t\t\t\tvar result = storeFunction.apply(store, args)\n\t\t\t\tstorageOwner.removeChild(storage)\n\t\t\t\treturn result\n\t\t\t}\n\t\t}\n\n\t\t// In IE7, keys cannot start with a digit or contain certain chars.\n\t\t// See https://github.com/marcuswestin/store.js/issues/40\n\t\t// See https://github.com/marcuswestin/store.js/issues/83\n\t\tvar forbiddenCharsRegex = new RegExp(\"[!\\\"#$%&'()*+,/\\\\\\\\:;<=>?@[\\\\]^`{|}~]\", \"g\")\n\t\tvar ieKeyFix = function(key) {\n\t\t\treturn key.replace(/^d/, '___$&').replace(forbiddenCharsRegex, '___')\n\t\t}\n\t\tstore.set = withIEStorage(function(storage, key, val) {\n\t\t\tkey = ieKeyFix(key)\n\t\t\tif (val === undefined) { return store.remove(key) }\n\t\t\tstorage.setAttribute(key, store.serialize(val))\n\t\t\tstorage.save(localStorageName)\n\t\t\treturn val\n\t\t})\n\t\tstore.get = withIEStorage(function(storage, key, defaultVal) {\n\t\t\tkey = ieKeyFix(key)\n\t\t\tvar val = store.deserialize(storage.getAttribute(key))\n\t\t\treturn (val === undefined ? defaultVal : val)\n\t\t})\n\t\tstore.remove = withIEStorage(function(storage, key) {\n\t\t\tkey = ieKeyFix(key)\n\t\t\tstorage.removeAttribute(key)\n\t\t\tstorage.save(localStorageName)\n\t\t})\n\t\tstore.clear = withIEStorage(function(storage) {\n\t\t\tvar attributes = storage.XMLDocument.documentElement.attributes\n\t\t\tstorage.load(localStorageName)\n\t\t\tfor (var i=attributes.length-1; i>=0; i--) {\n\t\t\t\tstorage.removeAttribute(attributes[i].name)\n\t\t\t}\n\t\t\tstorage.save(localStorageName)\n\t\t})\n\t\tstore.getAll = function(storage) {\n\t\t\tvar ret = {}\n\t\t\tstore.forEach(function(key, val) {\n\t\t\t\tret[key] = val\n\t\t\t})\n\t\t\treturn ret\n\t\t}\n\t\tstore.forEach = withIEStorage(function(storage, callback) {\n\t\t\tvar attributes = storage.XMLDocument.documentElement.attributes\n\t\t\tfor (var i=0, attr; attr=attributes[i]; ++i) {\n\t\t\t\tcallback(attr.name, store.deserialize(storage.getAttribute(attr.name)))\n\t\t\t}\n\t\t})\n\t}\n\n\ttry {\n\t\tvar testKey = '__storejs__'\n\t\tstore.set(testKey, testKey)\n\t\tif (store.get(testKey) != testKey) { store.disabled = true }\n\t\tstore.remove(testKey)\n\t} catch(e) {\n\t\tstore.disabled = true\n\t}\n\tstore.enabled = !store.disabled\n\t\n\treturn store\n}));\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n\n},{}],23:[function(require,module,exports){\nmodule.exports={\n \"_args\": [\n [\n {\n \"raw\": \"yasgui-utils@^1.6.0\",\n \"scope\": null,\n \"escapedName\": \"yasgui-utils\",\n \"name\": \"yasgui-utils\",\n \"rawSpec\": \"^1.6.0\",\n \"spec\": \">=1.6.0 <2.0.0\",\n \"type\": \"range\"\n },\n \"/home/lrd900/yasgui/yasr\"\n ]\n ],\n \"_from\": \"yasgui-utils@>=1.6.0 <2.0.0\",\n \"_id\": \"yasgui-utils@1.6.0\",\n \"_inCache\": true,\n \"_installable\": true,\n \"_location\": \"/yasgui-utils\",\n \"_npmUser\": {\n \"name\": \"laurens.rietveld\",\n \"email\": \"laurens.rietveld@gmail.com\"\n },\n \"_npmVersion\": \"1.4.3\",\n \"_phantomChildren\": {},\n \"_requested\": {\n \"raw\": \"yasgui-utils@^1.6.0\",\n \"scope\": null,\n \"escapedName\": \"yasgui-utils\",\n \"name\": \"yasgui-utils\",\n \"rawSpec\": \"^1.6.0\",\n \"spec\": \">=1.6.0 <2.0.0\",\n \"type\": \"range\"\n },\n \"_requiredBy\": [\n \"/\",\n \"/yasgui-yasqe\"\n ],\n \"_resolved\": \"https://registry.npmjs.org/yasgui-utils/-/yasgui-utils-1.6.0.tgz\",\n \"_shasum\": \"bcb9091109c233e3e82737c94c202e6512389c47\",\n \"_shrinkwrap\": null,\n \"_spec\": \"yasgui-utils@^1.6.0\",\n \"_where\": \"/home/lrd900/yasgui/yasr\",\n \"author\": {\n \"name\": \"Laurens Rietveld\"\n },\n \"bugs\": {\n \"url\": \"https://github.com/YASGUI/Utils/issues\"\n },\n \"dependencies\": {\n \"store\": \"^1.3.14\"\n },\n \"description\": \"Utils for YASGUI libs\",\n \"devDependencies\": {},\n \"directories\": {},\n \"dist\": {\n \"shasum\": \"bcb9091109c233e3e82737c94c202e6512389c47\",\n \"tarball\": \"https://registry.npmjs.org/yasgui-utils/-/yasgui-utils-1.6.0.tgz\"\n },\n \"homepage\": \"https://github.com/YASGUI/Utils\",\n \"licenses\": [\n {\n \"type\": \"MIT\",\n \"url\": \"http://yasgui.github.io/license.txt\"\n }\n ],\n \"main\": \"src/main.js\",\n \"maintainers\": [\n {\n \"name\": \"laurens.rietveld\",\n \"email\": \"laurens.rietveld@gmail.com\"\n }\n ],\n \"name\": \"yasgui-utils\",\n \"optionalDependencies\": {},\n \"readme\": \"ERROR: No README data found!\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git://github.com/YASGUI/Utils.git\"\n },\n \"version\": \"1.6.0\"\n}\n\n},{}],24:[function(require,module,exports){\nwindow.console = window.console || {\"log\":function(){}};//make sure any console statements don't break IE\nmodule.exports = {\n\tstorage: require(\"./storage.js\"),\n\tsvg: require(\"./svg.js\"),\n\tversion: {\n\t\t\"yasgui-utils\" : require(\"../package.json\").version,\n\t},\n\tnestedExists : function(obj) {\n\t\tvar args = Array.prototype.slice.call(arguments, 1);\n\n\t\tfor (var i = 0; i < args.length; i++) {\n\t\t\tif (!obj || !obj.hasOwnProperty(args[i])) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tobj = obj[args[i]];\n\t\t}\n\t\treturn true;\n\t}\n};\n\n},{\"../package.json\":23,\"./storage.js\":25,\"./svg.js\":26}],25:[function(require,module,exports){\nvar store = require(\"store\");\nvar times = {\n\tday: function() {\n\t\treturn 1000 * 3600 * 24;//millis to day\n\t},\n\tmonth: function() {\n\t\ttimes.day() * 30;\n\t},\n\tyear: function() {\n\t\ttimes.month() * 12;\n\t}\n};\n\nvar root = module.exports = {\n\tset : function(key, val, exp) {\n if (!store.enabled) return;//this is probably in private mode. Don't run, as we might get Js errors\n\t\tif (key && val !== undefined) {\n\t\t\tif (typeof exp == \"string\") {\n\t\t\t\texp = times[exp]();\n\t\t\t}\n\t\t\t//try to store string for dom objects (e.g. XML result). Otherwise, we might get a circular reference error when stringifying this\n\t\t\tif (val.documentElement) val = new XMLSerializer().serializeToString(val.documentElement);\n\t\t\tstore.set(key, {\n\t\t\t\tval : val,\n\t\t\t\texp : exp,\n\t\t\t\ttime : new Date().getTime()\n\t\t\t});\n\t\t}\n\t},\n\tremove: function(key) {\n\t\tif (!store.enabled) return;//this is probably in private mode. Don't run, as we might get Js errors\n\t\tif (key) store.remove(key)\n\t},\n\tremoveAll: function(filter) {\n\t\tif (!store.enabled) return;//this is probably in private mode. Don't run, as we might get Js errors\n\t\tif (typeof filter === 'function') {\n\t\t\tfor (var key in store.getAll()) {\n\t\t\t\tif (filter(key, root.get(key))) root.remove(key);\n\t\t\t}\n\t\t}\n\t},\n\tget : function(key) {\n if (!store.enabled) return null;//this is probably in private mode. Don't run, as we might get Js errors\n\t\tif (key) {\n\t\t\tvar info = store.get(key);\n\t\t\tif (!info) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\tif (info.exp && new Date().getTime() - info.time > info.exp) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\treturn info.val;\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t}\n\n};\n\n},{\"store\":22}],26:[function(require,module,exports){\nmodule.exports = {\n\tdraw: function(parent, svgString) {\n\t\tif (!parent) return;\n\t\tvar el = module.exports.getElement(svgString);\n\t\tif (el) {\n\t\t\tif (parent.append) {\n\t\t\t\tparent.append(el);\n\t\t\t} else {\n\t\t\t\t//regular dom doc\n\t\t\t\tparent.appendChild(el);\n\t\t\t}\n\t\t}\n\t},\n\tgetElement: function(svgString) {\n\t\tif (svgString && svgString.indexOf(\"<svg\") == 0) {\n\t\t\t//no style passed via config. guess own styles\n\t\t\tvar parser = new DOMParser();\n\t\t\tvar dom = parser.parseFromString(svgString, \"text/xml\");\n\t\t\tvar svg = dom.documentElement;\n\t\t\t\n\t\t\tvar svgContainer = document.createElement(\"div\");\n\t\t\tsvgContainer.className = 'svgImg';\n\t\t\tsvgContainer.appendChild(svg);\n\t\t\treturn svgContainer;\n\t\t}\n\t\treturn false;\n\t}\n};\n},{}],27:[function(require,module,exports){\nmodule.exports={\n \"name\": \"yasgui-yasr\",\n \"description\": \"Yet Another SPARQL Resultset GUI\",\n \"version\": \"2.8.6\",\n \"main\": \"src/main.js\",\n \"license\": \"MIT\",\n \"author\": \"Laurens Rietveld\",\n \"homepage\": \"http://yasr.yasgui.org\",\n \"devDependencies\": {\n \"bootstrap-sass\": \"^3.3.7\",\n \"browserify\": \"^13.1.0\",\n \"browserify-shim\": \"^3.8.12\",\n \"browserify-transform-tools\": \"^1.6.0\",\n \"exorcist\": \"^0.4.0\",\n \"gulp\": \"^3.9.1\",\n \"gulp-autoprefixer\": \"^3.1.0\",\n \"gulp-bump\": \"^2.2.0\",\n \"gulp-clean-css\": \"^2.0.12\",\n \"gulp-concat\": \"^2.6.0\",\n \"gulp-connect\": \"^4.2.0\",\n \"gulp-cssimport\": \"^3.1.0\",\n \"gulp-embedlr\": \"^0.5.2\",\n \"gulp-filter\": \"^4.0.0\",\n \"gulp-git\": \"^1.10.0\",\n \"gulp-html-replace\": \"^1.6.1\",\n \"gulp-jsvalidate\": \"^2.1.0\",\n \"gulp-livereload\": \"^3.8.1\",\n \"gulp-minify-css\": \"1.2.4\",\n \"gulp-notify\": \"^2.2.0\",\n \"gulp-rename\": \"^1.2.2\",\n \"gulp-sass\": \"^2.3.2\",\n \"gulp-sourcemaps\": \"^1.6.0\",\n \"gulp-streamify\": \"1.0.2\",\n \"gulp-tag-version\": \"^1.3.0\",\n \"gulp-uglify\": \"^1.5.4\",\n \"node-sass\": \"^3.8.0\",\n \"require-dir\": \"^0.3.0\",\n \"run-sequence\": \"^1.2.2\",\n \"vinyl-buffer\": \"^1.0.0\",\n \"vinyl-source-stream\": \"~1.1.0\",\n \"vinyl-transform\": \"1.0.0\",\n \"watchify\": \"^3.7.0\",\n \"yasgui-yasqe\": \"^2.10.1\"\n },\n \"bugs\": \"https://github.com/YASGUI/YASR/issues/\",\n \"keywords\": [\n \"JavaScript\",\n \"SPARQL\",\n \"Editor\",\n \"Semantic Web\",\n \"Linked Data\"\n ],\n \"scripts\": {\n \"dev\": \"gulp serve\",\n \"build\": \"gulp\",\n \"patch\": \"gulp patch\",\n \"minor\": \"gulp minor\",\n \"major\": \"gulp major\"\n },\n \"maintainers\": [\n {\n \"name\": \"Laurens Rietveld\",\n \"email\": \"laurens.rietveld@gmail.com\",\n \"web\": \"http://laurensrietveld.nl\"\n }\n ],\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/YASGUI/YASR.git\"\n },\n \"dependencies\": {\n \"codemirror\": \"^5.17.0\",\n \"d3\": \"^4.1.1\",\n \"datatables.net\": \"^1.10.12\",\n \"datatables.net-dt\": \"^1.10.12\",\n \"jquery\": \"^2.2.4\",\n \"jquery-ui\": \"1.10.5\",\n \"pivottable\": \"^2.1.0\",\n \"yasgui-utils\": \"^1.6.0\"\n },\n \"browserify-shim\": {\n \"google\": \"global:google\"\n },\n \"browserify\": {\n \"transform\": [\n \"browserify-shim\"\n ]\n },\n \"optionalShim\": {\n \"codemirror\": {\n \"require\": \"codemirror\",\n \"global\": \"CodeMirror\"\n },\n \"jquery\": {\n \"require\": \"jquery\",\n \"global\": \"jQuery\"\n },\n \"../../lib/codemirror\": {\n \"require\": \"codemirror\",\n \"global\": \"CodeMirror\"\n },\n \"datatables\": {\n \"require\": \"datatables\",\n \"global\": \"jQuery\"\n },\n \"d3\": {\n \"require\": \"d3\",\n \"global\": \"d3\"\n },\n \"jquery-ui/sortable\": {\n \"require\": \"jquery-ui/sortable\",\n \"global\": \"jQuery\"\n },\n \"pivottable\": {\n \"require\": \"pivottable\",\n \"global\": \"jQuery\"\n }\n }\n}\n\n},{}],28:[function(require,module,exports){\n'use strict';\nmodule.exports = function(result) {\n\tvar quote = \"\\\"\";\n\tvar delimiter = \",\";\n\tvar lineBreak = \"\\n\";\n\n\tvar variables = result.head.vars;\n\n\tvar querySolutions = result.results.bindings;\n\n\n\n\tvar createHeader = function() {\n\t\tfor (var i = 0; i < variables.length; i++) {\n\t\t\taddValueToString(variables[i]);\n\t\t}\n\t\tcsvString += lineBreak;\n\t};\n\n\tvar createBody = function() {\n\t\tfor (var i = 0; i < querySolutions.length; i++) {\n\t\t\taddQuerySolutionToString(querySolutions[i]);\n\t\t\tcsvString += lineBreak;\n\t\t}\n\t};\n\n\tvar addQuerySolutionToString = function(querySolution) {\n\t\tfor (var i = 0; i < variables.length; i++) {\n\t\t\tvar variable = variables[i];\n\t\t\tif (querySolution.hasOwnProperty(variable)) {\n\t\t\t\taddValueToString(querySolution[variable][\"value\"]);\n\t\t\t} else {\n\t\t\t\taddValueToString(\"\");\n\t\t\t}\n\t\t}\n\t};\n\tvar addValueToString = function(value) {\n\t\t//Quotes in the string need to be escaped\n\t\tvalue.replace(quote, quote + quote);\n\t\tif (needToQuoteString(value)) {\n\t\t\tvalue = quote + value + quote;\n\t\t}\n\t\tcsvString += \" \" + value + \" \" + delimiter;\n\t};\n\n\tvar needToQuoteString = function(value) {\n\t\t//quote when it contains whitespace or the delimiter\n\t\tvar needQuoting = false;\n\t\tif (value.match(\"[\\\\w|\" + delimiter + \"|\" + quote + \"]\")) {\n\t\t\tneedQuoting = true;\n\t\t}\n\t\treturn needQuoting;\n\t};\n\n\tvar csvString = \"\";\n\tcreateHeader();\n\tcreateBody();\n\treturn csvString;\n};\n},{}],29:[function(require,module,exports){\n'use strict';\nvar $ = require(\"jquery\");\n\n/**\n * Constructor of plugin which displays boolean info\n * \n * @param yasr {object}\n * @param parent {DOM element}\n * @param options {object}\n * @class YASR.plugins.boolean\n * @return yasr-boolean (doc)\n * \n */\nvar root = module.exports = function(yasr) {\n\tvar container = $(\"<div class='booleanResult'></div>\");\n\tvar draw = function() {\n\t\tcontainer.empty().appendTo(yasr.resultsContainer);\n\t\tvar booleanVal = yasr.results.getBoolean();\n\n\t\tvar imgId = null;\n\t\tvar textVal = null;\n\t\tif (booleanVal === true) {\n\t\t\timgId = \"check\";\n\t\t\ttextVal = \"True\";\n\t\t} else if (booleanVal === false) {\n\t\t\timgId = \"cross\";\n\t\t\ttextVal = \"False\";\n\t\t} else {\n\t\t\tcontainer.width(\"140\");\n\t\t\ttextVal = \"Could not find boolean value in response\";\n\t\t}\n\n\t\t//add icon\n\t\tif (imgId) require(\"yasgui-utils\").svg.draw(container, require('./imgs.js')[imgId]);\n\n\t\t$(\"<span></span>\").text(textVal).appendTo(container);\n\t};\n\n\n\tvar canHandleResults = function() {\n\t\treturn yasr.results.getBoolean && (yasr.results.getBoolean() === true || yasr.results.getBoolean() == false);\n\t};\n\n\n\n\treturn {\n\t\tname: null, //don't need to set this: we don't show it in the selection widget anyway, so don't need a human-friendly name\n\t\tdraw: draw,\n\t\thideFromSelection: true,\n\t\tgetPriority: 10,\n\t\tcanHandleResults: canHandleResults\n\t}\n};\n\n\nroot.version = {\n\t\"YASR-boolean\": require(\"../package.json\").version,\n\t\"jquery\": $.fn.jquery,\n};\n},{\"../package.json\":27,\"./imgs.js\":36,\"jquery\":18,\"yasgui-utils\":24}],30:[function(require,module,exports){\n'use strict';\nvar $ = require('jquery');\nmodule.exports = {\n\t/**\n\t * key of default plugin to use\n\t * @property output\n\t * @type string\n\t * @default \"table\"\n\t */\n\toutput: \"table\",\n\tuseGoogleCharts: true,\n\toutputPlugins: [\"table\", \"error\", \"boolean\", \"rawResponse\", \"pivot\", \"gchart\"],\n\n\t/**\n\t * Draw the output selector widget\n\t * \n\t * @property drawOutputSelector\n\t * @type boolean\n\t * @default true\n\t */\n\tdrawOutputSelector: true,\n\n\t/**\n\t * Draw download icon. This issues html5 download functionality to 'download' files created on the client-side.\n\t * This allows the user to download results already queried for, such as a CSV when a table is shown, or the original response when the raw response output is selected\n\t * \n\t * @property drawDownloadIcon\n\t * @type boolean\n\t * @default true\n\t */\n\tdrawDownloadIcon: true,\n\n\n\tgetUsedPrefixes: null,\n\t/**\n\t * Make certain settings and values of YASR persistent. Setting a key\n\t * to null, will disable persistancy: nothing is stored between browser\n\t * sessions Setting the values to a string (or a function which returns a\n\t * string), will store the query in localstorage using the specified string.\n\t * By default, the ID is dynamically generated by finding the nearest DOM element with an \"id\" set,\n\t * to avoid collissions when using multiple YASR items on one page\n\t * \n\t * @property persistency\n\t * @type object\n\t */\n\tpersistency: {\n\t\tprefix: function(yasr) {\n\t\t\treturn \"yasr_\" + $(yasr.container).closest('[id]').attr('id') + \"_\";\n\t\t},\n\t\t/**\n\t\t * Persistency setting for the selected output\n\t\t * \n\t\t * @property persistency.outputSelector\n\t\t * @type string|function\n\t\t * @default function (determine unique id)\n\t\t */\n\t\toutputSelector: function(yasr) {\n\t\t\treturn \"selector\";\n\t\t},\n\t\t/**\n\t\t * Persistency setting for query results.\n\t\t * \n\t\t * @property persistency.results\n\t\t * @type object\n\t\t */\n\t\tresults: {\n\t\t\t/**\n\t\t\t * Get the key to store results in\n\t\t\t * \n\t\t\t * @property persistency.results.id\n\t\t\t * @type string|function\n\t\t\t * @default function (determine unique id)\n\t\t\t */\n\t\t\tid: function(yasr) {\n\t\t\t\treturn \"results_\" + $(yasr.container).closest('[id]').attr('id');\n\t\t\t},\n\t\t\tkey: 'results',\n\t\t\t/**\n\t\t\t * The result set might too large to fit in local storage. \n\t\t\t * It is impossible to detect how large the local storage is.\n\t\t\t * Therefore, we do not store all results in local storage, depending on a max number of characters in the SPARQL result serialization.\n\t\t\t * Set this function conservitavely. (especially when using multiple YASR instances on one page)\n\t\t\t * \n\t\t\t * @property persistency.results.maxSize\n\t\t\t * @type int\n\t\t\t * @default 100000\n\t\t\t */\n\t\t\tmaxSize: 100000 //char count\n\t\t}\n\n\t},\n\n\n};\n},{\"jquery\":18}],31:[function(require,module,exports){\n//this is the entry-point for browserify.\n//the current browserify version does not support require-ing js files which are used as entry-point\n//this way, we can still require our main.js file\nmodule.exports = require('./main.js');\n},{\"./main.js\":39}],32:[function(require,module,exports){\n'use strict';\nvar $ = require(\"jquery\");\n\n/**\n * Constructor of plugin which displays SPARQL errors\n * \n * @param yasr {object}\n * @param parent {DOM element}\n * @param options {object}\n * @class YASR.plugins.boolean\n * @return yasr-erro (doc)\n * \n */\nvar root = module.exports = function(yasr) {\n\tvar $container = $(\"<div class='errorResult'></div>\");\n\tvar options = $.extend(true, {}, root.defaults);\n\n\tvar getTryBtn = function() {\n\t\tvar $tryBtn = null;\n\t\tif (options.tryQueryLink) {\n\t\t\tvar link = options.tryQueryLink();\n\t\t\t$tryBtn = $('<button>', {\n\t\t\t\t\tclass: 'yasr_btn yasr_tryQuery'\n\t\t\t\t})\n\t\t\t\t.text('Try query in new browser window')\n\t\t\t\t.click(function() {\n\t\t\t\t\twindow.open(link, '_blank');\n\t\t\t\t\t$(this).blur();\n\t\t\t\t})\n\t\t}\n\t\treturn $tryBtn;\n\t}\n\n\tvar draw = function() {\n\t\tvar error = yasr.results.getException();\n\t\t$container.empty().appendTo(yasr.resultsContainer);\n\t\tvar $header = $(\"<div>\", {\n\t\t\tclass: 'errorHeader'\n\t\t}).appendTo($container);\n\n\t\tif (error.status !== 0) {\n\t\t\tvar statusText = 'Error';\n\t\t\tif (error.statusText && error.statusText.length < 100) {\n\t\t\t\t//use a max: otherwise the alert span will look ugly\n\t\t\t\tstatusText = error.statusText;\n\t\t\t}\n\t\t\tstatusText += ' (#' + error.status + ')';\n\n\t\t\t$header\n\t\t\t\t.append(\n\t\t\t\t\t$(\"<span>\", {\n\t\t\t\t\t\tclass: 'exception'\n\t\t\t\t\t})\n\t\t\t\t\t.text(statusText)\n\t\t\t\t)\n\t\t\t\t.append(getTryBtn());\n\n\t\t\tvar responseText = null;\n\t\t\tif (error.responseText) {\n\t\t\t\tresponseText = error.responseText;\n\t\t\t} else if (typeof error == \"string\") {\n\t\t\t\t//for backwards compatability (when creating the error string was done externally\n\t\t\t\tresponseText = error;\n\t\t\t}\n\t\t\tif (responseText) $container.append($(\"<pre>\").text(responseText));\n\t\t} else {\n\t\t\t$header.append(getTryBtn());\n\t\t\t//cors disabled, wrong url, or endpoint down\n\t\t\t$container\n\t\t\t\t.append(\n\t\t\t\t\t$('<div>', {\n\t\t\t\t\t\tclass: 'corsMessage'\n\t\t\t\t\t})\n\t\t\t\t\t.append(options.corsMessage)\n\t\t\t\t);\n\t\t}\n\n\t};\n\n\n\tvar canHandleResults = function(yasr) {\n\t\treturn yasr.results.getException() || false;\n\t};\n\n\treturn {\n\t\tname: null, //don't need to set this: we don't show it in the selection widget anyway, so don't need a human-friendly name\n\t\tdraw: draw,\n\t\tgetPriority: 20,\n\t\thideFromSelection: true,\n\t\tcanHandleResults: canHandleResults,\n\t}\n};\n\n/**\n * Defaults for error plugin\n * \n * @type object\n * @attribute YASR.plugins.error.defaults\n */\nroot.defaults = {\n\tcorsMessage: 'Unable to get response from endpoint',\n\ttryQueryLink: null,\n};\n},{\"jquery\":18}],33:[function(require,module,exports){\nmodule.exports = {\n\tGoogleTypeException: function(foundTypes, varName) {\n\t\tthis.foundTypes = foundTypes;\n\t\tthis.varName = varName;\n\t\tthis.toString = function() {\n\t\t\tvar string = 'Conflicting data types found for variable ' + this.varName + '. Assuming all values of this variable are \"string\".';\n\t\t\tstring += ' To avoid this issue, cast the values in your SPARQL query to the intended xsd datatype';\n\n\t\t\treturn string;\n\t\t};\n\t\tthis.toHtml = function() {\n\t\t\tvar string = 'Conflicting data types found for variable <i>' + this.varName + '</i>. Assuming all values of this variable are \"string\".';\n\t\t\tstring += ' As a result, several Google Charts will not render values of this particular variable.';\n\t\t\tstring += ' To avoid this issue, cast the values in your SPARQL query to the intended xsd datatype';\n\n\t\t\treturn string;\n\t\t};\n\t}\n}\n},{}],34:[function(require,module,exports){\n(function (global){\nvar EventEmitter = require('events').EventEmitter,\n\t$ = require('jquery');\n//cannot package google loader via browserify....\nvar loadingMain = false;\nvar loadingFailed = false;\n\nvar loader = function() {\n\tEventEmitter.call(this);\n\tvar mod = this;\n\tthis.init = function() {\n\t\tif (!loadingFailed && !(typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null) && !loadingMain) { //not initiated yet, not currently loading, and has not failed the previous time\n\t\t\tloadingMain = true;\n\t\t\t/**\n\t\t\t * It is extremely difficult to catch script loader errors (see http://www.html5rocks.com/en/tutorials/speed/script-loading/)\n\t\t\t * Existing libraries either ignore several browsers (e.g. jquery 2.x), or use ugly hacks (timeouts or something)\n\t\t\t * So, we use our own custom ugly hack (yes, timeouts)\n\t\t\t */\n\t\t\t //use protocol relative req when served via http. Otherwise, just use http:// (e.g. when yasr is served via file://)\n\t\t\tloadScript((window.location.protocol.indexOf(\"http\") === 0 ? '//': 'http://') + 'google.com/jsapi', function() {\n\t\t\t\tloadingMain = false;\n\t\t\t\tmod.emit('initDone');\n\t\t\t});\n\n\t\t\tvar timeout = 100; //ms\n\t\t\tvar maxTimeout = 6000; //so 6 sec max\n\t\t\tvar startTime = +new Date();\n\t\t\tvar checkAndWait = function() {\n\t\t\t\tif (!(typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null)) {\n\t\t\t\t\tif ((+new Date() - startTime) > maxTimeout) {\n\t\t\t\t\t\t//ok, we've waited long enough. Obviously we could not load the googleloader...\n\t\t\t\t\t\tloadingFailed = true;\n\t\t\t\t\t\tloadingMain = false;\n\t\t\t\t\t\tmod.emit('initError');\n\n\t\t\t\t\t\t//TODO: clear initDone callbacks. they won't fire anymore anyway\n\n\t\t\t\t\t} else {\n\t\t\t\t\t\tsetTimeout(checkAndWait, timeout);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t//TODO: clear initFailed callbacks. they won't fire anymore anyway\n\t\t\t\t}\n\t\t\t}\n\t\t\tcheckAndWait();\n\t\t} else {\n\t\t\tif ((typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null)) {\n\t\t\t\t//already loaded! everything is fine\n\t\t\t\tmod.emit('initDone');\n\t\t\t} else if (loadingFailed) {\n\t\t\t\tmod.emit('initError')\n\t\t\t} else {\n\t\t\t\t//hmmm, should never get here\n\t\t\t}\n\n\t\t}\n\t}\n\tthis.googleLoad = function() {\n\n\t\tvar load = function() {\n\t\t\t(typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null).load(\"visualization\", \"1\", {\n\t\t\t\tpackages: [\"corechart\", \"charteditor\"],\n\t\t\t\tcallback: function() {\n\t\t\t\t\tmod.emit('done')\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\t\tif (loadingMain) {\n\t\t\tmod.once('initDone', load);\n\t\t\tmod.once('initError', function() {\n\t\t\t\tmod.emit('error', 'Could not load google loader')\n\t\t\t});\n\t\t} else if ((typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null)) {\n\t\t\t//google loader is there. use it\n\t\t\tload();\n\t\t} else if (loadingFailed) {\n\t\t\tmod.emit('error', 'Could not load google loader');\n\t\t} else {\n\t\t\t//not loading, no loading error, and not loaded. it must not have been initialized yet. Do that\n\t\t\tmod.once('initDone', load);\n\t\t\tmod.once('initError', function() {\n\t\t\t\tmod.emit('error', 'Could not load google loader')\n\t\t\t});\n\t\t}\n\t};\n}\n\n\nvar loadScript = function(url, callback) {\n\tvar script = document.createElement(\"script\")\n\tscript.type = \"text/javascript\";\n\n\tif (script.readyState) { //IE\n\t\tscript.onreadystatechange = function() {\n\t\t\tif (script.readyState == \"loaded\" ||\n\t\t\t\tscript.readyState == \"complete\") {\n\t\t\t\tscript.onreadystatechange = null;\n\t\t\t\tcallback();\n\t\t\t}\n\t\t};\n\t} else { //Others\n\t\tscript.onload = function() {\n\t\t\tcallback();\n\t\t};\n\t}\n\n\tscript.src = url;\n\tdocument.body.appendChild(script);\n}\nloader.prototype = new EventEmitter;\nmodule.exports = new loader();\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n\n},{\"events\":13,\"jquery\":18}],35:[function(require,module,exports){\n(function (global){\n'use strict';\n/**\n * todo: chart height as option\n * \n */\nvar $ = require('jquery'),\n\tutils = require('./utils.js'),\n\tyUtils = require('yasgui-utils');\n\nvar root = module.exports = function(yasr) {\n\n\tvar options = $.extend(true, {}, root.defaults);\n\tvar id = yasr.container.closest('[id]').attr('id');\n\n\tvar chartWrapper = null;\n\tvar editor = null;\n\n\tvar initEditor = function(callback) {\n\t\tvar google = (typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null);\n\t\teditor = new google.visualization.ChartEditor();\n\t\tgoogle.visualization.events.addListener(editor, 'ok', function() {\n\t\t\tvar tmp;\n\t\t\tchartWrapper = editor.getChartWrapper();\n\t\t\ttmp = chartWrapper.getDataTable();\n\t\t\tchartWrapper.setDataTable(null);\n\t\t\t//ugly: need to parse json string to json obj again, as google chart does not provide access to object directly\n\t\t\toptions.chartConfig = JSON.parse(chartWrapper.toJSON());\n\t\t\t//remove container ID though, for portability\n\t\t\tif (options.chartConfig.containerId) delete options.chartConfig['containerId'];\n\t\t\tyasr.store();\n\t\t\tchartWrapper.setDataTable(tmp);\n\t\t\tvar wrapperId = id + '_gchartWrapper';\n\t\t\tvar $wrapper = $('#' + wrapperId);\n\t\t\tchartWrapper.setOption(\"width\", $wrapper.width());\n\t\t\tchartWrapper.setOption(\"height\", $wrapper.height());\n\t\t\tchartWrapper.draw();\n\t\t\tyasr.updateHeader();\n\t\t});\n\t\tif (callback) callback();\n\t};\n\n\treturn {\n\t\tname: \"Google Chart\",\n\t\thideFromSelection: false,\n\t\tpriority: 7,\n\t\toptions: options,\n\t\tgetPersistentSettings: function() {\n\t\t\treturn {\n\t\t\t\tchartConfig: options.chartConfig,\n\t\t\t\tmotionChartState: options.motionChartState\n\t\t\t}\n\t\t},\n\t\tsetPersistentSettings: function(persSettings) {\n\t\t\tif (persSettings['chartConfig']) options.chartConfig = persSettings['chartConfig'];\n\t\t\tif (persSettings['motionChartState']) options.motionChartState = persSettings['motionChartState'];\n\t\t},\n\t\tcanHandleResults: function(yasr) {\n\t\t\tvar results, variables;\n\t\t\treturn (results = yasr.results) != null && (variables = results.getVariables()) && variables.length > 0;\n\t\t},\n\t\tgetDownloadInfo: function() {\n\t\t\tif (!yasr.results) return null;\n\t\t\tvar svgEl = yasr.resultsContainer.find('svg');\n\t\t\tif (svgEl.length > 0) {\n\t\t\t\treturn {\n\t\t\t\t\tgetContent: function() {\n\t\t\t\t\t\tif (svgEl[0].outerHTML) {\n\t\t\t\t\t\t\treturn svgEl[0].outerHTML;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t//outerHTML not supported. use workaround\n\t\t\t\t\t\t\treturn $('<div>').append(svgEl.clone()).html();\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\tfilename: \"queryResults.svg\",\n\t\t\t\t\tcontentType: \"image/svg+xml\",\n\t\t\t\t\tbuttonTitle: \"Download SVG Image\"\n\t\t\t\t};\n\t\t\t}\n\t\t\t//ok, not a svg. is it a table?\n\t\t\tvar $table = yasr.resultsContainer.find('.google-visualization-table-table');\n\t\t\tif ($table.length > 0) {\n\t\t\t\treturn {\n\t\t\t\t\tgetContent: function() {\n\t\t\t\t\t\treturn $table.tableToCsv();\n\t\t\t\t\t},\n\t\t\t\t\tfilename: \"queryResults.csv\",\n\t\t\t\t\tcontentType: \"text/csv\",\n\t\t\t\t\tbuttonTitle: \"Download as CSV\"\n\t\t\t\t};\n\t\t\t}\n\t\t},\n\t\tgetEmbedHtml: function() {\n\t\t\tif (!yasr.results) return null;\n\n\t\t\tvar svgEl = yasr.resultsContainer.find('svg')\n\t\t\t\t.clone() //create clone, as we'd like to remove height/width attributes\n\t\t\t\t.removeAttr('height').removeAttr('width')\n\t\t\t\t.css('height', '').css('width', '');\n\t\t\tif (svgEl.length == 0) return null;\n\n\t\t\tvar htmlString = svgEl[0].outerHTML;\n\t\t\tif (!htmlString) {\n\t\t\t\t//outerHTML not supported. use workaround\n\t\t\t\thtmlString = $('<div>').append(svgEl.clone()).html();\n\t\t\t}\n\t\t\t//wrap in div, so users can more easily tune width/height\n\t\t\t//don't use jquery, so we can easily influence indentation\n\t\t\treturn '<div style=\"width: 800px; height: 600px;\">\\n' + htmlString + '\\n</div>';\n\t\t},\n\t\tdraw: function() {\n\t\t\tvar doDraw = function() {\n\t\t\t\t//clear previous results (if any)\n\t\t\t\tyasr.resultsContainer.empty();\n\t\t\t\tvar wrapperId = id + '_gchartWrapper';\n\n\t\t\t\tyasr.resultsContainer.append(\n\t\t\t\t\t$('<button>', {\n\t\t\t\t\t\tclass: 'openGchartBtn yasr_btn'\n\t\t\t\t\t})\n\t\t\t\t\t.text('Chart Config')\n\t\t\t\t\t.click(function() {\n\t\t\t\t\t\teditor.openDialog(chartWrapper);\n\t\t\t\t\t})\n\t\t\t\t).append(\n\t\t\t\t\t$('<div>', {\n\t\t\t\t\t\tid: wrapperId,\n\t\t\t\t\t\tclass: 'gchartWrapper'\n\t\t\t\t\t})\n\t\t\t\t);\n\t\t\t\tvar dataTable = new google.visualization.DataTable();\n\t\t\t\tvar jsonResults = yasr.results.getAsJson();\n\n\t\t\t\tjsonResults.head.vars.forEach(function(variable) {\n\t\t\t\t\tvar type = 'string';\n\t\t\t\t\ttry {\n\t\t\t\t\t\ttype = utils.getGoogleTypeForBindings(jsonResults.results.bindings, variable);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\tif (e instanceof require('./exceptions.js').GoogleTypeException) {\n\t\t\t\t\t\t\tyasr.warn(e.toHtml())\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthrow e;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tdataTable.addColumn(type, variable);\n\t\t\t\t});\n\t\t\t\tvar usedPrefixes = null;\n\t\t\t\tif (yasr.options.getUsedPrefixes) {\n\t\t\t\t\tusedPrefixes = (typeof yasr.options.getUsedPrefixes == \"function\" ? yasr.options.getUsedPrefixes(yasr) : yasr.options.getUsedPrefixes);\n\t\t\t\t}\n\t\t\t\tjsonResults.results.bindings.forEach(function(binding) {\n\t\t\t\t\tvar row = [];\n\t\t\t\t\tjsonResults.head.vars.forEach(function(variable, columnId) {\n\t\t\t\t\t\trow.push(utils.castGoogleType(binding[variable], usedPrefixes, dataTable.getColumnType(columnId)));\n\t\t\t\t\t})\n\t\t\t\t\tdataTable.addRow(row);\n\t\t\t\t});\n\n\t\t\t\tif (options.chartConfig && options.chartConfig.chartType) {\n\t\t\t\t\toptions.chartConfig.containerId = wrapperId;\n\t\t\t\t\tchartWrapper = new google.visualization.ChartWrapper(options.chartConfig);\n\t\t\t\t\tif (chartWrapper.getChartType() === \"MotionChart\" && options.motionChartState) {\n\t\t\t\t\t\tchartWrapper.setOption(\"state\", options.motionChartState);\n\t\t\t\t\t\tgoogle.visualization.events.addListener(chartWrapper, 'ready', function() {\n\t\t\t\t\t\t\tvar motionChart;\n\t\t\t\t\t\t\tmotionChart = chartWrapper.getChart();\n\t\t\t\t\t\t\tgoogle.visualization.events.addListener(motionChart, 'statechange', function() {\n\t\t\t\t\t\t\t\toptions.motionChartState = motionChart.getState();\n\t\t\t\t\t\t\t\tyasr.store();\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t\tchartWrapper.setDataTable(dataTable);\n\t\t\t\t} else {\n\t\t\t\t\tchartWrapper = new google.visualization.ChartWrapper({\n\t\t\t\t\t\tchartType: 'Table',\n\t\t\t\t\t\tdataTable: dataTable,\n\t\t\t\t\t\tcontainerId: wrapperId\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tvar $wrapper = $('#' + wrapperId);\n\t\t\t\tchartWrapper.setOption(\"width\", $wrapper.width());\n\t\t\t\tchartWrapper.setOption(\"height\", $wrapper.height());\n\t\t\t\tchartWrapper.draw();\n\t\t\t\tgoogle.visualization.events.addListener(chartWrapper, 'ready', yasr.updateHeader);\n\t\t\t}\n\n\t\t\tif (!(typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null) || !(typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null).visualization || !editor) {\n\t\t\t\trequire('./gChartLoader.js')\n\t\t\t\t\t.on('done', function() {\n\t\t\t\t\t\tinitEditor();\n\t\t\t\t\t\tdoDraw();\n\t\t\t\t\t})\n\t\t\t\t\t.on('error', function() {\n\t\t\t\t\t\t//TODO: disable or something?\n\t\t\t\t\t})\n\t\t\t\t\t.googleLoad();\n\t\t\t} else {\n\t\t\t\t//everything (editor as well) is already initialized\n\t\t\t\tdoDraw();\n\t\t\t}\n\t\t}\n\t};\n};\nroot.defaults = {\n\theight: \"100%\",\n\twidth: \"100%\",\n\tpersistencyId: 'gchart',\n\tchartConfig: null,\n\tmotionChartState: null\n};\n\nfunction deepEq$(x, y, type) {\n\tvar toString = {}.toString,\n\t\thasOwnProperty = {}.hasOwnProperty,\n\t\thas = function(obj, key) {\n\t\t\treturn hasOwnProperty.call(obj, key);\n\t\t};\n\tvar first = true;\n\treturn eq(x, y, []);\n\n\tfunction eq(a, b, stack) {\n\t\tvar className, length, size, result, alength, blength, r, key, ref, sizeB;\n\t\tif (a == null || b == null) {\n\t\t\treturn a === b;\n\t\t}\n\t\tif (a.__placeholder__ || b.__placeholder__) {\n\t\t\treturn true;\n\t\t}\n\t\tif (a === b) {\n\t\t\treturn a !== 0 || 1 / a == 1 / b;\n\t\t}\n\t\tclassName = toString.call(a);\n\t\tif (toString.call(b) != className) {\n\t\t\treturn false;\n\t\t}\n\t\tswitch (className) {\n\t\t\tcase '[object String]':\n\t\t\t\treturn a == String(b);\n\t\t\tcase '[object Number]':\n\t\t\t\treturn a != +a ? b != +b : (a == 0 ? 1 / a == 1 / b : a == +b);\n\t\t\tcase '[object Date]':\n\t\t\tcase '[object Boolean]':\n\t\t\t\treturn +a == +b;\n\t\t\tcase '[object RegExp]':\n\t\t\t\treturn a.source == b.source &&\n\t\t\t\t\ta.global == b.global &&\n\t\t\t\t\ta.multiline == b.multiline &&\n\t\t\t\t\ta.ignoreCase == b.ignoreCase;\n\t\t}\n\t\tif (typeof a != 'object' || typeof b != 'object') {\n\t\t\treturn false;\n\t\t}\n\t\tlength = stack.length;\n\t\twhile (length--) {\n\t\t\tif (stack[length] == a) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\tstack.push(a);\n\t\tsize = 0;\n\t\tresult = true;\n\t\tif (className == '[object Array]') {\n\t\t\talength = a.length;\n\t\t\tblength = b.length;\n\t\t\tif (first) {\n\t\t\t\tswitch (type) {\n\t\t\t\t\tcase '===':\n\t\t\t\t\t\tresult = alength === blength;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase '<==':\n\t\t\t\t\t\tresult = alength <= blength;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase '<<=':\n\t\t\t\t\t\tresult = alength < blength;\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tsize = alength;\n\t\t\t\tfirst = false;\n\t\t\t} else {\n\t\t\t\tresult = alength === blength;\n\t\t\t\tsize = alength;\n\t\t\t}\n\t\t\tif (result) {\n\t\t\t\twhile (size--) {\n\t\t\t\t\tif (!(result = size in a == size in b && eq(a[size], b[size], stack))) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tif ('constructor' in a != 'constructor' in b || a.constructor != b.constructor) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tfor (key in a) {\n\t\t\t\tif (has(a, key)) {\n\t\t\t\t\tsize++;\n\t\t\t\t\tif (!(result = has(b, key) && eq(a[key], b[key], stack))) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (result) {\n\t\t\t\tsizeB = 0;\n\t\t\t\tfor (key in b) {\n\t\t\t\t\tif (has(b, key)) {\n\t\t\t\t\t\t++sizeB;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (first) {\n\t\t\t\t\tif (type === '<<=') {\n\t\t\t\t\t\tresult = size < sizeB;\n\t\t\t\t\t} else if (type === '<==') {\n\t\t\t\t\t\tresult = size <= sizeB\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult = size === sizeB;\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tfirst = false;\n\t\t\t\t\tresult = size === sizeB;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tstack.pop();\n\t\treturn result;\n\t}\n}\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n\n},{\"./exceptions.js\":33,\"./gChartLoader.js\":34,\"./utils.js\":49,\"jquery\":18,\"yasgui-utils\":24}],36:[function(require,module,exports){\n'use strict';\nmodule.exports = {\n\tcross: '<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" version=\"1.1\" x=\"0px\" y=\"0px\" width=\"30px\" height=\"30px\" viewBox=\"0 0 100 100\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\"><g>\t<path d=\"M83.288,88.13c-2.114,2.112-5.575,2.112-7.689,0L53.659,66.188c-2.114-2.112-5.573-2.112-7.687,0L24.251,87.907 c-2.113,2.114-5.571,2.114-7.686,0l-4.693-4.691c-2.114-2.114-2.114-5.573,0-7.688l21.719-21.721c2.113-2.114,2.113-5.573,0-7.686 L11.872,24.4c-2.114-2.113-2.114-5.571,0-7.686l4.842-4.842c2.113-2.114,5.571-2.114,7.686,0L46.12,33.591 c2.114,2.114,5.572,2.114,7.688,0l21.721-21.719c2.114-2.114,5.573-2.114,7.687,0l4.695,4.695c2.111,2.113,2.111,5.571-0.003,7.686 L66.188,45.973c-2.112,2.114-2.112,5.573,0,7.686L88.13,75.602c2.112,2.111,2.112,5.572,0,7.687L83.288,88.13z\"/></g></svg>',\n\tcheck: '<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" version=\"1.1\" x=\"0px\" y=\"0px\" width=\"30px\" height=\"30px\" viewBox=\"0 0 100 100\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\"><path fill=\"#000000\" d=\"M14.301,49.982l22.606,17.047L84.361,4.903c2.614-3.733,7.76-4.64,11.493-2.026l0.627,0.462 c3.732,2.614,4.64,7.758,2.025,11.492l-51.783,79.77c-1.955,2.791-3.896,3.762-7.301,3.988c-3.405,0.225-5.464-1.039-7.508-3.084 L2.447,61.814c-3.263-3.262-3.263-8.553,0-11.814l0.041-0.019C5.75,46.718,11.039,46.718,14.301,49.982z\"/></svg>',\n\tunsorted: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" id=\"Layer_1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"0 0 54.552711 113.78478\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\"><g id=\"g5\" transform=\"matrix(-0.70522156,-0.70898699,-0.70898699,0.70522156,97.988199,55.081205)\"><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path7\" d=\"M 57.911,66.915 45.808,55.063 42.904,52.238 31.661,41.25 31.435,41.083 31.131,40.775 30.794,40.523 30.486,40.3 30.069,40.05 29.815,39.911 29.285,39.659 29.089,39.576 28.474,39.326 28.363,39.297 H 28.336 L 27.665,39.128 27.526,39.1 26.94,38.99 26.714,38.961 26.212,38.934 h -0.31 -0.444 l -0.339,0.027 c -1.45,0.139 -2.876,0.671 -4.11,1.564 l -0.223,0.141 -0.279,0.25 -0.335,0.308 -0.054,0.029 -0.171,0.194 -0.334,0.364 -0.224,0.279 -0.25,0.336 -0.225,0.362 -0.192,0.308 -0.197,0.421 -0.142,0.279 -0.193,0.477 -0.084,0.222 -12.441,38.414 c -0.814,2.458 -0.313,5.029 1.115,6.988 v 0.026 l 0.418,0.532 0.17,0.165 0.251,0.281 0.084,0.079 0.283,0.281 0.25,0.194 0.474,0.367 0.083,0.053 c 2.015,1.371 4.641,1.874 7.131,1.094 L 55.228,80.776 c 4.303,-1.342 6.679,-5.814 5.308,-10.006 -0.387,-1.259 -1.086,-2.35 -1.979,-3.215 l -0.368,-0.337 -0.278,-0.303 z m -6.318,5.896 0.079,0.114 -37.369,11.57 11.854,-36.538 10.565,10.317 2.876,2.825 11.995,11.712 z\" /></g><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path7-9\" d=\"m 8.8748339,52.571766 16.9382111,-0.222584 4.050851,-0.06665 15.719154,-0.222166 0.27778,-0.04246 0.43276,0.0017 0.41632,-0.06121 0.37532,-0.0611 0.47132,-0.119342 0.27767,-0.08206 0.55244,-0.198047 0.19707,-0.08043 0.61095,-0.259721 0.0988,-0.05825 0.019,-0.01914 0.59303,-0.356548 0.11787,-0.0788 0.49125,-0.337892 0.17994,-0.139779 0.37317,-0.336871 0.21862,-0.219786 0.31311,-0.31479 0.21993,-0.259387 c 0.92402,-1.126057 1.55249,-2.512251 1.78961,-4.016904 l 0.0573,-0.25754 0.0195,-0.374113 0.0179,-0.454719 0.0175,-0.05874 -0.0169,-0.258049 -0.0225,-0.493503 -0.0398,-0.355569 -0.0619,-0.414201 -0.098,-0.414812 -0.083,-0.353334 L 53.23955,41.1484 53.14185,40.850967 52.93977,40.377742 52.84157,40.161628 34.38021,4.2507375 C 33.211567,1.9401875 31.035446,0.48226552 28.639484,0.11316952 l -0.01843,-0.01834 -0.671963,-0.07882 -0.236871,0.0042 L 27.335984,-4.7826577e-7 27.220736,0.00379952 l -0.398804,0.0025 -0.313848,0.04043 -0.594474,0.07724 -0.09611,0.02147 C 23.424549,0.60716252 21.216017,2.1142355 20.013025,4.4296865 L 0.93967491,40.894479 c -2.08310801,3.997178 -0.588125,8.835482 3.35080799,10.819749 1.165535,0.613495 2.43199,0.88731 3.675026,0.864202 l 0.49845,-0.02325 0.410875,0.01658 z M 9.1502369,43.934401 9.0136999,43.910011 27.164145,9.2564625 44.70942,43.42818 l -14.765289,0.214677 -4.031106,0.0468 -16.7627881,0.244744 z\" /></svg>',\n\tsortDesc: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" id=\"Layer_1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"0 0 54.552711 113.78478\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\"><g id=\"g5\" transform=\"matrix(-0.70522156,-0.70898699,-0.70898699,0.70522156,97.988199,55.081205)\"><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path7\" d=\"M 57.911,66.915 45.808,55.063 42.904,52.238 31.661,41.25 31.435,41.083 31.131,40.775 30.794,40.523 30.486,40.3 30.069,40.05 29.815,39.911 29.285,39.659 29.089,39.576 28.474,39.326 28.363,39.297 H 28.336 L 27.665,39.128 27.526,39.1 26.94,38.99 26.714,38.961 26.212,38.934 h -0.31 -0.444 l -0.339,0.027 c -1.45,0.139 -2.876,0.671 -4.11,1.564 l -0.223,0.141 -0.279,0.25 -0.335,0.308 -0.054,0.029 -0.171,0.194 -0.334,0.364 -0.224,0.279 -0.25,0.336 -0.225,0.362 -0.192,0.308 -0.197,0.421 -0.142,0.279 -0.193,0.477 -0.084,0.222 -12.441,38.414 c -0.814,2.458 -0.313,5.029 1.115,6.988 v 0.026 l 0.418,0.532 0.17,0.165 0.251,0.281 0.084,0.079 0.283,0.281 0.25,0.194 0.474,0.367 0.083,0.053 c 2.015,1.371 4.641,1.874 7.131,1.094 L 55.228,80.776 c 4.303,-1.342 6.679,-5.814 5.308,-10.006 -0.387,-1.259 -1.086,-2.35 -1.979,-3.215 l -0.368,-0.337 -0.278,-0.303 z m -6.318,5.896 0.079,0.114 -37.369,11.57 11.854,-36.538 10.565,10.317 2.876,2.825 11.995,11.712 z\" /></g><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path9\" d=\"m 27.813273,0.12823506 0.09753,0.02006 c 2.39093,0.458209 4.599455,1.96811104 5.80244,4.28639004 L 52.785897,40.894525 c 2.088044,4.002139 0.590949,8.836902 -3.348692,10.821875 -1.329078,0.688721 -2.766603,0.943695 -4.133174,0.841768 l -0.454018,0.02 L 27.910392,52.354171 23.855313,52.281851 8.14393,52.061827 7.862608,52.021477 7.429856,52.021738 7.014241,51.959818 6.638216,51.900838 6.164776,51.779369 5.889216,51.699439 5.338907,51.500691 5.139719,51.419551 4.545064,51.145023 4.430618,51.105123 4.410168,51.084563 3.817138,50.730843 3.693615,50.647783 3.207314,50.310611 3.028071,50.174369 2.652795,49.833957 2.433471,49.613462 2.140099,49.318523 1.901127,49.041407 C 0.97781,47.916059 0.347935,46.528448 0.11153,45.021676 L 0.05352,44.766255 0.05172,44.371683 0.01894,43.936017 0,43.877277 0.01836,43.62206 0.03666,43.122889 0.0765,42.765905 0.13912,42.352413 0.23568,41.940425 0.32288,41.588517 0.481021,41.151945 0.579391,40.853806 0.77369,40.381268 0.876097,40.162336 19.338869,4.2542801 c 1.172169,-2.308419 3.34759,-3.76846504 5.740829,-4.17716604 l 0.01975,0.01985 0.69605,-0.09573 0.218437,0.0225 0.490791,-0.02132 0.39809,0.0046 0.315972,0.03973 0.594462,0.08149 z\" /></svg>',\n\tsortAsc: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" id=\"Layer_1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"0 0 54.552711 113.78478\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\"><g id=\"g5\" transform=\"matrix(-0.70522156,0.70898699,-0.70898699,-0.70522156,97.988199,58.704807)\"><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path7\" d=\"M 57.911,66.915 45.808,55.063 42.904,52.238 31.661,41.25 31.435,41.083 31.131,40.775 30.794,40.523 30.486,40.3 30.069,40.05 29.815,39.911 29.285,39.659 29.089,39.576 28.474,39.326 28.363,39.297 H 28.336 L 27.665,39.128 27.526,39.1 26.94,38.99 26.714,38.961 26.212,38.934 h -0.31 -0.444 l -0.339,0.027 c -1.45,0.139 -2.876,0.671 -4.11,1.564 l -0.223,0.141 -0.279,0.25 -0.335,0.308 -0.054,0.029 -0.171,0.194 -0.334,0.364 -0.224,0.279 -0.25,0.336 -0.225,0.362 -0.192,0.308 -0.197,0.421 -0.142,0.279 -0.193,0.477 -0.084,0.222 -12.441,38.414 c -0.814,2.458 -0.313,5.029 1.115,6.988 v 0.026 l 0.418,0.532 0.17,0.165 0.251,0.281 0.084,0.079 0.283,0.281 0.25,0.194 0.474,0.367 0.083,0.053 c 2.015,1.371 4.641,1.874 7.131,1.094 L 55.228,80.776 c 4.303,-1.342 6.679,-5.814 5.308,-10.006 -0.387,-1.259 -1.086,-2.35 -1.979,-3.215 l -0.368,-0.337 -0.278,-0.303 z m -6.318,5.896 0.079,0.114 -37.369,11.57 11.854,-36.538 10.565,10.317 2.876,2.825 11.995,11.712 z\" /></g><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path9\" d=\"m 27.813273,113.65778 0.09753,-0.0201 c 2.39093,-0.45821 4.599455,-1.96811 5.80244,-4.28639 L 52.785897,72.891487 c 2.088044,-4.002139 0.590949,-8.836902 -3.348692,-10.821875 -1.329078,-0.688721 -2.766603,-0.943695 -4.133174,-0.841768 l -0.454018,-0.02 -16.939621,0.223997 -4.055079,0.07232 -15.711383,0.220024 -0.281322,0.04035 -0.432752,-2.61e-4 -0.415615,0.06192 -0.376025,0.05898 -0.47344,0.121469 -0.27556,0.07993 -0.550309,0.198748 -0.199188,0.08114 -0.594655,0.274528 -0.114446,0.0399 -0.02045,0.02056 -0.59303,0.35372 -0.123523,0.08306 -0.486301,0.337172 -0.179243,0.136242 -0.375276,0.340412 -0.219324,0.220495 -0.293372,0.294939 -0.238972,0.277116 C 0.97781,65.869953 0.347935,67.257564 0.11153,68.764336 L 0.05352,69.019757 0.05172,69.414329 0.01894,69.849995 0,69.908735 l 0.01836,0.255217 0.0183,0.499171 0.03984,0.356984 0.06262,0.413492 0.09656,0.411988 0.0872,0.351908 0.158141,0.436572 0.09837,0.298139 0.194299,0.472538 0.102407,0.218932 18.462772,35.908054 c 1.172169,2.30842 3.34759,3.76847 5.740829,4.17717 l 0.01975,-0.0199 0.69605,0.0957 0.218437,-0.0225 0.490791,0.0213 0.39809,-0.005 0.315972,-0.0397 0.594462,-0.0815 z\" /></svg>',\n\tdownload: '<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" version=\"1.1\" baseProfile=\"tiny\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"0 0 100 100\" xml:space=\"preserve\"><g id=\"Captions\"></g><g id=\"Your_Icon\">\t<path fill-rule=\"evenodd\" fill=\"#000000\" d=\"M88,84v-2c0-2.961-0.859-4-4-4H16c-2.961,0-4,0.98-4,4v2c0,3.102,1.039,4,4,4h68 C87.02,88,88,87.039,88,84z M58,12H42c-5,0-6,0.941-6,6v22H16l34,34l34-34H64V18C64,12.941,62.939,12,58,12z\"/></g></svg>',\n\tmove: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" id=\"Layer_1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"5 -10 74.074074 100\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\" inkscape:version=\"0.48.4 r9939\" sodipodi:docname=\"noun_11656_cc.svg\"><metadata ><rdf:RDF><cc:Work rdf:about=\"\"><dc:format>image/svg+xml</dc:format><dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\" /></cc:Work></rdf:RDF></metadata><defs /><sodipodi:namedview pagecolor=\"#ffffff\" bordercolor=\"#666666\" borderopacity=\"1\" objecttolerance=\"10\" gridtolerance=\"10\" guidetolerance=\"10\" inkscape:pageopacity=\"0\" inkscape:pageshadow=\"2\" inkscape:window-width=\"753\" inkscape:window-height=\"480\" showgrid=\"false\" fit-margin-top=\"0\" fit-margin-left=\"0\" fit-margin-right=\"0\" fit-margin-bottom=\"0\" inkscape:zoom=\"2.36\" inkscape:cx=\"44.101509\" inkscape:cy=\"31.481481\" inkscape:window-x=\"287\" inkscape:window-y=\"249\" inkscape:window-maximized=\"0\" inkscape:current-layer=\"Layer_1\" /><polygon points=\"33,83 50,100 67,83 54,83 54,17 67,17 50,0 33,17 46,17 46,83 \" transform=\"translate(-7.962963,-10)\" /><polygon points=\"83,67 100,50 83,33 83,46 17,46 17,33 0,50 17,67 17,54 83,54 \" transform=\"translate(-7.962963,-10)\" /></svg>',\n\tfullscreen: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"5 -10 74.074074 100\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\" inkscape:version=\"0.48.4 r9939\" sodipodi:docname=\"noun_2186_cc.svg\"><metadata ><rdf:RDF><cc:Work rdf:about=\"\"><dc:format>image/svg+xml</dc:format><dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\" /></cc:Work></rdf:RDF></metadata><defs /><sodipodi:namedview pagecolor=\"#ffffff\" bordercolor=\"#666666\" borderopacity=\"1\" objecttolerance=\"10\" gridtolerance=\"10\" guidetolerance=\"10\" inkscape:pageopacity=\"0\" inkscape:pageshadow=\"2\" inkscape:window-width=\"640\" inkscape:window-height=\"480\" showgrid=\"false\" fit-margin-top=\"0\" fit-margin-left=\"0\" fit-margin-right=\"0\" fit-margin-bottom=\"0\" inkscape:zoom=\"2.36\" inkscape:cx=\"44.101509\" inkscape:cy=\"31.481481\" inkscape:window-x=\"65\" inkscape:window-y=\"24\" inkscape:window-maximized=\"0\" inkscape:current-layer=\"Layer_1\" /><path d=\"m -7.962963,-10 v 38.889 l 16.667,-16.667 16.667,16.667 5.555,-5.555 -16.667,-16.667 16.667,-16.667 h -38.889 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"m 92.037037,-10 v 38.889 l -16.667,-16.667 -16.666,16.667 -5.556,-5.555 16.666,-16.667 -16.666,-16.667 h 38.889 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"M -7.962963,90 V 51.111 l 16.667,16.666 16.667,-16.666 5.555,5.556 -16.667,16.666 16.667,16.667 h -38.889 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"M 92.037037,90 V 51.111 l -16.667,16.666 -16.666,-16.666 -5.556,5.556 16.666,16.666 -16.666,16.667 h 38.889 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /></svg>',\n\tsmallscreen: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"5 -10 74.074074 100\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\" inkscape:version=\"0.48.4 r9939\" sodipodi:docname=\"noun_2186_cc.svg\"><metadata ><rdf:RDF><cc:Work rdf:about=\"\"><dc:format>image/svg+xml</dc:format><dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\" /></cc:Work></rdf:RDF></metadata><defs /><sodipodi:namedview pagecolor=\"#ffffff\" bordercolor=\"#666666\" borderopacity=\"1\" objecttolerance=\"10\" gridtolerance=\"10\" guidetolerance=\"10\" inkscape:pageopacity=\"0\" inkscape:pageshadow=\"2\" inkscape:window-width=\"1855\" inkscape:window-height=\"1056\" showgrid=\"false\" fit-margin-top=\"0\" fit-margin-left=\"0\" fit-margin-right=\"0\" fit-margin-bottom=\"0\" inkscape:zoom=\"2.36\" inkscape:cx=\"44.101509\" inkscape:cy=\"31.481481\" inkscape:window-x=\"65\" inkscape:window-y=\"24\" inkscape:window-maximized=\"1\" inkscape:current-layer=\"Layer_1\" /><path d=\"m 30.926037,28.889 0,-38.889 -16.667,16.667 -16.667,-16.667 -5.555,5.555 16.667,16.667 -16.667,16.667 38.889,0 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"m 53.148037,28.889 0,-38.889 16.667,16.667 16.666,-16.667 5.556,5.555 -16.666,16.667 16.666,16.667 -38.889,0 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"m 30.926037,51.111 0,38.889 -16.667,-16.666 -16.667,16.666 -5.555,-5.556 16.667,-16.666 -16.667,-16.667 38.889,0 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"m 53.148037,51.111 0,38.889 16.667,-16.666 16.666,16.666 5.556,-5.556 -16.666,-16.666 16.666,-16.667 -38.889,0 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /></svg>',\n};\n},{}],37:[function(require,module,exports){\nrequire('./tableToCsv.js');\n},{\"./tableToCsv.js\":38}],38:[function(require,module,exports){\n'use strict';\nvar $ = require('jquery');\n\n\n$.fn.tableToCsv = function(config) {\n\tvar csvString = \"\";\n\tconfig = $.extend({\n\t\tquote: \"\\\"\",\n\t\tdelimiter: \",\",\n\t\tlineBreak: \"\\n\",\n\t}, config)\n\n\n\n\n\tvar needToQuoteString = function(value) {\n\t\t//quote when it contains whitespace or the delimiter\n\t\tvar needQuoting = false;\n\t\tif (value.match(\"[\\\\w|\" + config.delimiter + \"|\" + config.quote + \"]\")) {\n\t\t\tneedQuoting = true;\n\t\t}\n\t\treturn needQuoting;\n\t};\n\tvar addValueToString = function(value) {\n\t\t//Quotes in the string need to be escaped\n\t\tvalue.replace(config.quote, config.quote + config.quote);\n\t\tif (needToQuoteString(value)) {\n\t\t\tvalue = config.quote + value + config.quote;\n\t\t}\n\t\tcsvString += \" \" + value + \" \" + config.delimiter;\n\t};\n\n\tvar addRowToString = function(rowArray) {\n\t\trowArray.forEach(function(val) {\n\t\t\taddValueToString(val);\n\t\t});\n\t\tcsvString += config.lineBreak;\n\t}\n\n\tvar tableArrays = [];\n\tvar $el = $(this);\n\tvar rowspans = {};\n\n\n\n\tvar totalColCount = 0;\n\t$el.find('tr:first *').each(function() {\n\t\tif ($(this).attr('colspan')) {\n\t\t\ttotalColCount += +$(this).attr('colspan');\n\t\t} else {\n\t\t\ttotalColCount++;\n\t\t}\n\t});\n\n\t$el.find('tr').each(function(rowId, tr) {\n\t\tvar $tr = $(tr);\n\t\tvar rowArray = []\n\n\t\tvar htmlColId = 0;\n\t\tvar actualColId = 0;\n\t\twhile (actualColId < totalColCount) {\n\t\t\tif (rowspans[actualColId]) {\n\t\t\t\trowArray.push(rowspans[actualColId].text);\n\t\t\t\trowspans[actualColId].rowSpan--;\n\t\t\t\tif (!rowspans[actualColId].rowSpan) rowspans[actualColId] = null;\n\t\t\t\tactualColId++;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tvar $cell = $tr.find(':nth-child(' + (htmlColId + 1) + ')');\n\t\t\tif (!$cell) break;\n\t\t\tvar colspan = $cell.attr('colspan') || 1;\n\t\t\tvar rowspan = $cell.attr('rowspan') || 1;\n\n\t\t\tfor (var i = 0; i < colspan; i++) {\n\t\t\t\trowArray.push($cell.text());\n\t\t\t\tif (rowspan > 1) {\n\t\t\t\t\trowspans[actualColId] = {\n\t\t\t\t\t\trowSpan: rowspan - 1,\n\t\t\t\t\t\ttext: $cell.text(),\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tactualColId++;\n\t\t\t}\n\t\t\thtmlColId++;\n\t\t}\n\t\taddRowToString(rowArray);\n\n\n\t})\n\n\treturn csvString;\n}\n\n},{\"jquery\":18}],39:[function(require,module,exports){\n'use strict';\nvar $ = require(\"jquery\"),\n\tEventEmitter = require('events').EventEmitter,\n\tutils = require(\"yasgui-utils\");\nconsole = console || {\n\t\"log\": function() {}\n}; //make sure any console statements don't break in IE\n\nrequire('./jquery/extendJquery.js');\n\n\n/**\n * Main YASR constructor\n *\n * @constructor\n * @param {DOM-Element} parent element to append editor to.\n * @param {object} settings\n * @class YASR\n * @return {doc} YASR document\n */\nvar YASR = function(parent, options, queryResults) {\n\tEventEmitter.call(this);\n\tvar yasr = this;\n\t// console.log(EventEmitter.call(this));\n\n\t// var yasr = {};\n\t// EventEmitter.call(yasr);\n\tyasr.options = $.extend(true, {}, module.exports.defaults, options);\n\t//the recursive copy does merge (overwrite) array values how we want it to. Do this manually\n\tif (options && options.outputPlugins) yasr.options.outputPlugins = options.outputPlugins;\n\n\tyasr.container = $(\"<div class='yasr'></div>\").appendTo(parent);\n\tyasr.header = $(\"<div class='yasr_header'></div>\").appendTo(yasr.container);\n\tyasr.resultsContainer = $(\"<div class='yasr_results'></div>\").appendTo(yasr.container);\n\tyasr.storage = utils.storage;\n\n\tvar prefix = null;\n\tyasr.getPersistencyId = function(postfix) {\n\t\tif (prefix === null) {\n\t\t\t//instantiate prefix\n\t\t\tif (yasr.options.persistency && yasr.options.persistency.prefix) {\n\t\t\t\tprefix = (typeof yasr.options.persistency.prefix == 'string' ? yasr.options.persistency.prefix : yasr.options.persistency.prefix(yasr));\n\t\t\t} else {\n\t\t\t\tprefix = false;\n\t\t\t}\n\t\t}\n\t\tif (prefix && postfix != null) {\n\t\t\treturn prefix + (typeof postfix == 'string' ? postfix : postfix(yasr));\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t};\n\n\tif (yasr.options.useGoogleCharts) {\n\t\t//pre-load google-loader\n\t\trequire('./gChartLoader.js')\n\t\t\t.once('initError', function() {\n\t\t\t\tyasr.options.useGoogleCharts = false\n\t\t\t})\n\t\t\t.init();\n\t}\n\n\t//first initialize plugins\n\tyasr.plugins = {};\n\tfor (var pluginName in module.exports.plugins) {\n\t\tif (!yasr.options.useGoogleCharts && pluginName == \"gchart\") continue;\n\t\tyasr.plugins[pluginName] = new module.exports.plugins[pluginName](yasr);\n\t}\n\n\n\tyasr.updateHeader = function() {\n\t\tvar downloadIcon = yasr.header.find(\".yasr_downloadIcon\")\n\t\t\t.removeAttr(\"title\"); //and remove previous titles\n\t\tvar embedButton = yasr.header.find(\".yasr_embedBtn\");\n\t\tvar outputPlugin = yasr.plugins[yasr.options.output];\n\t\tif (outputPlugin) {\n\n\t\t\t//Manage download link\n\t\t\tvar info = (outputPlugin.getDownloadInfo ? outputPlugin.getDownloadInfo() : null);\n\t\t\tif (info) {\n\t\t\t\tif (info.buttonTitle) downloadIcon.attr('title', info.buttonTitle);\n\t\t\t\tdownloadIcon.prop(\"disabled\", false);\n\t\t\t\tdownloadIcon.find(\"path\").each(function() {\n\t\t\t\t\tthis.style.fill = \"black\";\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tdownloadIcon.prop(\"disabled\", true).prop(\"title\", \"Download not supported for this result representation\");\n\t\t\t\tdownloadIcon.find(\"path\").each(function() {\n\t\t\t\t\tthis.style.fill = \"gray\";\n\t\t\t\t});\n\t\t\t}\n\n\t\t\t//Manage embed button\n\t\t\tvar link = null;\n\t\t\tif (outputPlugin.getEmbedHtml) link = outputPlugin.getEmbedHtml();\n\t\t\tif (link && link.length > 0) {\n\t\t\t\tembedButton.show();\n\t\t\t} else {\n\t\t\t\tembedButton.hide();\n\t\t\t}\n\t\t}\n\t};\n\tyasr.draw = function(output) {\n\t\tif (!yasr.results) return false;\n\t\tif (!output) output = yasr.options.output;\n\n\n\t\t//ah, our default output does not take our current results. Try to autodetect\n\t\tvar selectedOutput = null;\n\t\tvar selectedOutputPriority = -1;\n\t\tvar unsupportedOutputs = [];\n\t\tfor (var tryOutput in yasr.plugins) {\n\t\t\tif (yasr.plugins[tryOutput].canHandleResults(yasr)) {\n\t\t\t\tvar priority = yasr.plugins[tryOutput].getPriority;\n\t\t\t\tif (typeof priority == \"function\") priority = priority(yasr);\n\t\t\t\tif (priority != null && priority != undefined && priority > selectedOutputPriority) {\n\t\t\t\t\tselectedOutputPriority = priority;\n\t\t\t\t\tselectedOutput = tryOutput;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tunsupportedOutputs.push(tryOutput);\n\t\t\t}\n\t\t}\n\t\tdisableOutputs(unsupportedOutputs);\n\t\tvar outputToDraw = null;\n\t\tif (output in yasr.plugins && yasr.plugins[output].canHandleResults(yasr)) {\n\t\t\toutputToDraw = output;\n\t\t} else if (selectedOutput) {\n\t\t\toutputToDraw = selectedOutput;\n\t\t}\n\n\t\tif (outputToDraw) {\n\t\t\t$(yasr.resultsContainer).empty();\n\t\t\tyasr.emit('draw', yasr, yasr.plugins[outputToDraw]);\n\t\t\tyasr.plugins[outputToDraw].draw();\n\t\t\tyasr.emit('drawn', yasr, yasr.plugins[outputToDraw]);\n\t\t\tyasr.updateHeader();\n\t\t\treturn true;\n\t\t} else {\n\t\t\tyasr.updateHeader();\n\t\t\treturn false;\n\t\t}\n\t};\n\n\tvar disableOutputs = function(outputs) {\n\t\t//first enable everything.\n\t\tyasr.header.find('.yasr_btnGroup .yasr_btn').removeClass('disabled');\n\n\n\t\t//now disable the outputs passed as param\n\t\toutputs.forEach(function(outputName) {\n\t\t\tyasr.header.find('.yasr_btnGroup .select_' + outputName).addClass('disabled');\n\t\t});\n\n\t};\n\tyasr.somethingDrawn = function() {\n\t\treturn !yasr.resultsContainer.is(\":empty\");\n\t};\n\n\tyasr.setResponse = function(dataOrJqXhr, textStatus, jqXhrOrErrorString) {\n\t\ttry {\n\t\t\tyasr.results = require(\"./parsers/wrapper.js\")(dataOrJqXhr, textStatus, jqXhrOrErrorString);\n\t\t} catch (exception) {\n\t\t\tyasr.results = {\n\t\t\t\tgetException: function() {\n\t\t\t\t\treturn exception\n\t\t\t\t}\n\t\t\t};\n\t\t}\n\t\tyasr.draw();\n\n\t\t//store if needed\n\t\tvar resultsId = yasr.getPersistencyId(yasr.options.persistency.results.key);\n\t\tif (resultsId) {\n\t\t\tif (yasr.results.getOriginalResponseAsString && yasr.results.getOriginalResponseAsString().length < yasr.options.persistency.results.maxSize) {\n\t\t\t\tutils.storage.set(resultsId, yasr.results.getAsStoreObject(), \"month\");\n\t\t\t} else {\n\t\t\t\t//remove old string\n\t\t\t\tutils.storage.remove(resultsId);\n\t\t\t}\n\t\t}\n\t};\n\tvar $toggableWarning = null;\n\tvar $toggableWarningClose = null;\n\tvar $toggableWarningMsg = null;\n\tyasr.warn = function(warning) {\n\t\tif (!$toggableWarning) {\n\t\t\t//first time instantiation\n\t\t\t$toggableWarning = $('<div>', {\n\t\t\t\tclass: 'toggableWarning'\n\t\t\t}).prependTo(yasr.container).hide();\n\t\t\t$toggableWarningClose = $('<span>', {\n\t\t\t\t\tclass: 'toggleWarning'\n\t\t\t\t})\n\t\t\t\t.html('×')\n\t\t\t\t.click(function() {\n\t\t\t\t\t$toggableWarning.hide(400);\n\t\t\t\t})\n\t\t\t\t.appendTo($toggableWarning);\n\t\t\t$toggableWarningMsg = $('<span>', {\n\t\t\t\tclass: 'toggableMsg'\n\t\t\t}).appendTo($toggableWarning);\n\t\t}\n\t\t$toggableWarningMsg.empty();\n\t\tif (warning instanceof $) {\n\t\t\t$toggableWarningMsg.append(warning);\n\t\t} else {\n\t\t\t$toggableWarningMsg.html(warning);\n\t\t}\n\t\t$toggableWarning.show(400);\n\t};\n\n\tvar blobDownloadSupported = null;\n\tvar checkBlobDownloadSupported = function() {\n\t\tif (blobDownloadSupported === null) {\n\t\t\tvar windowUrl = window.URL || window.webkitURL || window.mozURL || window.msURL;\n\t\t\tblobDownloadSupported = windowUrl && Blob;\n\t\t}\n\t\treturn blobDownloadSupported;\n\t};\n\tvar embedBtn = null;\n\tvar drawHeader = function(yasr) {\n\t\tvar drawOutputSelector = function() {\n\t\t\tvar btnGroup = $('<div class=\"yasr_btnGroup\"></div>');\n\t\t\t$.each(yasr.options.outputPlugins, function(i, pluginName) {\n\t\t\t\tvar plugin = yasr.plugins[pluginName];\n\t\t\t\tif (!plugin) return; //plugin not loaded\n\n\t\t\t\tif (plugin.hideFromSelection) return;\n\t\t\t\tvar name = plugin.name || pluginName;\n\t\t\t\tvar button = $(\"<button class='yasr_btn'></button>\")\n\t\t\t\t\t.text(name)\n\t\t\t\t\t.addClass(\"select_\" + pluginName)\n\t\t\t\t\t.click(function() {\n\t\t\t\t\t\t//update buttons\n\t\t\t\t\t\tbtnGroup.find(\"button.selected\").removeClass(\"selected\");\n\t\t\t\t\t\t$(this).addClass(\"selected\");\n\t\t\t\t\t\t//set and draw output\n\t\t\t\t\t\tyasr.options.output = pluginName;\n\n\t\t\t\t\t\t//store if needed\n\t\t\t\t\t\tyasr.store();\n\n\t\t\t\t\t\t//close warning if there is any\n\t\t\t\t\t\tif ($toggableWarning) $toggableWarning.hide(400);\n\n\t\t\t\t\t\tyasr.draw();\n\t\t\t\t\t})\n\t\t\t\t\t.appendTo(btnGroup);\n\t\t\t\tif (yasr.options.output == pluginName) button.addClass(\"selected\");\n\t\t\t});\n\n\t\t\tif (btnGroup.children().length > 1) yasr.header.append(btnGroup);\n\t\t};\n\t\tvar drawDownloadIcon = function() {\n\t\t\tvar stringToUrl = function(string, contentType) {\n\t\t\t\tvar url = null;\n\t\t\t\tvar windowUrl = window.URL || window.webkitURL || window.mozURL || window.msURL;\n\t\t\t\tif (windowUrl && Blob) {\n\t\t\t\t\tvar blob = new Blob([string], {\n\t\t\t\t\t\ttype: contentType\n\t\t\t\t\t});\n\t\t\t\t\turl = windowUrl.createObjectURL(blob);\n\t\t\t\t}\n\t\t\t\treturn url;\n\t\t\t};\n\t\t\tvar button = $(\"<button class='yasr_btn yasr_downloadIcon btn_icon'></button>\")\n\t\t\t\t.append(require(\"yasgui-utils\").svg.getElement(require('./imgs.js').download))\n\t\t\t\t.click(function() {\n\t\t\t\t\tvar currentPlugin = yasr.plugins[yasr.options.output];\n\t\t\t\t\tif (currentPlugin && currentPlugin.getDownloadInfo) {\n\t\t\t\t\t\tvar downloadInfo = currentPlugin.getDownloadInfo();\n\t\t\t\t\t\tvar downloadUrl = stringToUrl(downloadInfo.getContent(), (downloadInfo.contentType ? downloadInfo.contentType : \"text/plain\"));\n\t\t\t\t\t\tvar downloadMockLink = $(\"<a></a>\", {\n\t\t\t\t\t\t\thref: downloadUrl,\n\t\t\t\t\t\t\tdownload: downloadInfo.filename\n\t\t\t\t\t\t});\n\t\t\t\t\t\trequire('./utils.js').fireClick(downloadMockLink);\n\t\t\t\t\t\t//\t\t\t\t\t\tdownloadMockLink[0].click();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\tyasr.header.append(button);\n\t\t};\n\t\tvar drawFullscreenButton = function() {\n\t\t\tvar button = $(\"<button class='yasr_btn btn_fullscreen btn_icon'></button>\")\n\t\t\t\t.append(require(\"yasgui-utils\").svg.getElement(require('./imgs.js').fullscreen))\n\t\t\t\t.click(function() {\n\t\t\t\t\tyasr.container.addClass('yasr_fullscreen');\n\t\t\t\t});\n\t\t\tyasr.header.append(button);\n\t\t};\n\t\tvar drawSmallscreenButton = function() {\n\t\t\tvar button = $(\"<button class='yasr_btn btn_smallscreen btn_icon'></button>\")\n\t\t\t\t.append(require(\"yasgui-utils\").svg.getElement(require('./imgs.js').smallscreen))\n\t\t\t\t.click(function() {\n\t\t\t\t\tyasr.container.removeClass('yasr_fullscreen');\n\t\t\t\t});\n\t\t\tyasr.header.append(button);\n\t\t};\n\t\tvar drawEmbedButton = function() {\n\t\t\tembedBtn = $(\"<button>\", {\n\t\t\t\t\tclass: 'yasr_btn yasr_embedBtn',\n\t\t\t\t\ttitle: 'Get HTML snippet to embed results on a web page'\n\t\t\t\t})\n\t\t\t\t.text('</>')\n\t\t\t\t.click(function(event) {\n\t\t\t\t\tvar currentPlugin = yasr.plugins[yasr.options.output];\n\t\t\t\t\tif (currentPlugin && currentPlugin.getEmbedHtml) {\n\t\t\t\t\t\tvar embedLink = currentPlugin.getEmbedHtml();\n\n\t\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t\t\tvar popup = $(\"<div class='yasr_embedPopup'></div>\").appendTo(yasr.header);\n\t\t\t\t\t\t$('html').click(function() {\n\t\t\t\t\t\t\tif (popup) popup.remove();\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tpopup.click(function(event) {\n\t\t\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t\t\t\t//dont close when clicking on popup\n\t\t\t\t\t\t});\n\t\t\t\t\t\tvar prePopup = $(\"<textarea>\").val(embedLink);\n\t\t\t\t\t\tprePopup.focus(function() {\n\t\t\t\t\t\t\tvar $this = $(this);\n\t\t\t\t\t\t\t$this.select();\n\n\t\t\t\t\t\t\t// Work around Chrome's little problem\n\t\t\t\t\t\t\t$this.mouseup(function() {\n\t\t\t\t\t\t\t\t// Prevent further mouseup intervention\n\t\t\t\t\t\t\t\t$this.unbind(\"mouseup\");\n\t\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tpopup.empty().append(prePopup);\n\t\t\t\t\t\tvar positions = embedBtn.position();\n\t\t\t\t\t\tvar top = (positions.top + embedBtn.outerHeight()) + 'px';\n\t\t\t\t\t\tvar left = Math.max(((positions.left + embedBtn.outerWidth()) - popup.outerWidth()), 0) + 'px';\n\n\t\t\t\t\t\tpopup.css(\"top\", top).css(\"left\", left);\n\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\tyasr.header.append(embedBtn);\n\t\t};\n\t\tdrawFullscreenButton();\n\t\tdrawSmallscreenButton();\n\t\tif (yasr.options.drawOutputSelector) drawOutputSelector();\n\t\tif (yasr.options.drawDownloadIcon && checkBlobDownloadSupported()) drawDownloadIcon(); //only draw when it's supported\n\t\tdrawEmbedButton();\n\t};\n\n\tvar persistentId = null;\n\t//store persistent options (not results though. store these separately, as they are too large)\n\tyasr.store = function() {\n\t\tif (!persistentId) persistentId = yasr.getPersistencyId('main');\n\t\tif (persistentId) {\n\t\t\tutils.storage.set(persistentId, yasr.getPersistentSettings());\n\t\t}\n\t};\n\n\n\tyasr.load = function() {\n\t\tif (!persistentId) persistentId = yasr.getPersistencyId('main');\n\t\tyasr.setPersistentSettings(utils.storage.get(persistentId));\n\t};\n\n\n\tyasr.setPersistentSettings = function(settings) {\n\t\tif (settings) {\n\t\t\tif (settings.output) {\n\t\t\t\tyasr.options.output = settings.output;\n\t\t\t}\n\t\t\tfor (var pluginName in settings.plugins) {\n\t\t\t\tif (yasr.plugins[pluginName] && yasr.plugins[pluginName].setPersistentSettings) {\n\t\t\t\t\tyasr.plugins[pluginName].setPersistentSettings(settings.plugins[pluginName]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tyasr.getPersistentSettings = function() {\n\t\tvar settings = {\n\t\t\toutput: yasr.options.output,\n\t\t\tplugins: {}\n\t\t};\n\t\tfor (var pluginName in yasr.plugins) {\n\t\t\tif (yasr.plugins[pluginName].getPersistentSettings) {\n\t\t\t\tsettings.plugins[pluginName] = yasr.plugins[pluginName].getPersistentSettings();\n\t\t\t}\n\t\t}\n\t\treturn settings;\n\t}\n\n\n\t/**\n\t * postprocess\n\t */\n\tyasr.load();\n\tdrawHeader(yasr);\n\tif (!queryResults && yasr.options.persistency && yasr.options.persistency.results) {\n\t\tvar resultsId = yasr.getPersistencyId(yasr.options.persistency.results.key)\n\t\tvar fromStorage;\n\t\tif (resultsId) {\n\t\t\tfromStorage = utils.storage.get(resultsId);\n\t\t}\n\n\n\t\tif (!fromStorage && yasr.options.persistency.results.id) {\n\t\t\t//deprecated! But keep for backwards compatability\n\t\t\t//if results are stored under old ID. Fetch the results, and delete that key (results can be large, and clutter space)\n\t\t\t//setting the results, will automatically store it under the new key, so we don't have to worry about that here\n\t\t\tvar deprId = (typeof yasr.options.persistency.results.id == \"string\" ? yasr.options.persistency.results.id : yasr.options.persistency.results.id(yasr));\n\t\t\tif (deprId) {\n\t\t\t\tfromStorage = utils.storage.get(deprId);\n\t\t\t\tif (fromStorage) utils.storage.remove(deprId);\n\t\t\t}\n\t\t}\n\t\tif (fromStorage) {\n\t\t\tif ($.isArray(fromStorage)) {\n\t\t\t\tyasr.setResponse.apply(this, fromStorage);\n\t\t\t} else {\n\t\t\t\tyasr.setResponse(fromStorage);\n\t\t\t}\n\t\t}\n\t}\n\n\tif (queryResults) {\n\t\tyasr.setResponse(queryResults);\n\t}\n\tyasr.updateHeader();\n\n\n\treturn yasr;\n};\n\nYASR.prototype = new EventEmitter;\nmodule.exports = function(parent, options, queryResults) {\n\treturn new YASR(parent, options, queryResults);\n}\n\n\nmodule.exports.plugins = {};\nmodule.exports.registerOutput = function(name, constructor) {\n\tmodule.exports.plugins[name] = constructor;\n};\n\n\n\n\n/**\n * The default options of YASR. Either change the default options by setting YASR.defaults, or by\n * passing your own options as second argument to the YASR constructor\n *\n * @attribute YASR.defaults\n */\nmodule.exports.defaults = require('./defaults.js');\nmodule.exports.version = {\n\t\"YASR\": require(\"../package.json\").version,\n\t\"jquery\": $.fn.jquery,\n\t\"yasgui-utils\": require(\"yasgui-utils\").version\n};\nmodule.exports.$ = $;\n\n\n\n//put these in a try-catch. When using the unbundled version, and when some dependencies are missing, then YASR as a whole will still function\ntry {\n\tmodule.exports.registerOutput('boolean', require(\"./boolean.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\ntry {\n\tmodule.exports.registerOutput('rawResponse', require(\"./rawResponse.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\ntry {\n\tmodule.exports.registerOutput('table', require(\"./table.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\ntry {\n\tmodule.exports.registerOutput('error', require(\"./error.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\ntry {\n\tmodule.exports.registerOutput('pivot', require(\"./pivot.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\ntry {\n\tmodule.exports.registerOutput('gchart', require(\"./gchart.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\n\n},{\"../package.json\":27,\"./boolean.js\":29,\"./defaults.js\":30,\"./error.js\":32,\"./gChartLoader.js\":34,\"./gchart.js\":35,\"./imgs.js\":36,\"./jquery/extendJquery.js\":37,\"./parsers/wrapper.js\":44,\"./pivot.js\":46,\"./rawResponse.js\":47,\"./table.js\":48,\"./utils.js\":49,\"events\":13,\"jquery\":18,\"yasgui-utils\":24}],40:[function(require,module,exports){\n'use strict';\nvar $ = require(\"jquery\");\nvar root = module.exports = function(queryResponse) {\n\treturn require(\"./dlv.js\")(queryResponse, \",\");\n};\n},{\"./dlv.js\":41,\"jquery\":18}],41:[function(require,module,exports){\n'use strict';\nvar $ = require('jquery');\nrequire(\"../../lib/jquery.csv-0.71.js\");\nvar root = module.exports = function(queryResponse, separator) {\n\tvar json = {};\n\tvar arrays = $.csv.toArrays(queryResponse, {\n\t\tseparator: separator\n\t});\n\tvar detectType = function(value) {\n\t\tif (value.indexOf(\"http\") == 0) {\n\t\t\treturn \"uri\";\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t};\n\n\tvar getBoolean = function() {\n\t\tif (arrays.length == 2 && arrays[0].length == 1 && arrays[1].length == 1 && arrays[0][0] == \"boolean\" && (arrays[1][0] == \"1\" || arrays[1][0] == \"0\")) {\n\t\t\tjson.boolean = (arrays[1][0] == \"1\" ? true : false);\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t};\n\n\tvar getVariables = function() {\n\t\tif (arrays.length > 0 && arrays[0].length > 0) {\n\t\t\tjson.head = {\n\t\t\t\tvars: arrays[0]\n\t\t\t};\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t};\n\n\tvar getBindings = function() {\n\t\tif (arrays.length > 1) {\n\t\t\tjson.results = {\n\t\t\t\tbindings: []\n\t\t\t};\n\t\t\tfor (var rowIt = 1; rowIt < arrays.length; rowIt++) {\n\t\t\t\tvar binding = {};\n\t\t\t\tfor (var colIt = 0; colIt < arrays[rowIt].length; colIt++) {\n\t\t\t\t\tvar varName = json.head.vars[colIt];\n\t\t\t\t\tif (varName) {\n\t\t\t\t\t\tvar value = arrays[rowIt][colIt];\n\t\t\t\t\t\tvar detectedType = detectType(value);\n\t\t\t\t\t\tbinding[varName] = {\n\t\t\t\t\t\t\tvalue: value\n\t\t\t\t\t\t};\n\t\t\t\t\t\tif (detectedType) binding[varName].type = detectedType;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tjson.results.bindings.push(binding);\n\t\t\t}\n\t\t\tjson.head = {\n\t\t\t\tvars: arrays[0]\n\t\t\t};\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t};\n\tvar isBoolean = getBoolean();\n\tif (!isBoolean) {\n\t\tvar varsFetched = getVariables();\n\t\tif (varsFetched) getBindings();\n\t}\n\n\treturn json;\n};\n},{\"../../lib/jquery.csv-0.71.js\":2,\"jquery\":18}],42:[function(require,module,exports){\n'use strict';\nvar $ = require(\"jquery\");\nvar root = module.exports = function(queryResponse) {\n\n\tif (typeof queryResponse == \"string\") {\n\t\ttry {\n\t\t\treturn JSON.parse(queryResponse);\n\t\t} catch (e) {\n\t\t\treturn false;\n\t\t}\n\t}\n\tif (typeof queryResponse == \"object\" && queryResponse.constructor === {}.constructor) {\n\t\treturn queryResponse;\n\t}\n\treturn false;\n\n};\n},{\"jquery\":18}],43:[function(require,module,exports){\n'use strict';\nvar $ = require(\"jquery\");\nvar root = module.exports = function(queryResponse) {\n\treturn require(\"./dlv.js\")(queryResponse, \"\\t\");\n};\n},{\"./dlv.js\":41,\"jquery\":18}],44:[function(require,module,exports){\n'use strict';\nvar $ = require(\"jquery\");\n\n/**\n * arg1 can be:\n * - a string (an exception, or e.g. a csv result string)\n * - an object (e.g. xml or json object)\n * - an object with exception key (contains solely a string to display)\n * - a jqXHR object (when this function is used as 'fail' callback for jquery)\n * arg2 can be:\n * - the textstatus of the response\n * arg3 can be:\n * - a jqXHR object (when this function is used as 'done/success' callback for jquery)\n * - an 'errorThrown' string (\n */\nvar root = module.exports = function(dataOrJqXhr, textStatus, jqXhrOrErrorString) {\n\tvar parsers = {\n\t\txml: require(\"./xml.js\"),\n\t\tjson: require(\"./json.js\"),\n\t\ttsv: require(\"./tsv.js\"),\n\t\tcsv: require(\"./csv.js\")\n\t};\n\tvar contentType = null;\n\tvar origResponse = null;\n\tvar json = null;\n\tvar type = null; //json, xml, csv, or tsv\n\tvar exception = null;\n\n\tvar init = function() {\n\t\tif (typeof dataOrJqXhr == \"object\") {\n\t\t\t/**\n\t\t\t * Extract exception info (if there is any)\n\t\t\t */\n\t\t\tif (dataOrJqXhr.exception) {\n\t\t\t\t//this object just has this exception string, nothing more. (here for backwards compatability)\n\t\t\t\texception = dataOrJqXhr.exception;\n\t\t\t} else if (dataOrJqXhr.status != undefined && (dataOrJqXhr.status >= 300 || dataOrJqXhr.status === 0)) {\n\t\t\t\t//this is an exception, and jquery response\n\t\t\t\texception = {\n\t\t\t\t\tstatus: dataOrJqXhr.status\n\t\t\t\t};\n\t\t\t\tif (typeof jqXhrOrErrorString == \"string\") exception.errorString = jqXhrOrErrorString;\n\t\t\t\tif (dataOrJqXhr.responseText) exception.responseText = dataOrJqXhr.responseText;\n\t\t\t\tif (dataOrJqXhr.statusText) exception.statusText = dataOrJqXhr.statusText;\n\t\t\t}\n\n\t\t\t/**\n\t\t\t * Extract content type info (if there is any)\n\t\t\t */\n\t\t\tif (dataOrJqXhr.contentType) {\n\t\t\t\t//this is not a jqXhr object, but a manually generated object (mostly for backwards compatability)\n\t\t\t\tcontentType = dataOrJqXhr.contentType.toLowerCase();\n\t\t\t} else if (dataOrJqXhr.getResponseHeader && dataOrJqXhr.getResponseHeader(\"content-type\")) {\n\t\t\t\tvar ct = dataOrJqXhr.getResponseHeader(\"content-type\").trim().toLowerCase();\n\t\t\t\tif (ct.length > 0) contentType = ct;\n\t\t\t}\n\n\t\t\t/**\n\t\t\t * extract original response\n\t\t\t */\n\t\t\tif (dataOrJqXhr.response) {\n\t\t\t\t//this is not a jqXhr object, but a manually generated object (mostly for backwards compatability)\n\t\t\t\torigResponse = dataOrJqXhr.response;\n\t\t\t} else if (!textStatus && !jqXhrOrErrorString) {\n\t\t\t\t//not called from jquery, as these other arguments are undefined.\n\t\t\t\t//so, we can only assume the current object is a proper response (e.g. xml or json) object\n\t\t\t\torigResponse = dataOrJqXhr;\n\t\t\t}\n\t\t}\n\t\tif (!exception && !origResponse) {\n\t\t\t//if this is called via a jquery complete callback, we should fetch the result for the jqXHR object\n\t\t\tif (dataOrJqXhr.responseText) {\n\t\t\t\torigResponse = dataOrJqXhr.responseText;\n\t\t\t} else {\n\t\t\t\t//if all else fails, assume first arg to be data object\n\t\t\t\t//(which should be the case for most situations)\n\t\t\t\torigResponse = dataOrJqXhr;\n\t\t\t}\n\t\t}\n\t};\n\n\tvar getAsJson = function() {\n\t\tif (json) return json;\n\t\tif (json === false || exception) return false; //already tried parsing this, and failed. do not try again... \n\t\tvar getParserFromContentType = function() {\n\t\t\tif (contentType) {\n\t\t\t\tif (contentType.indexOf(\"json\") > -1) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tjson = parsers.json(origResponse);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\texception = e;\n\t\t\t\t\t}\n\t\t\t\t\ttype = \"json\";\n\t\t\t\t} else if (contentType.indexOf(\"xml\") > -1) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tjson = parsers.xml(origResponse);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\texception = e;\n\t\t\t\t\t}\n\t\t\t\t\ttype = \"xml\";\n\t\t\t\t} else if (contentType.indexOf(\"csv\") > -1) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tjson = parsers.csv(origResponse);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\texception = e;\n\t\t\t\t\t}\n\t\t\t\t\ttype = \"csv\";\n\t\t\t\t} else if (contentType.indexOf(\"tab-separated\") > -1) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tjson = parsers.tsv(origResponse);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\texception = e;\n\t\t\t\t\t}\n\t\t\t\t\ttype = \"tsv\";\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\n\t\tvar doLuckyGuess = function() {\n\t\t\tjson = parsers.json(origResponse);\n\t\t\tif (json) {\n\t\t\t\ttype = \"json\";\n\t\t\t} else {\n\t\t\t\ttry {\n\t\t\t\t\tjson = parsers.xml(origResponse);\n\t\t\t\t\tif (json) type = \"xml\";\n\t\t\t\t} catch (err) {};\n\t\t\t}\n\t\t};\n\n\n\t\tgetParserFromContentType();\n\t\tif (!json) {\n\t\t\tdoLuckyGuess();\n\t\t}\n\t\tif (!json) json = false; //explicitly set to false, so we don't try to parse this thing again..\n\t\treturn json;\n\t};\n\n\n\tvar getVariables = function() {\n\t\tvar json = getAsJson();\n\t\tif (json && \"head\" in json) {\n\t\t\treturn json.head.vars;\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t};\n\n\tvar getBindings = function() {\n\t\tvar json = getAsJson();\n\t\tif (json && \"results\" in json) {\n\t\t\treturn json.results.bindings;\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t};\n\n\tvar getBoolean = function() {\n\t\tvar json = getAsJson();\n\t\tif (json && \"boolean\" in json) {\n\t\t\treturn json.boolean;\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t};\n\tvar getOriginalResponse = function() {\n\t\treturn origResponse;\n\t};\n\tvar getOriginalResponseAsString = function() {\n\t\tvar responseString = \"\";\n\t\tif (typeof origResponse == \"string\") {\n\t\t\tresponseString = origResponse;\n\t\t} else if (type == \"json\") {\n\t\t\tresponseString = JSON.stringify(origResponse, undefined, 2); //prettifies as well\n\t\t} else if (type == \"xml\") {\n\t\t\tresponseString = new XMLSerializer().serializeToString(origResponse);\n\t\t}\n\t\treturn responseString;\n\t};\n\tvar getException = function() {\n\t\treturn exception;\n\t};\n\tvar getType = function() {\n\t\tif (type == null) getAsJson(); //detects type as well\n\t\treturn type;\n\t};\n\n\t//process the input parameters in such a way that we can store it in local storage (i.e., no function)\n\t//and, make sure we can easily pass it on back to this wrapper function when loading it again from storage\n\tvar getAsStoreObject = function() {\n\t\tvar storeArray = [];\n\t\tvar arg1 = {};\n\t\tif (dataOrJqXhr.status) {\n\t\t\t//jqXhr object\n\t\t\targ1.status = dataOrJqXhr.status;\n\t\t\targ1.responseText = dataOrJqXhr.responseText;\n\t\t\targ1.statusText = dataOrJqXhr.statusText;\n\t\t\targ1.contentType = contentType; //this is a function in a jqXhr object (problem for storing). but this wrapper will read it as string as well\n\t\t} else {\n\t\t\t//the other instances of this param (whether it is a json, xml, or exception object), we can normally store\n\t\t\targ1 = dataOrJqXhr;\n\t\t}\n\n\n\t\tvar arg2 = textStatus;\n\t\tvar arg3 = undefined;\n\t\tif (typeof jqXhrOrErrorString == \"string\") arg3 = jqXhrOrErrorString;\n\n\t\treturn [arg1, arg2, arg3];\n\t};\n\n\n\n\tinit();\n\tjson = getAsJson();\n\n\treturn {\n\t\tgetAsStoreObject: getAsStoreObject,\n\t\tgetAsJson: getAsJson,\n\t\tgetOriginalResponse: getOriginalResponse,\n\t\tgetOriginalResponseAsString: getOriginalResponseAsString,\n\t\tgetOriginalContentType: function() {\n\t\t\treturn contentType;\n\t\t},\n\t\tgetVariables: getVariables,\n\t\tgetBindings: getBindings,\n\t\tgetBoolean: getBoolean,\n\t\tgetType: getType,\n\t\tgetException: getException\n\t};\n};\n},{\"./csv.js\":40,\"./json.js\":42,\"./tsv.js\":43,\"./xml.js\":45,\"jquery\":18}],45:[function(require,module,exports){\n'use strict';\nvar $ = require(\"jquery\");\nvar root = module.exports = function(xml) {\n\n\n\n\t/**\n\t * head\n\t */\n\tvar parseHead = function(node) {\n\t\tjson.head = {};\n\t\tfor (var headNodeIt = 0; headNodeIt < node.childNodes.length; headNodeIt++) {\n\t\t\tvar headNode = node.childNodes[headNodeIt];\n\t\t\tif (headNode.nodeName == \"variable\") {\n\t\t\t\tif (!json.head.vars) json.head.vars = [];\n\t\t\t\tvar name = headNode.getAttribute(\"name\");\n\t\t\t\tif (name) json.head.vars.push(name);\n\t\t\t}\n\t\t}\n\t};\n\n\tvar parseResults = function(node) {\n\t\tjson.results = {};\n\t\tjson.results.bindings = [];\n\t\tfor (var resultIt = 0; resultIt < node.childNodes.length; resultIt++) {\n\t\t\tvar resultNode = node.childNodes[resultIt];\n\t\t\tvar jsonResult = null;\n\n\t\t\tfor (var bindingIt = 0; bindingIt < resultNode.childNodes.length; bindingIt++) {\n\t\t\t\tvar bindingNode = resultNode.childNodes[bindingIt];\n\t\t\t\tif (bindingNode.nodeName == \"binding\") {\n\t\t\t\t\tvar varName = bindingNode.getAttribute(\"name\");\n\t\t\t\t\tif (varName) {\n\t\t\t\t\t\tjsonResult = jsonResult || {};\n\t\t\t\t\t\tjsonResult[varName] = {};\n\t\t\t\t\t\tfor (var bindingInfIt = 0; bindingInfIt < bindingNode.childNodes.length; bindingInfIt++) {\n\t\t\t\t\t\t\tvar bindingInf = bindingNode.childNodes[bindingInfIt];\n\t\t\t\t\t\t\tvar type = bindingInf.nodeName;\n\t\t\t\t\t\t\tif (type == \"#text\") continue;\n\t\t\t\t\t\t\tjsonResult[varName].type = type;\n\t\t\t\t\t\t\tjsonResult[varName].value = bindingInf.innerHTML;\n\t\t\t\t\t\t\tvar dataType = bindingInf.getAttribute(\"datatype\");\n\t\t\t\t\t\t\tif (dataType) jsonResult[varName].datatype = dataType;\n\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (jsonResult) json.results.bindings.push(jsonResult);\n\t\t}\n\t};\n\n\tvar parseBoolean = function(node) {\n\t\tif (node.innerHTML == \"true\") {\n\t\t\tjson.boolean = true;\n\t\t} else {\n\t\t\tjson.boolean = false;\n\t\t}\n\t};\n\tvar mainXml = null;\n\tif (typeof xml == \"string\") {\n\t\tmainXml = $.parseXML(xml);\n\t} else if ($.isXMLDoc(xml)) {\n\t\tmainXml = xml;\n\t}\n\tvar xml = null;\n\tif (mainXml.childNodes.length > 0) {\n\t\t//enter the main 'sparql' node\n\t\txml = mainXml.childNodes[0];\n\t} else {\n\t\treturn null;\n\t}\n\tvar json = {};\n\n\n\tfor (var i = 0; i < xml.childNodes.length; i++) {\n\t\tvar node = xml.childNodes[i];\n\t\tif (node.nodeName == \"head\") parseHead(node);\n\t\tif (node.nodeName == \"results\") parseResults(node);\n\t\tif (node.nodeName == \"boolean\") parseBoolean(node);\n\t}\n\n\treturn json;\n};\n},{\"jquery\":18}],46:[function(require,module,exports){\n'use strict';\nvar $ = require(\"jquery\"),\n\tutils = require('./utils.js'),\n\tyUtils = require('yasgui-utils'),\n\timgs = require('./imgs.js');\nrequire('jquery-ui/sortable');\nrequire('pivottable');\n\nif (!$.fn.pivotUI) throw new Error(\"Pivot lib not loaded\");\nvar root = module.exports = function(yasr) {\n\tvar plugin = {};\n\tvar options = $.extend(true, {}, root.defaults);\n\n\tif (options.useD3Chart) {\n\t\ttry {\n\t\t\tvar d3 = require('d3');\n\t\t\tif (d3) require('pivottable/dist/d3_renderers.js');\n\t\t} catch (e) {\n\t\t\t//do nothing. just make sure we don't use this renderer\n\t\t}\n\t\tif ($.pivotUtilities.d3_renderers) $.extend(true, $.pivotUtilities.renderers, $.pivotUtilities.d3_renderers);\n\t}\n\n\n\n\tvar $pivotWrapper;\n\tvar mergeLabelPostfix = null;\n\tvar getShownVariables = function() {\n\t\tvar variables = yasr.results.getVariables();\n\t\tif (!options.mergeLabelsWithUris) return variables;\n\t\tvar shownVariables = [];\n\n\t\tmergeLabelPostfix = (typeof options.mergeLabelsWithUris == \"string\" ? options.mergeLabelsWithUris : \"Label\");\n\t\tvariables.forEach(function(variable) {\n\t\t\tif (variable.indexOf(mergeLabelPostfix, variable.length - mergeLabelPostfix.length) !== -1) {\n\t\t\t\t//this one ends with a postfix\n\t\t\t\tif (variables.indexOf(variable.substring(0, variable.length - mergeLabelPostfix.length)) >= 0) {\n\t\t\t\t\t//we have a shorter version of this variable. So, do not include the ..<postfix> variable in the table\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\tshownVariables.push(variable);\n\t\t});\n\t\treturn shownVariables;\n\t};\n\n\tvar formatForPivot = function(callback) {\n\n\t\tvar vars = getShownVariables();\n\t\tvar usedPrefixes = null;\n\t\tif (yasr.options.getUsedPrefixes) {\n\t\t\tusedPrefixes = (typeof yasr.options.getUsedPrefixes == \"function\" ? yasr.options.getUsedPrefixes(yasr) : yasr.options.getUsedPrefixes);\n\t\t}\n\t\tyasr.results.getBindings().forEach(function(binding) {\n\t\t\tvar rowObj = {};\n\t\t\tvars.forEach(function(variable) {\n\t\t\t\tif (variable in binding) {\n\t\t\t\t\tvar val = binding[variable].value;\n\t\t\t\t\tif (mergeLabelPostfix && binding[variable + mergeLabelPostfix]) {\n\t\t\t\t\t\tval = binding[variable + mergeLabelPostfix].value;\n\t\t\t\t\t} else if (binding[variable].type == \"uri\") {\n\t\t\t\t\t\tval = utils.uriToPrefixed(usedPrefixes, val);\n\t\t\t\t\t}\n\t\t\t\t\trowObj[variable] = val;\n\t\t\t\t} else {\n\t\t\t\t\trowObj[variable] = null;\n\t\t\t\t}\n\t\t\t});\n\t\t\tcallback(rowObj);\n\t\t});\n\t}\n\n\n\tvar validatePivotTableOptions = function(pivotOptions) {\n\t\t//validate settings. we may have different variables, or renderers might be gone\n\t\tif (pivotOptions) {\n\t\t\tif (yasr.results) {\n\t\t\t\tvar vars = yasr.results.getVariables();\n\t\t\t\tvar keepColsAndRows = true;\n\t\t\t\tpivotOptions.cols.forEach(function(variable) {\n\t\t\t\t\tif (vars.indexOf(variable) < 0) keepColsAndRows = false;\n\t\t\t\t});\n\t\t\t\tif (keepColsAndRows) {\n\t\t\t\t\tpivotOptionse.rows.forEach(function(variable) {\n\t\t\t\t\t\tif (vars.indexOf(variable) < 0) keepColsAndRows = false;\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tif (!keepColsAndRows) {\n\t\t\t\t\tpivotOptions.cols = [];\n\t\t\t\t\tpivotOptions.rows = [];\n\t\t\t\t}\n\t\t\t\tif (!$.pivotUtilities.renderers[settings.rendererName]) delete pivotOptions.rendererName;\n\t\t\t}\n\t\t} else {\n\t\t\tpivotOptions = {};\n\t\t}\n\t\treturn pivotOptions;\n\t};\n\tvar draw = function() {\n\t\tvar doDraw = function() {\n\t\t\tvar onRefresh = function(pivotObj) {\n\t\t\t\toptions.pivotTable.cols = pivotObj.cols;\n\t\t\t\toptions.pivotTable.rows = pivotObj.rows;\n\t\t\t\toptions.pivotTable.rendererName = pivotObj.rendererName;\n\t\t\t\toptions.pivotTable.aggregatorName = pivotObj.aggregatorName;\n\t\t\t\toptions.pivotTable.vals = pivotObj.vals;\n\t\t\t\tyasr.store();\n\n\t\t\t\tif (pivotObj.rendererName.toLowerCase().indexOf(' chart') >= 0) {\n\t\t\t\t\topenGchartBtn.show();\n\t\t\t\t} else {\n\t\t\t\t\topenGchartBtn.hide();\n\t\t\t\t}\n\t\t\t\tyasr.updateHeader();\n\t\t\t};\n\n\n\t\t\tvar openGchartBtn = $('<button>', {\n\t\t\t\t\tclass: 'openPivotGchart yasr_btn'\n\t\t\t\t})\n\t\t\t\t.text('Chart Config')\n\t\t\t\t.click(function() {\n\t\t\t\t\t$pivotWrapper.find('div[dir=\"ltr\"]').dblclick();\n\t\t\t\t}).appendTo(yasr.resultsContainer);\n\t\t\t$pivotWrapper = $('<div>', {\n\t\t\t\tclass: 'pivotTable'\n\t\t\t}).appendTo($(yasr.resultsContainer));\n\n\t\t\toptions.pivotTable.onRefresh = (function() {\n\t\t\t\tvar originalRefresh = options.pivotTable.onRefresh;\n\t\t\t\treturn function(pivotObj) {\n\t\t\t\t\tonRefresh(pivotObj);\n\t\t\t\t\tif (originalRefresh) originalRefresh(pivotObj);\n\t\t\t\t};\n\t\t\t})();\n\n\t\t\twindow.pivot = $pivotWrapper.pivotUI(formatForPivot, options.pivotTable);\n\n\t\t\t/**\n\t\t\t * post process\n\t\t\t */\n\t\t\t//use 'move' handler for variables. This removes the 'filter' button though. Might want to re-enable this in the future\n\t\t\tvar icon = $(yUtils.svg.getElement(imgs.move));\n\t\t\t$pivotWrapper.find('.pvtTriangle').replaceWith(icon);\n\n\t\t\t//add headers to selector rows\n\t\t\t$('.pvtCols').prepend($('<div>', {\n\t\t\t\tclass: 'containerHeader'\n\t\t\t}).text(\"Columns\"));\n\t\t\t$('.pvtRows').prepend($('<div>', {\n\t\t\t\tclass: 'containerHeader'\n\t\t\t}).text(\"Rows\"));\n\t\t\t$('.pvtUnused').prepend($('<div>', {\n\t\t\t\tclass: 'containerHeader'\n\t\t\t}).text(\"Available Variables\"));\n\t\t\t$('.pvtVals').prepend($('<div>', {\n\t\t\t\tclass: 'containerHeader'\n\t\t\t}).text(\"Cells\"));\n\n\t\t\t//hmmm, directly after the callback finishes (i.e., directly after this line), the svg is draw.\n\t\t\t//just use a short timeout to update the header\n\t\t\tsetTimeout(yasr.updateHeader, 400);\n\t\t}\n\n\t\tif (yasr.options.useGoogleCharts && options.useGoogleCharts && !$.pivotUtilities.gchart_renderers) {\n\t\t\trequire('./gChartLoader.js')\n\t\t\t\t.on('done', function() {\n\t\t\t\t\ttry {\n\t\t\t\t\t\trequire('pivottable/dist/gchart_renderers.js');\n\t\t\t\t\t\t$.extend(true, $.pivotUtilities.renderers, $.pivotUtilities.gchart_renderers);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t//hmm, still something went wrong. forget about it;\n\t\t\t\t\t\toptions.useGoogleCharts = false;\n\t\t\t\t\t}\n\t\t\t\t\tdoDraw();\n\t\t\t\t})\n\t\t\t\t.on('error', function() {\n\t\t\t\t\tconsole.log('could not load gchart');\n\t\t\t\t\toptions.useGoogleCharts = false;\n\t\t\t\t\tdoDraw();\n\t\t\t\t})\n\t\t\t\t.googleLoad();\n\t\t} else {\n\t\t\t//everything is already loaded. just draw\n\t\t\tdoDraw();\n\t\t}\n\t};\n\tvar canHandleResults = function() {\n\t\treturn yasr.results && yasr.results.getVariables && yasr.results.getVariables() && yasr.results.getVariables().length > 0;\n\t};\n\n\tvar getDownloadInfo = function() {\n\t\tif (!yasr.results) return null;\n\t\tvar svgEl = yasr.resultsContainer.find('.pvtRendererArea svg');\n\t\tif (svgEl.length > 0) {\n\n\t\t\treturn {\n\t\t\t\tgetContent: function() {\n\t\t\t\t\tif (svgEl[0].outerHTML) {\n\t\t\t\t\t\treturn svgEl[0].outerHTML;\n\t\t\t\t\t} else {\n\t\t\t\t\t\t//outerHTML not supported. use workaround\n\t\t\t\t\t\treturn $('<div>').append(svgEl.clone()).html();\n\t\t\t\t\t}\n\t\t\t\t},\n\n\t\t\t\tfilename: \"queryResults.svg\",\n\t\t\t\tcontentType: \"image/svg+xml\",\n\t\t\t\tbuttonTitle: \"Download SVG Image\"\n\t\t\t};\n\t\t}\n\n\t\t//ok, not a svg. is it a table?\n\t\tvar $table = yasr.resultsContainer.find('.pvtRendererArea table');\n\t\tif ($table.length > 0) {\n\t\t\treturn {\n\t\t\t\tgetContent: function() {\n\t\t\t\t\treturn $table.tableToCsv();\n\t\t\t\t},\n\t\t\t\tfilename: \"queryResults.csv\",\n\t\t\t\tcontentType: \"text/csv\",\n\t\t\t\tbuttonTitle: \"Download as CSV\"\n\t\t\t};\n\t\t}\n\n\t};\n\tvar getEmbedHtml = function() {\n\t\tif (!yasr.results) return null;\n\n\t\tvar svgEl = yasr.resultsContainer.find('.pvtRendererArea svg')\n\t\t\t.clone() //create clone, as we'd like to remove height/width attributes\n\t\t\t.removeAttr('height').removeAttr('width')\n\t\t\t.css('height', '').css('width', '');\n\t\tif (svgEl.length == 0) return null;\n\n\t\tvar htmlString = svgEl[0].outerHTML;\n\t\tif (!htmlString) {\n\t\t\t//outerHTML not supported. use workaround\n\t\t\thtmlString = $('<div>').append(svgEl.clone()).html();\n\t\t}\n\t\t//wrap in div, so users can more easily tune width/height\n\t\t//don't use jquery, so we can easily influence indentation\n\t\treturn '<div style=\"width: 800px; height: 600px;\">\\n' + htmlString + '\\n</div>';\n\t};\n\treturn {\n\t\tgetPersistentSettings: function() {\n\t\t\treturn {\n\t\t\t\tpivotTable: options.pivotTable\n\t\t\t};\n\t\t},\n\t\tsetPersistentSettings: function(newSettings) {\n\t\t\tif (newSettings.pivotTable) {\n\t\t\t\toptions.pivotTable = validatePivotTableOptions(newSettings.pivotTable);\n\t\t\t}\n\n\t\t},\n\t\tgetDownloadInfo: getDownloadInfo,\n\t\tgetEmbedHtml: getEmbedHtml,\n\t\toptions: options,\n\t\tdraw: draw,\n\t\tname: \"Pivot Table\",\n\t\tcanHandleResults: canHandleResults,\n\t\tgetPriority: 4,\n\t}\n};\n\n\n\nroot.defaults = {\n\tmergeLabelsWithUris: false,\n\tuseGoogleCharts: true,\n\tuseD3Chart: true,\n\tpersistencyId: 'pivot',\n\tpivotTable: {}\n};\n\nroot.version = {\n\t\"YASR-rawResponse\": require(\"../package.json\").version,\n\t\"jquery\": $.fn.jquery,\n};\n\n},{\"../package.json\":27,\"./gChartLoader.js\":34,\"./imgs.js\":36,\"./utils.js\":49,\"d3\":11,\"jquery\":18,\"jquery-ui/sortable\":16,\"pivottable\":21,\"pivottable/dist/d3_renderers.js\":19,\"pivottable/dist/gchart_renderers.js\":20,\"yasgui-utils\":24}],47:[function(require,module,exports){\n'use strict';\nvar $ = require(\"jquery\"),\n\tCodeMirror = require(\"codemirror\");\n\nrequire('codemirror/addon/fold/foldcode.js');\nrequire('codemirror/addon/fold/foldgutter.js');\nrequire('codemirror/addon/fold/xml-fold.js');\nrequire('codemirror/addon/fold/brace-fold.js');\n\nrequire('codemirror/addon/edit/matchbrackets.js');\nrequire('codemirror/mode/xml/xml.js');\nrequire('codemirror/mode/javascript/javascript.js');\n\nvar root = module.exports = function(yasr) {\n\tvar plugin = {};\n\tvar options = $.extend(true, {}, root.defaults);\n\tvar cm = null;\n\tvar draw = function() {\n\t\tvar cmOptions = options.CodeMirror;\n\t\tcmOptions.value = yasr.results.getOriginalResponseAsString();\n\n\t\tvar mode = yasr.results.getType();\n\t\tif (mode) {\n\t\t\tif (mode == \"json\") {\n\t\t\t\tmode = {\n\t\t\t\t\tname: \"javascript\",\n\t\t\t\t\tjson: true\n\t\t\t\t};\n\t\t\t}\n\t\t\tcmOptions.mode = mode;\n\t\t}\n\n\t\tcm = CodeMirror(yasr.resultsContainer.get()[0], cmOptions);\n\n\t\t//CM has some issues with folding and unfolding (blank parts in the codemirror area, which are only filled after clicking it)\n\t\t//so, refresh cm after folding/unfolding\n\t\tcm.on('fold', function() {\n\t\t\tcm.refresh();\n\t\t});\n\t\tcm.on('unfold', function() {\n\t\t\tcm.refresh();\n\t\t});\n\n\t};\n\tvar canHandleResults = function() {\n\t\tif (!yasr.results) return false;\n\t\tif (!yasr.results.getOriginalResponseAsString) return false;\n\t\tvar response = yasr.results.getOriginalResponseAsString();\n\t\tif ((!response || response.length == 0) && yasr.results.getException()) return false; //in this case, show exception instead, as we have nothing to show anyway\n\t\treturn true;\n\t};\n\n\tvar getDownloadInfo = function() {\n\t\tif (!yasr.results) return null;\n\t\tvar contentType = yasr.results.getOriginalContentType();\n\t\tvar type = yasr.results.getType();\n\t\treturn {\n\t\t\tgetContent: function() {\n\t\t\t\treturn yasr.results.getOriginalResponse();\n\t\t\t},\n\t\t\tfilename: \"queryResults\" + (type ? \".\" + type : \"\"),\n\t\t\tcontentType: (contentType ? contentType : \"text/plain\"),\n\t\t\tbuttonTitle: \"Download raw response\"\n\t\t};\n\t};\n\n\treturn {\n\t\tdraw: draw,\n\t\tname: \"Raw Response\",\n\t\tcanHandleResults: canHandleResults,\n\t\tgetPriority: 2,\n\t\tgetDownloadInfo: getDownloadInfo,\n\n\t}\n};\n\n\n\nroot.defaults = {\n\tCodeMirror: {\n\t\treadOnly: true,\n\t\tlineNumbers: true,\n\t\tlineWrapping: true,\n\t\tfoldGutter: true,\n\t\tgutters: [\"CodeMirror-linenumbers\", \"CodeMirror-foldgutter\"]\n\t}\n};\n\nroot.version = {\n\t\"YASR-rawResponse\": require(\"../package.json\").version,\n\t\"jquery\": $.fn.jquery,\n\t\"CodeMirror\": CodeMirror.version\n};\n},{\"../package.json\":27,\"codemirror\":8,\"codemirror/addon/edit/matchbrackets.js\":3,\"codemirror/addon/fold/brace-fold.js\":4,\"codemirror/addon/fold/foldcode.js\":5,\"codemirror/addon/fold/foldgutter.js\":6,\"codemirror/addon/fold/xml-fold.js\":7,\"codemirror/mode/javascript/javascript.js\":9,\"codemirror/mode/xml/xml.js\":10,\"jquery\":18}],48:[function(require,module,exports){\n'use strict';\nvar $ = require(\"jquery\"),\n\tyutils = require(\"yasgui-utils\"),\n\tutils = require('./utils.js'),\n\timgs = require('./imgs.js');\nrequire(\"datatables.net\")();\nrequire(\"../lib/colResizable-1.4.js\");\n\n\n\n/**\n * Constructor of plugin which displays results as a table\n *\n * @param yasr {object}\n * @param parent {DOM element}\n * @param options {object}\n * @class YASR.plugins.table\n * @return yasr-table (doc)\n *\n */\nvar root = module.exports = function(yasr) {\n\tvar table = null;\n\tvar plugin = {\n\t\tname: \"Table\",\n\t\tgetPriority: 10,\n\t};\n\tvar options = plugin.options = $.extend(true, {}, root.defaults);\n\tvar tableLengthPersistencyId = (options.persistency ? yasr.getPersistencyId(options.persistency.tableLength) : null);\n\n\tvar getRows = function() {\n\t\tvar rows = [];\n\t\tvar bindings = yasr.results.getBindings();\n\t\tvar vars = yasr.results.getVariables();\n\t\tvar usedPrefixes = null;\n\t\tif (yasr.options.getUsedPrefixes) {\n\t\t\tusedPrefixes = (typeof yasr.options.getUsedPrefixes == \"function\" ? yasr.options.getUsedPrefixes(yasr) : yasr.options.getUsedPrefixes);\n\t\t}\n\t\tfor (var rowId = 0; rowId < bindings.length; rowId++) {\n\t\t\tvar row = [];\n\t\t\trow.push(\"\"); //row numbers\n\t\t\tvar binding = bindings[rowId];\n\t\t\tfor (var colId = 0; colId < vars.length; colId++) {\n\t\t\t\tvar sparqlVar = vars[colId];\n\t\t\t\tif (sparqlVar in binding) {\n\t\t\t\t\tif (options.getCellContent) {\n\t\t\t\t\t\trow.push(options.getCellContent(yasr, plugin, binding, sparqlVar, {\n\t\t\t\t\t\t\t'rowId': rowId,\n\t\t\t\t\t\t\t'colId': colId,\n\t\t\t\t\t\t\t'usedPrefixes': usedPrefixes\n\t\t\t\t\t\t}));\n\t\t\t\t\t} else {\n\t\t\t\t\t\trow.push(\"\");\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\trow.push(\"\");\n\t\t\t\t}\n\t\t\t}\n\t\t\trows.push(row);\n\t\t}\n\t\treturn rows;\n\t};\n\n\tvar eventId = yasr.getPersistencyId('eventId') || \"yasr_\" + $(yasr.container).closest('[id]').attr('id');\n\tvar addEvents = function() {\n\t\ttable.on('order.dt', function() {\n\t\t\tdrawSvgIcons();\n\t\t});\n\t\tif (tableLengthPersistencyId) {\n\t\t\ttable.on('length.dt', function(e, settings, len) {\n\t\t\t\tyutils.storage.set(tableLengthPersistencyId, len, \"month\");\n\t\t\t});\n\t\t}\n\t\t$.extend(true, options.callbacks, options.handlers);\n\t\ttable.delegate(\"td\", \"click\", function(event) {\n\t\t\tif (options.callbacks && options.callbacks.onCellClick) {\n\t\t\t\tvar result = options.callbacks.onCellClick(this, event);\n\t\t\t\tif (result === false) return false;\n\t\t\t}\n\t\t}).delegate(\"td\", 'mouseenter', function(event) {\n\t\t\tif (options.callbacks && options.callbacks.onCellMouseEnter) {\n\t\t\t\toptions.callbacks.onCellMouseEnter(this, event);\n\t\t\t}\n\t\t\tvar tdEl = $(this);\n\t\t\tif (options.fetchTitlesFromPreflabel && tdEl.attr(\"title\") === undefined && tdEl.text().trim().indexOf(\"http\") == 0) {\n\t\t\t\taddPrefLabel(tdEl);\n\t\t\t}\n\t\t}).delegate(\"td\", 'mouseleave', function(event) {\n\t\t\tif (options.callbacks && options.callbacks.onCellMouseLeave) {\n\t\t\t\toptions.callbacks.onCellMouseLeave(this, event);\n\n\t\t\t}\n\t\t});\n\t};\n\n\tplugin.draw = function() {\n\t\ttable = $('<table cellpadding=\"0\" cellspacing=\"0\" border=\"0\" class=\"resultsTable\"></table>');\n\t\t$(yasr.resultsContainer).html(table);\n\n\t\tvar dataTableConfig = options.datatable;\n\t\tdataTableConfig.data = getRows();\n\t\tdataTableConfig.columns = options.getColumns(yasr, plugin);\n\n\t\t//fetch stored datatables length value\n\t\tvar pLength = yutils.storage.get(tableLengthPersistencyId);\n\t\tif (pLength) dataTableConfig.pageLength = pLength;\n\n\n\n\t\ttable.DataTable($.extend(true, {}, dataTableConfig)); //make copy. datatables adds properties for backwards compatability reasons, and don't want this cluttering our own\n\n\n\t\tdrawSvgIcons();\n\n\t\taddEvents();\n\n\t\t//finally, make the columns dragable:\n\t\ttable.colResizable();\n\t};\n\n\tvar drawSvgIcons = function() {\n\t\tvar sortings = {\n\t\t\t\"sorting\": \"unsorted\",\n\t\t\t\"sorting_asc\": \"sortAsc\",\n\t\t\t\"sorting_desc\": \"sortDesc\"\n\t\t};\n\t\ttable.find(\".sortIcons\").remove();\n\t\tfor (var sorting in sortings) {\n\t\t\tvar svgDiv = $(\"<div class='sortIcons'></div>\");\n\t\t\tyutils.svg.draw(svgDiv, imgs[sortings[sorting]]);\n\t\t\ttable.find(\"th.\" + sorting).append(svgDiv);\n\t\t}\n\t};\n\t/**\n\t * Check whether this plugin can handler the current results\n\t *\n\t * @property canHandleResults\n\t * @type function\n\t * @default If resultset contains variables in the resultset, return true\n\t */\n\tplugin.canHandleResults = function() {\n\t\treturn yasr.results && yasr.results.getVariables && yasr.results.getVariables() && yasr.results.getVariables().length > 0;\n\t};\n\n\n\tplugin.getDownloadInfo = function() {\n\t\tif (!yasr.results) return null;\n\t\treturn {\n\t\t\tgetContent: function() {\n\t\t\t\treturn require(\"./bindingsToCsv.js\")(yasr.results.getAsJson());\n\t\t\t},\n\t\t\tfilename: \"queryResults.csv\",\n\t\t\tcontentType: \"text/csv\",\n\t\t\tbuttonTitle: \"Download as CSV\"\n\t\t};\n\t};\n\n\n\treturn plugin;\n};\n\n\nvar formatLiteral = function(yasr, plugin, literalBinding) {\n\tvar stringRepresentation = utils.escapeHtmlEntities(literalBinding.value);\n\tif (literalBinding[\"xml:lang\"]) {\n\t\tstringRepresentation = '\"' + stringRepresentation + '\"<sup>@' + literalBinding[\"xml:lang\"] + '</sup>';\n\t} else if (literalBinding.datatype) {\n\t\tvar xmlSchemaNs = \"http://www.w3.org/2001/XMLSchema#\";\n\t\tvar dataType = literalBinding.datatype;\n\t\tif (dataType.indexOf(xmlSchemaNs) === 0) {\n\t\t\tdataType = \"xsd:\" + dataType.substring(xmlSchemaNs.length);\n\t\t} else {\n\t\t\tdataType = \"<\" + dataType + \">\";\n\t\t}\n\n\t\tstringRepresentation = '\"' + stringRepresentation + '\"<sup>^^' + dataType + '</sup>';\n\t}\n\treturn stringRepresentation;\n};\nvar getCellContent = function(yasr, plugin, bindings, sparqlVar, context) {\n\tvar binding = bindings[sparqlVar];\n\tvar value = null;\n\tif (binding.type == \"uri\") {\n\t\tvar title = null;\n\t\tvar href = binding.value;\n\t\tvar visibleString = href;\n\t\tif (context.usedPrefixes) {\n\t\t\tfor (var prefix in context.usedPrefixes) {\n\t\t\t\tif (visibleString.indexOf(context.usedPrefixes[prefix]) == 0) {\n\t\t\t\t\tvisibleString = prefix + ':' + href.substring(context.usedPrefixes[prefix].length);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tif (plugin.options.mergeLabelsWithUris) {\n\t\t\tvar postFix = (typeof plugin.options.mergeLabelsWithUris == \"string\" ? plugin.options.mergeLabelsWithUris : \"Label\");\n\t\t\tif (bindings[sparqlVar + postFix]) {\n\t\t\t\tvisibleString = formatLiteral(yasr, plugin, bindings[sparqlVar + postFix]);\n\t\t\t\ttitle = href;\n\t\t\t}\n\t\t}\n\t\tvalue = \"<a \" + (title ? \"title='\" + href + \"' \" : \"\") + \"class='uri' target='_blank' href='\" + href + \"'>\" + visibleString + \"</a>\";\n\t} else {\n\t\tvalue = \"<span class='nonUri'>\" + formatLiteral(yasr, plugin, binding) + \"</span>\";\n\t}\n\treturn \"<div>\" + value + \"</div>\";\n};\n\n\n\n\n\n\nvar addPrefLabel = function(td) {\n\tvar addEmptyTitle = function() {\n\t\ttd.attr(\"title\", \"\"); //this avoids trying to fetch the label again on next hover\n\t};\n\t$.get(\"//preflabel.org/api/v1/label/\" + encodeURIComponent(td.text()) + \"?silent=true\")\n\t\t.success(function(data) {\n\t\t\tif (typeof data == \"object\" && data.label) {\n\t\t\t\ttd.attr(\"title\", data.label);\n\t\t\t} else if (typeof data == \"string\" && data.length > 0) {\n\t\t\t\ttd.attr(\"title\", data);\n\t\t\t} else {\n\t\t\t\taddEmptyTitle();\n\t\t\t}\n\n\t\t})\n\t\t.fail(addEmptyTitle);\n};\n\nvar openCellUriInNewWindow = function(cell) {\n\tif (cell.className.indexOf(\"uri\") >= 0) {\n\t\twindow.open(this.innerHTML);\n\t}\n};\n\n/**\n * Defaults for table plugin\n *\n * @type object\n * @attribute YASR.plugins.table.defaults\n */\nroot.defaults = {\n\n\t/**\n\t * Draw the cell content, from a given binding\n\t *\n\t * @property drawCellContent\n\t * @param binding {object}\n\t * @type function\n\t * @return string\n\t * @default YASR.plugins.table.getFormattedValueFromBinding\n\t */\n\tgetCellContent: getCellContent,\n\n\tpersistency: {\n\t\ttableLength: \"tableLength\",\n\t},\n\n\tgetColumns: function(yasr, plugin) {\n\t\tvar includeVariable = function(variableToCheck) {\n\t\t\tif (!plugin.options.mergeLabelsWithUris) return true;\n\t\t\tvar postFix = (typeof plugin.options.mergeLabelsWithUris == \"string\" ? plugin.options.mergeLabelsWithUris : \"Label\");\n\t\t\tif (variableToCheck.indexOf(postFix, variableToCheck.length - postFix.length) !== -1) {\n\t\t\t\t//this one ends with a postfix\n\t\t\t\tif (yasr.results.getVariables().indexOf(variableToCheck.substring(0, variableToCheck.length - postFix.length)) >= 0) {\n\t\t\t\t\t//we have a shorter version of this variable. So, do not include the ..<postfix> variable in the table\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t};\n\n\t\tvar cols = [];\n\t\tcols.push({\n\t\t\t\"title\": \"\"\n\t\t}); //row numbers column\n\t\tyasr.results.getVariables().forEach(function(variable) {\n\t\t\tcols.push({\n\t\t\t\t\"title\": \"<span>\" + variable + \"</span>\",\n\t\t\t\t\"visible\": includeVariable(variable)\n\t\t\t});\n\t\t});\n\t\treturn cols;\n\t},\n\t/**\n\t * Try to fetch the label representation for each URI, using the preflabel.org services. (fetching occurs when hovering over the cell)\n\t *\n\t * @property fetchTitlesFromPreflabel\n\t * @type boolean\n\t * @default false, if YASR is served via https\n\t */\n\t//important to keep supporting serving yasr via file:// protocol\n\tfetchTitlesFromPreflabel: (window.location.protocol === \"https:\" ? false: true),\n\n\tmergeLabelsWithUris: false,\n\t/**\n\t * Set a number of handlers for the table\n\t *\n\t * @property handlers\n\t * @type object\n\t */\n\tcallbacks: {\n\t\t/**\n\t\t * Mouse-enter-cell event\n\t\t *\n\t\t * @property handlers.onCellMouseEnter\n\t\t * @type function\n\t\t * @param td-element\n\t\t * @default null\n\t\t */\n\t\tonCellMouseEnter: null,\n\t\t/**\n\t\t * Mouse-leave-cell event\n\t\t *\n\t\t * @property handlers.onCellMouseLeave\n\t\t * @type function\n\t\t * @param td-element\n\t\t * @default null\n\t\t */\n\t\tonCellMouseLeave: null,\n\t\t/**\n\t\t * Cell clicked event\n\t\t *\n\t\t * @property handlers.onCellClick\n\t\t * @type function\n\t\t * @param td-element\n\t\t * @default null\n\t\t */\n\t\tonCellClick: null\n\t},\n\t/**\n\t * This plugin uses the datatables jquery plugin (See datatables.net). For any datatables specific defaults, change this object.\n\t * See the datatables reference for more information\n\t *\n\t * @property datatable\n\t * @type object\n\t */\n\tdatatable: {\n\t\t\"autoWidth\": false,\n\t\t\"dom\": '<\"dtTopHeader\"ilf>rtip',\n\t\t\"order\": [], //disable initial sorting\n\t\t\"pageLength\": 50, //default page length\n\t\t\"lengthMenu\": [\n\t\t\t[10, 50, 100, 1000, -1],\n\t\t\t[10, 50, 100, 1000, \"All\"]\n\t\t], //possible page lengths\n\t\t\"lengthChange\": true, //allow changing page length\n\t\t\"pagingType\": \"full_numbers\", //how to show the pagination options\n\t\t\"drawCallback\": function(oSettings) {\n\t\t\t//trick to show row numbers\n\t\t\tfor (var i = 0; i < oSettings.aiDisplay.length; i++) {\n\t\t\t\t$('td:eq(0)', oSettings.aoData[oSettings.aiDisplay[i]].nTr).html(i + 1);\n\t\t\t}\n\n\t\t\t//Hide pagination when we have a single page\n\t\t\tvar activePaginateButton = false;\n\t\t\t$(oSettings.nTableWrapper).find(\".paginate_button\").each(function() {\n\t\t\t\tif ($(this).attr(\"class\").indexOf(\"current\") == -1 && $(this).attr(\"class\").indexOf(\"disabled\") == -1) {\n\t\t\t\t\tactivePaginateButton = true;\n\t\t\t\t}\n\t\t\t});\n\t\t\tif (activePaginateButton) {\n\t\t\t\t$(oSettings.nTableWrapper).find(\".dataTables_paginate\").show();\n\t\t\t} else {\n\t\t\t\t$(oSettings.nTableWrapper).find(\".dataTables_paginate\").hide();\n\t\t\t}\n\t\t},\n\t\t\"columnDefs\": [{\n\t\t\t\t\"width\": \"32px\",\n\t\t\t\t\"orderable\": false,\n\t\t\t\t\"targets\": 0\n\t\t\t} //disable row sorting for first col\n\t\t],\n\t},\n};\nroot.version = {\n\t\"YASR-table\": require(\"../package.json\").version,\n\t\"jquery\": $.fn.jquery,\n\t\"jquery-datatables\": $.fn.DataTable.version\n};\n\n},{\"../lib/colResizable-1.4.js\":1,\"../package.json\":27,\"./bindingsToCsv.js\":28,\"./imgs.js\":36,\"./utils.js\":49,\"datatables.net\":12,\"jquery\":18,\"yasgui-utils\":24}],49:[function(require,module,exports){\n'use strict';\nvar $ = require('jquery'),\n\tGoogleTypeException = require('./exceptions.js').GoogleTypeException;\n\nmodule.exports = {\n\tescapeHtmlEntities: function(unescaped) {\n\t\t//taken from http://stackoverflow.com/questions/5499078/fastest-method-to-escape-html-tags-as-html-entities\n\t\treturn unescaped.replace(/&/g, '&').replace(/</g, '<').replace(/>/g, '>');\n\t},\n\turiToPrefixed: function(prefixes, uri) {\n\t\tif (prefixes) {\n\t\t\tfor (var prefix in prefixes) {\n\t\t\t\tif (uri.indexOf(prefixes[prefix]) == 0) {\n\t\t\t\t\turi = prefix + ':' + uri.substring(prefixes[prefix].length);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn uri;\n\t},\n\tgetGoogleTypeForBinding: function(binding) {\n\t\tif (binding == null) return null;\n\t\tif (binding.type != null && (binding.type === 'typed-literal' || binding.type === 'literal')) {\n\t\t\tswitch (binding.datatype) {\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#double':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#float':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#decimal':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#int':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#integer':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#long':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gYearMonth':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gYear':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gMonthDay':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gDay':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gMonth':\n\t\t\t\t\treturn \"number\";\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#date':\n\t\t\t\t\treturn \"date\";\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#dateTime':\n\t\t\t\t\treturn \"datetime\";\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#time':\n\t\t\t\t\treturn \"timeofday\";\n\t\t\t\tdefault:\n\t\t\t\t\treturn \"string\";\n\t\t\t}\n\t\t} else {\n\t\t\treturn \"string\";\n\t\t}\n\t},\n\tgetGoogleTypeForBindings: function(bindings, varName) {\n\t\tvar types = {};\n\t\tvar typeCount = 0;\n\t\tbindings.forEach(function(binding) {\n\t\t\tvar type = module.exports.getGoogleTypeForBinding(binding[varName]);\n\t\t\tif (type != null) {\n\t\t\t\tif (!(type in types)) {\n\t\t\t\t\ttypes[type] = 0;\n\t\t\t\t\ttypeCount++;\n\t\t\t\t}\n\t\t\t\ttypes[type]++;\n\t\t\t}\n\t\t});\n\t\tif (typeCount == 0) {\n\t\t\treturn 'string';\n\t\t} else if (typeCount == 1) {\n\t\t\tfor (var type in types) {\n\t\t\t\treturn type; //just return this one\n\t\t\t}\n\t\t} else {\n\t\t\t//we have conflicting types. Throw error\n\t\t\tthrow new GoogleTypeException(types, varName);\n\t\t}\n\t},\n\n\tcastGoogleType: function(binding, prefixes, googleType) {\n\t\tif (binding == null) {\n\t\t\treturn null;\n\t\t}\n\n\t\tif (googleType != 'string' && binding.type != null && (binding.type === 'typed-literal' || binding.type === 'literal')) {\n\t\t\tswitch (binding.datatype) {\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#float':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#decimal':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#int':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#integer':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#long':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gYearMonth':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gYear':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gMonthDay':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gDay':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gMonth':\n\t\t\t\t\treturn Number(binding.value);\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#double':\n\t\t\t\t\treturn Number(parseFloat(binding.value));\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#date':\n\t\t\t\t\t//grrr, the date function does not parse -any- date (including most xsd dates!)\n\t\t\t\t\t//datetime and time seem to be fine though.\n\t\t\t\t\t//so, first try our custom parser. if that does not work, try the regular date parser anyway\n\t\t\t\t\tvar date = parseXmlSchemaDate(binding.value);\n\t\t\t\t\tif (date) return date;\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#dateTime':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#time':\n\t\t\t\t\treturn new Date(binding.value);\n\t\t\t\tdefault:\n\t\t\t\t\treturn binding.value;\n\t\t\t}\n\t\t} else {\n\t\t\tif (binding.type = 'uri') {\n\t\t\t\treturn module.exports.uriToPrefixed(prefixes, binding.value);\n\t\t\t} else {\n\t\t\t\treturn binding.value;\n\t\t\t}\n\t\t}\n\t},\n\tfireClick: function($els) {\n\t\tif (!$els)\n\t\t\treturn;\n\t\t$els.each(function(i, el) {\n\t\t\tvar $el = $(el);\n\t\t\tif (document.dispatchEvent) { // W3C\n\t\t\t\tvar oEvent = document.createEvent(\"MouseEvents\");\n\t\t\t\toEvent.initMouseEvent(\"click\", true, true, window, 1, 1, 1, 1, 1,\n\t\t\t\t\tfalse, false, false, false, 0, $el[0]);\n\t\t\t\t$el[0].dispatchEvent(oEvent);\n\t\t\t} else if (document.fireEvent) { // IE\n\t\t\t\t$el[0].click();\n\t\t\t}\n\t\t});\n\t}\n};\n//There are no PROPER xml schema to js date parsers\n//A few libraries exist: moment, jsdate, Xdate, but none of them parse valid xml schema dates (e.g. 1999-11-05+02:00).\n//And: I'm not going to write one myself\n//There are other hacky solutions (regular expressions based on trial/error) such as http://stackoverflow.com/questions/2731579/convert-an-xml-schema-date-string-to-a-javascript-date\n//But if we're doing hacky stuff, I at least want to do it MYSELF!\nvar parseXmlSchemaDate = function(dateString) {\n\t//change +02:00 to Z+02:00 (something which is parseable by js date)\n\tvar date = new Date(dateString.replace(/(\\d)([\\+-]\\d{2}:\\d{2})/, '$1Z$2'));\n\tif (isNaN(date)) return null;\n\treturn date;\n};\n\n},{\"./exceptions.js\":33,\"jquery\":18}]},{},[31])(31)\n});\n\n","/**\n * jQuery-csv (jQuery Plugin)\n * version: 0.71 (2012-11-19)\n *\n * This document is licensed as free software under the terms of the\n * MIT License: http://www.opensource.org/licenses/mit-license.php\n *\n * Acknowledgements:\n * The original design and influence to implement this library as a jquery\n * plugin is influenced by jquery-json (http://code.google.com/p/jquery-json/).\n * If you're looking to use native JSON.Stringify but want additional backwards\n * compatibility for browsers that don't support it, I highly recommend you\n * check it out.\n *\n * A special thanks goes out to rwk@acm.org for providing a lot of valuable\n * feedback to the project including the core for the new FSM\n * (Finite State Machine) parsers. If you're looking for a stable TSV parser\n * be sure to take a look at jquery-tsv (http://code.google.com/p/jquery-tsv/).\n\n * For legal purposes I'll include the \"NO WARRANTY EXPRESSED OR IMPLIED.\n * USE AT YOUR OWN RISK.\". Which, in 'layman's terms' means, by using this\n * library you are accepting responsibility if it breaks your code.\n *\n * Legal jargon aside, I will do my best to provide a useful and stable core\n * that can effectively be built on.\n *\n * Copyrighted 2012 by Evan Plaice.\n */\n\nRegExp.escape= function(s) {\n return s.replace(/[-\\/\\\\^$*+?.()|[\\]{}]/g, '\\\\$&');\n};\n\n 'use strict'\n var $ = require('jquery');\n /**\n * jQuery.csv.defaults\n * Encapsulates the method paramater defaults for the CSV plugin module.\n */\n\n $.csv = {\n defaults: {\n separator:',',\n delimiter:'\"',\n headers:true\n },\n\n hooks: {\n castToScalar: function(value, state) {\n var hasDot = /\\./;\n if (isNaN(value)) {\n return value;\n } else {\n if (hasDot.test(value)) {\n return parseFloat(value);\n } else {\n var integer = parseInt(value);\n if(isNaN(integer)) {\n return null;\n } else {\n return integer;\n }\n }\n }\n }\n },\n\n parsers: {\n parse: function(csv, options) {\n // cache settings\n var separator = options.separator;\n var delimiter = options.delimiter;\n\n // set initial state if it's missing\n if(!options.state.rowNum) {\n options.state.rowNum = 1;\n }\n if(!options.state.colNum) {\n options.state.colNum = 1;\n }\n\n // clear initial state\n var data = [];\n var entry = [];\n var state = 0;\n var value = ''\n var exit = false;\n\n function endOfEntry() {\n // reset the state\n state = 0;\n value = '';\n\n // if 'start' hasn't been met, don't output\n if(options.start && options.state.rowNum < options.start) {\n // update global state\n entry = [];\n options.state.rowNum++;\n options.state.colNum = 1;\n return;\n }\n \n if(options.onParseEntry === undefined) {\n // onParseEntry hook not set\n data.push(entry);\n } else {\n var hookVal = options.onParseEntry(entry, options.state); // onParseEntry Hook\n // false skips the row, configurable through a hook\n if(hookVal !== false) {\n data.push(hookVal);\n }\n }\n //console.log('entry:' + entry);\n \n // cleanup\n entry = [];\n\n // if 'end' is met, stop parsing\n if(options.end && options.state.rowNum >= options.end) {\n exit = true;\n }\n \n // update global state\n options.state.rowNum++;\n options.state.colNum = 1;\n }\n\n function endOfValue() {\n if(options.onParseValue === undefined) {\n // onParseValue hook not set\n entry.push(value);\n } else {\n var hook = options.onParseValue(value, options.state); // onParseValue Hook\n // false skips the row, configurable through a hook\n if(hook !== false) {\n entry.push(hook);\n }\n }\n //console.log('value:' + value);\n // reset the state\n value = '';\n state = 0;\n // update global state\n options.state.colNum++;\n }\n\n // escape regex-specific control chars\n var escSeparator = RegExp.escape(separator);\n var escDelimiter = RegExp.escape(delimiter);\n\n // compile the regEx str using the custom delimiter/separator\n var match = /(D|S|\\n|\\r|[^DS\\r\\n]+)/;\n var matchSrc = match.source;\n matchSrc = matchSrc.replace(/S/g, escSeparator);\n matchSrc = matchSrc.replace(/D/g, escDelimiter);\n match = RegExp(matchSrc, 'gm');\n\n // put on your fancy pants...\n // process control chars individually, use look-ahead on non-control chars\n csv.replace(match, function (m0) {\n if(exit) {\n return;\n }\n switch (state) {\n // the start of a value\n case 0:\n // null last value\n if (m0 === separator) {\n value += '';\n endOfValue();\n break;\n }\n // opening delimiter\n if (m0 === delimiter) {\n state = 1;\n break;\n }\n // null last value\n if (m0 === '\\n') {\n endOfValue();\n endOfEntry();\n break;\n }\n // phantom carriage return\n if (/^\\r$/.test(m0)) {\n break;\n }\n // un-delimited value\n value += m0;\n state = 3;\n break;\n\n // delimited input\n case 1:\n // second delimiter? check further\n if (m0 === delimiter) {\n state = 2;\n break;\n }\n // delimited data\n value += m0;\n state = 1;\n break;\n\n // delimiter found in delimited input\n case 2:\n // escaped delimiter?\n if (m0 === delimiter) {\n value += m0;\n state = 1;\n break;\n }\n // null value\n if (m0 === separator) {\n endOfValue();\n break;\n }\n // end of entry\n if (m0 === '\\n') {\n endOfValue();\n endOfEntry();\n break;\n }\n // phantom carriage return\n if (/^\\r$/.test(m0)) {\n break;\n }\n // broken paser?\n throw new Error('CSVDataError: Illegal State [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n\n // un-delimited input\n case 3:\n // null last value\n if (m0 === separator) {\n endOfValue();\n break;\n }\n // end of entry\n if (m0 === '\\n') {\n endOfValue();\n endOfEntry();\n break;\n }\n // phantom carriage return\n if (/^\\r$/.test(m0)) {\n break;\n }\n if (m0 === delimiter) {\n // non-compliant data\n throw new Error('CSVDataError: Illegal Quote [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n }\n // broken parser?\n throw new Error('CSVDataError: Illegal Data [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n default:\n // shenanigans\n throw new Error('CSVDataError: Unknown State [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n }\n //console.log('val:' + m0 + ' state:' + state);\n });\n\n // submit the last entry\n // ignore null last line\n if(entry.length !== 0) {\n endOfValue();\n endOfEntry();\n }\n\n return data;\n },\n\n // a csv-specific line splitter\n splitLines: function(csv, options) {\n // cache settings\n var separator = options.separator;\n var delimiter = options.delimiter;\n\n // set initial state if it's missing\n if(!options.state.rowNum) {\n options.state.rowNum = 1;\n }\n\n // clear initial state\n var entries = [];\n var state = 0;\n var entry = '';\n var exit = false;\n\n function endOfLine() { \n // reset the state\n state = 0;\n \n // if 'start' hasn't been met, don't output\n if(options.start && options.state.rowNum < options.start) {\n // update global state\n entry = '';\n options.state.rowNum++;\n return;\n }\n \n if(options.onParseEntry === undefined) {\n // onParseEntry hook not set\n entries.push(entry);\n } else {\n var hookVal = options.onParseEntry(entry, options.state); // onParseEntry Hook\n // false skips the row, configurable through a hook\n if(hookVal !== false) {\n entries.push(hookVal);\n }\n }\n\n // cleanup\n entry = '';\n\n // if 'end' is met, stop parsing\n if(options.end && options.state.rowNum >= options.end) {\n exit = true;\n }\n \n // update global state\n options.state.rowNum++;\n }\n\n // escape regex-specific control chars\n var escSeparator = RegExp.escape(separator);\n var escDelimiter = RegExp.escape(delimiter);\n\n // compile the regEx str using the custom delimiter/separator\n var match = /(D|S|\\n|\\r|[^DS\\r\\n]+)/;\n var matchSrc = match.source;\n matchSrc = matchSrc.replace(/S/g, escSeparator);\n matchSrc = matchSrc.replace(/D/g, escDelimiter);\n match = RegExp(matchSrc, 'gm');\n \n // put on your fancy pants...\n // process control chars individually, use look-ahead on non-control chars\n csv.replace(match, function (m0) {\n if(exit) {\n return;\n }\n switch (state) {\n // the start of a value/entry\n case 0:\n // null value\n if (m0 === separator) {\n entry += m0;\n state = 0;\n break;\n }\n // opening delimiter\n if (m0 === delimiter) {\n entry += m0;\n state = 1;\n break;\n }\n // end of line\n if (m0 === '\\n') {\n endOfLine();\n break;\n }\n // phantom carriage return\n if (/^\\r$/.test(m0)) {\n break;\n }\n // un-delimit value\n entry += m0;\n state = 3;\n break;\n\n // delimited input\n case 1:\n // second delimiter? check further\n if (m0 === delimiter) {\n entry += m0;\n state = 2;\n break;\n }\n // delimited data\n entry += m0;\n state = 1;\n break;\n\n // delimiter found in delimited input\n case 2:\n // escaped delimiter?\n var prevChar = entry.substr(entry.length - 1);\n if (m0 === delimiter && prevChar === delimiter) {\n entry += m0;\n state = 1;\n break;\n }\n // end of value\n if (m0 === separator) {\n entry += m0;\n state = 0;\n break;\n }\n // end of line\n if (m0 === '\\n') {\n endOfLine();\n break;\n }\n // phantom carriage return\n if (m0 === '\\r') {\n break;\n }\n // broken paser?\n throw new Error('CSVDataError: Illegal state [Row:' + options.state.rowNum + ']');\n\n // un-delimited input\n case 3:\n // null value\n if (m0 === separator) {\n entry += m0;\n state = 0;\n break;\n }\n // end of line\n if (m0 === '\\n') {\n endOfLine();\n break;\n }\n // phantom carriage return\n if (m0 === '\\r') {\n break;\n }\n // non-compliant data\n if (m0 === delimiter) {\n throw new Error('CSVDataError: Illegal quote [Row:' + options.state.rowNum + ']');\n }\n // broken parser?\n throw new Error('CSVDataError: Illegal state [Row:' + options.state.rowNum + ']');\n default:\n // shenanigans\n throw new Error('CSVDataError: Unknown state [Row:' + options.state.rowNum + ']');\n }\n //console.log('val:' + m0 + ' state:' + state);\n });\n\n // submit the last entry\n // ignore null last line\n if(entry !== '') {\n endOfLine();\n }\n\n return entries;\n },\n\n // a csv entry parser\n parseEntry: function(csv, options) {\n // cache settings\n var separator = options.separator;\n var delimiter = options.delimiter;\n \n // set initial state if it's missing\n if(!options.state.rowNum) {\n options.state.rowNum = 1;\n }\n if(!options.state.colNum) {\n options.state.colNum = 1;\n }\n\n // clear initial state\n var entry = [];\n var state = 0;\n var value = '';\n\n function endOfValue() {\n if(options.onParseValue === undefined) {\n // onParseValue hook not set\n entry.push(value);\n } else {\n var hook = options.onParseValue(value, options.state); // onParseValue Hook\n // false skips the value, configurable through a hook\n if(hook !== false) {\n entry.push(hook);\n }\n }\n // reset the state\n value = '';\n state = 0;\n // update global state\n options.state.colNum++;\n }\n\n // checked for a cached regEx first\n if(!options.match) {\n // escape regex-specific control chars\n var escSeparator = RegExp.escape(separator);\n var escDelimiter = RegExp.escape(delimiter);\n \n // compile the regEx str using the custom delimiter/separator\n var match = /(D|S|\\n|\\r|[^DS\\r\\n]+)/;\n var matchSrc = match.source;\n matchSrc = matchSrc.replace(/S/g, escSeparator);\n matchSrc = matchSrc.replace(/D/g, escDelimiter);\n options.match = RegExp(matchSrc, 'gm');\n }\n\n // put on your fancy pants...\n // process control chars individually, use look-ahead on non-control chars\n csv.replace(options.match, function (m0) {\n switch (state) {\n // the start of a value\n case 0:\n // null last value\n if (m0 === separator) {\n value += '';\n endOfValue();\n break;\n }\n // opening delimiter\n if (m0 === delimiter) {\n state = 1;\n break;\n }\n // skip un-delimited new-lines\n if (m0 === '\\n' || m0 === '\\r') {\n break;\n }\n // un-delimited value\n value += m0;\n state = 3;\n break;\n\n // delimited input\n case 1:\n // second delimiter? check further\n if (m0 === delimiter) {\n state = 2;\n break;\n }\n // delimited data\n value += m0;\n state = 1;\n break;\n\n // delimiter found in delimited input\n case 2:\n // escaped delimiter?\n if (m0 === delimiter) {\n value += m0;\n state = 1;\n break;\n }\n // null value\n if (m0 === separator) {\n endOfValue();\n break;\n }\n // skip un-delimited new-lines\n if (m0 === '\\n' || m0 === '\\r') {\n break;\n }\n // broken paser?\n throw new Error('CSVDataError: Illegal State [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n\n // un-delimited input\n case 3:\n // null last value\n if (m0 === separator) {\n endOfValue();\n break;\n }\n // skip un-delimited new-lines\n if (m0 === '\\n' || m0 === '\\r') {\n break;\n }\n // non-compliant data\n if (m0 === delimiter) {\n throw new Error('CSVDataError: Illegal Quote [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n }\n // broken parser?\n throw new Error('CSVDataError: Illegal Data [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n default:\n // shenanigans\n throw new Error('CSVDataError: Unknown State [Row:' + options.state.rowNum + '][Col:' + options.state.colNum + ']');\n }\n //console.log('val:' + m0 + ' state:' + state);\n });\n\n // submit the last value\n endOfValue();\n\n return entry;\n }\n },\n\n /**\n * $.csv.toArray(csv)\n * Converts a CSV entry string to a javascript array.\n *\n * @param {Array} csv The string containing the CSV data.\n * @param {Object} [options] An object containing user-defined options.\n * @param {Character} [separator] An override for the separator character. Defaults to a comma(,).\n * @param {Character} [delimiter] An override for the delimiter character. Defaults to a double-quote(\").\n *\n * This method deals with simple CSV strings only. It's useful if you only\n * need to parse a single entry. If you need to parse more than one line,\n * use $.csv2Array instead.\n */\n toArray: function(csv, options, callback) {\n var options = (options !== undefined ? options : {});\n var config = {};\n config.callback = ((callback !== undefined && typeof(callback) === 'function') ? callback : false);\n config.separator = 'separator' in options ? options.separator : $.csv.defaults.separator;\n config.delimiter = 'delimiter' in options ? options.delimiter : $.csv.defaults.delimiter;\n var state = (options.state !== undefined ? options.state : {});\n\n // setup\n var options = {\n delimiter: config.delimiter,\n separator: config.separator,\n onParseEntry: options.onParseEntry,\n onParseValue: options.onParseValue,\n state: state\n }\n\n var entry = $.csv.parsers.parseEntry(csv, options);\n\n // push the value to a callback if one is defined\n if(!config.callback) {\n return entry;\n } else {\n config.callback('', entry);\n }\n },\n\n /**\n * $.csv.toArrays(csv)\n * Converts a CSV string to a javascript array.\n *\n * @param {String} csv The string containing the raw CSV data.\n * @param {Object} [options] An object containing user-defined options.\n * @param {Character} [separator] An override for the separator character. Defaults to a comma(,).\n * @param {Character} [delimiter] An override for the delimiter character. Defaults to a double-quote(\").\n *\n * This method deals with multi-line CSV. The breakdown is simple. The first\n * dimension of the array represents the line (or entry/row) while the second\n * dimension contains the values (or values/columns).\n */\n toArrays: function(csv, options, callback) {\n var options = (options !== undefined ? options : {});\n var config = {};\n config.callback = ((callback !== undefined && typeof(callback) === 'function') ? callback : false);\n config.separator = 'separator' in options ? options.separator : $.csv.defaults.separator;\n config.delimiter = 'delimiter' in options ? options.delimiter : $.csv.defaults.delimiter;\n \n // setup\n var data = [];\n var options = {\n delimiter: config.delimiter,\n separator: config.separator,\n onParseEntry: options.onParseEntry,\n onParseValue: options.onParseValue,\n start: options.start,\n end: options.end,\n state: {\n rowNum: 1,\n colNum: 1\n }\n };\n\n // break the data down to lines\n data = $.csv.parsers.parse(csv, options);\n\n // push the value to a callback if one is defined\n if(!config.callback) {\n return data;\n } else {\n config.callback('', data);\n }\n },\n\n /**\n * $.csv.toObjects(csv)\n * Converts a CSV string to a javascript object.\n * @param {String} csv The string containing the raw CSV data.\n * @param {Object} [options] An object containing user-defined options.\n * @param {Character} [separator] An override for the separator character. Defaults to a comma(,).\n * @param {Character} [delimiter] An override for the delimiter character. Defaults to a double-quote(\").\n * @param {Boolean} [headers] Indicates whether the data contains a header line. Defaults to true.\n *\n * This method deals with multi-line CSV strings. Where the headers line is\n * used as the key for each value per entry.\n */\n toObjects: function(csv, options, callback) {\n var options = (options !== undefined ? options : {});\n var config = {};\n config.callback = ((callback !== undefined && typeof(callback) === 'function') ? callback : false);\n config.separator = 'separator' in options ? options.separator : $.csv.defaults.separator;\n config.delimiter = 'delimiter' in options ? options.delimiter : $.csv.defaults.delimiter;\n config.headers = 'headers' in options ? options.headers : $.csv.defaults.headers;\n options.start = 'start' in options ? options.start : 1;\n \n // account for headers\n if(config.headers) {\n options.start++;\n }\n if(options.end && config.headers) {\n options.end++;\n }\n \n // setup\n var lines = [];\n var data = [];\n \n var options = {\n delimiter: config.delimiter,\n separator: config.separator,\n onParseEntry: options.onParseEntry,\n onParseValue: options.onParseValue,\n start: options.start,\n end: options.end,\n state: {\n rowNum: 1,\n colNum: 1\n },\n match: false\n };\n\n // fetch the headers\n var headerOptions = {\n delimiter: config.delimiter,\n separator: config.separator,\n start: 1,\n end: 1,\n state: {\n rowNum:1,\n colNum:1\n }\n }\n var headerLine = $.csv.parsers.splitLines(csv, headerOptions);\n var headers = $.csv.toArray(headerLine[0], options);\n\n // fetch the data\n var lines = $.csv.parsers.splitLines(csv, options);\n \n // reset the state for re-use\n options.state.colNum = 1;\n if(headers){\n options.state.rowNum = 2;\n } else {\n options.state.rowNum = 1;\n }\n \n // convert data to objects\n for(var i=0, len=lines.length; i<len; i++) {\n var entry = $.csv.toArray(lines[i], options);\n var object = {};\n for(var j in headers) {\n object[headers[j]] = entry[j];\n }\n data.push(object);\n \n // update row state\n options.state.rowNum++;\n }\n\n // push the value to a callback if one is defined\n if(!config.callback) {\n return data;\n } else {\n config.callback('', data);\n }\n },\n\n /**\n * $.csv.fromArrays(arrays)\n * Converts a javascript array to a CSV String.\n *\n * @param {Array} array An array containing an array of CSV entries.\n * @param {Object} [options] An object containing user-defined options.\n * @param {Character} [separator] An override for the separator character. Defaults to a comma(,).\n * @param {Character} [delimiter] An override for the delimiter character. Defaults to a double-quote(\").\n *\n * This method generates a CSV file from an array of arrays (representing entries).\n */\n fromArrays: function(arrays, options, callback) {\n var options = (options !== undefined ? options : {});\n var config = {};\n config.callback = ((callback !== undefined && typeof(callback) === 'function') ? callback : false);\n config.separator = 'separator' in options ? options.separator : $.csv.defaults.separator;\n config.delimiter = 'delimiter' in options ? options.delimiter : $.csv.defaults.delimiter;\n config.escaper = 'escaper' in options ? options.escaper : $.csv.defaults.escaper;\n config.experimental = 'experimental' in options ? options.experimental : false;\n\n if(!config.experimental) {\n throw new Error('not implemented');\n }\n\n var output = [];\n for(i in arrays) {\n output.push(arrays[i]);\n }\n\n // push the value to a callback if one is defined\n if(!config.callback) {\n return output;\n } else {\n config.callback('', output);\n }\n },\n\n /**\n * $.csv.fromObjects(objects)\n * Converts a javascript dictionary to a CSV string.\n * @param {Object} objects An array of objects containing the data.\n * @param {Object} [options] An object containing user-defined options.\n * @param {Character} [separator] An override for the separator character. Defaults to a comma(,).\n * @param {Character} [delimiter] An override for the delimiter character. Defaults to a double-quote(\").\n *\n * This method generates a CSV file from an array of objects (name:value pairs).\n * It starts by detecting the headers and adding them as the first line of\n * the CSV file, followed by a structured dump of the data.\n */\n fromObjects2CSV: function(objects, options, callback) {\n var options = (options !== undefined ? options : {});\n var config = {};\n config.callback = ((callback !== undefined && typeof(callback) === 'function') ? callback : false);\n config.separator = 'separator' in options ? options.separator : $.csv.defaults.separator;\n config.delimiter = 'delimiter' in options ? options.delimiter : $.csv.defaults.delimiter;\n config.experimental = 'experimental' in options ? options.experimental : false;\n\n if(!config.experimental) {\n throw new Error('not implemented');\n }\n\n var output = [];\n for(i in objects) {\n output.push(arrays[i]);\n }\n\n // push the value to a callback if one is defined\n if(!config.callback) {\n return output;\n } else {\n config.callback('', output);\n }\n }\n };\n\n // Maintenance code to maintain backward-compatibility\n // Will be removed in release 1.0\n $.csvEntry2Array = $.csv.toArray;\n $.csv2Array = $.csv.toArrays;\n $.csv2Dictionary = $.csv.toObjects;\n\n\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n var ie_lt8 = /MSIE \\d/.test(navigator.userAgent) &&\n (document.documentMode == null || document.documentMode < 8);\n\n var Pos = CodeMirror.Pos;\n\n var matching = {\"(\": \")>\", \")\": \"(<\", \"[\": \"]>\", \"]\": \"[<\", \"{\": \"}>\", \"}\": \"{<\"};\n\n function findMatchingBracket(cm, where, strict, config) {\n var line = cm.getLineHandle(where.line), pos = where.ch - 1;\n var match = (pos >= 0 && matching[line.text.charAt(pos)]) || matching[line.text.charAt(++pos)];\n if (!match) return null;\n var dir = match.charAt(1) == \">\" ? 1 : -1;\n if (strict && (dir > 0) != (pos == where.ch)) return null;\n var style = cm.getTokenTypeAt(Pos(where.line, pos + 1));\n\n var found = scanForBracket(cm, Pos(where.line, pos + (dir > 0 ? 1 : 0)), dir, style || null, config);\n if (found == null) return null;\n return {from: Pos(where.line, pos), to: found && found.pos,\n match: found && found.ch == match.charAt(0), forward: dir > 0};\n }\n\n // bracketRegex is used to specify which type of bracket to scan\n // should be a regexp, e.g. /[[\\]]/\n //\n // Note: If \"where\" is on an open bracket, then this bracket is ignored.\n //\n // Returns false when no bracket was found, null when it reached\n // maxScanLines and gave up\n function scanForBracket(cm, where, dir, style, config) {\n var maxScanLen = (config && config.maxScanLineLength) || 10000;\n var maxScanLines = (config && config.maxScanLines) || 1000;\n\n var stack = [];\n var re = config && config.bracketRegex ? config.bracketRegex : /[(){}[\\]]/;\n var lineEnd = dir > 0 ? Math.min(where.line + maxScanLines, cm.lastLine() + 1)\n : Math.max(cm.firstLine() - 1, where.line - maxScanLines);\n for (var lineNo = where.line; lineNo != lineEnd; lineNo += dir) {\n var line = cm.getLine(lineNo);\n if (!line) continue;\n var pos = dir > 0 ? 0 : line.length - 1, end = dir > 0 ? line.length : -1;\n if (line.length > maxScanLen) continue;\n if (lineNo == where.line) pos = where.ch - (dir < 0 ? 1 : 0);\n for (; pos != end; pos += dir) {\n var ch = line.charAt(pos);\n if (re.test(ch) && (style === undefined || cm.getTokenTypeAt(Pos(lineNo, pos + 1)) == style)) {\n var match = matching[ch];\n if ((match.charAt(1) == \">\") == (dir > 0)) stack.push(ch);\n else if (!stack.length) return {pos: Pos(lineNo, pos), ch: ch};\n else stack.pop();\n }\n }\n }\n return lineNo - dir == (dir > 0 ? cm.lastLine() : cm.firstLine()) ? false : null;\n }\n\n function matchBrackets(cm, autoclear, config) {\n // Disable brace matching in long lines, since it'll cause hugely slow updates\n var maxHighlightLen = cm.state.matchBrackets.maxHighlightLineLength || 1000;\n var marks = [], ranges = cm.listSelections();\n for (var i = 0; i < ranges.length; i++) {\n var match = ranges[i].empty() && findMatchingBracket(cm, ranges[i].head, false, config);\n if (match && cm.getLine(match.from.line).length <= maxHighlightLen) {\n var style = match.match ? \"CodeMirror-matchingbracket\" : \"CodeMirror-nonmatchingbracket\";\n marks.push(cm.markText(match.from, Pos(match.from.line, match.from.ch + 1), {className: style}));\n if (match.to && cm.getLine(match.to.line).length <= maxHighlightLen)\n marks.push(cm.markText(match.to, Pos(match.to.line, match.to.ch + 1), {className: style}));\n }\n }\n\n if (marks.length) {\n // Kludge to work around the IE bug from issue #1193, where text\n // input stops going to the textare whever this fires.\n if (ie_lt8 && cm.state.focused) cm.focus();\n\n var clear = function() {\n cm.operation(function() {\n for (var i = 0; i < marks.length; i++) marks[i].clear();\n });\n };\n if (autoclear) setTimeout(clear, 800);\n else return clear;\n }\n }\n\n var currentlyHighlighted = null;\n function doMatchBrackets(cm) {\n cm.operation(function() {\n if (currentlyHighlighted) {currentlyHighlighted(); currentlyHighlighted = null;}\n currentlyHighlighted = matchBrackets(cm, false, cm.state.matchBrackets);\n });\n }\n\n CodeMirror.defineOption(\"matchBrackets\", false, function(cm, val, old) {\n if (old && old != CodeMirror.Init)\n cm.off(\"cursorActivity\", doMatchBrackets);\n if (val) {\n cm.state.matchBrackets = typeof val == \"object\" ? val : {};\n cm.on(\"cursorActivity\", doMatchBrackets);\n }\n });\n\n CodeMirror.defineExtension(\"matchBrackets\", function() {matchBrackets(this, true);});\n CodeMirror.defineExtension(\"findMatchingBracket\", function(pos, strict, config){\n return findMatchingBracket(this, pos, strict, config);\n });\n CodeMirror.defineExtension(\"scanForBracket\", function(pos, dir, style, config){\n return scanForBracket(this, pos, dir, style, config);\n });\n});\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n\"use strict\";\n\nCodeMirror.registerHelper(\"fold\", \"brace\", function(cm, start) {\n var line = start.line, lineText = cm.getLine(line);\n var tokenType;\n\n function findOpening(openCh) {\n for (var at = start.ch, pass = 0;;) {\n var found = at <= 0 ? -1 : lineText.lastIndexOf(openCh, at - 1);\n if (found == -1) {\n if (pass == 1) break;\n pass = 1;\n at = lineText.length;\n continue;\n }\n if (pass == 1 && found < start.ch) break;\n tokenType = cm.getTokenTypeAt(CodeMirror.Pos(line, found + 1));\n if (!/^(comment|string)/.test(tokenType)) return found + 1;\n at = found - 1;\n }\n }\n\n var startToken = \"{\", endToken = \"}\", startCh = findOpening(\"{\");\n if (startCh == null) {\n startToken = \"[\", endToken = \"]\";\n startCh = findOpening(\"[\");\n }\n\n if (startCh == null) return;\n var count = 1, lastLine = cm.lastLine(), end, endCh;\n outer: for (var i = line; i <= lastLine; ++i) {\n var text = cm.getLine(i), pos = i == line ? startCh : 0;\n for (;;) {\n var nextOpen = text.indexOf(startToken, pos), nextClose = text.indexOf(endToken, pos);\n if (nextOpen < 0) nextOpen = text.length;\n if (nextClose < 0) nextClose = text.length;\n pos = Math.min(nextOpen, nextClose);\n if (pos == text.length) break;\n if (cm.getTokenTypeAt(CodeMirror.Pos(i, pos + 1)) == tokenType) {\n if (pos == nextOpen) ++count;\n else if (!--count) { end = i; endCh = pos; break outer; }\n }\n ++pos;\n }\n }\n if (end == null || line == end && endCh == startCh) return;\n return {from: CodeMirror.Pos(line, startCh),\n to: CodeMirror.Pos(end, endCh)};\n});\n\nCodeMirror.registerHelper(\"fold\", \"import\", function(cm, start) {\n function hasImport(line) {\n if (line < cm.firstLine() || line > cm.lastLine()) return null;\n var start = cm.getTokenAt(CodeMirror.Pos(line, 1));\n if (!/\\S/.test(start.string)) start = cm.getTokenAt(CodeMirror.Pos(line, start.end + 1));\n if (start.type != \"keyword\" || start.string != \"import\") return null;\n // Now find closing semicolon, return its position\n for (var i = line, e = Math.min(cm.lastLine(), line + 10); i <= e; ++i) {\n var text = cm.getLine(i), semi = text.indexOf(\";\");\n if (semi != -1) return {startCh: start.end, end: CodeMirror.Pos(i, semi)};\n }\n }\n\n var startLine = start.line, has = hasImport(startLine), prev;\n if (!has || hasImport(startLine - 1) || ((prev = hasImport(startLine - 2)) && prev.end.line == startLine - 1))\n return null;\n for (var end = has.end;;) {\n var next = hasImport(end.line + 1);\n if (next == null) break;\n end = next.end;\n }\n return {from: cm.clipPos(CodeMirror.Pos(startLine, has.startCh + 1)), to: end};\n});\n\nCodeMirror.registerHelper(\"fold\", \"include\", function(cm, start) {\n function hasInclude(line) {\n if (line < cm.firstLine() || line > cm.lastLine()) return null;\n var start = cm.getTokenAt(CodeMirror.Pos(line, 1));\n if (!/\\S/.test(start.string)) start = cm.getTokenAt(CodeMirror.Pos(line, start.end + 1));\n if (start.type == \"meta\" && start.string.slice(0, 8) == \"#include\") return start.start + 8;\n }\n\n var startLine = start.line, has = hasInclude(startLine);\n if (has == null || hasInclude(startLine - 1) != null) return null;\n for (var end = startLine;;) {\n var next = hasInclude(end + 1);\n if (next == null) break;\n ++end;\n }\n return {from: CodeMirror.Pos(startLine, has + 1),\n to: cm.clipPos(CodeMirror.Pos(end))};\n});\n\n});\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n \"use strict\";\n\n function doFold(cm, pos, options, force) {\n if (options && options.call) {\n var finder = options;\n options = null;\n } else {\n var finder = getOption(cm, options, \"rangeFinder\");\n }\n if (typeof pos == \"number\") pos = CodeMirror.Pos(pos, 0);\n var minSize = getOption(cm, options, \"minFoldSize\");\n\n function getRange(allowFolded) {\n var range = finder(cm, pos);\n if (!range || range.to.line - range.from.line < minSize) return null;\n var marks = cm.findMarksAt(range.from);\n for (var i = 0; i < marks.length; ++i) {\n if (marks[i].__isFold && force !== \"fold\") {\n if (!allowFolded) return null;\n range.cleared = true;\n marks[i].clear();\n }\n }\n return range;\n }\n\n var range = getRange(true);\n if (getOption(cm, options, \"scanUp\")) while (!range && pos.line > cm.firstLine()) {\n pos = CodeMirror.Pos(pos.line - 1, 0);\n range = getRange(false);\n }\n if (!range || range.cleared || force === \"unfold\") return;\n\n var myWidget = makeWidget(cm, options);\n CodeMirror.on(myWidget, \"mousedown\", function(e) {\n myRange.clear();\n CodeMirror.e_preventDefault(e);\n });\n var myRange = cm.markText(range.from, range.to, {\n replacedWith: myWidget,\n clearOnEnter: getOption(cm, options, \"clearOnEnter\"),\n __isFold: true\n });\n myRange.on(\"clear\", function(from, to) {\n CodeMirror.signal(cm, \"unfold\", cm, from, to);\n });\n CodeMirror.signal(cm, \"fold\", cm, range.from, range.to);\n }\n\n function makeWidget(cm, options) {\n var widget = getOption(cm, options, \"widget\");\n if (typeof widget == \"string\") {\n var text = document.createTextNode(widget);\n widget = document.createElement(\"span\");\n widget.appendChild(text);\n widget.className = \"CodeMirror-foldmarker\";\n }\n return widget;\n }\n\n // Clumsy backwards-compatible interface\n CodeMirror.newFoldFunction = function(rangeFinder, widget) {\n return function(cm, pos) { doFold(cm, pos, {rangeFinder: rangeFinder, widget: widget}); };\n };\n\n // New-style interface\n CodeMirror.defineExtension(\"foldCode\", function(pos, options, force) {\n doFold(this, pos, options, force);\n });\n\n CodeMirror.defineExtension(\"isFolded\", function(pos) {\n var marks = this.findMarksAt(pos);\n for (var i = 0; i < marks.length; ++i)\n if (marks[i].__isFold) return true;\n });\n\n CodeMirror.commands.toggleFold = function(cm) {\n cm.foldCode(cm.getCursor());\n };\n CodeMirror.commands.fold = function(cm) {\n cm.foldCode(cm.getCursor(), null, \"fold\");\n };\n CodeMirror.commands.unfold = function(cm) {\n cm.foldCode(cm.getCursor(), null, \"unfold\");\n };\n CodeMirror.commands.foldAll = function(cm) {\n cm.operation(function() {\n for (var i = cm.firstLine(), e = cm.lastLine(); i <= e; i++)\n cm.foldCode(CodeMirror.Pos(i, 0), null, \"fold\");\n });\n };\n CodeMirror.commands.unfoldAll = function(cm) {\n cm.operation(function() {\n for (var i = cm.firstLine(), e = cm.lastLine(); i <= e; i++)\n cm.foldCode(CodeMirror.Pos(i, 0), null, \"unfold\");\n });\n };\n\n CodeMirror.registerHelper(\"fold\", \"combine\", function() {\n var funcs = Array.prototype.slice.call(arguments, 0);\n return function(cm, start) {\n for (var i = 0; i < funcs.length; ++i) {\n var found = funcs[i](cm, start);\n if (found) return found;\n }\n };\n });\n\n CodeMirror.registerHelper(\"fold\", \"auto\", function(cm, start) {\n var helpers = cm.getHelpers(start, \"fold\");\n for (var i = 0; i < helpers.length; i++) {\n var cur = helpers[i](cm, start);\n if (cur) return cur;\n }\n });\n\n var defaultOptions = {\n rangeFinder: CodeMirror.fold.auto,\n widget: \"\\u2194\",\n minFoldSize: 0,\n scanUp: false,\n clearOnEnter: true\n };\n\n CodeMirror.defineOption(\"foldOptions\", null);\n\n function getOption(cm, options, name) {\n if (options && options[name] !== undefined)\n return options[name];\n var editorOptions = cm.options.foldOptions;\n if (editorOptions && editorOptions[name] !== undefined)\n return editorOptions[name];\n return defaultOptions[name];\n }\n\n CodeMirror.defineExtension(\"foldOption\", function(options, name) {\n return getOption(this, options, name);\n });\n});\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"), require(\"./foldcode\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\", \"./foldcode\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n \"use strict\";\n\n CodeMirror.defineOption(\"foldGutter\", false, function(cm, val, old) {\n if (old && old != CodeMirror.Init) {\n cm.clearGutter(cm.state.foldGutter.options.gutter);\n cm.state.foldGutter = null;\n cm.off(\"gutterClick\", onGutterClick);\n cm.off(\"change\", onChange);\n cm.off(\"viewportChange\", onViewportChange);\n cm.off(\"fold\", onFold);\n cm.off(\"unfold\", onFold);\n cm.off(\"swapDoc\", onChange);\n }\n if (val) {\n cm.state.foldGutter = new State(parseOptions(val));\n updateInViewport(cm);\n cm.on(\"gutterClick\", onGutterClick);\n cm.on(\"change\", onChange);\n cm.on(\"viewportChange\", onViewportChange);\n cm.on(\"fold\", onFold);\n cm.on(\"unfold\", onFold);\n cm.on(\"swapDoc\", onChange);\n }\n });\n\n var Pos = CodeMirror.Pos;\n\n function State(options) {\n this.options = options;\n this.from = this.to = 0;\n }\n\n function parseOptions(opts) {\n if (opts === true) opts = {};\n if (opts.gutter == null) opts.gutter = \"CodeMirror-foldgutter\";\n if (opts.indicatorOpen == null) opts.indicatorOpen = \"CodeMirror-foldgutter-open\";\n if (opts.indicatorFolded == null) opts.indicatorFolded = \"CodeMirror-foldgutter-folded\";\n return opts;\n }\n\n function isFolded(cm, line) {\n var marks = cm.findMarks(Pos(line, 0), Pos(line + 1, 0));\n for (var i = 0; i < marks.length; ++i)\n if (marks[i].__isFold && marks[i].find().from.line == line) return marks[i];\n }\n\n function marker(spec) {\n if (typeof spec == \"string\") {\n var elt = document.createElement(\"div\");\n elt.className = spec + \" CodeMirror-guttermarker-subtle\";\n return elt;\n } else {\n return spec.cloneNode(true);\n }\n }\n\n function updateFoldInfo(cm, from, to) {\n var opts = cm.state.foldGutter.options, cur = from;\n var minSize = cm.foldOption(opts, \"minFoldSize\");\n var func = cm.foldOption(opts, \"rangeFinder\");\n cm.eachLine(from, to, function(line) {\n var mark = null;\n if (isFolded(cm, cur)) {\n mark = marker(opts.indicatorFolded);\n } else {\n var pos = Pos(cur, 0);\n var range = func && func(cm, pos);\n if (range && range.to.line - range.from.line >= minSize)\n mark = marker(opts.indicatorOpen);\n }\n cm.setGutterMarker(line, opts.gutter, mark);\n ++cur;\n });\n }\n\n function updateInViewport(cm) {\n var vp = cm.getViewport(), state = cm.state.foldGutter;\n if (!state) return;\n cm.operation(function() {\n updateFoldInfo(cm, vp.from, vp.to);\n });\n state.from = vp.from; state.to = vp.to;\n }\n\n function onGutterClick(cm, line, gutter) {\n var state = cm.state.foldGutter;\n if (!state) return;\n var opts = state.options;\n if (gutter != opts.gutter) return;\n var folded = isFolded(cm, line);\n if (folded) folded.clear();\n else cm.foldCode(Pos(line, 0), opts.rangeFinder);\n }\n\n function onChange(cm) {\n var state = cm.state.foldGutter;\n if (!state) return;\n var opts = state.options;\n state.from = state.to = 0;\n clearTimeout(state.changeUpdate);\n state.changeUpdate = setTimeout(function() { updateInViewport(cm); }, opts.foldOnChangeTimeSpan || 600);\n }\n\n function onViewportChange(cm) {\n var state = cm.state.foldGutter;\n if (!state) return;\n var opts = state.options;\n clearTimeout(state.changeUpdate);\n state.changeUpdate = setTimeout(function() {\n var vp = cm.getViewport();\n if (state.from == state.to || vp.from - state.to > 20 || state.from - vp.to > 20) {\n updateInViewport(cm);\n } else {\n cm.operation(function() {\n if (vp.from < state.from) {\n updateFoldInfo(cm, vp.from, state.from);\n state.from = vp.from;\n }\n if (vp.to > state.to) {\n updateFoldInfo(cm, state.to, vp.to);\n state.to = vp.to;\n }\n });\n }\n }, opts.updateViewportTimeSpan || 400);\n }\n\n function onFold(cm, from) {\n var state = cm.state.foldGutter;\n if (!state) return;\n var line = from.line;\n if (line >= state.from && line < state.to)\n updateFoldInfo(cm, line, line + 1);\n }\n});\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n \"use strict\";\n\n var Pos = CodeMirror.Pos;\n function cmp(a, b) { return a.line - b.line || a.ch - b.ch; }\n\n var nameStartChar = \"A-Z_a-z\\\\u00C0-\\\\u00D6\\\\u00D8-\\\\u00F6\\\\u00F8-\\\\u02FF\\\\u0370-\\\\u037D\\\\u037F-\\\\u1FFF\\\\u200C-\\\\u200D\\\\u2070-\\\\u218F\\\\u2C00-\\\\u2FEF\\\\u3001-\\\\uD7FF\\\\uF900-\\\\uFDCF\\\\uFDF0-\\\\uFFFD\";\n var nameChar = nameStartChar + \"\\-\\:\\.0-9\\\\u00B7\\\\u0300-\\\\u036F\\\\u203F-\\\\u2040\";\n var xmlTagStart = new RegExp(\"<(/?)([\" + nameStartChar + \"][\" + nameChar + \"]*)\", \"g\");\n\n function Iter(cm, line, ch, range) {\n this.line = line; this.ch = ch;\n this.cm = cm; this.text = cm.getLine(line);\n this.min = range ? range.from : cm.firstLine();\n this.max = range ? range.to - 1 : cm.lastLine();\n }\n\n function tagAt(iter, ch) {\n var type = iter.cm.getTokenTypeAt(Pos(iter.line, ch));\n return type && /\\btag\\b/.test(type);\n }\n\n function nextLine(iter) {\n if (iter.line >= iter.max) return;\n iter.ch = 0;\n iter.text = iter.cm.getLine(++iter.line);\n return true;\n }\n function prevLine(iter) {\n if (iter.line <= iter.min) return;\n iter.text = iter.cm.getLine(--iter.line);\n iter.ch = iter.text.length;\n return true;\n }\n\n function toTagEnd(iter) {\n for (;;) {\n var gt = iter.text.indexOf(\">\", iter.ch);\n if (gt == -1) { if (nextLine(iter)) continue; else return; }\n if (!tagAt(iter, gt + 1)) { iter.ch = gt + 1; continue; }\n var lastSlash = iter.text.lastIndexOf(\"/\", gt);\n var selfClose = lastSlash > -1 && !/\\S/.test(iter.text.slice(lastSlash + 1, gt));\n iter.ch = gt + 1;\n return selfClose ? \"selfClose\" : \"regular\";\n }\n }\n function toTagStart(iter) {\n for (;;) {\n var lt = iter.ch ? iter.text.lastIndexOf(\"<\", iter.ch - 1) : -1;\n if (lt == -1) { if (prevLine(iter)) continue; else return; }\n if (!tagAt(iter, lt + 1)) { iter.ch = lt; continue; }\n xmlTagStart.lastIndex = lt;\n iter.ch = lt;\n var match = xmlTagStart.exec(iter.text);\n if (match && match.index == lt) return match;\n }\n }\n\n function toNextTag(iter) {\n for (;;) {\n xmlTagStart.lastIndex = iter.ch;\n var found = xmlTagStart.exec(iter.text);\n if (!found) { if (nextLine(iter)) continue; else return; }\n if (!tagAt(iter, found.index + 1)) { iter.ch = found.index + 1; continue; }\n iter.ch = found.index + found[0].length;\n return found;\n }\n }\n function toPrevTag(iter) {\n for (;;) {\n var gt = iter.ch ? iter.text.lastIndexOf(\">\", iter.ch - 1) : -1;\n if (gt == -1) { if (prevLine(iter)) continue; else return; }\n if (!tagAt(iter, gt + 1)) { iter.ch = gt; continue; }\n var lastSlash = iter.text.lastIndexOf(\"/\", gt);\n var selfClose = lastSlash > -1 && !/\\S/.test(iter.text.slice(lastSlash + 1, gt));\n iter.ch = gt + 1;\n return selfClose ? \"selfClose\" : \"regular\";\n }\n }\n\n function findMatchingClose(iter, tag) {\n var stack = [];\n for (;;) {\n var next = toNextTag(iter), end, startLine = iter.line, startCh = iter.ch - (next ? next[0].length : 0);\n if (!next || !(end = toTagEnd(iter))) return;\n if (end == \"selfClose\") continue;\n if (next[1]) { // closing tag\n for (var i = stack.length - 1; i >= 0; --i) if (stack[i] == next[2]) {\n stack.length = i;\n break;\n }\n if (i < 0 && (!tag || tag == next[2])) return {\n tag: next[2],\n from: Pos(startLine, startCh),\n to: Pos(iter.line, iter.ch)\n };\n } else { // opening tag\n stack.push(next[2]);\n }\n }\n }\n function findMatchingOpen(iter, tag) {\n var stack = [];\n for (;;) {\n var prev = toPrevTag(iter);\n if (!prev) return;\n if (prev == \"selfClose\") { toTagStart(iter); continue; }\n var endLine = iter.line, endCh = iter.ch;\n var start = toTagStart(iter);\n if (!start) return;\n if (start[1]) { // closing tag\n stack.push(start[2]);\n } else { // opening tag\n for (var i = stack.length - 1; i >= 0; --i) if (stack[i] == start[2]) {\n stack.length = i;\n break;\n }\n if (i < 0 && (!tag || tag == start[2])) return {\n tag: start[2],\n from: Pos(iter.line, iter.ch),\n to: Pos(endLine, endCh)\n };\n }\n }\n }\n\n CodeMirror.registerHelper(\"fold\", \"xml\", function(cm, start) {\n var iter = new Iter(cm, start.line, 0);\n for (;;) {\n var openTag = toNextTag(iter), end;\n if (!openTag || iter.line != start.line || !(end = toTagEnd(iter))) return;\n if (!openTag[1] && end != \"selfClose\") {\n var startPos = Pos(iter.line, iter.ch);\n var endPos = findMatchingClose(iter, openTag[2]);\n return endPos && {from: startPos, to: endPos.from};\n }\n }\n });\n CodeMirror.findMatchingTag = function(cm, pos, range) {\n var iter = new Iter(cm, pos.line, pos.ch, range);\n if (iter.text.indexOf(\">\") == -1 && iter.text.indexOf(\"<\") == -1) return;\n var end = toTagEnd(iter), to = end && Pos(iter.line, iter.ch);\n var start = end && toTagStart(iter);\n if (!end || !start || cmp(iter, pos) > 0) return;\n var here = {from: Pos(iter.line, iter.ch), to: to, tag: start[2]};\n if (end == \"selfClose\") return {open: here, close: null, at: \"open\"};\n\n if (start[1]) { // closing tag\n return {open: findMatchingOpen(iter, start[2]), close: here, at: \"close\"};\n } else { // opening tag\n iter = new Iter(cm, to.line, to.ch, range);\n return {open: here, close: findMatchingClose(iter, start[2]), at: \"open\"};\n }\n };\n\n CodeMirror.findEnclosingTag = function(cm, pos, range) {\n var iter = new Iter(cm, pos.line, pos.ch, range);\n for (;;) {\n var open = findMatchingOpen(iter);\n if (!open) break;\n var forward = new Iter(cm, pos.line, pos.ch, range);\n var close = findMatchingClose(forward, open.tag);\n if (close) return {open: open, close: close};\n }\n };\n\n // Used by addon/edit/closetag.js\n CodeMirror.scanForClosingTag = function(cm, pos, name, end) {\n var iter = new Iter(cm, pos.line, pos.ch, end ? {from: 0, to: end} : null);\n return findMatchingClose(iter, name);\n };\n});\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n// This is CodeMirror (http://codemirror.net), a code editor\n// implemented in JavaScript on top of the browser's DOM.\n//\n// You can find some technical background for some of the code below\n// at http://marijnhaverbeke.nl/blog/#cm-internals .\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n module.exports = mod();\n else if (typeof define == \"function\" && define.amd) // AMD\n return define([], mod);\n else // Plain browser env\n (this || window).CodeMirror = mod();\n})(function() {\n \"use strict\";\n\n // BROWSER SNIFFING\n\n // Kludges for bugs and behavior differences that can't be feature\n // detected are enabled based on userAgent etc sniffing.\n var userAgent = navigator.userAgent;\n var platform = navigator.platform;\n\n var gecko = /gecko\\/\\d/i.test(userAgent);\n var ie_upto10 = /MSIE \\d/.test(userAgent);\n var ie_11up = /Trident\\/(?:[7-9]|\\d{2,})\\..*rv:(\\d+)/.exec(userAgent);\n var ie = ie_upto10 || ie_11up;\n var ie_version = ie && (ie_upto10 ? document.documentMode || 6 : ie_11up[1]);\n var webkit = /WebKit\\//.test(userAgent);\n var qtwebkit = webkit && /Qt\\/\\d+\\.\\d+/.test(userAgent);\n var chrome = /Chrome\\//.test(userAgent);\n var presto = /Opera\\//.test(userAgent);\n var safari = /Apple Computer/.test(navigator.vendor);\n var mac_geMountainLion = /Mac OS X 1\\d\\D([8-9]|\\d\\d)\\D/.test(userAgent);\n var phantom = /PhantomJS/.test(userAgent);\n\n var ios = /AppleWebKit/.test(userAgent) && /Mobile\\/\\w+/.test(userAgent);\n // This is woefully incomplete. Suggestions for alternative methods welcome.\n var mobile = ios || /Android|webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(userAgent);\n var mac = ios || /Mac/.test(platform);\n var chromeOS = /\\bCrOS\\b/.test(userAgent);\n var windows = /win/i.test(platform);\n\n var presto_version = presto && userAgent.match(/Version\\/(\\d*\\.\\d*)/);\n if (presto_version) presto_version = Number(presto_version[1]);\n if (presto_version && presto_version >= 15) { presto = false; webkit = true; }\n // Some browsers use the wrong event properties to signal cmd/ctrl on OS X\n var flipCtrlCmd = mac && (qtwebkit || presto && (presto_version == null || presto_version < 12.11));\n var captureRightClick = gecko || (ie && ie_version >= 9);\n\n // Optimize some code when these features are not used.\n var sawReadOnlySpans = false, sawCollapsedSpans = false;\n\n // EDITOR CONSTRUCTOR\n\n // A CodeMirror instance represents an editor. This is the object\n // that user code is usually dealing with.\n\n function CodeMirror(place, options) {\n if (!(this instanceof CodeMirror)) return new CodeMirror(place, options);\n\n this.options = options = options ? copyObj(options) : {};\n // Determine effective options based on given values and defaults.\n copyObj(defaults, options, false);\n setGuttersForLineNumbers(options);\n\n var doc = options.value;\n if (typeof doc == \"string\") doc = new Doc(doc, options.mode, null, options.lineSeparator);\n this.doc = doc;\n\n var input = new CodeMirror.inputStyles[options.inputStyle](this);\n var display = this.display = new Display(place, doc, input);\n display.wrapper.CodeMirror = this;\n updateGutters(this);\n themeChanged(this);\n if (options.lineWrapping)\n this.display.wrapper.className += \" CodeMirror-wrap\";\n if (options.autofocus && !mobile) display.input.focus();\n initScrollbars(this);\n\n this.state = {\n keyMaps: [], // stores maps added by addKeyMap\n overlays: [], // highlighting overlays, as added by addOverlay\n modeGen: 0, // bumped when mode/overlay changes, used to invalidate highlighting info\n overwrite: false,\n delayingBlurEvent: false,\n focused: false,\n suppressEdits: false, // used to disable editing during key handlers when in readOnly mode\n pasteIncoming: false, cutIncoming: false, // help recognize paste/cut edits in input.poll\n selectingText: false,\n draggingText: false,\n highlight: new Delayed(), // stores highlight worker timeout\n keySeq: null, // Unfinished key sequence\n specialChars: null\n };\n\n var cm = this;\n\n // Override magic textarea content restore that IE sometimes does\n // on our hidden textarea on reload\n if (ie && ie_version < 11) setTimeout(function() { cm.display.input.reset(true); }, 20);\n\n registerEventHandlers(this);\n ensureGlobalHandlers();\n\n startOperation(this);\n this.curOp.forceUpdate = true;\n attachDoc(this, doc);\n\n if ((options.autofocus && !mobile) || cm.hasFocus())\n setTimeout(bind(onFocus, this), 20);\n else\n onBlur(this);\n\n for (var opt in optionHandlers) if (optionHandlers.hasOwnProperty(opt))\n optionHandlers[opt](this, options[opt], Init);\n maybeUpdateLineNumberWidth(this);\n if (options.finishInit) options.finishInit(this);\n for (var i = 0; i < initHooks.length; ++i) initHooks[i](this);\n endOperation(this);\n // Suppress optimizelegibility in Webkit, since it breaks text\n // measuring on line wrapping boundaries.\n if (webkit && options.lineWrapping &&\n getComputedStyle(display.lineDiv).textRendering == \"optimizelegibility\")\n display.lineDiv.style.textRendering = \"auto\";\n }\n\n // DISPLAY CONSTRUCTOR\n\n // The display handles the DOM integration, both for input reading\n // and content drawing. It holds references to DOM nodes and\n // display-related state.\n\n function Display(place, doc, input) {\n var d = this;\n this.input = input;\n\n // Covers bottom-right square when both scrollbars are present.\n d.scrollbarFiller = elt(\"div\", null, \"CodeMirror-scrollbar-filler\");\n d.scrollbarFiller.setAttribute(\"cm-not-content\", \"true\");\n // Covers bottom of gutter when coverGutterNextToScrollbar is on\n // and h scrollbar is present.\n d.gutterFiller = elt(\"div\", null, \"CodeMirror-gutter-filler\");\n d.gutterFiller.setAttribute(\"cm-not-content\", \"true\");\n // Will contain the actual code, positioned to cover the viewport.\n d.lineDiv = elt(\"div\", null, \"CodeMirror-code\");\n // Elements are added to these to represent selection and cursors.\n d.selectionDiv = elt(\"div\", null, null, \"position: relative; z-index: 1\");\n d.cursorDiv = elt(\"div\", null, \"CodeMirror-cursors\");\n // A visibility: hidden element used to find the size of things.\n d.measure = elt(\"div\", null, \"CodeMirror-measure\");\n // When lines outside of the viewport are measured, they are drawn in this.\n d.lineMeasure = elt(\"div\", null, \"CodeMirror-measure\");\n // Wraps everything that needs to exist inside the vertically-padded coordinate system\n d.lineSpace = elt(\"div\", [d.measure, d.lineMeasure, d.selectionDiv, d.cursorDiv, d.lineDiv],\n null, \"position: relative; outline: none\");\n // Moved around its parent to cover visible view.\n d.mover = elt(\"div\", [elt(\"div\", [d.lineSpace], \"CodeMirror-lines\")], null, \"position: relative\");\n // Set to the height of the document, allowing scrolling.\n d.sizer = elt(\"div\", [d.mover], \"CodeMirror-sizer\");\n d.sizerWidth = null;\n // Behavior of elts with overflow: auto and padding is\n // inconsistent across browsers. This is used to ensure the\n // scrollable area is big enough.\n d.heightForcer = elt(\"div\", null, null, \"position: absolute; height: \" + scrollerGap + \"px; width: 1px;\");\n // Will contain the gutters, if any.\n d.gutters = elt(\"div\", null, \"CodeMirror-gutters\");\n d.lineGutter = null;\n // Actual scrollable element.\n d.scroller = elt(\"div\", [d.sizer, d.heightForcer, d.gutters], \"CodeMirror-scroll\");\n d.scroller.setAttribute(\"tabIndex\", \"-1\");\n // The element in which the editor lives.\n d.wrapper = elt(\"div\", [d.scrollbarFiller, d.gutterFiller, d.scroller], \"CodeMirror\");\n\n // Work around IE7 z-index bug (not perfect, hence IE7 not really being supported)\n if (ie && ie_version < 8) { d.gutters.style.zIndex = -1; d.scroller.style.paddingRight = 0; }\n if (!webkit && !(gecko && mobile)) d.scroller.draggable = true;\n\n if (place) {\n if (place.appendChild) place.appendChild(d.wrapper);\n else place(d.wrapper);\n }\n\n // Current rendered range (may be bigger than the view window).\n d.viewFrom = d.viewTo = doc.first;\n d.reportedViewFrom = d.reportedViewTo = doc.first;\n // Information about the rendered lines.\n d.view = [];\n d.renderedView = null;\n // Holds info about a single rendered line when it was rendered\n // for measurement, while not in view.\n d.externalMeasured = null;\n // Empty space (in pixels) above the view\n d.viewOffset = 0;\n d.lastWrapHeight = d.lastWrapWidth = 0;\n d.updateLineNumbers = null;\n\n d.nativeBarWidth = d.barHeight = d.barWidth = 0;\n d.scrollbarsClipped = false;\n\n // Used to only resize the line number gutter when necessary (when\n // the amount of lines crosses a boundary that makes its width change)\n d.lineNumWidth = d.lineNumInnerWidth = d.lineNumChars = null;\n // Set to true when a non-horizontal-scrolling line widget is\n // added. As an optimization, line widget aligning is skipped when\n // this is false.\n d.alignWidgets = false;\n\n d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;\n\n // Tracks the maximum line length so that the horizontal scrollbar\n // can be kept static when scrolling.\n d.maxLine = null;\n d.maxLineLength = 0;\n d.maxLineChanged = false;\n\n // Used for measuring wheel scrolling granularity\n d.wheelDX = d.wheelDY = d.wheelStartX = d.wheelStartY = null;\n\n // True when shift is held down.\n d.shift = false;\n\n // Used to track whether anything happened since the context menu\n // was opened.\n d.selForContextMenu = null;\n\n d.activeTouch = null;\n\n input.init(d);\n }\n\n // STATE UPDATES\n\n // Used to get the editor into a consistent state again when options change.\n\n function loadMode(cm) {\n cm.doc.mode = CodeMirror.getMode(cm.options, cm.doc.modeOption);\n resetModeState(cm);\n }\n\n function resetModeState(cm) {\n cm.doc.iter(function(line) {\n if (line.stateAfter) line.stateAfter = null;\n if (line.styles) line.styles = null;\n });\n cm.doc.frontier = cm.doc.first;\n startWorker(cm, 100);\n cm.state.modeGen++;\n if (cm.curOp) regChange(cm);\n }\n\n function wrappingChanged(cm) {\n if (cm.options.lineWrapping) {\n addClass(cm.display.wrapper, \"CodeMirror-wrap\");\n cm.display.sizer.style.minWidth = \"\";\n cm.display.sizerWidth = null;\n } else {\n rmClass(cm.display.wrapper, \"CodeMirror-wrap\");\n findMaxLine(cm);\n }\n estimateLineHeights(cm);\n regChange(cm);\n clearCaches(cm);\n setTimeout(function(){updateScrollbars(cm);}, 100);\n }\n\n // Returns a function that estimates the height of a line, to use as\n // first approximation until the line becomes visible (and is thus\n // properly measurable).\n function estimateHeight(cm) {\n var th = textHeight(cm.display), wrapping = cm.options.lineWrapping;\n var perLine = wrapping && Math.max(5, cm.display.scroller.clientWidth / charWidth(cm.display) - 3);\n return function(line) {\n if (lineIsHidden(cm.doc, line)) return 0;\n\n var widgetsHeight = 0;\n if (line.widgets) for (var i = 0; i < line.widgets.length; i++) {\n if (line.widgets[i].height) widgetsHeight += line.widgets[i].height;\n }\n\n if (wrapping)\n return widgetsHeight + (Math.ceil(line.text.length / perLine) || 1) * th;\n else\n return widgetsHeight + th;\n };\n }\n\n function estimateLineHeights(cm) {\n var doc = cm.doc, est = estimateHeight(cm);\n doc.iter(function(line) {\n var estHeight = est(line);\n if (estHeight != line.height) updateLineHeight(line, estHeight);\n });\n }\n\n function themeChanged(cm) {\n cm.display.wrapper.className = cm.display.wrapper.className.replace(/\\s*cm-s-\\S+/g, \"\") +\n cm.options.theme.replace(/(^|\\s)\\s*/g, \" cm-s-\");\n clearCaches(cm);\n }\n\n function guttersChanged(cm) {\n updateGutters(cm);\n regChange(cm);\n setTimeout(function(){alignHorizontally(cm);}, 20);\n }\n\n // Rebuild the gutter elements, ensure the margin to the left of the\n // code matches their width.\n function updateGutters(cm) {\n var gutters = cm.display.gutters, specs = cm.options.gutters;\n removeChildren(gutters);\n for (var i = 0; i < specs.length; ++i) {\n var gutterClass = specs[i];\n var gElt = gutters.appendChild(elt(\"div\", null, \"CodeMirror-gutter \" + gutterClass));\n if (gutterClass == \"CodeMirror-linenumbers\") {\n cm.display.lineGutter = gElt;\n gElt.style.width = (cm.display.lineNumWidth || 1) + \"px\";\n }\n }\n gutters.style.display = i ? \"\" : \"none\";\n updateGutterSpace(cm);\n }\n\n function updateGutterSpace(cm) {\n var width = cm.display.gutters.offsetWidth;\n cm.display.sizer.style.marginLeft = width + \"px\";\n }\n\n // Compute the character length of a line, taking into account\n // collapsed ranges (see markText) that might hide parts, and join\n // other lines onto it.\n function lineLength(line) {\n if (line.height == 0) return 0;\n var len = line.text.length, merged, cur = line;\n while (merged = collapsedSpanAtStart(cur)) {\n var found = merged.find(0, true);\n cur = found.from.line;\n len += found.from.ch - found.to.ch;\n }\n cur = line;\n while (merged = collapsedSpanAtEnd(cur)) {\n var found = merged.find(0, true);\n len -= cur.text.length - found.from.ch;\n cur = found.to.line;\n len += cur.text.length - found.to.ch;\n }\n return len;\n }\n\n // Find the longest line in the document.\n function findMaxLine(cm) {\n var d = cm.display, doc = cm.doc;\n d.maxLine = getLine(doc, doc.first);\n d.maxLineLength = lineLength(d.maxLine);\n d.maxLineChanged = true;\n doc.iter(function(line) {\n var len = lineLength(line);\n if (len > d.maxLineLength) {\n d.maxLineLength = len;\n d.maxLine = line;\n }\n });\n }\n\n // Make sure the gutters options contains the element\n // \"CodeMirror-linenumbers\" when the lineNumbers option is true.\n function setGuttersForLineNumbers(options) {\n var found = indexOf(options.gutters, \"CodeMirror-linenumbers\");\n if (found == -1 && options.lineNumbers) {\n options.gutters = options.gutters.concat([\"CodeMirror-linenumbers\"]);\n } else if (found > -1 && !options.lineNumbers) {\n options.gutters = options.gutters.slice(0);\n options.gutters.splice(found, 1);\n }\n }\n\n // SCROLLBARS\n\n // Prepare DOM reads needed to update the scrollbars. Done in one\n // shot to minimize update/measure roundtrips.\n function measureForScrollbars(cm) {\n var d = cm.display, gutterW = d.gutters.offsetWidth;\n var docH = Math.round(cm.doc.height + paddingVert(cm.display));\n return {\n clientHeight: d.scroller.clientHeight,\n viewHeight: d.wrapper.clientHeight,\n scrollWidth: d.scroller.scrollWidth, clientWidth: d.scroller.clientWidth,\n viewWidth: d.wrapper.clientWidth,\n barLeft: cm.options.fixedGutter ? gutterW : 0,\n docHeight: docH,\n scrollHeight: docH + scrollGap(cm) + d.barHeight,\n nativeBarWidth: d.nativeBarWidth,\n gutterWidth: gutterW\n };\n }\n\n function NativeScrollbars(place, scroll, cm) {\n this.cm = cm;\n var vert = this.vert = elt(\"div\", [elt(\"div\", null, null, \"min-width: 1px\")], \"CodeMirror-vscrollbar\");\n var horiz = this.horiz = elt(\"div\", [elt(\"div\", null, null, \"height: 100%; min-height: 1px\")], \"CodeMirror-hscrollbar\");\n place(vert); place(horiz);\n\n on(vert, \"scroll\", function() {\n if (vert.clientHeight) scroll(vert.scrollTop, \"vertical\");\n });\n on(horiz, \"scroll\", function() {\n if (horiz.clientWidth) scroll(horiz.scrollLeft, \"horizontal\");\n });\n\n this.checkedZeroWidth = false;\n // Need to set a minimum width to see the scrollbar on IE7 (but must not set it on IE8).\n if (ie && ie_version < 8) this.horiz.style.minHeight = this.vert.style.minWidth = \"18px\";\n }\n\n NativeScrollbars.prototype = copyObj({\n update: function(measure) {\n var needsH = measure.scrollWidth > measure.clientWidth + 1;\n var needsV = measure.scrollHeight > measure.clientHeight + 1;\n var sWidth = measure.nativeBarWidth;\n\n if (needsV) {\n this.vert.style.display = \"block\";\n this.vert.style.bottom = needsH ? sWidth + \"px\" : \"0\";\n var totalHeight = measure.viewHeight - (needsH ? sWidth : 0);\n // A bug in IE8 can cause this value to be negative, so guard it.\n this.vert.firstChild.style.height =\n Math.max(0, measure.scrollHeight - measure.clientHeight + totalHeight) + \"px\";\n } else {\n this.vert.style.display = \"\";\n this.vert.firstChild.style.height = \"0\";\n }\n\n if (needsH) {\n this.horiz.style.display = \"block\";\n this.horiz.style.right = needsV ? sWidth + \"px\" : \"0\";\n this.horiz.style.left = measure.barLeft + \"px\";\n var totalWidth = measure.viewWidth - measure.barLeft - (needsV ? sWidth : 0);\n this.horiz.firstChild.style.width =\n (measure.scrollWidth - measure.clientWidth + totalWidth) + \"px\";\n } else {\n this.horiz.style.display = \"\";\n this.horiz.firstChild.style.width = \"0\";\n }\n\n if (!this.checkedZeroWidth && measure.clientHeight > 0) {\n if (sWidth == 0) this.zeroWidthHack();\n this.checkedZeroWidth = true;\n }\n\n return {right: needsV ? sWidth : 0, bottom: needsH ? sWidth : 0};\n },\n setScrollLeft: function(pos) {\n if (this.horiz.scrollLeft != pos) this.horiz.scrollLeft = pos;\n if (this.disableHoriz) this.enableZeroWidthBar(this.horiz, this.disableHoriz);\n },\n setScrollTop: function(pos) {\n if (this.vert.scrollTop != pos) this.vert.scrollTop = pos;\n if (this.disableVert) this.enableZeroWidthBar(this.vert, this.disableVert);\n },\n zeroWidthHack: function() {\n var w = mac && !mac_geMountainLion ? \"12px\" : \"18px\";\n this.horiz.style.height = this.vert.style.width = w;\n this.horiz.style.pointerEvents = this.vert.style.pointerEvents = \"none\";\n this.disableHoriz = new Delayed;\n this.disableVert = new Delayed;\n },\n enableZeroWidthBar: function(bar, delay) {\n bar.style.pointerEvents = \"auto\";\n function maybeDisable() {\n // To find out whether the scrollbar is still visible, we\n // check whether the element under the pixel in the bottom\n // left corner of the scrollbar box is the scrollbar box\n // itself (when the bar is still visible) or its filler child\n // (when the bar is hidden). If it is still visible, we keep\n // it enabled, if it's hidden, we disable pointer events.\n var box = bar.getBoundingClientRect();\n var elt = document.elementFromPoint(box.left + 1, box.bottom - 1);\n if (elt != bar) bar.style.pointerEvents = \"none\";\n else delay.set(1000, maybeDisable);\n }\n delay.set(1000, maybeDisable);\n },\n clear: function() {\n var parent = this.horiz.parentNode;\n parent.removeChild(this.horiz);\n parent.removeChild(this.vert);\n }\n }, NativeScrollbars.prototype);\n\n function NullScrollbars() {}\n\n NullScrollbars.prototype = copyObj({\n update: function() { return {bottom: 0, right: 0}; },\n setScrollLeft: function() {},\n setScrollTop: function() {},\n clear: function() {}\n }, NullScrollbars.prototype);\n\n CodeMirror.scrollbarModel = {\"native\": NativeScrollbars, \"null\": NullScrollbars};\n\n function initScrollbars(cm) {\n if (cm.display.scrollbars) {\n cm.display.scrollbars.clear();\n if (cm.display.scrollbars.addClass)\n rmClass(cm.display.wrapper, cm.display.scrollbars.addClass);\n }\n\n cm.display.scrollbars = new CodeMirror.scrollbarModel[cm.options.scrollbarStyle](function(node) {\n cm.display.wrapper.insertBefore(node, cm.display.scrollbarFiller);\n // Prevent clicks in the scrollbars from killing focus\n on(node, \"mousedown\", function() {\n if (cm.state.focused) setTimeout(function() { cm.display.input.focus(); }, 0);\n });\n node.setAttribute(\"cm-not-content\", \"true\");\n }, function(pos, axis) {\n if (axis == \"horizontal\") setScrollLeft(cm, pos);\n else setScrollTop(cm, pos);\n }, cm);\n if (cm.display.scrollbars.addClass)\n addClass(cm.display.wrapper, cm.display.scrollbars.addClass);\n }\n\n function updateScrollbars(cm, measure) {\n if (!measure) measure = measureForScrollbars(cm);\n var startWidth = cm.display.barWidth, startHeight = cm.display.barHeight;\n updateScrollbarsInner(cm, measure);\n for (var i = 0; i < 4 && startWidth != cm.display.barWidth || startHeight != cm.display.barHeight; i++) {\n if (startWidth != cm.display.barWidth && cm.options.lineWrapping)\n updateHeightsInViewport(cm);\n updateScrollbarsInner(cm, measureForScrollbars(cm));\n startWidth = cm.display.barWidth; startHeight = cm.display.barHeight;\n }\n }\n\n // Re-synchronize the fake scrollbars with the actual size of the\n // content.\n function updateScrollbarsInner(cm, measure) {\n var d = cm.display;\n var sizes = d.scrollbars.update(measure);\n\n d.sizer.style.paddingRight = (d.barWidth = sizes.right) + \"px\";\n d.sizer.style.paddingBottom = (d.barHeight = sizes.bottom) + \"px\";\n d.heightForcer.style.borderBottom = sizes.bottom + \"px solid transparent\"\n\n if (sizes.right && sizes.bottom) {\n d.scrollbarFiller.style.display = \"block\";\n d.scrollbarFiller.style.height = sizes.bottom + \"px\";\n d.scrollbarFiller.style.width = sizes.right + \"px\";\n } else d.scrollbarFiller.style.display = \"\";\n if (sizes.bottom && cm.options.coverGutterNextToScrollbar && cm.options.fixedGutter) {\n d.gutterFiller.style.display = \"block\";\n d.gutterFiller.style.height = sizes.bottom + \"px\";\n d.gutterFiller.style.width = measure.gutterWidth + \"px\";\n } else d.gutterFiller.style.display = \"\";\n }\n\n // Compute the lines that are visible in a given viewport (defaults\n // the the current scroll position). viewport may contain top,\n // height, and ensure (see op.scrollToPos) properties.\n function visibleLines(display, doc, viewport) {\n var top = viewport && viewport.top != null ? Math.max(0, viewport.top) : display.scroller.scrollTop;\n top = Math.floor(top - paddingTop(display));\n var bottom = viewport && viewport.bottom != null ? viewport.bottom : top + display.wrapper.clientHeight;\n\n var from = lineAtHeight(doc, top), to = lineAtHeight(doc, bottom);\n // Ensure is a {from: {line, ch}, to: {line, ch}} object, and\n // forces those lines into the viewport (if possible).\n if (viewport && viewport.ensure) {\n var ensureFrom = viewport.ensure.from.line, ensureTo = viewport.ensure.to.line;\n if (ensureFrom < from) {\n from = ensureFrom;\n to = lineAtHeight(doc, heightAtLine(getLine(doc, ensureFrom)) + display.wrapper.clientHeight);\n } else if (Math.min(ensureTo, doc.lastLine()) >= to) {\n from = lineAtHeight(doc, heightAtLine(getLine(doc, ensureTo)) - display.wrapper.clientHeight);\n to = ensureTo;\n }\n }\n return {from: from, to: Math.max(to, from + 1)};\n }\n\n // LINE NUMBERS\n\n // Re-align line numbers and gutter marks to compensate for\n // horizontal scrolling.\n function alignHorizontally(cm) {\n var display = cm.display, view = display.view;\n if (!display.alignWidgets && (!display.gutters.firstChild || !cm.options.fixedGutter)) return;\n var comp = compensateForHScroll(display) - display.scroller.scrollLeft + cm.doc.scrollLeft;\n var gutterW = display.gutters.offsetWidth, left = comp + \"px\";\n for (var i = 0; i < view.length; i++) if (!view[i].hidden) {\n if (cm.options.fixedGutter && view[i].gutter)\n view[i].gutter.style.left = left;\n var align = view[i].alignable;\n if (align) for (var j = 0; j < align.length; j++)\n align[j].style.left = left;\n }\n if (cm.options.fixedGutter)\n display.gutters.style.left = (comp + gutterW) + \"px\";\n }\n\n // Used to ensure that the line number gutter is still the right\n // size for the current document size. Returns true when an update\n // is needed.\n function maybeUpdateLineNumberWidth(cm) {\n if (!cm.options.lineNumbers) return false;\n var doc = cm.doc, last = lineNumberFor(cm.options, doc.first + doc.size - 1), display = cm.display;\n if (last.length != display.lineNumChars) {\n var test = display.measure.appendChild(elt(\"div\", [elt(\"div\", last)],\n \"CodeMirror-linenumber CodeMirror-gutter-elt\"));\n var innerW = test.firstChild.offsetWidth, padding = test.offsetWidth - innerW;\n display.lineGutter.style.width = \"\";\n display.lineNumInnerWidth = Math.max(innerW, display.lineGutter.offsetWidth - padding) + 1;\n display.lineNumWidth = display.lineNumInnerWidth + padding;\n display.lineNumChars = display.lineNumInnerWidth ? last.length : -1;\n display.lineGutter.style.width = display.lineNumWidth + \"px\";\n updateGutterSpace(cm);\n return true;\n }\n return false;\n }\n\n function lineNumberFor(options, i) {\n return String(options.lineNumberFormatter(i + options.firstLineNumber));\n }\n\n // Computes display.scroller.scrollLeft + display.gutters.offsetWidth,\n // but using getBoundingClientRect to get a sub-pixel-accurate\n // result.\n function compensateForHScroll(display) {\n return display.scroller.getBoundingClientRect().left - display.sizer.getBoundingClientRect().left;\n }\n\n // DISPLAY DRAWING\n\n function DisplayUpdate(cm, viewport, force) {\n var display = cm.display;\n\n this.viewport = viewport;\n // Store some values that we'll need later (but don't want to force a relayout for)\n this.visible = visibleLines(display, cm.doc, viewport);\n this.editorIsHidden = !display.wrapper.offsetWidth;\n this.wrapperHeight = display.wrapper.clientHeight;\n this.wrapperWidth = display.wrapper.clientWidth;\n this.oldDisplayWidth = displayWidth(cm);\n this.force = force;\n this.dims = getDimensions(cm);\n this.events = [];\n }\n\n DisplayUpdate.prototype.signal = function(emitter, type) {\n if (hasHandler(emitter, type))\n this.events.push(arguments);\n };\n DisplayUpdate.prototype.finish = function() {\n for (var i = 0; i < this.events.length; i++)\n signal.apply(null, this.events[i]);\n };\n\n function maybeClipScrollbars(cm) {\n var display = cm.display;\n if (!display.scrollbarsClipped && display.scroller.offsetWidth) {\n display.nativeBarWidth = display.scroller.offsetWidth - display.scroller.clientWidth;\n display.heightForcer.style.height = scrollGap(cm) + \"px\";\n display.sizer.style.marginBottom = -display.nativeBarWidth + \"px\";\n display.sizer.style.borderRightWidth = scrollGap(cm) + \"px\";\n display.scrollbarsClipped = true;\n }\n }\n\n // Does the actual updating of the line display. Bails out\n // (returning false) when there is nothing to be done and forced is\n // false.\n function updateDisplayIfNeeded(cm, update) {\n var display = cm.display, doc = cm.doc;\n\n if (update.editorIsHidden) {\n resetView(cm);\n return false;\n }\n\n // Bail out if the visible area is already rendered and nothing changed.\n if (!update.force &&\n update.visible.from >= display.viewFrom && update.visible.to <= display.viewTo &&\n (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo) &&\n display.renderedView == display.view && countDirtyView(cm) == 0)\n return false;\n\n if (maybeUpdateLineNumberWidth(cm)) {\n resetView(cm);\n update.dims = getDimensions(cm);\n }\n\n // Compute a suitable new viewport (from & to)\n var end = doc.first + doc.size;\n var from = Math.max(update.visible.from - cm.options.viewportMargin, doc.first);\n var to = Math.min(end, update.visible.to + cm.options.viewportMargin);\n if (display.viewFrom < from && from - display.viewFrom < 20) from = Math.max(doc.first, display.viewFrom);\n if (display.viewTo > to && display.viewTo - to < 20) to = Math.min(end, display.viewTo);\n if (sawCollapsedSpans) {\n from = visualLineNo(cm.doc, from);\n to = visualLineEndNo(cm.doc, to);\n }\n\n var different = from != display.viewFrom || to != display.viewTo ||\n display.lastWrapHeight != update.wrapperHeight || display.lastWrapWidth != update.wrapperWidth;\n adjustView(cm, from, to);\n\n display.viewOffset = heightAtLine(getLine(cm.doc, display.viewFrom));\n // Position the mover div to align with the current scroll position\n cm.display.mover.style.top = display.viewOffset + \"px\";\n\n var toUpdate = countDirtyView(cm);\n if (!different && toUpdate == 0 && !update.force && display.renderedView == display.view &&\n (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo))\n return false;\n\n // For big changes, we hide the enclosing element during the\n // update, since that speeds up the operations on most browsers.\n var focused = activeElt();\n if (toUpdate > 4) display.lineDiv.style.display = \"none\";\n patchDisplay(cm, display.updateLineNumbers, update.dims);\n if (toUpdate > 4) display.lineDiv.style.display = \"\";\n display.renderedView = display.view;\n // There might have been a widget with a focused element that got\n // hidden or updated, if so re-focus it.\n if (focused && activeElt() != focused && focused.offsetHeight) focused.focus();\n\n // Prevent selection and cursors from interfering with the scroll\n // width and height.\n removeChildren(display.cursorDiv);\n removeChildren(display.selectionDiv);\n display.gutters.style.height = display.sizer.style.minHeight = 0;\n\n if (different) {\n display.lastWrapHeight = update.wrapperHeight;\n display.lastWrapWidth = update.wrapperWidth;\n startWorker(cm, 400);\n }\n\n display.updateLineNumbers = null;\n\n return true;\n }\n\n function postUpdateDisplay(cm, update) {\n var viewport = update.viewport;\n\n for (var first = true;; first = false) {\n if (!first || !cm.options.lineWrapping || update.oldDisplayWidth == displayWidth(cm)) {\n // Clip forced viewport to actual scrollable area.\n if (viewport && viewport.top != null)\n viewport = {top: Math.min(cm.doc.height + paddingVert(cm.display) - displayHeight(cm), viewport.top)};\n // Updated line heights might result in the drawn area not\n // actually covering the viewport. Keep looping until it does.\n update.visible = visibleLines(cm.display, cm.doc, viewport);\n if (update.visible.from >= cm.display.viewFrom && update.visible.to <= cm.display.viewTo)\n break;\n }\n if (!updateDisplayIfNeeded(cm, update)) break;\n updateHeightsInViewport(cm);\n var barMeasure = measureForScrollbars(cm);\n updateSelection(cm);\n updateScrollbars(cm, barMeasure);\n setDocumentHeight(cm, barMeasure);\n }\n\n update.signal(cm, \"update\", cm);\n if (cm.display.viewFrom != cm.display.reportedViewFrom || cm.display.viewTo != cm.display.reportedViewTo) {\n update.signal(cm, \"viewportChange\", cm, cm.display.viewFrom, cm.display.viewTo);\n cm.display.reportedViewFrom = cm.display.viewFrom; cm.display.reportedViewTo = cm.display.viewTo;\n }\n }\n\n function updateDisplaySimple(cm, viewport) {\n var update = new DisplayUpdate(cm, viewport);\n if (updateDisplayIfNeeded(cm, update)) {\n updateHeightsInViewport(cm);\n postUpdateDisplay(cm, update);\n var barMeasure = measureForScrollbars(cm);\n updateSelection(cm);\n updateScrollbars(cm, barMeasure);\n setDocumentHeight(cm, barMeasure);\n update.finish();\n }\n }\n\n function setDocumentHeight(cm, measure) {\n cm.display.sizer.style.minHeight = measure.docHeight + \"px\";\n cm.display.heightForcer.style.top = measure.docHeight + \"px\";\n cm.display.gutters.style.height = (measure.docHeight + cm.display.barHeight + scrollGap(cm)) + \"px\";\n }\n\n // Read the actual heights of the rendered lines, and update their\n // stored heights to match.\n function updateHeightsInViewport(cm) {\n var display = cm.display;\n var prevBottom = display.lineDiv.offsetTop;\n for (var i = 0; i < display.view.length; i++) {\n var cur = display.view[i], height;\n if (cur.hidden) continue;\n if (ie && ie_version < 8) {\n var bot = cur.node.offsetTop + cur.node.offsetHeight;\n height = bot - prevBottom;\n prevBottom = bot;\n } else {\n var box = cur.node.getBoundingClientRect();\n height = box.bottom - box.top;\n }\n var diff = cur.line.height - height;\n if (height < 2) height = textHeight(display);\n if (diff > .001 || diff < -.001) {\n updateLineHeight(cur.line, height);\n updateWidgetHeight(cur.line);\n if (cur.rest) for (var j = 0; j < cur.rest.length; j++)\n updateWidgetHeight(cur.rest[j]);\n }\n }\n }\n\n // Read and store the height of line widgets associated with the\n // given line.\n function updateWidgetHeight(line) {\n if (line.widgets) for (var i = 0; i < line.widgets.length; ++i)\n line.widgets[i].height = line.widgets[i].node.parentNode.offsetHeight;\n }\n\n // Do a bulk-read of the DOM positions and sizes needed to draw the\n // view, so that we don't interleave reading and writing to the DOM.\n function getDimensions(cm) {\n var d = cm.display, left = {}, width = {};\n var gutterLeft = d.gutters.clientLeft;\n for (var n = d.gutters.firstChild, i = 0; n; n = n.nextSibling, ++i) {\n left[cm.options.gutters[i]] = n.offsetLeft + n.clientLeft + gutterLeft;\n width[cm.options.gutters[i]] = n.clientWidth;\n }\n return {fixedPos: compensateForHScroll(d),\n gutterTotalWidth: d.gutters.offsetWidth,\n gutterLeft: left,\n gutterWidth: width,\n wrapperWidth: d.wrapper.clientWidth};\n }\n\n // Sync the actual display DOM structure with display.view, removing\n // nodes for lines that are no longer in view, and creating the ones\n // that are not there yet, and updating the ones that are out of\n // date.\n function patchDisplay(cm, updateNumbersFrom, dims) {\n var display = cm.display, lineNumbers = cm.options.lineNumbers;\n var container = display.lineDiv, cur = container.firstChild;\n\n function rm(node) {\n var next = node.nextSibling;\n // Works around a throw-scroll bug in OS X Webkit\n if (webkit && mac && cm.display.currentWheelTarget == node)\n node.style.display = \"none\";\n else\n node.parentNode.removeChild(node);\n return next;\n }\n\n var view = display.view, lineN = display.viewFrom;\n // Loop over the elements in the view, syncing cur (the DOM nodes\n // in display.lineDiv) with the view as we go.\n for (var i = 0; i < view.length; i++) {\n var lineView = view[i];\n if (lineView.hidden) {\n } else if (!lineView.node || lineView.node.parentNode != container) { // Not drawn yet\n var node = buildLineElement(cm, lineView, lineN, dims);\n container.insertBefore(node, cur);\n } else { // Already drawn\n while (cur != lineView.node) cur = rm(cur);\n var updateNumber = lineNumbers && updateNumbersFrom != null &&\n updateNumbersFrom <= lineN && lineView.lineNumber;\n if (lineView.changes) {\n if (indexOf(lineView.changes, \"gutter\") > -1) updateNumber = false;\n updateLineForChanges(cm, lineView, lineN, dims);\n }\n if (updateNumber) {\n removeChildren(lineView.lineNumber);\n lineView.lineNumber.appendChild(document.createTextNode(lineNumberFor(cm.options, lineN)));\n }\n cur = lineView.node.nextSibling;\n }\n lineN += lineView.size;\n }\n while (cur) cur = rm(cur);\n }\n\n // When an aspect of a line changes, a string is added to\n // lineView.changes. This updates the relevant part of the line's\n // DOM structure.\n function updateLineForChanges(cm, lineView, lineN, dims) {\n for (var j = 0; j < lineView.changes.length; j++) {\n var type = lineView.changes[j];\n if (type == \"text\") updateLineText(cm, lineView);\n else if (type == \"gutter\") updateLineGutter(cm, lineView, lineN, dims);\n else if (type == \"class\") updateLineClasses(lineView);\n else if (type == \"widget\") updateLineWidgets(cm, lineView, dims);\n }\n lineView.changes = null;\n }\n\n // Lines with gutter elements, widgets or a background class need to\n // be wrapped, and have the extra elements added to the wrapper div\n function ensureLineWrapped(lineView) {\n if (lineView.node == lineView.text) {\n lineView.node = elt(\"div\", null, null, \"position: relative\");\n if (lineView.text.parentNode)\n lineView.text.parentNode.replaceChild(lineView.node, lineView.text);\n lineView.node.appendChild(lineView.text);\n if (ie && ie_version < 8) lineView.node.style.zIndex = 2;\n }\n return lineView.node;\n }\n\n function updateLineBackground(lineView) {\n var cls = lineView.bgClass ? lineView.bgClass + \" \" + (lineView.line.bgClass || \"\") : lineView.line.bgClass;\n if (cls) cls += \" CodeMirror-linebackground\";\n if (lineView.background) {\n if (cls) lineView.background.className = cls;\n else { lineView.background.parentNode.removeChild(lineView.background); lineView.background = null; }\n } else if (cls) {\n var wrap = ensureLineWrapped(lineView);\n lineView.background = wrap.insertBefore(elt(\"div\", null, cls), wrap.firstChild);\n }\n }\n\n // Wrapper around buildLineContent which will reuse the structure\n // in display.externalMeasured when possible.\n function getLineContent(cm, lineView) {\n var ext = cm.display.externalMeasured;\n if (ext && ext.line == lineView.line) {\n cm.display.externalMeasured = null;\n lineView.measure = ext.measure;\n return ext.built;\n }\n return buildLineContent(cm, lineView);\n }\n\n // Redraw the line's text. Interacts with the background and text\n // classes because the mode may output tokens that influence these\n // classes.\n function updateLineText(cm, lineView) {\n var cls = lineView.text.className;\n var built = getLineContent(cm, lineView);\n if (lineView.text == lineView.node) lineView.node = built.pre;\n lineView.text.parentNode.replaceChild(built.pre, lineView.text);\n lineView.text = built.pre;\n if (built.bgClass != lineView.bgClass || built.textClass != lineView.textClass) {\n lineView.bgClass = built.bgClass;\n lineView.textClass = built.textClass;\n updateLineClasses(lineView);\n } else if (cls) {\n lineView.text.className = cls;\n }\n }\n\n function updateLineClasses(lineView) {\n updateLineBackground(lineView);\n if (lineView.line.wrapClass)\n ensureLineWrapped(lineView).className = lineView.line.wrapClass;\n else if (lineView.node != lineView.text)\n lineView.node.className = \"\";\n var textClass = lineView.textClass ? lineView.textClass + \" \" + (lineView.line.textClass || \"\") : lineView.line.textClass;\n lineView.text.className = textClass || \"\";\n }\n\n function updateLineGutter(cm, lineView, lineN, dims) {\n if (lineView.gutter) {\n lineView.node.removeChild(lineView.gutter);\n lineView.gutter = null;\n }\n if (lineView.gutterBackground) {\n lineView.node.removeChild(lineView.gutterBackground);\n lineView.gutterBackground = null;\n }\n if (lineView.line.gutterClass) {\n var wrap = ensureLineWrapped(lineView);\n lineView.gutterBackground = elt(\"div\", null, \"CodeMirror-gutter-background \" + lineView.line.gutterClass,\n \"left: \" + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) +\n \"px; width: \" + dims.gutterTotalWidth + \"px\");\n wrap.insertBefore(lineView.gutterBackground, lineView.text);\n }\n var markers = lineView.line.gutterMarkers;\n if (cm.options.lineNumbers || markers) {\n var wrap = ensureLineWrapped(lineView);\n var gutterWrap = lineView.gutter = elt(\"div\", null, \"CodeMirror-gutter-wrapper\", \"left: \" +\n (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + \"px\");\n cm.display.input.setUneditable(gutterWrap);\n wrap.insertBefore(gutterWrap, lineView.text);\n if (lineView.line.gutterClass)\n gutterWrap.className += \" \" + lineView.line.gutterClass;\n if (cm.options.lineNumbers && (!markers || !markers[\"CodeMirror-linenumbers\"]))\n lineView.lineNumber = gutterWrap.appendChild(\n elt(\"div\", lineNumberFor(cm.options, lineN),\n \"CodeMirror-linenumber CodeMirror-gutter-elt\",\n \"left: \" + dims.gutterLeft[\"CodeMirror-linenumbers\"] + \"px; width: \"\n + cm.display.lineNumInnerWidth + \"px\"));\n if (markers) for (var k = 0; k < cm.options.gutters.length; ++k) {\n var id = cm.options.gutters[k], found = markers.hasOwnProperty(id) && markers[id];\n if (found)\n gutterWrap.appendChild(elt(\"div\", [found], \"CodeMirror-gutter-elt\", \"left: \" +\n dims.gutterLeft[id] + \"px; width: \" + dims.gutterWidth[id] + \"px\"));\n }\n }\n }\n\n function updateLineWidgets(cm, lineView, dims) {\n if (lineView.alignable) lineView.alignable = null;\n for (var node = lineView.node.firstChild, next; node; node = next) {\n var next = node.nextSibling;\n if (node.className == \"CodeMirror-linewidget\")\n lineView.node.removeChild(node);\n }\n insertLineWidgets(cm, lineView, dims);\n }\n\n // Build a line's DOM representation from scratch\n function buildLineElement(cm, lineView, lineN, dims) {\n var built = getLineContent(cm, lineView);\n lineView.text = lineView.node = built.pre;\n if (built.bgClass) lineView.bgClass = built.bgClass;\n if (built.textClass) lineView.textClass = built.textClass;\n\n updateLineClasses(lineView);\n updateLineGutter(cm, lineView, lineN, dims);\n insertLineWidgets(cm, lineView, dims);\n return lineView.node;\n }\n\n // A lineView may contain multiple logical lines (when merged by\n // collapsed spans). The widgets for all of them need to be drawn.\n function insertLineWidgets(cm, lineView, dims) {\n insertLineWidgetsFor(cm, lineView.line, lineView, dims, true);\n if (lineView.rest) for (var i = 0; i < lineView.rest.length; i++)\n insertLineWidgetsFor(cm, lineView.rest[i], lineView, dims, false);\n }\n\n function insertLineWidgetsFor(cm, line, lineView, dims, allowAbove) {\n if (!line.widgets) return;\n var wrap = ensureLineWrapped(lineView);\n for (var i = 0, ws = line.widgets; i < ws.length; ++i) {\n var widget = ws[i], node = elt(\"div\", [widget.node], \"CodeMirror-linewidget\");\n if (!widget.handleMouseEvents) node.setAttribute(\"cm-ignore-events\", \"true\");\n positionLineWidget(widget, node, lineView, dims);\n cm.display.input.setUneditable(node);\n if (allowAbove && widget.above)\n wrap.insertBefore(node, lineView.gutter || lineView.text);\n else\n wrap.appendChild(node);\n signalLater(widget, \"redraw\");\n }\n }\n\n function positionLineWidget(widget, node, lineView, dims) {\n if (widget.noHScroll) {\n (lineView.alignable || (lineView.alignable = [])).push(node);\n var width = dims.wrapperWidth;\n node.style.left = dims.fixedPos + \"px\";\n if (!widget.coverGutter) {\n width -= dims.gutterTotalWidth;\n node.style.paddingLeft = dims.gutterTotalWidth + \"px\";\n }\n node.style.width = width + \"px\";\n }\n if (widget.coverGutter) {\n node.style.zIndex = 5;\n node.style.position = \"relative\";\n if (!widget.noHScroll) node.style.marginLeft = -dims.gutterTotalWidth + \"px\";\n }\n }\n\n // POSITION OBJECT\n\n // A Pos instance represents a position within the text.\n var Pos = CodeMirror.Pos = function(line, ch) {\n if (!(this instanceof Pos)) return new Pos(line, ch);\n this.line = line; this.ch = ch;\n };\n\n // Compare two positions, return 0 if they are the same, a negative\n // number when a is less, and a positive number otherwise.\n var cmp = CodeMirror.cmpPos = function(a, b) { return a.line - b.line || a.ch - b.ch; };\n\n function copyPos(x) {return Pos(x.line, x.ch);}\n function maxPos(a, b) { return cmp(a, b) < 0 ? b : a; }\n function minPos(a, b) { return cmp(a, b) < 0 ? a : b; }\n\n // INPUT HANDLING\n\n function ensureFocus(cm) {\n if (!cm.state.focused) { cm.display.input.focus(); onFocus(cm); }\n }\n\n // This will be set to a {lineWise: bool, text: [string]} object, so\n // that, when pasting, we know what kind of selections the copied\n // text was made out of.\n var lastCopied = null;\n\n function applyTextInput(cm, inserted, deleted, sel, origin) {\n var doc = cm.doc;\n cm.display.shift = false;\n if (!sel) sel = doc.sel;\n\n var paste = cm.state.pasteIncoming || origin == \"paste\";\n var textLines = doc.splitLines(inserted), multiPaste = null\n // When pasing N lines into N selections, insert one line per selection\n if (paste && sel.ranges.length > 1) {\n if (lastCopied && lastCopied.text.join(\"\\n\") == inserted) {\n if (sel.ranges.length % lastCopied.text.length == 0) {\n multiPaste = [];\n for (var i = 0; i < lastCopied.text.length; i++)\n multiPaste.push(doc.splitLines(lastCopied.text[i]));\n }\n } else if (textLines.length == sel.ranges.length) {\n multiPaste = map(textLines, function(l) { return [l]; });\n }\n }\n\n // Normal behavior is to insert the new text into every selection\n for (var i = sel.ranges.length - 1; i >= 0; i--) {\n var range = sel.ranges[i];\n var from = range.from(), to = range.to();\n if (range.empty()) {\n if (deleted && deleted > 0) // Handle deletion\n from = Pos(from.line, from.ch - deleted);\n else if (cm.state.overwrite && !paste) // Handle overwrite\n to = Pos(to.line, Math.min(getLine(doc, to.line).text.length, to.ch + lst(textLines).length));\n else if (lastCopied && lastCopied.lineWise && lastCopied.text.join(\"\\n\") == inserted)\n from = to = Pos(from.line, 0)\n }\n var updateInput = cm.curOp.updateInput;\n var changeEvent = {from: from, to: to, text: multiPaste ? multiPaste[i % multiPaste.length] : textLines,\n origin: origin || (paste ? \"paste\" : cm.state.cutIncoming ? \"cut\" : \"+input\")};\n makeChange(cm.doc, changeEvent);\n signalLater(cm, \"inputRead\", cm, changeEvent);\n }\n if (inserted && !paste)\n triggerElectric(cm, inserted);\n\n ensureCursorVisible(cm);\n cm.curOp.updateInput = updateInput;\n cm.curOp.typing = true;\n cm.state.pasteIncoming = cm.state.cutIncoming = false;\n }\n\n function handlePaste(e, cm) {\n var pasted = e.clipboardData && e.clipboardData.getData(\"text/plain\");\n if (pasted) {\n e.preventDefault();\n if (!cm.isReadOnly() && !cm.options.disableInput)\n runInOp(cm, function() { applyTextInput(cm, pasted, 0, null, \"paste\"); });\n return true;\n }\n }\n\n function triggerElectric(cm, inserted) {\n // When an 'electric' character is inserted, immediately trigger a reindent\n if (!cm.options.electricChars || !cm.options.smartIndent) return;\n var sel = cm.doc.sel;\n\n for (var i = sel.ranges.length - 1; i >= 0; i--) {\n var range = sel.ranges[i];\n if (range.head.ch > 100 || (i && sel.ranges[i - 1].head.line == range.head.line)) continue;\n var mode = cm.getModeAt(range.head);\n var indented = false;\n if (mode.electricChars) {\n for (var j = 0; j < mode.electricChars.length; j++)\n if (inserted.indexOf(mode.electricChars.charAt(j)) > -1) {\n indented = indentLine(cm, range.head.line, \"smart\");\n break;\n }\n } else if (mode.electricInput) {\n if (mode.electricInput.test(getLine(cm.doc, range.head.line).text.slice(0, range.head.ch)))\n indented = indentLine(cm, range.head.line, \"smart\");\n }\n if (indented) signalLater(cm, \"electricInput\", cm, range.head.line);\n }\n }\n\n function copyableRanges(cm) {\n var text = [], ranges = [];\n for (var i = 0; i < cm.doc.sel.ranges.length; i++) {\n var line = cm.doc.sel.ranges[i].head.line;\n var lineRange = {anchor: Pos(line, 0), head: Pos(line + 1, 0)};\n ranges.push(lineRange);\n text.push(cm.getRange(lineRange.anchor, lineRange.head));\n }\n return {text: text, ranges: ranges};\n }\n\n function disableBrowserMagic(field) {\n field.setAttribute(\"autocorrect\", \"off\");\n field.setAttribute(\"autocapitalize\", \"off\");\n field.setAttribute(\"spellcheck\", \"false\");\n }\n\n // TEXTAREA INPUT STYLE\n\n function TextareaInput(cm) {\n this.cm = cm;\n // See input.poll and input.reset\n this.prevInput = \"\";\n\n // Flag that indicates whether we expect input to appear real soon\n // now (after some event like 'keypress' or 'input') and are\n // polling intensively.\n this.pollingFast = false;\n // Self-resetting timeout for the poller\n this.polling = new Delayed();\n // Tracks when input.reset has punted to just putting a short\n // string into the textarea instead of the full selection.\n this.inaccurateSelection = false;\n // Used to work around IE issue with selection being forgotten when focus moves away from textarea\n this.hasSelection = false;\n this.composing = null;\n };\n\n function hiddenTextarea() {\n var te = elt(\"textarea\", null, null, \"position: absolute; bottom: -1em; padding: 0; width: 1px; height: 1em; outline: none\");\n var div = elt(\"div\", [te], null, \"overflow: hidden; position: relative; width: 3px; height: 0px;\");\n // The textarea is kept positioned near the cursor to prevent the\n // fact that it'll be scrolled into view on input from scrolling\n // our fake cursor out of view. On webkit, when wrap=off, paste is\n // very slow. So make the area wide instead.\n if (webkit) te.style.width = \"1000px\";\n else te.setAttribute(\"wrap\", \"off\");\n // If border: 0; -- iOS fails to open keyboard (issue #1287)\n if (ios) te.style.border = \"1px solid black\";\n disableBrowserMagic(te);\n return div;\n }\n\n TextareaInput.prototype = copyObj({\n init: function(display) {\n var input = this, cm = this.cm;\n\n // Wraps and hides input textarea\n var div = this.wrapper = hiddenTextarea();\n // The semihidden textarea that is focused when the editor is\n // focused, and receives input.\n var te = this.textarea = div.firstChild;\n display.wrapper.insertBefore(div, display.wrapper.firstChild);\n\n // Needed to hide big blue blinking cursor on Mobile Safari (doesn't seem to work in iOS 8 anymore)\n if (ios) te.style.width = \"0px\";\n\n on(te, \"input\", function() {\n if (ie && ie_version >= 9 && input.hasSelection) input.hasSelection = null;\n input.poll();\n });\n\n on(te, \"paste\", function(e) {\n if (signalDOMEvent(cm, e) || handlePaste(e, cm)) return\n\n cm.state.pasteIncoming = true;\n input.fastPoll();\n });\n\n function prepareCopyCut(e) {\n if (signalDOMEvent(cm, e)) return\n if (cm.somethingSelected()) {\n lastCopied = {lineWise: false, text: cm.getSelections()};\n if (input.inaccurateSelection) {\n input.prevInput = \"\";\n input.inaccurateSelection = false;\n te.value = lastCopied.text.join(\"\\n\");\n selectInput(te);\n }\n } else if (!cm.options.lineWiseCopyCut) {\n return;\n } else {\n var ranges = copyableRanges(cm);\n lastCopied = {lineWise: true, text: ranges.text};\n if (e.type == \"cut\") {\n cm.setSelections(ranges.ranges, null, sel_dontScroll);\n } else {\n input.prevInput = \"\";\n te.value = ranges.text.join(\"\\n\");\n selectInput(te);\n }\n }\n if (e.type == \"cut\") cm.state.cutIncoming = true;\n }\n on(te, \"cut\", prepareCopyCut);\n on(te, \"copy\", prepareCopyCut);\n\n on(display.scroller, \"paste\", function(e) {\n if (eventInWidget(display, e) || signalDOMEvent(cm, e)) return;\n cm.state.pasteIncoming = true;\n input.focus();\n });\n\n // Prevent normal selection in the editor (we handle our own)\n on(display.lineSpace, \"selectstart\", function(e) {\n if (!eventInWidget(display, e)) e_preventDefault(e);\n });\n\n on(te, \"compositionstart\", function() {\n var start = cm.getCursor(\"from\");\n if (input.composing) input.composing.range.clear()\n input.composing = {\n start: start,\n range: cm.markText(start, cm.getCursor(\"to\"), {className: \"CodeMirror-composing\"})\n };\n });\n on(te, \"compositionend\", function() {\n if (input.composing) {\n input.poll();\n input.composing.range.clear();\n input.composing = null;\n }\n });\n },\n\n prepareSelection: function() {\n // Redraw the selection and/or cursor\n var cm = this.cm, display = cm.display, doc = cm.doc;\n var result = prepareSelection(cm);\n\n // Move the hidden textarea near the cursor to prevent scrolling artifacts\n if (cm.options.moveInputWithCursor) {\n var headPos = cursorCoords(cm, doc.sel.primary().head, \"div\");\n var wrapOff = display.wrapper.getBoundingClientRect(), lineOff = display.lineDiv.getBoundingClientRect();\n result.teTop = Math.max(0, Math.min(display.wrapper.clientHeight - 10,\n headPos.top + lineOff.top - wrapOff.top));\n result.teLeft = Math.max(0, Math.min(display.wrapper.clientWidth - 10,\n headPos.left + lineOff.left - wrapOff.left));\n }\n\n return result;\n },\n\n showSelection: function(drawn) {\n var cm = this.cm, display = cm.display;\n removeChildrenAndAdd(display.cursorDiv, drawn.cursors);\n removeChildrenAndAdd(display.selectionDiv, drawn.selection);\n if (drawn.teTop != null) {\n this.wrapper.style.top = drawn.teTop + \"px\";\n this.wrapper.style.left = drawn.teLeft + \"px\";\n }\n },\n\n // Reset the input to correspond to the selection (or to be empty,\n // when not typing and nothing is selected)\n reset: function(typing) {\n if (this.contextMenuPending) return;\n var minimal, selected, cm = this.cm, doc = cm.doc;\n if (cm.somethingSelected()) {\n this.prevInput = \"\";\n var range = doc.sel.primary();\n minimal = hasCopyEvent &&\n (range.to().line - range.from().line > 100 || (selected = cm.getSelection()).length > 1000);\n var content = minimal ? \"-\" : selected || cm.getSelection();\n this.textarea.value = content;\n if (cm.state.focused) selectInput(this.textarea);\n if (ie && ie_version >= 9) this.hasSelection = content;\n } else if (!typing) {\n this.prevInput = this.textarea.value = \"\";\n if (ie && ie_version >= 9) this.hasSelection = null;\n }\n this.inaccurateSelection = minimal;\n },\n\n getField: function() { return this.textarea; },\n\n supportsTouch: function() { return false; },\n\n focus: function() {\n if (this.cm.options.readOnly != \"nocursor\" && (!mobile || activeElt() != this.textarea)) {\n try { this.textarea.focus(); }\n catch (e) {} // IE8 will throw if the textarea is display: none or not in DOM\n }\n },\n\n blur: function() { this.textarea.blur(); },\n\n resetPosition: function() {\n this.wrapper.style.top = this.wrapper.style.left = 0;\n },\n\n receivedFocus: function() { this.slowPoll(); },\n\n // Poll for input changes, using the normal rate of polling. This\n // runs as long as the editor is focused.\n slowPoll: function() {\n var input = this;\n if (input.pollingFast) return;\n input.polling.set(this.cm.options.pollInterval, function() {\n input.poll();\n if (input.cm.state.focused) input.slowPoll();\n });\n },\n\n // When an event has just come in that is likely to add or change\n // something in the input textarea, we poll faster, to ensure that\n // the change appears on the screen quickly.\n fastPoll: function() {\n var missed = false, input = this;\n input.pollingFast = true;\n function p() {\n var changed = input.poll();\n if (!changed && !missed) {missed = true; input.polling.set(60, p);}\n else {input.pollingFast = false; input.slowPoll();}\n }\n input.polling.set(20, p);\n },\n\n // Read input from the textarea, and update the document to match.\n // When something is selected, it is present in the textarea, and\n // selected (unless it is huge, in which case a placeholder is\n // used). When nothing is selected, the cursor sits after previously\n // seen text (can be empty), which is stored in prevInput (we must\n // not reset the textarea when typing, because that breaks IME).\n poll: function() {\n var cm = this.cm, input = this.textarea, prevInput = this.prevInput;\n // Since this is called a *lot*, try to bail out as cheaply as\n // possible when it is clear that nothing happened. hasSelection\n // will be the case when there is a lot of text in the textarea,\n // in which case reading its value would be expensive.\n if (this.contextMenuPending || !cm.state.focused ||\n (hasSelection(input) && !prevInput && !this.composing) ||\n cm.isReadOnly() || cm.options.disableInput || cm.state.keySeq)\n return false;\n\n var text = input.value;\n // If nothing changed, bail.\n if (text == prevInput && !cm.somethingSelected()) return false;\n // Work around nonsensical selection resetting in IE9/10, and\n // inexplicable appearance of private area unicode characters on\n // some key combos in Mac (#2689).\n if (ie && ie_version >= 9 && this.hasSelection === text ||\n mac && /[\\uf700-\\uf7ff]/.test(text)) {\n cm.display.input.reset();\n return false;\n }\n\n if (cm.doc.sel == cm.display.selForContextMenu) {\n var first = text.charCodeAt(0);\n if (first == 0x200b && !prevInput) prevInput = \"\\u200b\";\n if (first == 0x21da) { this.reset(); return this.cm.execCommand(\"undo\"); }\n }\n // Find the part of the input that is actually new\n var same = 0, l = Math.min(prevInput.length, text.length);\n while (same < l && prevInput.charCodeAt(same) == text.charCodeAt(same)) ++same;\n\n var self = this;\n runInOp(cm, function() {\n applyTextInput(cm, text.slice(same), prevInput.length - same,\n null, self.composing ? \"*compose\" : null);\n\n // Don't leave long text in the textarea, since it makes further polling slow\n if (text.length > 1000 || text.indexOf(\"\\n\") > -1) input.value = self.prevInput = \"\";\n else self.prevInput = text;\n\n if (self.composing) {\n self.composing.range.clear();\n self.composing.range = cm.markText(self.composing.start, cm.getCursor(\"to\"),\n {className: \"CodeMirror-composing\"});\n }\n });\n return true;\n },\n\n ensurePolled: function() {\n if (this.pollingFast && this.poll()) this.pollingFast = false;\n },\n\n onKeyPress: function() {\n if (ie && ie_version >= 9) this.hasSelection = null;\n this.fastPoll();\n },\n\n onContextMenu: function(e) {\n var input = this, cm = input.cm, display = cm.display, te = input.textarea;\n var pos = posFromMouse(cm, e), scrollPos = display.scroller.scrollTop;\n if (!pos || presto) return; // Opera is difficult.\n\n // Reset the current text selection only if the click is done outside of the selection\n // and 'resetSelectionOnContextMenu' option is true.\n var reset = cm.options.resetSelectionOnContextMenu;\n if (reset && cm.doc.sel.contains(pos) == -1)\n operation(cm, setSelection)(cm.doc, simpleSelection(pos), sel_dontScroll);\n\n var oldCSS = te.style.cssText, oldWrapperCSS = input.wrapper.style.cssText;\n input.wrapper.style.cssText = \"position: absolute\"\n var wrapperBox = input.wrapper.getBoundingClientRect()\n te.style.cssText = \"position: absolute; width: 30px; height: 30px; top: \" + (e.clientY - wrapperBox.top - 5) +\n \"px; left: \" + (e.clientX - wrapperBox.left - 5) + \"px; z-index: 1000; background: \" +\n (ie ? \"rgba(255, 255, 255, .05)\" : \"transparent\") +\n \"; outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);\";\n if (webkit) var oldScrollY = window.scrollY; // Work around Chrome issue (#2712)\n display.input.focus();\n if (webkit) window.scrollTo(null, oldScrollY);\n display.input.reset();\n // Adds \"Select all\" to context menu in FF\n if (!cm.somethingSelected()) te.value = input.prevInput = \" \";\n input.contextMenuPending = true;\n display.selForContextMenu = cm.doc.sel;\n clearTimeout(display.detectingSelectAll);\n\n // Select-all will be greyed out if there's nothing to select, so\n // this adds a zero-width space so that we can later check whether\n // it got selected.\n function prepareSelectAllHack() {\n if (te.selectionStart != null) {\n var selected = cm.somethingSelected();\n var extval = \"\\u200b\" + (selected ? te.value : \"\");\n te.value = \"\\u21da\"; // Used to catch context-menu undo\n te.value = extval;\n input.prevInput = selected ? \"\" : \"\\u200b\";\n te.selectionStart = 1; te.selectionEnd = extval.length;\n // Re-set this, in case some other handler touched the\n // selection in the meantime.\n display.selForContextMenu = cm.doc.sel;\n }\n }\n function rehide() {\n input.contextMenuPending = false;\n input.wrapper.style.cssText = oldWrapperCSS\n te.style.cssText = oldCSS;\n if (ie && ie_version < 9) display.scrollbars.setScrollTop(display.scroller.scrollTop = scrollPos);\n\n // Try to detect the user choosing select-all\n if (te.selectionStart != null) {\n if (!ie || (ie && ie_version < 9)) prepareSelectAllHack();\n var i = 0, poll = function() {\n if (display.selForContextMenu == cm.doc.sel && te.selectionStart == 0 &&\n te.selectionEnd > 0 && input.prevInput == \"\\u200b\")\n operation(cm, commands.selectAll)(cm);\n else if (i++ < 10) display.detectingSelectAll = setTimeout(poll, 500);\n else display.input.reset();\n };\n display.detectingSelectAll = setTimeout(poll, 200);\n }\n }\n\n if (ie && ie_version >= 9) prepareSelectAllHack();\n if (captureRightClick) {\n e_stop(e);\n var mouseup = function() {\n off(window, \"mouseup\", mouseup);\n setTimeout(rehide, 20);\n };\n on(window, \"mouseup\", mouseup);\n } else {\n setTimeout(rehide, 50);\n }\n },\n\n readOnlyChanged: function(val) {\n if (!val) this.reset();\n },\n\n setUneditable: nothing,\n\n needsContentAttribute: false\n }, TextareaInput.prototype);\n\n // CONTENTEDITABLE INPUT STYLE\n\n function ContentEditableInput(cm) {\n this.cm = cm;\n this.lastAnchorNode = this.lastAnchorOffset = this.lastFocusNode = this.lastFocusOffset = null;\n this.polling = new Delayed();\n this.gracePeriod = false;\n }\n\n ContentEditableInput.prototype = copyObj({\n init: function(display) {\n var input = this, cm = input.cm;\n var div = input.div = display.lineDiv;\n disableBrowserMagic(div);\n\n on(div, \"paste\", function(e) {\n if (!signalDOMEvent(cm, e)) handlePaste(e, cm);\n })\n\n on(div, \"compositionstart\", function(e) {\n var data = e.data;\n input.composing = {sel: cm.doc.sel, data: data, startData: data};\n if (!data) return;\n var prim = cm.doc.sel.primary();\n var line = cm.getLine(prim.head.line);\n var found = line.indexOf(data, Math.max(0, prim.head.ch - data.length));\n if (found > -1 && found <= prim.head.ch)\n input.composing.sel = simpleSelection(Pos(prim.head.line, found),\n Pos(prim.head.line, found + data.length));\n });\n on(div, \"compositionupdate\", function(e) {\n input.composing.data = e.data;\n });\n on(div, \"compositionend\", function(e) {\n var ours = input.composing;\n if (!ours) return;\n if (e.data != ours.startData && !/\\u200b/.test(e.data))\n ours.data = e.data;\n // Need a small delay to prevent other code (input event,\n // selection polling) from doing damage when fired right after\n // compositionend.\n setTimeout(function() {\n if (!ours.handled)\n input.applyComposition(ours);\n if (input.composing == ours)\n input.composing = null;\n }, 50);\n });\n\n on(div, \"touchstart\", function() {\n input.forceCompositionEnd();\n });\n\n on(div, \"input\", function() {\n if (input.composing) return;\n if (cm.isReadOnly() || !input.pollContent())\n runInOp(input.cm, function() {regChange(cm);});\n });\n\n function onCopyCut(e) {\n if (signalDOMEvent(cm, e)) return\n if (cm.somethingSelected()) {\n lastCopied = {lineWise: false, text: cm.getSelections()};\n if (e.type == \"cut\") cm.replaceSelection(\"\", null, \"cut\");\n } else if (!cm.options.lineWiseCopyCut) {\n return;\n } else {\n var ranges = copyableRanges(cm);\n lastCopied = {lineWise: true, text: ranges.text};\n if (e.type == \"cut\") {\n cm.operation(function() {\n cm.setSelections(ranges.ranges, 0, sel_dontScroll);\n cm.replaceSelection(\"\", null, \"cut\");\n });\n }\n }\n // iOS exposes the clipboard API, but seems to discard content inserted into it\n if (e.clipboardData && !ios) {\n e.preventDefault();\n e.clipboardData.clearData();\n e.clipboardData.setData(\"text/plain\", lastCopied.text.join(\"\\n\"));\n } else {\n // Old-fashioned briefly-focus-a-textarea hack\n var kludge = hiddenTextarea(), te = kludge.firstChild;\n cm.display.lineSpace.insertBefore(kludge, cm.display.lineSpace.firstChild);\n te.value = lastCopied.text.join(\"\\n\");\n var hadFocus = document.activeElement;\n selectInput(te);\n setTimeout(function() {\n cm.display.lineSpace.removeChild(kludge);\n hadFocus.focus();\n }, 50);\n }\n }\n on(div, \"copy\", onCopyCut);\n on(div, \"cut\", onCopyCut);\n },\n\n prepareSelection: function() {\n var result = prepareSelection(this.cm, false);\n result.focus = this.cm.state.focused;\n return result;\n },\n\n showSelection: function(info, takeFocus) {\n if (!info || !this.cm.display.view.length) return;\n if (info.focus || takeFocus) this.showPrimarySelection();\n this.showMultipleSelections(info);\n },\n\n showPrimarySelection: function() {\n var sel = window.getSelection(), prim = this.cm.doc.sel.primary();\n var curAnchor = domToPos(this.cm, sel.anchorNode, sel.anchorOffset);\n var curFocus = domToPos(this.cm, sel.focusNode, sel.focusOffset);\n if (curAnchor && !curAnchor.bad && curFocus && !curFocus.bad &&\n cmp(minPos(curAnchor, curFocus), prim.from()) == 0 &&\n cmp(maxPos(curAnchor, curFocus), prim.to()) == 0)\n return;\n\n var start = posToDOM(this.cm, prim.from());\n var end = posToDOM(this.cm, prim.to());\n if (!start && !end) return;\n\n var view = this.cm.display.view;\n var old = sel.rangeCount && sel.getRangeAt(0);\n if (!start) {\n start = {node: view[0].measure.map[2], offset: 0};\n } else if (!end) { // FIXME dangerously hacky\n var measure = view[view.length - 1].measure;\n var map = measure.maps ? measure.maps[measure.maps.length - 1] : measure.map;\n end = {node: map[map.length - 1], offset: map[map.length - 2] - map[map.length - 3]};\n }\n\n try { var rng = range(start.node, start.offset, end.offset, end.node); }\n catch(e) {} // Our model of the DOM might be outdated, in which case the range we try to set can be impossible\n if (rng) {\n if (!gecko && this.cm.state.focused) {\n sel.collapse(start.node, start.offset);\n if (!rng.collapsed) sel.addRange(rng);\n } else {\n sel.removeAllRanges();\n sel.addRange(rng);\n }\n if (old && sel.anchorNode == null) sel.addRange(old);\n else if (gecko) this.startGracePeriod();\n }\n this.rememberSelection();\n },\n\n startGracePeriod: function() {\n var input = this;\n clearTimeout(this.gracePeriod);\n this.gracePeriod = setTimeout(function() {\n input.gracePeriod = false;\n if (input.selectionChanged())\n input.cm.operation(function() { input.cm.curOp.selectionChanged = true; });\n }, 20);\n },\n\n showMultipleSelections: function(info) {\n removeChildrenAndAdd(this.cm.display.cursorDiv, info.cursors);\n removeChildrenAndAdd(this.cm.display.selectionDiv, info.selection);\n },\n\n rememberSelection: function() {\n var sel = window.getSelection();\n this.lastAnchorNode = sel.anchorNode; this.lastAnchorOffset = sel.anchorOffset;\n this.lastFocusNode = sel.focusNode; this.lastFocusOffset = sel.focusOffset;\n },\n\n selectionInEditor: function() {\n var sel = window.getSelection();\n if (!sel.rangeCount) return false;\n var node = sel.getRangeAt(0).commonAncestorContainer;\n return contains(this.div, node);\n },\n\n focus: function() {\n if (this.cm.options.readOnly != \"nocursor\") this.div.focus();\n },\n blur: function() { this.div.blur(); },\n getField: function() { return this.div; },\n\n supportsTouch: function() { return true; },\n\n receivedFocus: function() {\n var input = this;\n if (this.selectionInEditor())\n this.pollSelection();\n else\n runInOp(this.cm, function() { input.cm.curOp.selectionChanged = true; });\n\n function poll() {\n if (input.cm.state.focused) {\n input.pollSelection();\n input.polling.set(input.cm.options.pollInterval, poll);\n }\n }\n this.polling.set(this.cm.options.pollInterval, poll);\n },\n\n selectionChanged: function() {\n var sel = window.getSelection();\n return sel.anchorNode != this.lastAnchorNode || sel.anchorOffset != this.lastAnchorOffset ||\n sel.focusNode != this.lastFocusNode || sel.focusOffset != this.lastFocusOffset;\n },\n\n pollSelection: function() {\n if (!this.composing && !this.gracePeriod && this.selectionChanged()) {\n var sel = window.getSelection(), cm = this.cm;\n this.rememberSelection();\n var anchor = domToPos(cm, sel.anchorNode, sel.anchorOffset);\n var head = domToPos(cm, sel.focusNode, sel.focusOffset);\n if (anchor && head) runInOp(cm, function() {\n setSelection(cm.doc, simpleSelection(anchor, head), sel_dontScroll);\n if (anchor.bad || head.bad) cm.curOp.selectionChanged = true;\n });\n }\n },\n\n pollContent: function() {\n var cm = this.cm, display = cm.display, sel = cm.doc.sel.primary();\n var from = sel.from(), to = sel.to();\n if (from.line < display.viewFrom || to.line > display.viewTo - 1) return false;\n\n var fromIndex;\n if (from.line == display.viewFrom || (fromIndex = findViewIndex(cm, from.line)) == 0) {\n var fromLine = lineNo(display.view[0].line);\n var fromNode = display.view[0].node;\n } else {\n var fromLine = lineNo(display.view[fromIndex].line);\n var fromNode = display.view[fromIndex - 1].node.nextSibling;\n }\n var toIndex = findViewIndex(cm, to.line);\n if (toIndex == display.view.length - 1) {\n var toLine = display.viewTo - 1;\n var toNode = display.lineDiv.lastChild;\n } else {\n var toLine = lineNo(display.view[toIndex + 1].line) - 1;\n var toNode = display.view[toIndex + 1].node.previousSibling;\n }\n\n var newText = cm.doc.splitLines(domTextBetween(cm, fromNode, toNode, fromLine, toLine));\n var oldText = getBetween(cm.doc, Pos(fromLine, 0), Pos(toLine, getLine(cm.doc, toLine).text.length));\n while (newText.length > 1 && oldText.length > 1) {\n if (lst(newText) == lst(oldText)) { newText.pop(); oldText.pop(); toLine--; }\n else if (newText[0] == oldText[0]) { newText.shift(); oldText.shift(); fromLine++; }\n else break;\n }\n\n var cutFront = 0, cutEnd = 0;\n var newTop = newText[0], oldTop = oldText[0], maxCutFront = Math.min(newTop.length, oldTop.length);\n while (cutFront < maxCutFront && newTop.charCodeAt(cutFront) == oldTop.charCodeAt(cutFront))\n ++cutFront;\n var newBot = lst(newText), oldBot = lst(oldText);\n var maxCutEnd = Math.min(newBot.length - (newText.length == 1 ? cutFront : 0),\n oldBot.length - (oldText.length == 1 ? cutFront : 0));\n while (cutEnd < maxCutEnd &&\n newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1))\n ++cutEnd;\n\n newText[newText.length - 1] = newBot.slice(0, newBot.length - cutEnd);\n newText[0] = newText[0].slice(cutFront);\n\n var chFrom = Pos(fromLine, cutFront);\n var chTo = Pos(toLine, oldText.length ? lst(oldText).length - cutEnd : 0);\n if (newText.length > 1 || newText[0] || cmp(chFrom, chTo)) {\n replaceRange(cm.doc, newText, chFrom, chTo, \"+input\");\n return true;\n }\n },\n\n ensurePolled: function() {\n this.forceCompositionEnd();\n },\n reset: function() {\n this.forceCompositionEnd();\n },\n forceCompositionEnd: function() {\n if (!this.composing || this.composing.handled) return;\n this.applyComposition(this.composing);\n this.composing.handled = true;\n this.div.blur();\n this.div.focus();\n },\n applyComposition: function(composing) {\n if (this.cm.isReadOnly())\n operation(this.cm, regChange)(this.cm)\n else if (composing.data && composing.data != composing.startData)\n operation(this.cm, applyTextInput)(this.cm, composing.data, 0, composing.sel);\n },\n\n setUneditable: function(node) {\n node.contentEditable = \"false\"\n },\n\n onKeyPress: function(e) {\n e.preventDefault();\n if (!this.cm.isReadOnly())\n operation(this.cm, applyTextInput)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0);\n },\n\n readOnlyChanged: function(val) {\n this.div.contentEditable = String(val != \"nocursor\")\n },\n\n onContextMenu: nothing,\n resetPosition: nothing,\n\n needsContentAttribute: true\n }, ContentEditableInput.prototype);\n\n function posToDOM(cm, pos) {\n var view = findViewForLine(cm, pos.line);\n if (!view || view.hidden) return null;\n var line = getLine(cm.doc, pos.line);\n var info = mapFromLineView(view, line, pos.line);\n\n var order = getOrder(line), side = \"left\";\n if (order) {\n var partPos = getBidiPartAt(order, pos.ch);\n side = partPos % 2 ? \"right\" : \"left\";\n }\n var result = nodeAndOffsetInLineMap(info.map, pos.ch, side);\n result.offset = result.collapse == \"right\" ? result.end : result.start;\n return result;\n }\n\n function badPos(pos, bad) { if (bad) pos.bad = true; return pos; }\n\n function domToPos(cm, node, offset) {\n var lineNode;\n if (node == cm.display.lineDiv) {\n lineNode = cm.display.lineDiv.childNodes[offset];\n if (!lineNode) return badPos(cm.clipPos(Pos(cm.display.viewTo - 1)), true);\n node = null; offset = 0;\n } else {\n for (lineNode = node;; lineNode = lineNode.parentNode) {\n if (!lineNode || lineNode == cm.display.lineDiv) return null;\n if (lineNode.parentNode && lineNode.parentNode == cm.display.lineDiv) break;\n }\n }\n for (var i = 0; i < cm.display.view.length; i++) {\n var lineView = cm.display.view[i];\n if (lineView.node == lineNode)\n return locateNodeInLineView(lineView, node, offset);\n }\n }\n\n function locateNodeInLineView(lineView, node, offset) {\n var wrapper = lineView.text.firstChild, bad = false;\n if (!node || !contains(wrapper, node)) return badPos(Pos(lineNo(lineView.line), 0), true);\n if (node == wrapper) {\n bad = true;\n node = wrapper.childNodes[offset];\n offset = 0;\n if (!node) {\n var line = lineView.rest ? lst(lineView.rest) : lineView.line;\n return badPos(Pos(lineNo(line), line.text.length), bad);\n }\n }\n\n var textNode = node.nodeType == 3 ? node : null, topNode = node;\n if (!textNode && node.childNodes.length == 1 && node.firstChild.nodeType == 3) {\n textNode = node.firstChild;\n if (offset) offset = textNode.nodeValue.length;\n }\n while (topNode.parentNode != wrapper) topNode = topNode.parentNode;\n var measure = lineView.measure, maps = measure.maps;\n\n function find(textNode, topNode, offset) {\n for (var i = -1; i < (maps ? maps.length : 0); i++) {\n var map = i < 0 ? measure.map : maps[i];\n for (var j = 0; j < map.length; j += 3) {\n var curNode = map[j + 2];\n if (curNode == textNode || curNode == topNode) {\n var line = lineNo(i < 0 ? lineView.line : lineView.rest[i]);\n var ch = map[j] + offset;\n if (offset < 0 || curNode != textNode) ch = map[j + (offset ? 1 : 0)];\n return Pos(line, ch);\n }\n }\n }\n }\n var found = find(textNode, topNode, offset);\n if (found) return badPos(found, bad);\n\n // FIXME this is all really shaky. might handle the few cases it needs to handle, but likely to cause problems\n for (var after = topNode.nextSibling, dist = textNode ? textNode.nodeValue.length - offset : 0; after; after = after.nextSibling) {\n found = find(after, after.firstChild, 0);\n if (found)\n return badPos(Pos(found.line, found.ch - dist), bad);\n else\n dist += after.textContent.length;\n }\n for (var before = topNode.previousSibling, dist = offset; before; before = before.previousSibling) {\n found = find(before, before.firstChild, -1);\n if (found)\n return badPos(Pos(found.line, found.ch + dist), bad);\n else\n dist += after.textContent.length;\n }\n }\n\n function domTextBetween(cm, from, to, fromLine, toLine) {\n var text = \"\", closing = false, lineSep = cm.doc.lineSeparator();\n function recognizeMarker(id) { return function(marker) { return marker.id == id; }; }\n function walk(node) {\n if (node.nodeType == 1) {\n var cmText = node.getAttribute(\"cm-text\");\n if (cmText != null) {\n if (cmText == \"\") cmText = node.textContent.replace(/\\u200b/g, \"\");\n text += cmText;\n return;\n }\n var markerID = node.getAttribute(\"cm-marker\"), range;\n if (markerID) {\n var found = cm.findMarks(Pos(fromLine, 0), Pos(toLine + 1, 0), recognizeMarker(+markerID));\n if (found.length && (range = found[0].find()))\n text += getBetween(cm.doc, range.from, range.to).join(lineSep);\n return;\n }\n if (node.getAttribute(\"contenteditable\") == \"false\") return;\n for (var i = 0; i < node.childNodes.length; i++)\n walk(node.childNodes[i]);\n if (/^(pre|div|p)$/i.test(node.nodeName))\n closing = true;\n } else if (node.nodeType == 3) {\n var val = node.nodeValue;\n if (!val) return;\n if (closing) {\n text += lineSep;\n closing = false;\n }\n text += val;\n }\n }\n for (;;) {\n walk(from);\n if (from == to) break;\n from = from.nextSibling;\n }\n return text;\n }\n\n CodeMirror.inputStyles = {\"textarea\": TextareaInput, \"contenteditable\": ContentEditableInput};\n\n // SELECTION / CURSOR\n\n // Selection objects are immutable. A new one is created every time\n // the selection changes. A selection is one or more non-overlapping\n // (and non-touching) ranges, sorted, and an integer that indicates\n // which one is the primary selection (the one that's scrolled into\n // view, that getCursor returns, etc).\n function Selection(ranges, primIndex) {\n this.ranges = ranges;\n this.primIndex = primIndex;\n }\n\n Selection.prototype = {\n primary: function() { return this.ranges[this.primIndex]; },\n equals: function(other) {\n if (other == this) return true;\n if (other.primIndex != this.primIndex || other.ranges.length != this.ranges.length) return false;\n for (var i = 0; i < this.ranges.length; i++) {\n var here = this.ranges[i], there = other.ranges[i];\n if (cmp(here.anchor, there.anchor) != 0 || cmp(here.head, there.head) != 0) return false;\n }\n return true;\n },\n deepCopy: function() {\n for (var out = [], i = 0; i < this.ranges.length; i++)\n out[i] = new Range(copyPos(this.ranges[i].anchor), copyPos(this.ranges[i].head));\n return new Selection(out, this.primIndex);\n },\n somethingSelected: function() {\n for (var i = 0; i < this.ranges.length; i++)\n if (!this.ranges[i].empty()) return true;\n return false;\n },\n contains: function(pos, end) {\n if (!end) end = pos;\n for (var i = 0; i < this.ranges.length; i++) {\n var range = this.ranges[i];\n if (cmp(end, range.from()) >= 0 && cmp(pos, range.to()) <= 0)\n return i;\n }\n return -1;\n }\n };\n\n function Range(anchor, head) {\n this.anchor = anchor; this.head = head;\n }\n\n Range.prototype = {\n from: function() { return minPos(this.anchor, this.head); },\n to: function() { return maxPos(this.anchor, this.head); },\n empty: function() {\n return this.head.line == this.anchor.line && this.head.ch == this.anchor.ch;\n }\n };\n\n // Take an unsorted, potentially overlapping set of ranges, and\n // build a selection out of it. 'Consumes' ranges array (modifying\n // it).\n function normalizeSelection(ranges, primIndex) {\n var prim = ranges[primIndex];\n ranges.sort(function(a, b) { return cmp(a.from(), b.from()); });\n primIndex = indexOf(ranges, prim);\n for (var i = 1; i < ranges.length; i++) {\n var cur = ranges[i], prev = ranges[i - 1];\n if (cmp(prev.to(), cur.from()) >= 0) {\n var from = minPos(prev.from(), cur.from()), to = maxPos(prev.to(), cur.to());\n var inv = prev.empty() ? cur.from() == cur.head : prev.from() == prev.head;\n if (i <= primIndex) --primIndex;\n ranges.splice(--i, 2, new Range(inv ? to : from, inv ? from : to));\n }\n }\n return new Selection(ranges, primIndex);\n }\n\n function simpleSelection(anchor, head) {\n return new Selection([new Range(anchor, head || anchor)], 0);\n }\n\n // Most of the external API clips given positions to make sure they\n // actually exist within the document.\n function clipLine(doc, n) {return Math.max(doc.first, Math.min(n, doc.first + doc.size - 1));}\n function clipPos(doc, pos) {\n if (pos.line < doc.first) return Pos(doc.first, 0);\n var last = doc.first + doc.size - 1;\n if (pos.line > last) return Pos(last, getLine(doc, last).text.length);\n return clipToLen(pos, getLine(doc, pos.line).text.length);\n }\n function clipToLen(pos, linelen) {\n var ch = pos.ch;\n if (ch == null || ch > linelen) return Pos(pos.line, linelen);\n else if (ch < 0) return Pos(pos.line, 0);\n else return pos;\n }\n function isLine(doc, l) {return l >= doc.first && l < doc.first + doc.size;}\n function clipPosArray(doc, array) {\n for (var out = [], i = 0; i < array.length; i++) out[i] = clipPos(doc, array[i]);\n return out;\n }\n\n // SELECTION UPDATES\n\n // The 'scroll' parameter given to many of these indicated whether\n // the new cursor position should be scrolled into view after\n // modifying the selection.\n\n // If shift is held or the extend flag is set, extends a range to\n // include a given position (and optionally a second position).\n // Otherwise, simply returns the range between the given positions.\n // Used for cursor motion and such.\n function extendRange(doc, range, head, other) {\n if (doc.cm && doc.cm.display.shift || doc.extend) {\n var anchor = range.anchor;\n if (other) {\n var posBefore = cmp(head, anchor) < 0;\n if (posBefore != (cmp(other, anchor) < 0)) {\n anchor = head;\n head = other;\n } else if (posBefore != (cmp(head, other) < 0)) {\n head = other;\n }\n }\n return new Range(anchor, head);\n } else {\n return new Range(other || head, head);\n }\n }\n\n // Extend the primary selection range, discard the rest.\n function extendSelection(doc, head, other, options) {\n setSelection(doc, new Selection([extendRange(doc, doc.sel.primary(), head, other)], 0), options);\n }\n\n // Extend all selections (pos is an array of selections with length\n // equal the number of selections)\n function extendSelections(doc, heads, options) {\n for (var out = [], i = 0; i < doc.sel.ranges.length; i++)\n out[i] = extendRange(doc, doc.sel.ranges[i], heads[i], null);\n var newSel = normalizeSelection(out, doc.sel.primIndex);\n setSelection(doc, newSel, options);\n }\n\n // Updates a single range in the selection.\n function replaceOneSelection(doc, i, range, options) {\n var ranges = doc.sel.ranges.slice(0);\n ranges[i] = range;\n setSelection(doc, normalizeSelection(ranges, doc.sel.primIndex), options);\n }\n\n // Reset the selection to a single range.\n function setSimpleSelection(doc, anchor, head, options) {\n setSelection(doc, simpleSelection(anchor, head), options);\n }\n\n // Give beforeSelectionChange handlers a change to influence a\n // selection update.\n function filterSelectionChange(doc, sel, options) {\n var obj = {\n ranges: sel.ranges,\n update: function(ranges) {\n this.ranges = [];\n for (var i = 0; i < ranges.length; i++)\n this.ranges[i] = new Range(clipPos(doc, ranges[i].anchor),\n clipPos(doc, ranges[i].head));\n },\n origin: options && options.origin\n };\n signal(doc, \"beforeSelectionChange\", doc, obj);\n if (doc.cm) signal(doc.cm, \"beforeSelectionChange\", doc.cm, obj);\n if (obj.ranges != sel.ranges) return normalizeSelection(obj.ranges, obj.ranges.length - 1);\n else return sel;\n }\n\n function setSelectionReplaceHistory(doc, sel, options) {\n var done = doc.history.done, last = lst(done);\n if (last && last.ranges) {\n done[done.length - 1] = sel;\n setSelectionNoUndo(doc, sel, options);\n } else {\n setSelection(doc, sel, options);\n }\n }\n\n // Set a new selection.\n function setSelection(doc, sel, options) {\n setSelectionNoUndo(doc, sel, options);\n addSelectionToHistory(doc, doc.sel, doc.cm ? doc.cm.curOp.id : NaN, options);\n }\n\n function setSelectionNoUndo(doc, sel, options) {\n if (hasHandler(doc, \"beforeSelectionChange\") || doc.cm && hasHandler(doc.cm, \"beforeSelectionChange\"))\n sel = filterSelectionChange(doc, sel, options);\n\n var bias = options && options.bias ||\n (cmp(sel.primary().head, doc.sel.primary().head) < 0 ? -1 : 1);\n setSelectionInner(doc, skipAtomicInSelection(doc, sel, bias, true));\n\n if (!(options && options.scroll === false) && doc.cm)\n ensureCursorVisible(doc.cm);\n }\n\n function setSelectionInner(doc, sel) {\n if (sel.equals(doc.sel)) return;\n\n doc.sel = sel;\n\n if (doc.cm) {\n doc.cm.curOp.updateInput = doc.cm.curOp.selectionChanged = true;\n signalCursorActivity(doc.cm);\n }\n signalLater(doc, \"cursorActivity\", doc);\n }\n\n // Verify that the selection does not partially select any atomic\n // marked ranges.\n function reCheckSelection(doc) {\n setSelectionInner(doc, skipAtomicInSelection(doc, doc.sel, null, false), sel_dontScroll);\n }\n\n // Return a selection that does not partially select any atomic\n // ranges.\n function skipAtomicInSelection(doc, sel, bias, mayClear) {\n var out;\n for (var i = 0; i < sel.ranges.length; i++) {\n var range = sel.ranges[i];\n var old = sel.ranges.length == doc.sel.ranges.length && doc.sel.ranges[i];\n var newAnchor = skipAtomic(doc, range.anchor, old && old.anchor, bias, mayClear);\n var newHead = skipAtomic(doc, range.head, old && old.head, bias, mayClear);\n if (out || newAnchor != range.anchor || newHead != range.head) {\n if (!out) out = sel.ranges.slice(0, i);\n out[i] = new Range(newAnchor, newHead);\n }\n }\n return out ? normalizeSelection(out, sel.primIndex) : sel;\n }\n\n function skipAtomicInner(doc, pos, oldPos, dir, mayClear) {\n var line = getLine(doc, pos.line);\n if (line.markedSpans) for (var i = 0; i < line.markedSpans.length; ++i) {\n var sp = line.markedSpans[i], m = sp.marker;\n if ((sp.from == null || (m.inclusiveLeft ? sp.from <= pos.ch : sp.from < pos.ch)) &&\n (sp.to == null || (m.inclusiveRight ? sp.to >= pos.ch : sp.to > pos.ch))) {\n if (mayClear) {\n signal(m, \"beforeCursorEnter\");\n if (m.explicitlyCleared) {\n if (!line.markedSpans) break;\n else {--i; continue;}\n }\n }\n if (!m.atomic) continue;\n\n if (oldPos) {\n var near = m.find(dir < 0 ? 1 : -1), diff;\n if (dir < 0 ? m.inclusiveRight : m.inclusiveLeft)\n near = movePos(doc, near, -dir, near && near.line == pos.line ? line : null);\n if (near && near.line == pos.line && (diff = cmp(near, oldPos)) && (dir < 0 ? diff < 0 : diff > 0))\n return skipAtomicInner(doc, near, pos, dir, mayClear);\n }\n\n var far = m.find(dir < 0 ? -1 : 1);\n if (dir < 0 ? m.inclusiveLeft : m.inclusiveRight)\n far = movePos(doc, far, dir, far.line == pos.line ? line : null);\n return far ? skipAtomicInner(doc, far, pos, dir, mayClear) : null;\n }\n }\n return pos;\n }\n\n // Ensure a given position is not inside an atomic range.\n function skipAtomic(doc, pos, oldPos, bias, mayClear) {\n var dir = bias || 1;\n var found = skipAtomicInner(doc, pos, oldPos, dir, mayClear) ||\n (!mayClear && skipAtomicInner(doc, pos, oldPos, dir, true)) ||\n skipAtomicInner(doc, pos, oldPos, -dir, mayClear) ||\n (!mayClear && skipAtomicInner(doc, pos, oldPos, -dir, true));\n if (!found) {\n doc.cantEdit = true;\n return Pos(doc.first, 0);\n }\n return found;\n }\n\n function movePos(doc, pos, dir, line) {\n if (dir < 0 && pos.ch == 0) {\n if (pos.line > doc.first) return clipPos(doc, Pos(pos.line - 1));\n else return null;\n } else if (dir > 0 && pos.ch == (line || getLine(doc, pos.line)).text.length) {\n if (pos.line < doc.first + doc.size - 1) return Pos(pos.line + 1, 0);\n else return null;\n } else {\n return new Pos(pos.line, pos.ch + dir);\n }\n }\n\n // SELECTION DRAWING\n\n function updateSelection(cm) {\n cm.display.input.showSelection(cm.display.input.prepareSelection());\n }\n\n function prepareSelection(cm, primary) {\n var doc = cm.doc, result = {};\n var curFragment = result.cursors = document.createDocumentFragment();\n var selFragment = result.selection = document.createDocumentFragment();\n\n for (var i = 0; i < doc.sel.ranges.length; i++) {\n if (primary === false && i == doc.sel.primIndex) continue;\n var range = doc.sel.ranges[i];\n if (range.from().line >= cm.display.viewTo || range.to().line < cm.display.viewFrom) continue;\n var collapsed = range.empty();\n if (collapsed || cm.options.showCursorWhenSelecting)\n drawSelectionCursor(cm, range.head, curFragment);\n if (!collapsed)\n drawSelectionRange(cm, range, selFragment);\n }\n return result;\n }\n\n // Draws a cursor for the given range\n function drawSelectionCursor(cm, head, output) {\n var pos = cursorCoords(cm, head, \"div\", null, null, !cm.options.singleCursorHeightPerLine);\n\n var cursor = output.appendChild(elt(\"div\", \"\\u00a0\", \"CodeMirror-cursor\"));\n cursor.style.left = pos.left + \"px\";\n cursor.style.top = pos.top + \"px\";\n cursor.style.height = Math.max(0, pos.bottom - pos.top) * cm.options.cursorHeight + \"px\";\n\n if (pos.other) {\n // Secondary cursor, shown when on a 'jump' in bi-directional text\n var otherCursor = output.appendChild(elt(\"div\", \"\\u00a0\", \"CodeMirror-cursor CodeMirror-secondarycursor\"));\n otherCursor.style.display = \"\";\n otherCursor.style.left = pos.other.left + \"px\";\n otherCursor.style.top = pos.other.top + \"px\";\n otherCursor.style.height = (pos.other.bottom - pos.other.top) * .85 + \"px\";\n }\n }\n\n // Draws the given range as a highlighted selection\n function drawSelectionRange(cm, range, output) {\n var display = cm.display, doc = cm.doc;\n var fragment = document.createDocumentFragment();\n var padding = paddingH(cm.display), leftSide = padding.left;\n var rightSide = Math.max(display.sizerWidth, displayWidth(cm) - display.sizer.offsetLeft) - padding.right;\n\n function add(left, top, width, bottom) {\n if (top < 0) top = 0;\n top = Math.round(top);\n bottom = Math.round(bottom);\n fragment.appendChild(elt(\"div\", null, \"CodeMirror-selected\", \"position: absolute; left: \" + left +\n \"px; top: \" + top + \"px; width: \" + (width == null ? rightSide - left : width) +\n \"px; height: \" + (bottom - top) + \"px\"));\n }\n\n function drawForLine(line, fromArg, toArg) {\n var lineObj = getLine(doc, line);\n var lineLen = lineObj.text.length;\n var start, end;\n function coords(ch, bias) {\n return charCoords(cm, Pos(line, ch), \"div\", lineObj, bias);\n }\n\n iterateBidiSections(getOrder(lineObj), fromArg || 0, toArg == null ? lineLen : toArg, function(from, to, dir) {\n var leftPos = coords(from, \"left\"), rightPos, left, right;\n if (from == to) {\n rightPos = leftPos;\n left = right = leftPos.left;\n } else {\n rightPos = coords(to - 1, \"right\");\n if (dir == \"rtl\") { var tmp = leftPos; leftPos = rightPos; rightPos = tmp; }\n left = leftPos.left;\n right = rightPos.right;\n }\n if (fromArg == null && from == 0) left = leftSide;\n if (rightPos.top - leftPos.top > 3) { // Different lines, draw top part\n add(left, leftPos.top, null, leftPos.bottom);\n left = leftSide;\n if (leftPos.bottom < rightPos.top) add(left, leftPos.bottom, null, rightPos.top);\n }\n if (toArg == null && to == lineLen) right = rightSide;\n if (!start || leftPos.top < start.top || leftPos.top == start.top && leftPos.left < start.left)\n start = leftPos;\n if (!end || rightPos.bottom > end.bottom || rightPos.bottom == end.bottom && rightPos.right > end.right)\n end = rightPos;\n if (left < leftSide + 1) left = leftSide;\n add(left, rightPos.top, right - left, rightPos.bottom);\n });\n return {start: start, end: end};\n }\n\n var sFrom = range.from(), sTo = range.to();\n if (sFrom.line == sTo.line) {\n drawForLine(sFrom.line, sFrom.ch, sTo.ch);\n } else {\n var fromLine = getLine(doc, sFrom.line), toLine = getLine(doc, sTo.line);\n var singleVLine = visualLine(fromLine) == visualLine(toLine);\n var leftEnd = drawForLine(sFrom.line, sFrom.ch, singleVLine ? fromLine.text.length + 1 : null).end;\n var rightStart = drawForLine(sTo.line, singleVLine ? 0 : null, sTo.ch).start;\n if (singleVLine) {\n if (leftEnd.top < rightStart.top - 2) {\n add(leftEnd.right, leftEnd.top, null, leftEnd.bottom);\n add(leftSide, rightStart.top, rightStart.left, rightStart.bottom);\n } else {\n add(leftEnd.right, leftEnd.top, rightStart.left - leftEnd.right, leftEnd.bottom);\n }\n }\n if (leftEnd.bottom < rightStart.top)\n add(leftSide, leftEnd.bottom, null, rightStart.top);\n }\n\n output.appendChild(fragment);\n }\n\n // Cursor-blinking\n function restartBlink(cm) {\n if (!cm.state.focused) return;\n var display = cm.display;\n clearInterval(display.blinker);\n var on = true;\n display.cursorDiv.style.visibility = \"\";\n if (cm.options.cursorBlinkRate > 0)\n display.blinker = setInterval(function() {\n display.cursorDiv.style.visibility = (on = !on) ? \"\" : \"hidden\";\n }, cm.options.cursorBlinkRate);\n else if (cm.options.cursorBlinkRate < 0)\n display.cursorDiv.style.visibility = \"hidden\";\n }\n\n // HIGHLIGHT WORKER\n\n function startWorker(cm, time) {\n if (cm.doc.mode.startState && cm.doc.frontier < cm.display.viewTo)\n cm.state.highlight.set(time, bind(highlightWorker, cm));\n }\n\n function highlightWorker(cm) {\n var doc = cm.doc;\n if (doc.frontier < doc.first) doc.frontier = doc.first;\n if (doc.frontier >= cm.display.viewTo) return;\n var end = +new Date + cm.options.workTime;\n var state = copyState(doc.mode, getStateBefore(cm, doc.frontier));\n var changedLines = [];\n\n doc.iter(doc.frontier, Math.min(doc.first + doc.size, cm.display.viewTo + 500), function(line) {\n if (doc.frontier >= cm.display.viewFrom) { // Visible\n var oldStyles = line.styles, tooLong = line.text.length > cm.options.maxHighlightLength;\n var highlighted = highlightLine(cm, line, tooLong ? copyState(doc.mode, state) : state, true);\n line.styles = highlighted.styles;\n var oldCls = line.styleClasses, newCls = highlighted.classes;\n if (newCls) line.styleClasses = newCls;\n else if (oldCls) line.styleClasses = null;\n var ischange = !oldStyles || oldStyles.length != line.styles.length ||\n oldCls != newCls && (!oldCls || !newCls || oldCls.bgClass != newCls.bgClass || oldCls.textClass != newCls.textClass);\n for (var i = 0; !ischange && i < oldStyles.length; ++i) ischange = oldStyles[i] != line.styles[i];\n if (ischange) changedLines.push(doc.frontier);\n line.stateAfter = tooLong ? state : copyState(doc.mode, state);\n } else {\n if (line.text.length <= cm.options.maxHighlightLength)\n processLine(cm, line.text, state);\n line.stateAfter = doc.frontier % 5 == 0 ? copyState(doc.mode, state) : null;\n }\n ++doc.frontier;\n if (+new Date > end) {\n startWorker(cm, cm.options.workDelay);\n return true;\n }\n });\n if (changedLines.length) runInOp(cm, function() {\n for (var i = 0; i < changedLines.length; i++)\n regLineChange(cm, changedLines[i], \"text\");\n });\n }\n\n // Finds the line to start with when starting a parse. Tries to\n // find a line with a stateAfter, so that it can start with a\n // valid state. If that fails, it returns the line with the\n // smallest indentation, which tends to need the least context to\n // parse correctly.\n function findStartLine(cm, n, precise) {\n var minindent, minline, doc = cm.doc;\n var lim = precise ? -1 : n - (cm.doc.mode.innerMode ? 1000 : 100);\n for (var search = n; search > lim; --search) {\n if (search <= doc.first) return doc.first;\n var line = getLine(doc, search - 1);\n if (line.stateAfter && (!precise || search <= doc.frontier)) return search;\n var indented = countColumn(line.text, null, cm.options.tabSize);\n if (minline == null || minindent > indented) {\n minline = search - 1;\n minindent = indented;\n }\n }\n return minline;\n }\n\n function getStateBefore(cm, n, precise) {\n var doc = cm.doc, display = cm.display;\n if (!doc.mode.startState) return true;\n var pos = findStartLine(cm, n, precise), state = pos > doc.first && getLine(doc, pos-1).stateAfter;\n if (!state) state = startState(doc.mode);\n else state = copyState(doc.mode, state);\n doc.iter(pos, n, function(line) {\n processLine(cm, line.text, state);\n var save = pos == n - 1 || pos % 5 == 0 || pos >= display.viewFrom && pos < display.viewTo;\n line.stateAfter = save ? copyState(doc.mode, state) : null;\n ++pos;\n });\n if (precise) doc.frontier = pos;\n return state;\n }\n\n // POSITION MEASUREMENT\n\n function paddingTop(display) {return display.lineSpace.offsetTop;}\n function paddingVert(display) {return display.mover.offsetHeight - display.lineSpace.offsetHeight;}\n function paddingH(display) {\n if (display.cachedPaddingH) return display.cachedPaddingH;\n var e = removeChildrenAndAdd(display.measure, elt(\"pre\", \"x\"));\n var style = window.getComputedStyle ? window.getComputedStyle(e) : e.currentStyle;\n var data = {left: parseInt(style.paddingLeft), right: parseInt(style.paddingRight)};\n if (!isNaN(data.left) && !isNaN(data.right)) display.cachedPaddingH = data;\n return data;\n }\n\n function scrollGap(cm) { return scrollerGap - cm.display.nativeBarWidth; }\n function displayWidth(cm) {\n return cm.display.scroller.clientWidth - scrollGap(cm) - cm.display.barWidth;\n }\n function displayHeight(cm) {\n return cm.display.scroller.clientHeight - scrollGap(cm) - cm.display.barHeight;\n }\n\n // Ensure the lineView.wrapping.heights array is populated. This is\n // an array of bottom offsets for the lines that make up a drawn\n // line. When lineWrapping is on, there might be more than one\n // height.\n function ensureLineHeights(cm, lineView, rect) {\n var wrapping = cm.options.lineWrapping;\n var curWidth = wrapping && displayWidth(cm);\n if (!lineView.measure.heights || wrapping && lineView.measure.width != curWidth) {\n var heights = lineView.measure.heights = [];\n if (wrapping) {\n lineView.measure.width = curWidth;\n var rects = lineView.text.firstChild.getClientRects();\n for (var i = 0; i < rects.length - 1; i++) {\n var cur = rects[i], next = rects[i + 1];\n if (Math.abs(cur.bottom - next.bottom) > 2)\n heights.push((cur.bottom + next.top) / 2 - rect.top);\n }\n }\n heights.push(rect.bottom - rect.top);\n }\n }\n\n // Find a line map (mapping character offsets to text nodes) and a\n // measurement cache for the given line number. (A line view might\n // contain multiple lines when collapsed ranges are present.)\n function mapFromLineView(lineView, line, lineN) {\n if (lineView.line == line)\n return {map: lineView.measure.map, cache: lineView.measure.cache};\n for (var i = 0; i < lineView.rest.length; i++)\n if (lineView.rest[i] == line)\n return {map: lineView.measure.maps[i], cache: lineView.measure.caches[i]};\n for (var i = 0; i < lineView.rest.length; i++)\n if (lineNo(lineView.rest[i]) > lineN)\n return {map: lineView.measure.maps[i], cache: lineView.measure.caches[i], before: true};\n }\n\n // Render a line into the hidden node display.externalMeasured. Used\n // when measurement is needed for a line that's not in the viewport.\n function updateExternalMeasurement(cm, line) {\n line = visualLine(line);\n var lineN = lineNo(line);\n var view = cm.display.externalMeasured = new LineView(cm.doc, line, lineN);\n view.lineN = lineN;\n var built = view.built = buildLineContent(cm, view);\n view.text = built.pre;\n removeChildrenAndAdd(cm.display.lineMeasure, built.pre);\n return view;\n }\n\n // Get a {top, bottom, left, right} box (in line-local coordinates)\n // for a given character.\n function measureChar(cm, line, ch, bias) {\n return measureCharPrepared(cm, prepareMeasureForLine(cm, line), ch, bias);\n }\n\n // Find a line view that corresponds to the given line number.\n function findViewForLine(cm, lineN) {\n if (lineN >= cm.display.viewFrom && lineN < cm.display.viewTo)\n return cm.display.view[findViewIndex(cm, lineN)];\n var ext = cm.display.externalMeasured;\n if (ext && lineN >= ext.lineN && lineN < ext.lineN + ext.size)\n return ext;\n }\n\n // Measurement can be split in two steps, the set-up work that\n // applies to the whole line, and the measurement of the actual\n // character. Functions like coordsChar, that need to do a lot of\n // measurements in a row, can thus ensure that the set-up work is\n // only done once.\n function prepareMeasureForLine(cm, line) {\n var lineN = lineNo(line);\n var view = findViewForLine(cm, lineN);\n if (view && !view.text) {\n view = null;\n } else if (view && view.changes) {\n updateLineForChanges(cm, view, lineN, getDimensions(cm));\n cm.curOp.forceUpdate = true;\n }\n if (!view)\n view = updateExternalMeasurement(cm, line);\n\n var info = mapFromLineView(view, line, lineN);\n return {\n line: line, view: view, rect: null,\n map: info.map, cache: info.cache, before: info.before,\n hasHeights: false\n };\n }\n\n // Given a prepared measurement object, measures the position of an\n // actual character (or fetches it from the cache).\n function measureCharPrepared(cm, prepared, ch, bias, varHeight) {\n if (prepared.before) ch = -1;\n var key = ch + (bias || \"\"), found;\n if (prepared.cache.hasOwnProperty(key)) {\n found = prepared.cache[key];\n } else {\n if (!prepared.rect)\n prepared.rect = prepared.view.text.getBoundingClientRect();\n if (!prepared.hasHeights) {\n ensureLineHeights(cm, prepared.view, prepared.rect);\n prepared.hasHeights = true;\n }\n found = measureCharInner(cm, prepared, ch, bias);\n if (!found.bogus) prepared.cache[key] = found;\n }\n return {left: found.left, right: found.right,\n top: varHeight ? found.rtop : found.top,\n bottom: varHeight ? found.rbottom : found.bottom};\n }\n\n var nullRect = {left: 0, right: 0, top: 0, bottom: 0};\n\n function nodeAndOffsetInLineMap(map, ch, bias) {\n var node, start, end, collapse;\n // First, search the line map for the text node corresponding to,\n // or closest to, the target character.\n for (var i = 0; i < map.length; i += 3) {\n var mStart = map[i], mEnd = map[i + 1];\n if (ch < mStart) {\n start = 0; end = 1;\n collapse = \"left\";\n } else if (ch < mEnd) {\n start = ch - mStart;\n end = start + 1;\n } else if (i == map.length - 3 || ch == mEnd && map[i + 3] > ch) {\n end = mEnd - mStart;\n start = end - 1;\n if (ch >= mEnd) collapse = \"right\";\n }\n if (start != null) {\n node = map[i + 2];\n if (mStart == mEnd && bias == (node.insertLeft ? \"left\" : \"right\"))\n collapse = bias;\n if (bias == \"left\" && start == 0)\n while (i && map[i - 2] == map[i - 3] && map[i - 1].insertLeft) {\n node = map[(i -= 3) + 2];\n collapse = \"left\";\n }\n if (bias == \"right\" && start == mEnd - mStart)\n while (i < map.length - 3 && map[i + 3] == map[i + 4] && !map[i + 5].insertLeft) {\n node = map[(i += 3) + 2];\n collapse = \"right\";\n }\n break;\n }\n }\n return {node: node, start: start, end: end, collapse: collapse, coverStart: mStart, coverEnd: mEnd};\n }\n\n function getUsefulRect(rects, bias) {\n var rect = nullRect\n if (bias == \"left\") for (var i = 0; i < rects.length; i++) {\n if ((rect = rects[i]).left != rect.right) break\n } else for (var i = rects.length - 1; i >= 0; i--) {\n if ((rect = rects[i]).left != rect.right) break\n }\n return rect\n }\n\n function measureCharInner(cm, prepared, ch, bias) {\n var place = nodeAndOffsetInLineMap(prepared.map, ch, bias);\n var node = place.node, start = place.start, end = place.end, collapse = place.collapse;\n\n var rect;\n if (node.nodeType == 3) { // If it is a text node, use a range to retrieve the coordinates.\n for (var i = 0; i < 4; i++) { // Retry a maximum of 4 times when nonsense rectangles are returned\n while (start && isExtendingChar(prepared.line.text.charAt(place.coverStart + start))) --start;\n while (place.coverStart + end < place.coverEnd && isExtendingChar(prepared.line.text.charAt(place.coverStart + end))) ++end;\n if (ie && ie_version < 9 && start == 0 && end == place.coverEnd - place.coverStart)\n rect = node.parentNode.getBoundingClientRect();\n else\n rect = getUsefulRect(range(node, start, end).getClientRects(), bias)\n if (rect.left || rect.right || start == 0) break;\n end = start;\n start = start - 1;\n collapse = \"right\";\n }\n if (ie && ie_version < 11) rect = maybeUpdateRectForZooming(cm.display.measure, rect);\n } else { // If it is a widget, simply get the box for the whole widget.\n if (start > 0) collapse = bias = \"right\";\n var rects;\n if (cm.options.lineWrapping && (rects = node.getClientRects()).length > 1)\n rect = rects[bias == \"right\" ? rects.length - 1 : 0];\n else\n rect = node.getBoundingClientRect();\n }\n if (ie && ie_version < 9 && !start && (!rect || !rect.left && !rect.right)) {\n var rSpan = node.parentNode.getClientRects()[0];\n if (rSpan)\n rect = {left: rSpan.left, right: rSpan.left + charWidth(cm.display), top: rSpan.top, bottom: rSpan.bottom};\n else\n rect = nullRect;\n }\n\n var rtop = rect.top - prepared.rect.top, rbot = rect.bottom - prepared.rect.top;\n var mid = (rtop + rbot) / 2;\n var heights = prepared.view.measure.heights;\n for (var i = 0; i < heights.length - 1; i++)\n if (mid < heights[i]) break;\n var top = i ? heights[i - 1] : 0, bot = heights[i];\n var result = {left: (collapse == \"right\" ? rect.right : rect.left) - prepared.rect.left,\n right: (collapse == \"left\" ? rect.left : rect.right) - prepared.rect.left,\n top: top, bottom: bot};\n if (!rect.left && !rect.right) result.bogus = true;\n if (!cm.options.singleCursorHeightPerLine) { result.rtop = rtop; result.rbottom = rbot; }\n\n return result;\n }\n\n // Work around problem with bounding client rects on ranges being\n // returned incorrectly when zoomed on IE10 and below.\n function maybeUpdateRectForZooming(measure, rect) {\n if (!window.screen || screen.logicalXDPI == null ||\n screen.logicalXDPI == screen.deviceXDPI || !hasBadZoomedRects(measure))\n return rect;\n var scaleX = screen.logicalXDPI / screen.deviceXDPI;\n var scaleY = screen.logicalYDPI / screen.deviceYDPI;\n return {left: rect.left * scaleX, right: rect.right * scaleX,\n top: rect.top * scaleY, bottom: rect.bottom * scaleY};\n }\n\n function clearLineMeasurementCacheFor(lineView) {\n if (lineView.measure) {\n lineView.measure.cache = {};\n lineView.measure.heights = null;\n if (lineView.rest) for (var i = 0; i < lineView.rest.length; i++)\n lineView.measure.caches[i] = {};\n }\n }\n\n function clearLineMeasurementCache(cm) {\n cm.display.externalMeasure = null;\n removeChildren(cm.display.lineMeasure);\n for (var i = 0; i < cm.display.view.length; i++)\n clearLineMeasurementCacheFor(cm.display.view[i]);\n }\n\n function clearCaches(cm) {\n clearLineMeasurementCache(cm);\n cm.display.cachedCharWidth = cm.display.cachedTextHeight = cm.display.cachedPaddingH = null;\n if (!cm.options.lineWrapping) cm.display.maxLineChanged = true;\n cm.display.lineNumChars = null;\n }\n\n function pageScrollX() { return window.pageXOffset || (document.documentElement || document.body).scrollLeft; }\n function pageScrollY() { return window.pageYOffset || (document.documentElement || document.body).scrollTop; }\n\n // Converts a {top, bottom, left, right} box from line-local\n // coordinates into another coordinate system. Context may be one of\n // \"line\", \"div\" (display.lineDiv), \"local\"/null (editor), \"window\",\n // or \"page\".\n function intoCoordSystem(cm, lineObj, rect, context) {\n if (lineObj.widgets) for (var i = 0; i < lineObj.widgets.length; ++i) if (lineObj.widgets[i].above) {\n var size = widgetHeight(lineObj.widgets[i]);\n rect.top += size; rect.bottom += size;\n }\n if (context == \"line\") return rect;\n if (!context) context = \"local\";\n var yOff = heightAtLine(lineObj);\n if (context == \"local\") yOff += paddingTop(cm.display);\n else yOff -= cm.display.viewOffset;\n if (context == \"page\" || context == \"window\") {\n var lOff = cm.display.lineSpace.getBoundingClientRect();\n yOff += lOff.top + (context == \"window\" ? 0 : pageScrollY());\n var xOff = lOff.left + (context == \"window\" ? 0 : pageScrollX());\n rect.left += xOff; rect.right += xOff;\n }\n rect.top += yOff; rect.bottom += yOff;\n return rect;\n }\n\n // Coverts a box from \"div\" coords to another coordinate system.\n // Context may be \"window\", \"page\", \"div\", or \"local\"/null.\n function fromCoordSystem(cm, coords, context) {\n if (context == \"div\") return coords;\n var left = coords.left, top = coords.top;\n // First move into \"page\" coordinate system\n if (context == \"page\") {\n left -= pageScrollX();\n top -= pageScrollY();\n } else if (context == \"local\" || !context) {\n var localBox = cm.display.sizer.getBoundingClientRect();\n left += localBox.left;\n top += localBox.top;\n }\n\n var lineSpaceBox = cm.display.lineSpace.getBoundingClientRect();\n return {left: left - lineSpaceBox.left, top: top - lineSpaceBox.top};\n }\n\n function charCoords(cm, pos, context, lineObj, bias) {\n if (!lineObj) lineObj = getLine(cm.doc, pos.line);\n return intoCoordSystem(cm, lineObj, measureChar(cm, lineObj, pos.ch, bias), context);\n }\n\n // Returns a box for a given cursor position, which may have an\n // 'other' property containing the position of the secondary cursor\n // on a bidi boundary.\n function cursorCoords(cm, pos, context, lineObj, preparedMeasure, varHeight) {\n lineObj = lineObj || getLine(cm.doc, pos.line);\n if (!preparedMeasure) preparedMeasure = prepareMeasureForLine(cm, lineObj);\n function get(ch, right) {\n var m = measureCharPrepared(cm, preparedMeasure, ch, right ? \"right\" : \"left\", varHeight);\n if (right) m.left = m.right; else m.right = m.left;\n return intoCoordSystem(cm, lineObj, m, context);\n }\n function getBidi(ch, partPos) {\n var part = order[partPos], right = part.level % 2;\n if (ch == bidiLeft(part) && partPos && part.level < order[partPos - 1].level) {\n part = order[--partPos];\n ch = bidiRight(part) - (part.level % 2 ? 0 : 1);\n right = true;\n } else if (ch == bidiRight(part) && partPos < order.length - 1 && part.level < order[partPos + 1].level) {\n part = order[++partPos];\n ch = bidiLeft(part) - part.level % 2;\n right = false;\n }\n if (right && ch == part.to && ch > part.from) return get(ch - 1);\n return get(ch, right);\n }\n var order = getOrder(lineObj), ch = pos.ch;\n if (!order) return get(ch);\n var partPos = getBidiPartAt(order, ch);\n var val = getBidi(ch, partPos);\n if (bidiOther != null) val.other = getBidi(ch, bidiOther);\n return val;\n }\n\n // Used to cheaply estimate the coordinates for a position. Used for\n // intermediate scroll updates.\n function estimateCoords(cm, pos) {\n var left = 0, pos = clipPos(cm.doc, pos);\n if (!cm.options.lineWrapping) left = charWidth(cm.display) * pos.ch;\n var lineObj = getLine(cm.doc, pos.line);\n var top = heightAtLine(lineObj) + paddingTop(cm.display);\n return {left: left, right: left, top: top, bottom: top + lineObj.height};\n }\n\n // Positions returned by coordsChar contain some extra information.\n // xRel is the relative x position of the input coordinates compared\n // to the found position (so xRel > 0 means the coordinates are to\n // the right of the character position, for example). When outside\n // is true, that means the coordinates lie outside the line's\n // vertical range.\n function PosWithInfo(line, ch, outside, xRel) {\n var pos = Pos(line, ch);\n pos.xRel = xRel;\n if (outside) pos.outside = true;\n return pos;\n }\n\n // Compute the character position closest to the given coordinates.\n // Input must be lineSpace-local (\"div\" coordinate system).\n function coordsChar(cm, x, y) {\n var doc = cm.doc;\n y += cm.display.viewOffset;\n if (y < 0) return PosWithInfo(doc.first, 0, true, -1);\n var lineN = lineAtHeight(doc, y), last = doc.first + doc.size - 1;\n if (lineN > last)\n return PosWithInfo(doc.first + doc.size - 1, getLine(doc, last).text.length, true, 1);\n if (x < 0) x = 0;\n\n var lineObj = getLine(doc, lineN);\n for (;;) {\n var found = coordsCharInner(cm, lineObj, lineN, x, y);\n var merged = collapsedSpanAtEnd(lineObj);\n var mergedPos = merged && merged.find(0, true);\n if (merged && (found.ch > mergedPos.from.ch || found.ch == mergedPos.from.ch && found.xRel > 0))\n lineN = lineNo(lineObj = mergedPos.to.line);\n else\n return found;\n }\n }\n\n function coordsCharInner(cm, lineObj, lineNo, x, y) {\n var innerOff = y - heightAtLine(lineObj);\n var wrongLine = false, adjust = 2 * cm.display.wrapper.clientWidth;\n var preparedMeasure = prepareMeasureForLine(cm, lineObj);\n\n function getX(ch) {\n var sp = cursorCoords(cm, Pos(lineNo, ch), \"line\", lineObj, preparedMeasure);\n wrongLine = true;\n if (innerOff > sp.bottom) return sp.left - adjust;\n else if (innerOff < sp.top) return sp.left + adjust;\n else wrongLine = false;\n return sp.left;\n }\n\n var bidi = getOrder(lineObj), dist = lineObj.text.length;\n var from = lineLeft(lineObj), to = lineRight(lineObj);\n var fromX = getX(from), fromOutside = wrongLine, toX = getX(to), toOutside = wrongLine;\n\n if (x > toX) return PosWithInfo(lineNo, to, toOutside, 1);\n // Do a binary search between these bounds.\n for (;;) {\n if (bidi ? to == from || to == moveVisually(lineObj, from, 1) : to - from <= 1) {\n var ch = x < fromX || x - fromX <= toX - x ? from : to;\n var outside = ch == from ? fromOutside : toOutside\n var xDiff = x - (ch == from ? fromX : toX);\n // This is a kludge to handle the case where the coordinates\n // are after a line-wrapped line. We should replace it with a\n // more general handling of cursor positions around line\n // breaks. (Issue #4078)\n if (toOutside && !bidi && !/\\s/.test(lineObj.text.charAt(ch)) && xDiff > 0 &&\n ch < lineObj.text.length && preparedMeasure.view.measure.heights.length > 1) {\n var charSize = measureCharPrepared(cm, preparedMeasure, ch, \"right\");\n if (innerOff <= charSize.bottom && innerOff >= charSize.top && Math.abs(x - charSize.right) < xDiff) {\n outside = false\n ch++\n xDiff = x - charSize.right\n }\n }\n while (isExtendingChar(lineObj.text.charAt(ch))) ++ch;\n var pos = PosWithInfo(lineNo, ch, outside, xDiff < -1 ? -1 : xDiff > 1 ? 1 : 0);\n return pos;\n }\n var step = Math.ceil(dist / 2), middle = from + step;\n if (bidi) {\n middle = from;\n for (var i = 0; i < step; ++i) middle = moveVisually(lineObj, middle, 1);\n }\n var middleX = getX(middle);\n if (middleX > x) {to = middle; toX = middleX; if (toOutside = wrongLine) toX += 1000; dist = step;}\n else {from = middle; fromX = middleX; fromOutside = wrongLine; dist -= step;}\n }\n }\n\n var measureText;\n // Compute the default text height.\n function textHeight(display) {\n if (display.cachedTextHeight != null) return display.cachedTextHeight;\n if (measureText == null) {\n measureText = elt(\"pre\");\n // Measure a bunch of lines, for browsers that compute\n // fractional heights.\n for (var i = 0; i < 49; ++i) {\n measureText.appendChild(document.createTextNode(\"x\"));\n measureText.appendChild(elt(\"br\"));\n }\n measureText.appendChild(document.createTextNode(\"x\"));\n }\n removeChildrenAndAdd(display.measure, measureText);\n var height = measureText.offsetHeight / 50;\n if (height > 3) display.cachedTextHeight = height;\n removeChildren(display.measure);\n return height || 1;\n }\n\n // Compute the default character width.\n function charWidth(display) {\n if (display.cachedCharWidth != null) return display.cachedCharWidth;\n var anchor = elt(\"span\", \"xxxxxxxxxx\");\n var pre = elt(\"pre\", [anchor]);\n removeChildrenAndAdd(display.measure, pre);\n var rect = anchor.getBoundingClientRect(), width = (rect.right - rect.left) / 10;\n if (width > 2) display.cachedCharWidth = width;\n return width || 10;\n }\n\n // OPERATIONS\n\n // Operations are used to wrap a series of changes to the editor\n // state in such a way that each change won't have to update the\n // cursor and display (which would be awkward, slow, and\n // error-prone). Instead, display updates are batched and then all\n // combined and executed at once.\n\n var operationGroup = null;\n\n var nextOpId = 0;\n // Start a new operation.\n function startOperation(cm) {\n cm.curOp = {\n cm: cm,\n viewChanged: false, // Flag that indicates that lines might need to be redrawn\n startHeight: cm.doc.height, // Used to detect need to update scrollbar\n forceUpdate: false, // Used to force a redraw\n updateInput: null, // Whether to reset the input textarea\n typing: false, // Whether this reset should be careful to leave existing text (for compositing)\n changeObjs: null, // Accumulated changes, for firing change events\n cursorActivityHandlers: null, // Set of handlers to fire cursorActivity on\n cursorActivityCalled: 0, // Tracks which cursorActivity handlers have been called already\n selectionChanged: false, // Whether the selection needs to be redrawn\n updateMaxLine: false, // Set when the widest line needs to be determined anew\n scrollLeft: null, scrollTop: null, // Intermediate scroll position, not pushed to DOM yet\n scrollToPos: null, // Used to scroll to a specific position\n focus: false,\n id: ++nextOpId // Unique ID\n };\n if (operationGroup) {\n operationGroup.ops.push(cm.curOp);\n } else {\n cm.curOp.ownsGroup = operationGroup = {\n ops: [cm.curOp],\n delayedCallbacks: []\n };\n }\n }\n\n function fireCallbacksForOps(group) {\n // Calls delayed callbacks and cursorActivity handlers until no\n // new ones appear\n var callbacks = group.delayedCallbacks, i = 0;\n do {\n for (; i < callbacks.length; i++)\n callbacks[i].call(null);\n for (var j = 0; j < group.ops.length; j++) {\n var op = group.ops[j];\n if (op.cursorActivityHandlers)\n while (op.cursorActivityCalled < op.cursorActivityHandlers.length)\n op.cursorActivityHandlers[op.cursorActivityCalled++].call(null, op.cm);\n }\n } while (i < callbacks.length);\n }\n\n // Finish an operation, updating the display and signalling delayed events\n function endOperation(cm) {\n var op = cm.curOp, group = op.ownsGroup;\n if (!group) return;\n\n try { fireCallbacksForOps(group); }\n finally {\n operationGroup = null;\n for (var i = 0; i < group.ops.length; i++)\n group.ops[i].cm.curOp = null;\n endOperations(group);\n }\n }\n\n // The DOM updates done when an operation finishes are batched so\n // that the minimum number of relayouts are required.\n function endOperations(group) {\n var ops = group.ops;\n for (var i = 0; i < ops.length; i++) // Read DOM\n endOperation_R1(ops[i]);\n for (var i = 0; i < ops.length; i++) // Write DOM (maybe)\n endOperation_W1(ops[i]);\n for (var i = 0; i < ops.length; i++) // Read DOM\n endOperation_R2(ops[i]);\n for (var i = 0; i < ops.length; i++) // Write DOM (maybe)\n endOperation_W2(ops[i]);\n for (var i = 0; i < ops.length; i++) // Read DOM\n endOperation_finish(ops[i]);\n }\n\n function endOperation_R1(op) {\n var cm = op.cm, display = cm.display;\n maybeClipScrollbars(cm);\n if (op.updateMaxLine) findMaxLine(cm);\n\n op.mustUpdate = op.viewChanged || op.forceUpdate || op.scrollTop != null ||\n op.scrollToPos && (op.scrollToPos.from.line < display.viewFrom ||\n op.scrollToPos.to.line >= display.viewTo) ||\n display.maxLineChanged && cm.options.lineWrapping;\n op.update = op.mustUpdate &&\n new DisplayUpdate(cm, op.mustUpdate && {top: op.scrollTop, ensure: op.scrollToPos}, op.forceUpdate);\n }\n\n function endOperation_W1(op) {\n op.updatedDisplay = op.mustUpdate && updateDisplayIfNeeded(op.cm, op.update);\n }\n\n function endOperation_R2(op) {\n var cm = op.cm, display = cm.display;\n if (op.updatedDisplay) updateHeightsInViewport(cm);\n\n op.barMeasure = measureForScrollbars(cm);\n\n // If the max line changed since it was last measured, measure it,\n // and ensure the document's width matches it.\n // updateDisplay_W2 will use these properties to do the actual resizing\n if (display.maxLineChanged && !cm.options.lineWrapping) {\n op.adjustWidthTo = measureChar(cm, display.maxLine, display.maxLine.text.length).left + 3;\n cm.display.sizerWidth = op.adjustWidthTo;\n op.barMeasure.scrollWidth =\n Math.max(display.scroller.clientWidth, display.sizer.offsetLeft + op.adjustWidthTo + scrollGap(cm) + cm.display.barWidth);\n op.maxScrollLeft = Math.max(0, display.sizer.offsetLeft + op.adjustWidthTo - displayWidth(cm));\n }\n\n if (op.updatedDisplay || op.selectionChanged)\n op.preparedSelection = display.input.prepareSelection(op.focus);\n }\n\n function endOperation_W2(op) {\n var cm = op.cm;\n\n if (op.adjustWidthTo != null) {\n cm.display.sizer.style.minWidth = op.adjustWidthTo + \"px\";\n if (op.maxScrollLeft < cm.doc.scrollLeft)\n setScrollLeft(cm, Math.min(cm.display.scroller.scrollLeft, op.maxScrollLeft), true);\n cm.display.maxLineChanged = false;\n }\n\n var takeFocus = op.focus && op.focus == activeElt() && (!document.hasFocus || document.hasFocus())\n if (op.preparedSelection)\n cm.display.input.showSelection(op.preparedSelection, takeFocus);\n if (op.updatedDisplay || op.startHeight != cm.doc.height)\n updateScrollbars(cm, op.barMeasure);\n if (op.updatedDisplay)\n setDocumentHeight(cm, op.barMeasure);\n\n if (op.selectionChanged) restartBlink(cm);\n\n if (cm.state.focused && op.updateInput)\n cm.display.input.reset(op.typing);\n if (takeFocus) ensureFocus(op.cm);\n }\n\n function endOperation_finish(op) {\n var cm = op.cm, display = cm.display, doc = cm.doc;\n\n if (op.updatedDisplay) postUpdateDisplay(cm, op.update);\n\n // Abort mouse wheel delta measurement, when scrolling explicitly\n if (display.wheelStartX != null && (op.scrollTop != null || op.scrollLeft != null || op.scrollToPos))\n display.wheelStartX = display.wheelStartY = null;\n\n // Propagate the scroll position to the actual DOM scroller\n if (op.scrollTop != null && (display.scroller.scrollTop != op.scrollTop || op.forceScroll)) {\n doc.scrollTop = Math.max(0, Math.min(display.scroller.scrollHeight - display.scroller.clientHeight, op.scrollTop));\n display.scrollbars.setScrollTop(doc.scrollTop);\n display.scroller.scrollTop = doc.scrollTop;\n }\n if (op.scrollLeft != null && (display.scroller.scrollLeft != op.scrollLeft || op.forceScroll)) {\n doc.scrollLeft = Math.max(0, Math.min(display.scroller.scrollWidth - display.scroller.clientWidth, op.scrollLeft));\n display.scrollbars.setScrollLeft(doc.scrollLeft);\n display.scroller.scrollLeft = doc.scrollLeft;\n alignHorizontally(cm);\n }\n // If we need to scroll a specific position into view, do so.\n if (op.scrollToPos) {\n var coords = scrollPosIntoView(cm, clipPos(doc, op.scrollToPos.from),\n clipPos(doc, op.scrollToPos.to), op.scrollToPos.margin);\n if (op.scrollToPos.isCursor && cm.state.focused) maybeScrollWindow(cm, coords);\n }\n\n // Fire events for markers that are hidden/unidden by editing or\n // undoing\n var hidden = op.maybeHiddenMarkers, unhidden = op.maybeUnhiddenMarkers;\n if (hidden) for (var i = 0; i < hidden.length; ++i)\n if (!hidden[i].lines.length) signal(hidden[i], \"hide\");\n if (unhidden) for (var i = 0; i < unhidden.length; ++i)\n if (unhidden[i].lines.length) signal(unhidden[i], \"unhide\");\n\n if (display.wrapper.offsetHeight)\n doc.scrollTop = cm.display.scroller.scrollTop;\n\n // Fire change events, and delayed event handlers\n if (op.changeObjs)\n signal(cm, \"changes\", cm, op.changeObjs);\n if (op.update)\n op.update.finish();\n }\n\n // Run the given function in an operation\n function runInOp(cm, f) {\n if (cm.curOp) return f();\n startOperation(cm);\n try { return f(); }\n finally { endOperation(cm); }\n }\n // Wraps a function in an operation. Returns the wrapped function.\n function operation(cm, f) {\n return function() {\n if (cm.curOp) return f.apply(cm, arguments);\n startOperation(cm);\n try { return f.apply(cm, arguments); }\n finally { endOperation(cm); }\n };\n }\n // Used to add methods to editor and doc instances, wrapping them in\n // operations.\n function methodOp(f) {\n return function() {\n if (this.curOp) return f.apply(this, arguments);\n startOperation(this);\n try { return f.apply(this, arguments); }\n finally { endOperation(this); }\n };\n }\n function docMethodOp(f) {\n return function() {\n var cm = this.cm;\n if (!cm || cm.curOp) return f.apply(this, arguments);\n startOperation(cm);\n try { return f.apply(this, arguments); }\n finally { endOperation(cm); }\n };\n }\n\n // VIEW TRACKING\n\n // These objects are used to represent the visible (currently drawn)\n // part of the document. A LineView may correspond to multiple\n // logical lines, if those are connected by collapsed ranges.\n function LineView(doc, line, lineN) {\n // The starting line\n this.line = line;\n // Continuing lines, if any\n this.rest = visualLineContinued(line);\n // Number of logical lines in this visual line\n this.size = this.rest ? lineNo(lst(this.rest)) - lineN + 1 : 1;\n this.node = this.text = null;\n this.hidden = lineIsHidden(doc, line);\n }\n\n // Create a range of LineView objects for the given lines.\n function buildViewArray(cm, from, to) {\n var array = [], nextPos;\n for (var pos = from; pos < to; pos = nextPos) {\n var view = new LineView(cm.doc, getLine(cm.doc, pos), pos);\n nextPos = pos + view.size;\n array.push(view);\n }\n return array;\n }\n\n // Updates the display.view data structure for a given change to the\n // document. From and to are in pre-change coordinates. Lendiff is\n // the amount of lines added or subtracted by the change. This is\n // used for changes that span multiple lines, or change the way\n // lines are divided into visual lines. regLineChange (below)\n // registers single-line changes.\n function regChange(cm, from, to, lendiff) {\n if (from == null) from = cm.doc.first;\n if (to == null) to = cm.doc.first + cm.doc.size;\n if (!lendiff) lendiff = 0;\n\n var display = cm.display;\n if (lendiff && to < display.viewTo &&\n (display.updateLineNumbers == null || display.updateLineNumbers > from))\n display.updateLineNumbers = from;\n\n cm.curOp.viewChanged = true;\n\n if (from >= display.viewTo) { // Change after\n if (sawCollapsedSpans && visualLineNo(cm.doc, from) < display.viewTo)\n resetView(cm);\n } else if (to <= display.viewFrom) { // Change before\n if (sawCollapsedSpans && visualLineEndNo(cm.doc, to + lendiff) > display.viewFrom) {\n resetView(cm);\n } else {\n display.viewFrom += lendiff;\n display.viewTo += lendiff;\n }\n } else if (from <= display.viewFrom && to >= display.viewTo) { // Full overlap\n resetView(cm);\n } else if (from <= display.viewFrom) { // Top overlap\n var cut = viewCuttingPoint(cm, to, to + lendiff, 1);\n if (cut) {\n display.view = display.view.slice(cut.index);\n display.viewFrom = cut.lineN;\n display.viewTo += lendiff;\n } else {\n resetView(cm);\n }\n } else if (to >= display.viewTo) { // Bottom overlap\n var cut = viewCuttingPoint(cm, from, from, -1);\n if (cut) {\n display.view = display.view.slice(0, cut.index);\n display.viewTo = cut.lineN;\n } else {\n resetView(cm);\n }\n } else { // Gap in the middle\n var cutTop = viewCuttingPoint(cm, from, from, -1);\n var cutBot = viewCuttingPoint(cm, to, to + lendiff, 1);\n if (cutTop && cutBot) {\n display.view = display.view.slice(0, cutTop.index)\n .concat(buildViewArray(cm, cutTop.lineN, cutBot.lineN))\n .concat(display.view.slice(cutBot.index));\n display.viewTo += lendiff;\n } else {\n resetView(cm);\n }\n }\n\n var ext = display.externalMeasured;\n if (ext) {\n if (to < ext.lineN)\n ext.lineN += lendiff;\n else if (from < ext.lineN + ext.size)\n display.externalMeasured = null;\n }\n }\n\n // Register a change to a single line. Type must be one of \"text\",\n // \"gutter\", \"class\", \"widget\"\n function regLineChange(cm, line, type) {\n cm.curOp.viewChanged = true;\n var display = cm.display, ext = cm.display.externalMeasured;\n if (ext && line >= ext.lineN && line < ext.lineN + ext.size)\n display.externalMeasured = null;\n\n if (line < display.viewFrom || line >= display.viewTo) return;\n var lineView = display.view[findViewIndex(cm, line)];\n if (lineView.node == null) return;\n var arr = lineView.changes || (lineView.changes = []);\n if (indexOf(arr, type) == -1) arr.push(type);\n }\n\n // Clear the view.\n function resetView(cm) {\n cm.display.viewFrom = cm.display.viewTo = cm.doc.first;\n cm.display.view = [];\n cm.display.viewOffset = 0;\n }\n\n // Find the view element corresponding to a given line. Return null\n // when the line isn't visible.\n function findViewIndex(cm, n) {\n if (n >= cm.display.viewTo) return null;\n n -= cm.display.viewFrom;\n if (n < 0) return null;\n var view = cm.display.view;\n for (var i = 0; i < view.length; i++) {\n n -= view[i].size;\n if (n < 0) return i;\n }\n }\n\n function viewCuttingPoint(cm, oldN, newN, dir) {\n var index = findViewIndex(cm, oldN), diff, view = cm.display.view;\n if (!sawCollapsedSpans || newN == cm.doc.first + cm.doc.size)\n return {index: index, lineN: newN};\n for (var i = 0, n = cm.display.viewFrom; i < index; i++)\n n += view[i].size;\n if (n != oldN) {\n if (dir > 0) {\n if (index == view.length - 1) return null;\n diff = (n + view[index].size) - oldN;\n index++;\n } else {\n diff = n - oldN;\n }\n oldN += diff; newN += diff;\n }\n while (visualLineNo(cm.doc, newN) != newN) {\n if (index == (dir < 0 ? 0 : view.length - 1)) return null;\n newN += dir * view[index - (dir < 0 ? 1 : 0)].size;\n index += dir;\n }\n return {index: index, lineN: newN};\n }\n\n // Force the view to cover a given range, adding empty view element\n // or clipping off existing ones as needed.\n function adjustView(cm, from, to) {\n var display = cm.display, view = display.view;\n if (view.length == 0 || from >= display.viewTo || to <= display.viewFrom) {\n display.view = buildViewArray(cm, from, to);\n display.viewFrom = from;\n } else {\n if (display.viewFrom > from)\n display.view = buildViewArray(cm, from, display.viewFrom).concat(display.view);\n else if (display.viewFrom < from)\n display.view = display.view.slice(findViewIndex(cm, from));\n display.viewFrom = from;\n if (display.viewTo < to)\n display.view = display.view.concat(buildViewArray(cm, display.viewTo, to));\n else if (display.viewTo > to)\n display.view = display.view.slice(0, findViewIndex(cm, to));\n }\n display.viewTo = to;\n }\n\n // Count the number of lines in the view whose DOM representation is\n // out of date (or nonexistent).\n function countDirtyView(cm) {\n var view = cm.display.view, dirty = 0;\n for (var i = 0; i < view.length; i++) {\n var lineView = view[i];\n if (!lineView.hidden && (!lineView.node || lineView.changes)) ++dirty;\n }\n return dirty;\n }\n\n // EVENT HANDLERS\n\n // Attach the necessary event handlers when initializing the editor\n function registerEventHandlers(cm) {\n var d = cm.display;\n on(d.scroller, \"mousedown\", operation(cm, onMouseDown));\n // Older IE's will not fire a second mousedown for a double click\n if (ie && ie_version < 11)\n on(d.scroller, \"dblclick\", operation(cm, function(e) {\n if (signalDOMEvent(cm, e)) return;\n var pos = posFromMouse(cm, e);\n if (!pos || clickInGutter(cm, e) || eventInWidget(cm.display, e)) return;\n e_preventDefault(e);\n var word = cm.findWordAt(pos);\n extendSelection(cm.doc, word.anchor, word.head);\n }));\n else\n on(d.scroller, \"dblclick\", function(e) { signalDOMEvent(cm, e) || e_preventDefault(e); });\n // Some browsers fire contextmenu *after* opening the menu, at\n // which point we can't mess with it anymore. Context menu is\n // handled in onMouseDown for these browsers.\n if (!captureRightClick) on(d.scroller, \"contextmenu\", function(e) {onContextMenu(cm, e);});\n\n // Used to suppress mouse event handling when a touch happens\n var touchFinished, prevTouch = {end: 0};\n function finishTouch() {\n if (d.activeTouch) {\n touchFinished = setTimeout(function() {d.activeTouch = null;}, 1000);\n prevTouch = d.activeTouch;\n prevTouch.end = +new Date;\n }\n };\n function isMouseLikeTouchEvent(e) {\n if (e.touches.length != 1) return false;\n var touch = e.touches[0];\n return touch.radiusX <= 1 && touch.radiusY <= 1;\n }\n function farAway(touch, other) {\n if (other.left == null) return true;\n var dx = other.left - touch.left, dy = other.top - touch.top;\n return dx * dx + dy * dy > 20 * 20;\n }\n on(d.scroller, \"touchstart\", function(e) {\n if (!signalDOMEvent(cm, e) && !isMouseLikeTouchEvent(e)) {\n clearTimeout(touchFinished);\n var now = +new Date;\n d.activeTouch = {start: now, moved: false,\n prev: now - prevTouch.end <= 300 ? prevTouch : null};\n if (e.touches.length == 1) {\n d.activeTouch.left = e.touches[0].pageX;\n d.activeTouch.top = e.touches[0].pageY;\n }\n }\n });\n on(d.scroller, \"touchmove\", function() {\n if (d.activeTouch) d.activeTouch.moved = true;\n });\n on(d.scroller, \"touchend\", function(e) {\n var touch = d.activeTouch;\n if (touch && !eventInWidget(d, e) && touch.left != null &&\n !touch.moved && new Date - touch.start < 300) {\n var pos = cm.coordsChar(d.activeTouch, \"page\"), range;\n if (!touch.prev || farAway(touch, touch.prev)) // Single tap\n range = new Range(pos, pos);\n else if (!touch.prev.prev || farAway(touch, touch.prev.prev)) // Double tap\n range = cm.findWordAt(pos);\n else // Triple tap\n range = new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0)));\n cm.setSelection(range.anchor, range.head);\n cm.focus();\n e_preventDefault(e);\n }\n finishTouch();\n });\n on(d.scroller, \"touchcancel\", finishTouch);\n\n // Sync scrolling between fake scrollbars and real scrollable\n // area, ensure viewport is updated when scrolling.\n on(d.scroller, \"scroll\", function() {\n if (d.scroller.clientHeight) {\n setScrollTop(cm, d.scroller.scrollTop);\n setScrollLeft(cm, d.scroller.scrollLeft, true);\n signal(cm, \"scroll\", cm);\n }\n });\n\n // Listen to wheel events in order to try and update the viewport on time.\n on(d.scroller, \"mousewheel\", function(e){onScrollWheel(cm, e);});\n on(d.scroller, \"DOMMouseScroll\", function(e){onScrollWheel(cm, e);});\n\n // Prevent wrapper from ever scrolling\n on(d.wrapper, \"scroll\", function() { d.wrapper.scrollTop = d.wrapper.scrollLeft = 0; });\n\n d.dragFunctions = {\n enter: function(e) {if (!signalDOMEvent(cm, e)) e_stop(e);},\n over: function(e) {if (!signalDOMEvent(cm, e)) { onDragOver(cm, e); e_stop(e); }},\n start: function(e){onDragStart(cm, e);},\n drop: operation(cm, onDrop),\n leave: function(e) {if (!signalDOMEvent(cm, e)) { clearDragCursor(cm); }}\n };\n\n var inp = d.input.getField();\n on(inp, \"keyup\", function(e) { onKeyUp.call(cm, e); });\n on(inp, \"keydown\", operation(cm, onKeyDown));\n on(inp, \"keypress\", operation(cm, onKeyPress));\n on(inp, \"focus\", bind(onFocus, cm));\n on(inp, \"blur\", bind(onBlur, cm));\n }\n\n function dragDropChanged(cm, value, old) {\n var wasOn = old && old != CodeMirror.Init;\n if (!value != !wasOn) {\n var funcs = cm.display.dragFunctions;\n var toggle = value ? on : off;\n toggle(cm.display.scroller, \"dragstart\", funcs.start);\n toggle(cm.display.scroller, \"dragenter\", funcs.enter);\n toggle(cm.display.scroller, \"dragover\", funcs.over);\n toggle(cm.display.scroller, \"dragleave\", funcs.leave);\n toggle(cm.display.scroller, \"drop\", funcs.drop);\n }\n }\n\n // Called when the window resizes\n function onResize(cm) {\n var d = cm.display;\n if (d.lastWrapHeight == d.wrapper.clientHeight && d.lastWrapWidth == d.wrapper.clientWidth)\n return;\n // Might be a text scaling operation, clear size caches.\n d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;\n d.scrollbarsClipped = false;\n cm.setSize();\n }\n\n // MOUSE EVENTS\n\n // Return true when the given mouse event happened in a widget\n function eventInWidget(display, e) {\n for (var n = e_target(e); n != display.wrapper; n = n.parentNode) {\n if (!n || (n.nodeType == 1 && n.getAttribute(\"cm-ignore-events\") == \"true\") ||\n (n.parentNode == display.sizer && n != display.mover))\n return true;\n }\n }\n\n // Given a mouse event, find the corresponding position. If liberal\n // is false, it checks whether a gutter or scrollbar was clicked,\n // and returns null if it was. forRect is used by rectangular\n // selections, and tries to estimate a character position even for\n // coordinates beyond the right of the text.\n function posFromMouse(cm, e, liberal, forRect) {\n var display = cm.display;\n if (!liberal && e_target(e).getAttribute(\"cm-not-content\") == \"true\") return null;\n\n var x, y, space = display.lineSpace.getBoundingClientRect();\n // Fails unpredictably on IE[67] when mouse is dragged around quickly.\n try { x = e.clientX - space.left; y = e.clientY - space.top; }\n catch (e) { return null; }\n var coords = coordsChar(cm, x, y), line;\n if (forRect && coords.xRel == 1 && (line = getLine(cm.doc, coords.line).text).length == coords.ch) {\n var colDiff = countColumn(line, line.length, cm.options.tabSize) - line.length;\n coords = Pos(coords.line, Math.max(0, Math.round((x - paddingH(cm.display).left) / charWidth(cm.display)) - colDiff));\n }\n return coords;\n }\n\n // A mouse down can be a single click, double click, triple click,\n // start of selection drag, start of text drag, new cursor\n // (ctrl-click), rectangle drag (alt-drag), or xwin\n // middle-click-paste. Or it might be a click on something we should\n // not interfere with, such as a scrollbar or widget.\n function onMouseDown(e) {\n var cm = this, display = cm.display;\n if (signalDOMEvent(cm, e) || display.activeTouch && display.input.supportsTouch()) return;\n display.shift = e.shiftKey;\n\n if (eventInWidget(display, e)) {\n if (!webkit) {\n // Briefly turn off draggability, to allow widgets to do\n // normal dragging things.\n display.scroller.draggable = false;\n setTimeout(function(){display.scroller.draggable = true;}, 100);\n }\n return;\n }\n if (clickInGutter(cm, e)) return;\n var start = posFromMouse(cm, e);\n window.focus();\n\n switch (e_button(e)) {\n case 1:\n // #3261: make sure, that we're not starting a second selection\n if (cm.state.selectingText)\n cm.state.selectingText(e);\n else if (start)\n leftButtonDown(cm, e, start);\n else if (e_target(e) == display.scroller)\n e_preventDefault(e);\n break;\n case 2:\n if (webkit) cm.state.lastMiddleDown = +new Date;\n if (start) extendSelection(cm.doc, start);\n setTimeout(function() {display.input.focus();}, 20);\n e_preventDefault(e);\n break;\n case 3:\n if (captureRightClick) onContextMenu(cm, e);\n else delayBlurEvent(cm);\n break;\n }\n }\n\n var lastClick, lastDoubleClick;\n function leftButtonDown(cm, e, start) {\n if (ie) setTimeout(bind(ensureFocus, cm), 0);\n else cm.curOp.focus = activeElt();\n\n var now = +new Date, type;\n if (lastDoubleClick && lastDoubleClick.time > now - 400 && cmp(lastDoubleClick.pos, start) == 0) {\n type = \"triple\";\n } else if (lastClick && lastClick.time > now - 400 && cmp(lastClick.pos, start) == 0) {\n type = \"double\";\n lastDoubleClick = {time: now, pos: start};\n } else {\n type = \"single\";\n lastClick = {time: now, pos: start};\n }\n\n var sel = cm.doc.sel, modifier = mac ? e.metaKey : e.ctrlKey, contained;\n if (cm.options.dragDrop && dragAndDrop && !cm.isReadOnly() &&\n type == \"single\" && (contained = sel.contains(start)) > -1 &&\n (cmp((contained = sel.ranges[contained]).from(), start) < 0 || start.xRel > 0) &&\n (cmp(contained.to(), start) > 0 || start.xRel < 0))\n leftButtonStartDrag(cm, e, start, modifier);\n else\n leftButtonSelect(cm, e, start, type, modifier);\n }\n\n // Start a text drag. When it ends, see if any dragging actually\n // happen, and treat as a click if it didn't.\n function leftButtonStartDrag(cm, e, start, modifier) {\n var display = cm.display, startTime = +new Date;\n var dragEnd = operation(cm, function(e2) {\n if (webkit) display.scroller.draggable = false;\n cm.state.draggingText = false;\n off(document, \"mouseup\", dragEnd);\n off(display.scroller, \"drop\", dragEnd);\n if (Math.abs(e.clientX - e2.clientX) + Math.abs(e.clientY - e2.clientY) < 10) {\n e_preventDefault(e2);\n if (!modifier && +new Date - 200 < startTime)\n extendSelection(cm.doc, start);\n // Work around unexplainable focus problem in IE9 (#2127) and Chrome (#3081)\n if (webkit || ie && ie_version == 9)\n setTimeout(function() {document.body.focus(); display.input.focus();}, 20);\n else\n display.input.focus();\n }\n });\n // Let the drag handler handle this.\n if (webkit) display.scroller.draggable = true;\n cm.state.draggingText = dragEnd;\n dragEnd.copy = mac ? e.altKey : e.ctrlKey\n // IE's approach to draggable\n if (display.scroller.dragDrop) display.scroller.dragDrop();\n on(document, \"mouseup\", dragEnd);\n on(display.scroller, \"drop\", dragEnd);\n }\n\n // Normal selection, as opposed to text dragging.\n function leftButtonSelect(cm, e, start, type, addNew) {\n var display = cm.display, doc = cm.doc;\n e_preventDefault(e);\n\n var ourRange, ourIndex, startSel = doc.sel, ranges = startSel.ranges;\n if (addNew && !e.shiftKey) {\n ourIndex = doc.sel.contains(start);\n if (ourIndex > -1)\n ourRange = ranges[ourIndex];\n else\n ourRange = new Range(start, start);\n } else {\n ourRange = doc.sel.primary();\n ourIndex = doc.sel.primIndex;\n }\n\n if (chromeOS ? e.shiftKey && e.metaKey : e.altKey) {\n type = \"rect\";\n if (!addNew) ourRange = new Range(start, start);\n start = posFromMouse(cm, e, true, true);\n ourIndex = -1;\n } else if (type == \"double\") {\n var word = cm.findWordAt(start);\n if (cm.display.shift || doc.extend)\n ourRange = extendRange(doc, ourRange, word.anchor, word.head);\n else\n ourRange = word;\n } else if (type == \"triple\") {\n var line = new Range(Pos(start.line, 0), clipPos(doc, Pos(start.line + 1, 0)));\n if (cm.display.shift || doc.extend)\n ourRange = extendRange(doc, ourRange, line.anchor, line.head);\n else\n ourRange = line;\n } else {\n ourRange = extendRange(doc, ourRange, start);\n }\n\n if (!addNew) {\n ourIndex = 0;\n setSelection(doc, new Selection([ourRange], 0), sel_mouse);\n startSel = doc.sel;\n } else if (ourIndex == -1) {\n ourIndex = ranges.length;\n setSelection(doc, normalizeSelection(ranges.concat([ourRange]), ourIndex),\n {scroll: false, origin: \"*mouse\"});\n } else if (ranges.length > 1 && ranges[ourIndex].empty() && type == \"single\" && !e.shiftKey) {\n setSelection(doc, normalizeSelection(ranges.slice(0, ourIndex).concat(ranges.slice(ourIndex + 1)), 0),\n {scroll: false, origin: \"*mouse\"});\n startSel = doc.sel;\n } else {\n replaceOneSelection(doc, ourIndex, ourRange, sel_mouse);\n }\n\n var lastPos = start;\n function extendTo(pos) {\n if (cmp(lastPos, pos) == 0) return;\n lastPos = pos;\n\n if (type == \"rect\") {\n var ranges = [], tabSize = cm.options.tabSize;\n var startCol = countColumn(getLine(doc, start.line).text, start.ch, tabSize);\n var posCol = countColumn(getLine(doc, pos.line).text, pos.ch, tabSize);\n var left = Math.min(startCol, posCol), right = Math.max(startCol, posCol);\n for (var line = Math.min(start.line, pos.line), end = Math.min(cm.lastLine(), Math.max(start.line, pos.line));\n line <= end; line++) {\n var text = getLine(doc, line).text, leftPos = findColumn(text, left, tabSize);\n if (left == right)\n ranges.push(new Range(Pos(line, leftPos), Pos(line, leftPos)));\n else if (text.length > leftPos)\n ranges.push(new Range(Pos(line, leftPos), Pos(line, findColumn(text, right, tabSize))));\n }\n if (!ranges.length) ranges.push(new Range(start, start));\n setSelection(doc, normalizeSelection(startSel.ranges.slice(0, ourIndex).concat(ranges), ourIndex),\n {origin: \"*mouse\", scroll: false});\n cm.scrollIntoView(pos);\n } else {\n var oldRange = ourRange;\n var anchor = oldRange.anchor, head = pos;\n if (type != \"single\") {\n if (type == \"double\")\n var range = cm.findWordAt(pos);\n else\n var range = new Range(Pos(pos.line, 0), clipPos(doc, Pos(pos.line + 1, 0)));\n if (cmp(range.anchor, anchor) > 0) {\n head = range.head;\n anchor = minPos(oldRange.from(), range.anchor);\n } else {\n head = range.anchor;\n anchor = maxPos(oldRange.to(), range.head);\n }\n }\n var ranges = startSel.ranges.slice(0);\n ranges[ourIndex] = new Range(clipPos(doc, anchor), head);\n setSelection(doc, normalizeSelection(ranges, ourIndex), sel_mouse);\n }\n }\n\n var editorSize = display.wrapper.getBoundingClientRect();\n // Used to ensure timeout re-tries don't fire when another extend\n // happened in the meantime (clearTimeout isn't reliable -- at\n // least on Chrome, the timeouts still happen even when cleared,\n // if the clear happens after their scheduled firing time).\n var counter = 0;\n\n function extend(e) {\n var curCount = ++counter;\n var cur = posFromMouse(cm, e, true, type == \"rect\");\n if (!cur) return;\n if (cmp(cur, lastPos) != 0) {\n cm.curOp.focus = activeElt();\n extendTo(cur);\n var visible = visibleLines(display, doc);\n if (cur.line >= visible.to || cur.line < visible.from)\n setTimeout(operation(cm, function(){if (counter == curCount) extend(e);}), 150);\n } else {\n var outside = e.clientY < editorSize.top ? -20 : e.clientY > editorSize.bottom ? 20 : 0;\n if (outside) setTimeout(operation(cm, function() {\n if (counter != curCount) return;\n display.scroller.scrollTop += outside;\n extend(e);\n }), 50);\n }\n }\n\n function done(e) {\n cm.state.selectingText = false;\n counter = Infinity;\n e_preventDefault(e);\n display.input.focus();\n off(document, \"mousemove\", move);\n off(document, \"mouseup\", up);\n doc.history.lastSelOrigin = null;\n }\n\n var move = operation(cm, function(e) {\n if (!e_button(e)) done(e);\n else extend(e);\n });\n var up = operation(cm, done);\n cm.state.selectingText = up;\n on(document, \"mousemove\", move);\n on(document, \"mouseup\", up);\n }\n\n // Determines whether an event happened in the gutter, and fires the\n // handlers for the corresponding event.\n function gutterEvent(cm, e, type, prevent) {\n try { var mX = e.clientX, mY = e.clientY; }\n catch(e) { return false; }\n if (mX >= Math.floor(cm.display.gutters.getBoundingClientRect().right)) return false;\n if (prevent) e_preventDefault(e);\n\n var display = cm.display;\n var lineBox = display.lineDiv.getBoundingClientRect();\n\n if (mY > lineBox.bottom || !hasHandler(cm, type)) return e_defaultPrevented(e);\n mY -= lineBox.top - display.viewOffset;\n\n for (var i = 0; i < cm.options.gutters.length; ++i) {\n var g = display.gutters.childNodes[i];\n if (g && g.getBoundingClientRect().right >= mX) {\n var line = lineAtHeight(cm.doc, mY);\n var gutter = cm.options.gutters[i];\n signal(cm, type, cm, line, gutter, e);\n return e_defaultPrevented(e);\n }\n }\n }\n\n function clickInGutter(cm, e) {\n return gutterEvent(cm, e, \"gutterClick\", true);\n }\n\n // Kludge to work around strange IE behavior where it'll sometimes\n // re-fire a series of drag-related events right after the drop (#1551)\n var lastDrop = 0;\n\n function onDrop(e) {\n var cm = this;\n clearDragCursor(cm);\n if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e))\n return;\n e_preventDefault(e);\n if (ie) lastDrop = +new Date;\n var pos = posFromMouse(cm, e, true), files = e.dataTransfer.files;\n if (!pos || cm.isReadOnly()) return;\n // Might be a file drop, in which case we simply extract the text\n // and insert it.\n if (files && files.length && window.FileReader && window.File) {\n var n = files.length, text = Array(n), read = 0;\n var loadFile = function(file, i) {\n if (cm.options.allowDropFileTypes &&\n indexOf(cm.options.allowDropFileTypes, file.type) == -1)\n return;\n\n var reader = new FileReader;\n reader.onload = operation(cm, function() {\n var content = reader.result;\n if (/[\\x00-\\x08\\x0e-\\x1f]{2}/.test(content)) content = \"\";\n text[i] = content;\n if (++read == n) {\n pos = clipPos(cm.doc, pos);\n var change = {from: pos, to: pos,\n text: cm.doc.splitLines(text.join(cm.doc.lineSeparator())),\n origin: \"paste\"};\n makeChange(cm.doc, change);\n setSelectionReplaceHistory(cm.doc, simpleSelection(pos, changeEnd(change)));\n }\n });\n reader.readAsText(file);\n };\n for (var i = 0; i < n; ++i) loadFile(files[i], i);\n } else { // Normal drop\n // Don't do a replace if the drop happened inside of the selected text.\n if (cm.state.draggingText && cm.doc.sel.contains(pos) > -1) {\n cm.state.draggingText(e);\n // Ensure the editor is re-focused\n setTimeout(function() {cm.display.input.focus();}, 20);\n return;\n }\n try {\n var text = e.dataTransfer.getData(\"Text\");\n if (text) {\n if (cm.state.draggingText && !cm.state.draggingText.copy)\n var selected = cm.listSelections();\n setSelectionNoUndo(cm.doc, simpleSelection(pos, pos));\n if (selected) for (var i = 0; i < selected.length; ++i)\n replaceRange(cm.doc, \"\", selected[i].anchor, selected[i].head, \"drag\");\n cm.replaceSelection(text, \"around\", \"paste\");\n cm.display.input.focus();\n }\n }\n catch(e){}\n }\n }\n\n function onDragStart(cm, e) {\n if (ie && (!cm.state.draggingText || +new Date - lastDrop < 100)) { e_stop(e); return; }\n if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) return;\n\n e.dataTransfer.setData(\"Text\", cm.getSelection());\n e.dataTransfer.effectAllowed = \"copyMove\"\n\n // Use dummy image instead of default browsers image.\n // Recent Safari (~6.0.2) have a tendency to segfault when this happens, so we don't do it there.\n if (e.dataTransfer.setDragImage && !safari) {\n var img = elt(\"img\", null, null, \"position: fixed; left: 0; top: 0;\");\n img.src = \"data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\";\n if (presto) {\n img.width = img.height = 1;\n cm.display.wrapper.appendChild(img);\n // Force a relayout, or Opera won't use our image for some obscure reason\n img._top = img.offsetTop;\n }\n e.dataTransfer.setDragImage(img, 0, 0);\n if (presto) img.parentNode.removeChild(img);\n }\n }\n\n function onDragOver(cm, e) {\n var pos = posFromMouse(cm, e);\n if (!pos) return;\n var frag = document.createDocumentFragment();\n drawSelectionCursor(cm, pos, frag);\n if (!cm.display.dragCursor) {\n cm.display.dragCursor = elt(\"div\", null, \"CodeMirror-cursors CodeMirror-dragcursors\");\n cm.display.lineSpace.insertBefore(cm.display.dragCursor, cm.display.cursorDiv);\n }\n removeChildrenAndAdd(cm.display.dragCursor, frag);\n }\n\n function clearDragCursor(cm) {\n if (cm.display.dragCursor) {\n cm.display.lineSpace.removeChild(cm.display.dragCursor);\n cm.display.dragCursor = null;\n }\n }\n\n // SCROLL EVENTS\n\n // Sync the scrollable area and scrollbars, ensure the viewport\n // covers the visible area.\n function setScrollTop(cm, val) {\n if (Math.abs(cm.doc.scrollTop - val) < 2) return;\n cm.doc.scrollTop = val;\n if (!gecko) updateDisplaySimple(cm, {top: val});\n if (cm.display.scroller.scrollTop != val) cm.display.scroller.scrollTop = val;\n cm.display.scrollbars.setScrollTop(val);\n if (gecko) updateDisplaySimple(cm);\n startWorker(cm, 100);\n }\n // Sync scroller and scrollbar, ensure the gutter elements are\n // aligned.\n function setScrollLeft(cm, val, isScroller) {\n if (isScroller ? val == cm.doc.scrollLeft : Math.abs(cm.doc.scrollLeft - val) < 2) return;\n val = Math.min(val, cm.display.scroller.scrollWidth - cm.display.scroller.clientWidth);\n cm.doc.scrollLeft = val;\n alignHorizontally(cm);\n if (cm.display.scroller.scrollLeft != val) cm.display.scroller.scrollLeft = val;\n cm.display.scrollbars.setScrollLeft(val);\n }\n\n // Since the delta values reported on mouse wheel events are\n // unstandardized between browsers and even browser versions, and\n // generally horribly unpredictable, this code starts by measuring\n // the scroll effect that the first few mouse wheel events have,\n // and, from that, detects the way it can convert deltas to pixel\n // offsets afterwards.\n //\n // The reason we want to know the amount a wheel event will scroll\n // is that it gives us a chance to update the display before the\n // actual scrolling happens, reducing flickering.\n\n var wheelSamples = 0, wheelPixelsPerUnit = null;\n // Fill in a browser-detected starting value on browsers where we\n // know one. These don't have to be accurate -- the result of them\n // being wrong would just be a slight flicker on the first wheel\n // scroll (if it is large enough).\n if (ie) wheelPixelsPerUnit = -.53;\n else if (gecko) wheelPixelsPerUnit = 15;\n else if (chrome) wheelPixelsPerUnit = -.7;\n else if (safari) wheelPixelsPerUnit = -1/3;\n\n var wheelEventDelta = function(e) {\n var dx = e.wheelDeltaX, dy = e.wheelDeltaY;\n if (dx == null && e.detail && e.axis == e.HORIZONTAL_AXIS) dx = e.detail;\n if (dy == null && e.detail && e.axis == e.VERTICAL_AXIS) dy = e.detail;\n else if (dy == null) dy = e.wheelDelta;\n return {x: dx, y: dy};\n };\n CodeMirror.wheelEventPixels = function(e) {\n var delta = wheelEventDelta(e);\n delta.x *= wheelPixelsPerUnit;\n delta.y *= wheelPixelsPerUnit;\n return delta;\n };\n\n function onScrollWheel(cm, e) {\n var delta = wheelEventDelta(e), dx = delta.x, dy = delta.y;\n\n var display = cm.display, scroll = display.scroller;\n // Quit if there's nothing to scroll here\n var canScrollX = scroll.scrollWidth > scroll.clientWidth;\n var canScrollY = scroll.scrollHeight > scroll.clientHeight;\n if (!(dx && canScrollX || dy && canScrollY)) return;\n\n // Webkit browsers on OS X abort momentum scrolls when the target\n // of the scroll event is removed from the scrollable element.\n // This hack (see related code in patchDisplay) makes sure the\n // element is kept around.\n if (dy && mac && webkit) {\n outer: for (var cur = e.target, view = display.view; cur != scroll; cur = cur.parentNode) {\n for (var i = 0; i < view.length; i++) {\n if (view[i].node == cur) {\n cm.display.currentWheelTarget = cur;\n break outer;\n }\n }\n }\n }\n\n // On some browsers, horizontal scrolling will cause redraws to\n // happen before the gutter has been realigned, causing it to\n // wriggle around in a most unseemly way. When we have an\n // estimated pixels/delta value, we just handle horizontal\n // scrolling entirely here. It'll be slightly off from native, but\n // better than glitching out.\n if (dx && !gecko && !presto && wheelPixelsPerUnit != null) {\n if (dy && canScrollY)\n setScrollTop(cm, Math.max(0, Math.min(scroll.scrollTop + dy * wheelPixelsPerUnit, scroll.scrollHeight - scroll.clientHeight)));\n setScrollLeft(cm, Math.max(0, Math.min(scroll.scrollLeft + dx * wheelPixelsPerUnit, scroll.scrollWidth - scroll.clientWidth)));\n // Only prevent default scrolling if vertical scrolling is\n // actually possible. Otherwise, it causes vertical scroll\n // jitter on OSX trackpads when deltaX is small and deltaY\n // is large (issue #3579)\n if (!dy || (dy && canScrollY))\n e_preventDefault(e);\n display.wheelStartX = null; // Abort measurement, if in progress\n return;\n }\n\n // 'Project' the visible viewport to cover the area that is being\n // scrolled into view (if we know enough to estimate it).\n if (dy && wheelPixelsPerUnit != null) {\n var pixels = dy * wheelPixelsPerUnit;\n var top = cm.doc.scrollTop, bot = top + display.wrapper.clientHeight;\n if (pixels < 0) top = Math.max(0, top + pixels - 50);\n else bot = Math.min(cm.doc.height, bot + pixels + 50);\n updateDisplaySimple(cm, {top: top, bottom: bot});\n }\n\n if (wheelSamples < 20) {\n if (display.wheelStartX == null) {\n display.wheelStartX = scroll.scrollLeft; display.wheelStartY = scroll.scrollTop;\n display.wheelDX = dx; display.wheelDY = dy;\n setTimeout(function() {\n if (display.wheelStartX == null) return;\n var movedX = scroll.scrollLeft - display.wheelStartX;\n var movedY = scroll.scrollTop - display.wheelStartY;\n var sample = (movedY && display.wheelDY && movedY / display.wheelDY) ||\n (movedX && display.wheelDX && movedX / display.wheelDX);\n display.wheelStartX = display.wheelStartY = null;\n if (!sample) return;\n wheelPixelsPerUnit = (wheelPixelsPerUnit * wheelSamples + sample) / (wheelSamples + 1);\n ++wheelSamples;\n }, 200);\n } else {\n display.wheelDX += dx; display.wheelDY += dy;\n }\n }\n }\n\n // KEY EVENTS\n\n // Run a handler that was bound to a key.\n function doHandleBinding(cm, bound, dropShift) {\n if (typeof bound == \"string\") {\n bound = commands[bound];\n if (!bound) return false;\n }\n // Ensure previous input has been read, so that the handler sees a\n // consistent view of the document\n cm.display.input.ensurePolled();\n var prevShift = cm.display.shift, done = false;\n try {\n if (cm.isReadOnly()) cm.state.suppressEdits = true;\n if (dropShift) cm.display.shift = false;\n done = bound(cm) != Pass;\n } finally {\n cm.display.shift = prevShift;\n cm.state.suppressEdits = false;\n }\n return done;\n }\n\n function lookupKeyForEditor(cm, name, handle) {\n for (var i = 0; i < cm.state.keyMaps.length; i++) {\n var result = lookupKey(name, cm.state.keyMaps[i], handle, cm);\n if (result) return result;\n }\n return (cm.options.extraKeys && lookupKey(name, cm.options.extraKeys, handle, cm))\n || lookupKey(name, cm.options.keyMap, handle, cm);\n }\n\n var stopSeq = new Delayed;\n function dispatchKey(cm, name, e, handle) {\n var seq = cm.state.keySeq;\n if (seq) {\n if (isModifierKey(name)) return \"handled\";\n stopSeq.set(50, function() {\n if (cm.state.keySeq == seq) {\n cm.state.keySeq = null;\n cm.display.input.reset();\n }\n });\n name = seq + \" \" + name;\n }\n var result = lookupKeyForEditor(cm, name, handle);\n\n if (result == \"multi\")\n cm.state.keySeq = name;\n if (result == \"handled\")\n signalLater(cm, \"keyHandled\", cm, name, e);\n\n if (result == \"handled\" || result == \"multi\") {\n e_preventDefault(e);\n restartBlink(cm);\n }\n\n if (seq && !result && /\\'$/.test(name)) {\n e_preventDefault(e);\n return true;\n }\n return !!result;\n }\n\n // Handle a key from the keydown event.\n function handleKeyBinding(cm, e) {\n var name = keyName(e, true);\n if (!name) return false;\n\n if (e.shiftKey && !cm.state.keySeq) {\n // First try to resolve full name (including 'Shift-'). Failing\n // that, see if there is a cursor-motion command (starting with\n // 'go') bound to the keyname without 'Shift-'.\n return dispatchKey(cm, \"Shift-\" + name, e, function(b) {return doHandleBinding(cm, b, true);})\n || dispatchKey(cm, name, e, function(b) {\n if (typeof b == \"string\" ? /^go[A-Z]/.test(b) : b.motion)\n return doHandleBinding(cm, b);\n });\n } else {\n return dispatchKey(cm, name, e, function(b) { return doHandleBinding(cm, b); });\n }\n }\n\n // Handle a key from the keypress event\n function handleCharBinding(cm, e, ch) {\n return dispatchKey(cm, \"'\" + ch + \"'\", e,\n function(b) { return doHandleBinding(cm, b, true); });\n }\n\n var lastStoppedKey = null;\n function onKeyDown(e) {\n var cm = this;\n cm.curOp.focus = activeElt();\n if (signalDOMEvent(cm, e)) return;\n // IE does strange things with escape.\n if (ie && ie_version < 11 && e.keyCode == 27) e.returnValue = false;\n var code = e.keyCode;\n cm.display.shift = code == 16 || e.shiftKey;\n var handled = handleKeyBinding(cm, e);\n if (presto) {\n lastStoppedKey = handled ? code : null;\n // Opera has no cut event... we try to at least catch the key combo\n if (!handled && code == 88 && !hasCopyEvent && (mac ? e.metaKey : e.ctrlKey))\n cm.replaceSelection(\"\", null, \"cut\");\n }\n\n // Turn mouse into crosshair when Alt is held on Mac.\n if (code == 18 && !/\\bCodeMirror-crosshair\\b/.test(cm.display.lineDiv.className))\n showCrossHair(cm);\n }\n\n function showCrossHair(cm) {\n var lineDiv = cm.display.lineDiv;\n addClass(lineDiv, \"CodeMirror-crosshair\");\n\n function up(e) {\n if (e.keyCode == 18 || !e.altKey) {\n rmClass(lineDiv, \"CodeMirror-crosshair\");\n off(document, \"keyup\", up);\n off(document, \"mouseover\", up);\n }\n }\n on(document, \"keyup\", up);\n on(document, \"mouseover\", up);\n }\n\n function onKeyUp(e) {\n if (e.keyCode == 16) this.doc.sel.shift = false;\n signalDOMEvent(this, e);\n }\n\n function onKeyPress(e) {\n var cm = this;\n if (eventInWidget(cm.display, e) || signalDOMEvent(cm, e) || e.ctrlKey && !e.altKey || mac && e.metaKey) return;\n var keyCode = e.keyCode, charCode = e.charCode;\n if (presto && keyCode == lastStoppedKey) {lastStoppedKey = null; e_preventDefault(e); return;}\n if ((presto && (!e.which || e.which < 10)) && handleKeyBinding(cm, e)) return;\n var ch = String.fromCharCode(charCode == null ? keyCode : charCode);\n if (handleCharBinding(cm, e, ch)) return;\n cm.display.input.onKeyPress(e);\n }\n\n // FOCUS/BLUR EVENTS\n\n function delayBlurEvent(cm) {\n cm.state.delayingBlurEvent = true;\n setTimeout(function() {\n if (cm.state.delayingBlurEvent) {\n cm.state.delayingBlurEvent = false;\n onBlur(cm);\n }\n }, 100);\n }\n\n function onFocus(cm) {\n if (cm.state.delayingBlurEvent) cm.state.delayingBlurEvent = false;\n\n if (cm.options.readOnly == \"nocursor\") return;\n if (!cm.state.focused) {\n signal(cm, \"focus\", cm);\n cm.state.focused = true;\n addClass(cm.display.wrapper, \"CodeMirror-focused\");\n // This test prevents this from firing when a context\n // menu is closed (since the input reset would kill the\n // select-all detection hack)\n if (!cm.curOp && cm.display.selForContextMenu != cm.doc.sel) {\n cm.display.input.reset();\n if (webkit) setTimeout(function() { cm.display.input.reset(true); }, 20); // Issue #1730\n }\n cm.display.input.receivedFocus();\n }\n restartBlink(cm);\n }\n function onBlur(cm) {\n if (cm.state.delayingBlurEvent) return;\n\n if (cm.state.focused) {\n signal(cm, \"blur\", cm);\n cm.state.focused = false;\n rmClass(cm.display.wrapper, \"CodeMirror-focused\");\n }\n clearInterval(cm.display.blinker);\n setTimeout(function() {if (!cm.state.focused) cm.display.shift = false;}, 150);\n }\n\n // CONTEXT MENU HANDLING\n\n // To make the context menu work, we need to briefly unhide the\n // textarea (making it as unobtrusive as possible) to let the\n // right-click take effect on it.\n function onContextMenu(cm, e) {\n if (eventInWidget(cm.display, e) || contextMenuInGutter(cm, e)) return;\n if (signalDOMEvent(cm, e, \"contextmenu\")) return;\n cm.display.input.onContextMenu(e);\n }\n\n function contextMenuInGutter(cm, e) {\n if (!hasHandler(cm, \"gutterContextMenu\")) return false;\n return gutterEvent(cm, e, \"gutterContextMenu\", false);\n }\n\n // UPDATING\n\n // Compute the position of the end of a change (its 'to' property\n // refers to the pre-change end).\n var changeEnd = CodeMirror.changeEnd = function(change) {\n if (!change.text) return change.to;\n return Pos(change.from.line + change.text.length - 1,\n lst(change.text).length + (change.text.length == 1 ? change.from.ch : 0));\n };\n\n // Adjust a position to refer to the post-change position of the\n // same text, or the end of the change if the change covers it.\n function adjustForChange(pos, change) {\n if (cmp(pos, change.from) < 0) return pos;\n if (cmp(pos, change.to) <= 0) return changeEnd(change);\n\n var line = pos.line + change.text.length - (change.to.line - change.from.line) - 1, ch = pos.ch;\n if (pos.line == change.to.line) ch += changeEnd(change).ch - change.to.ch;\n return Pos(line, ch);\n }\n\n function computeSelAfterChange(doc, change) {\n var out = [];\n for (var i = 0; i < doc.sel.ranges.length; i++) {\n var range = doc.sel.ranges[i];\n out.push(new Range(adjustForChange(range.anchor, change),\n adjustForChange(range.head, change)));\n }\n return normalizeSelection(out, doc.sel.primIndex);\n }\n\n function offsetPos(pos, old, nw) {\n if (pos.line == old.line)\n return Pos(nw.line, pos.ch - old.ch + nw.ch);\n else\n return Pos(nw.line + (pos.line - old.line), pos.ch);\n }\n\n // Used by replaceSelections to allow moving the selection to the\n // start or around the replaced test. Hint may be \"start\" or \"around\".\n function computeReplacedSel(doc, changes, hint) {\n var out = [];\n var oldPrev = Pos(doc.first, 0), newPrev = oldPrev;\n for (var i = 0; i < changes.length; i++) {\n var change = changes[i];\n var from = offsetPos(change.from, oldPrev, newPrev);\n var to = offsetPos(changeEnd(change), oldPrev, newPrev);\n oldPrev = change.to;\n newPrev = to;\n if (hint == \"around\") {\n var range = doc.sel.ranges[i], inv = cmp(range.head, range.anchor) < 0;\n out[i] = new Range(inv ? to : from, inv ? from : to);\n } else {\n out[i] = new Range(from, from);\n }\n }\n return new Selection(out, doc.sel.primIndex);\n }\n\n // Allow \"beforeChange\" event handlers to influence a change\n function filterChange(doc, change, update) {\n var obj = {\n canceled: false,\n from: change.from,\n to: change.to,\n text: change.text,\n origin: change.origin,\n cancel: function() { this.canceled = true; }\n };\n if (update) obj.update = function(from, to, text, origin) {\n if (from) this.from = clipPos(doc, from);\n if (to) this.to = clipPos(doc, to);\n if (text) this.text = text;\n if (origin !== undefined) this.origin = origin;\n };\n signal(doc, \"beforeChange\", doc, obj);\n if (doc.cm) signal(doc.cm, \"beforeChange\", doc.cm, obj);\n\n if (obj.canceled) return null;\n return {from: obj.from, to: obj.to, text: obj.text, origin: obj.origin};\n }\n\n // Apply a change to a document, and add it to the document's\n // history, and propagating it to all linked documents.\n function makeChange(doc, change, ignoreReadOnly) {\n if (doc.cm) {\n if (!doc.cm.curOp) return operation(doc.cm, makeChange)(doc, change, ignoreReadOnly);\n if (doc.cm.state.suppressEdits) return;\n }\n\n if (hasHandler(doc, \"beforeChange\") || doc.cm && hasHandler(doc.cm, \"beforeChange\")) {\n change = filterChange(doc, change, true);\n if (!change) return;\n }\n\n // Possibly split or suppress the update based on the presence\n // of read-only spans in its range.\n var split = sawReadOnlySpans && !ignoreReadOnly && removeReadOnlyRanges(doc, change.from, change.to);\n if (split) {\n for (var i = split.length - 1; i >= 0; --i)\n makeChangeInner(doc, {from: split[i].from, to: split[i].to, text: i ? [\"\"] : change.text});\n } else {\n makeChangeInner(doc, change);\n }\n }\n\n function makeChangeInner(doc, change) {\n if (change.text.length == 1 && change.text[0] == \"\" && cmp(change.from, change.to) == 0) return;\n var selAfter = computeSelAfterChange(doc, change);\n addChangeToHistory(doc, change, selAfter, doc.cm ? doc.cm.curOp.id : NaN);\n\n makeChangeSingleDoc(doc, change, selAfter, stretchSpansOverChange(doc, change));\n var rebased = [];\n\n linkedDocs(doc, function(doc, sharedHist) {\n if (!sharedHist && indexOf(rebased, doc.history) == -1) {\n rebaseHist(doc.history, change);\n rebased.push(doc.history);\n }\n makeChangeSingleDoc(doc, change, null, stretchSpansOverChange(doc, change));\n });\n }\n\n // Revert a change stored in a document's history.\n function makeChangeFromHistory(doc, type, allowSelectionOnly) {\n if (doc.cm && doc.cm.state.suppressEdits && !allowSelectionOnly) return;\n\n var hist = doc.history, event, selAfter = doc.sel;\n var source = type == \"undo\" ? hist.done : hist.undone, dest = type == \"undo\" ? hist.undone : hist.done;\n\n // Verify that there is a useable event (so that ctrl-z won't\n // needlessly clear selection events)\n for (var i = 0; i < source.length; i++) {\n event = source[i];\n if (allowSelectionOnly ? event.ranges && !event.equals(doc.sel) : !event.ranges)\n break;\n }\n if (i == source.length) return;\n hist.lastOrigin = hist.lastSelOrigin = null;\n\n for (;;) {\n event = source.pop();\n if (event.ranges) {\n pushSelectionToHistory(event, dest);\n if (allowSelectionOnly && !event.equals(doc.sel)) {\n setSelection(doc, event, {clearRedo: false});\n return;\n }\n selAfter = event;\n }\n else break;\n }\n\n // Build up a reverse change object to add to the opposite history\n // stack (redo when undoing, and vice versa).\n var antiChanges = [];\n pushSelectionToHistory(selAfter, dest);\n dest.push({changes: antiChanges, generation: hist.generation});\n hist.generation = event.generation || ++hist.maxGeneration;\n\n var filter = hasHandler(doc, \"beforeChange\") || doc.cm && hasHandler(doc.cm, \"beforeChange\");\n\n for (var i = event.changes.length - 1; i >= 0; --i) {\n var change = event.changes[i];\n change.origin = type;\n if (filter && !filterChange(doc, change, false)) {\n source.length = 0;\n return;\n }\n\n antiChanges.push(historyChangeFromChange(doc, change));\n\n var after = i ? computeSelAfterChange(doc, change) : lst(source);\n makeChangeSingleDoc(doc, change, after, mergeOldSpans(doc, change));\n if (!i && doc.cm) doc.cm.scrollIntoView({from: change.from, to: changeEnd(change)});\n var rebased = [];\n\n // Propagate to the linked documents\n linkedDocs(doc, function(doc, sharedHist) {\n if (!sharedHist && indexOf(rebased, doc.history) == -1) {\n rebaseHist(doc.history, change);\n rebased.push(doc.history);\n }\n makeChangeSingleDoc(doc, change, null, mergeOldSpans(doc, change));\n });\n }\n }\n\n // Sub-views need their line numbers shifted when text is added\n // above or below them in the parent document.\n function shiftDoc(doc, distance) {\n if (distance == 0) return;\n doc.first += distance;\n doc.sel = new Selection(map(doc.sel.ranges, function(range) {\n return new Range(Pos(range.anchor.line + distance, range.anchor.ch),\n Pos(range.head.line + distance, range.head.ch));\n }), doc.sel.primIndex);\n if (doc.cm) {\n regChange(doc.cm, doc.first, doc.first - distance, distance);\n for (var d = doc.cm.display, l = d.viewFrom; l < d.viewTo; l++)\n regLineChange(doc.cm, l, \"gutter\");\n }\n }\n\n // More lower-level change function, handling only a single document\n // (not linked ones).\n function makeChangeSingleDoc(doc, change, selAfter, spans) {\n if (doc.cm && !doc.cm.curOp)\n return operation(doc.cm, makeChangeSingleDoc)(doc, change, selAfter, spans);\n\n if (change.to.line < doc.first) {\n shiftDoc(doc, change.text.length - 1 - (change.to.line - change.from.line));\n return;\n }\n if (change.from.line > doc.lastLine()) return;\n\n // Clip the change to the size of this doc\n if (change.from.line < doc.first) {\n var shift = change.text.length - 1 - (doc.first - change.from.line);\n shiftDoc(doc, shift);\n change = {from: Pos(doc.first, 0), to: Pos(change.to.line + shift, change.to.ch),\n text: [lst(change.text)], origin: change.origin};\n }\n var last = doc.lastLine();\n if (change.to.line > last) {\n change = {from: change.from, to: Pos(last, getLine(doc, last).text.length),\n text: [change.text[0]], origin: change.origin};\n }\n\n change.removed = getBetween(doc, change.from, change.to);\n\n if (!selAfter) selAfter = computeSelAfterChange(doc, change);\n if (doc.cm) makeChangeSingleDocInEditor(doc.cm, change, spans);\n else updateDoc(doc, change, spans);\n setSelectionNoUndo(doc, selAfter, sel_dontScroll);\n }\n\n // Handle the interaction of a change to a document with the editor\n // that this document is part of.\n function makeChangeSingleDocInEditor(cm, change, spans) {\n var doc = cm.doc, display = cm.display, from = change.from, to = change.to;\n\n var recomputeMaxLength = false, checkWidthStart = from.line;\n if (!cm.options.lineWrapping) {\n checkWidthStart = lineNo(visualLine(getLine(doc, from.line)));\n doc.iter(checkWidthStart, to.line + 1, function(line) {\n if (line == display.maxLine) {\n recomputeMaxLength = true;\n return true;\n }\n });\n }\n\n if (doc.sel.contains(change.from, change.to) > -1)\n signalCursorActivity(cm);\n\n updateDoc(doc, change, spans, estimateHeight(cm));\n\n if (!cm.options.lineWrapping) {\n doc.iter(checkWidthStart, from.line + change.text.length, function(line) {\n var len = lineLength(line);\n if (len > display.maxLineLength) {\n display.maxLine = line;\n display.maxLineLength = len;\n display.maxLineChanged = true;\n recomputeMaxLength = false;\n }\n });\n if (recomputeMaxLength) cm.curOp.updateMaxLine = true;\n }\n\n // Adjust frontier, schedule worker\n doc.frontier = Math.min(doc.frontier, from.line);\n startWorker(cm, 400);\n\n var lendiff = change.text.length - (to.line - from.line) - 1;\n // Remember that these lines changed, for updating the display\n if (change.full)\n regChange(cm);\n else if (from.line == to.line && change.text.length == 1 && !isWholeLineUpdate(cm.doc, change))\n regLineChange(cm, from.line, \"text\");\n else\n regChange(cm, from.line, to.line + 1, lendiff);\n\n var changesHandler = hasHandler(cm, \"changes\"), changeHandler = hasHandler(cm, \"change\");\n if (changeHandler || changesHandler) {\n var obj = {\n from: from, to: to,\n text: change.text,\n removed: change.removed,\n origin: change.origin\n };\n if (changeHandler) signalLater(cm, \"change\", cm, obj);\n if (changesHandler) (cm.curOp.changeObjs || (cm.curOp.changeObjs = [])).push(obj);\n }\n cm.display.selForContextMenu = null;\n }\n\n function replaceRange(doc, code, from, to, origin) {\n if (!to) to = from;\n if (cmp(to, from) < 0) { var tmp = to; to = from; from = tmp; }\n if (typeof code == \"string\") code = doc.splitLines(code);\n makeChange(doc, {from: from, to: to, text: code, origin: origin});\n }\n\n // SCROLLING THINGS INTO VIEW\n\n // If an editor sits on the top or bottom of the window, partially\n // scrolled out of view, this ensures that the cursor is visible.\n function maybeScrollWindow(cm, coords) {\n if (signalDOMEvent(cm, \"scrollCursorIntoView\")) return;\n\n var display = cm.display, box = display.sizer.getBoundingClientRect(), doScroll = null;\n if (coords.top + box.top < 0) doScroll = true;\n else if (coords.bottom + box.top > (window.innerHeight || document.documentElement.clientHeight)) doScroll = false;\n if (doScroll != null && !phantom) {\n var scrollNode = elt(\"div\", \"\\u200b\", null, \"position: absolute; top: \" +\n (coords.top - display.viewOffset - paddingTop(cm.display)) + \"px; height: \" +\n (coords.bottom - coords.top + scrollGap(cm) + display.barHeight) + \"px; left: \" +\n coords.left + \"px; width: 2px;\");\n cm.display.lineSpace.appendChild(scrollNode);\n scrollNode.scrollIntoView(doScroll);\n cm.display.lineSpace.removeChild(scrollNode);\n }\n }\n\n // Scroll a given position into view (immediately), verifying that\n // it actually became visible (as line heights are accurately\n // measured, the position of something may 'drift' during drawing).\n function scrollPosIntoView(cm, pos, end, margin) {\n if (margin == null) margin = 0;\n for (var limit = 0; limit < 5; limit++) {\n var changed = false, coords = cursorCoords(cm, pos);\n var endCoords = !end || end == pos ? coords : cursorCoords(cm, end);\n var scrollPos = calculateScrollPos(cm, Math.min(coords.left, endCoords.left),\n Math.min(coords.top, endCoords.top) - margin,\n Math.max(coords.left, endCoords.left),\n Math.max(coords.bottom, endCoords.bottom) + margin);\n var startTop = cm.doc.scrollTop, startLeft = cm.doc.scrollLeft;\n if (scrollPos.scrollTop != null) {\n setScrollTop(cm, scrollPos.scrollTop);\n if (Math.abs(cm.doc.scrollTop - startTop) > 1) changed = true;\n }\n if (scrollPos.scrollLeft != null) {\n setScrollLeft(cm, scrollPos.scrollLeft);\n if (Math.abs(cm.doc.scrollLeft - startLeft) > 1) changed = true;\n }\n if (!changed) break;\n }\n return coords;\n }\n\n // Scroll a given set of coordinates into view (immediately).\n function scrollIntoView(cm, x1, y1, x2, y2) {\n var scrollPos = calculateScrollPos(cm, x1, y1, x2, y2);\n if (scrollPos.scrollTop != null) setScrollTop(cm, scrollPos.scrollTop);\n if (scrollPos.scrollLeft != null) setScrollLeft(cm, scrollPos.scrollLeft);\n }\n\n // Calculate a new scroll position needed to scroll the given\n // rectangle into view. Returns an object with scrollTop and\n // scrollLeft properties. When these are undefined, the\n // vertical/horizontal position does not need to be adjusted.\n function calculateScrollPos(cm, x1, y1, x2, y2) {\n var display = cm.display, snapMargin = textHeight(cm.display);\n if (y1 < 0) y1 = 0;\n var screentop = cm.curOp && cm.curOp.scrollTop != null ? cm.curOp.scrollTop : display.scroller.scrollTop;\n var screen = displayHeight(cm), result = {};\n if (y2 - y1 > screen) y2 = y1 + screen;\n var docBottom = cm.doc.height + paddingVert(display);\n var atTop = y1 < snapMargin, atBottom = y2 > docBottom - snapMargin;\n if (y1 < screentop) {\n result.scrollTop = atTop ? 0 : y1;\n } else if (y2 > screentop + screen) {\n var newTop = Math.min(y1, (atBottom ? docBottom : y2) - screen);\n if (newTop != screentop) result.scrollTop = newTop;\n }\n\n var screenleft = cm.curOp && cm.curOp.scrollLeft != null ? cm.curOp.scrollLeft : display.scroller.scrollLeft;\n var screenw = displayWidth(cm) - (cm.options.fixedGutter ? display.gutters.offsetWidth : 0);\n var tooWide = x2 - x1 > screenw;\n if (tooWide) x2 = x1 + screenw;\n if (x1 < 10)\n result.scrollLeft = 0;\n else if (x1 < screenleft)\n result.scrollLeft = Math.max(0, x1 - (tooWide ? 0 : 10));\n else if (x2 > screenw + screenleft - 3)\n result.scrollLeft = x2 + (tooWide ? 0 : 10) - screenw;\n return result;\n }\n\n // Store a relative adjustment to the scroll position in the current\n // operation (to be applied when the operation finishes).\n function addToScrollPos(cm, left, top) {\n if (left != null || top != null) resolveScrollToPos(cm);\n if (left != null)\n cm.curOp.scrollLeft = (cm.curOp.scrollLeft == null ? cm.doc.scrollLeft : cm.curOp.scrollLeft) + left;\n if (top != null)\n cm.curOp.scrollTop = (cm.curOp.scrollTop == null ? cm.doc.scrollTop : cm.curOp.scrollTop) + top;\n }\n\n // Make sure that at the end of the operation the current cursor is\n // shown.\n function ensureCursorVisible(cm) {\n resolveScrollToPos(cm);\n var cur = cm.getCursor(), from = cur, to = cur;\n if (!cm.options.lineWrapping) {\n from = cur.ch ? Pos(cur.line, cur.ch - 1) : cur;\n to = Pos(cur.line, cur.ch + 1);\n }\n cm.curOp.scrollToPos = {from: from, to: to, margin: cm.options.cursorScrollMargin, isCursor: true};\n }\n\n // When an operation has its scrollToPos property set, and another\n // scroll action is applied before the end of the operation, this\n // 'simulates' scrolling that position into view in a cheap way, so\n // that the effect of intermediate scroll commands is not ignored.\n function resolveScrollToPos(cm) {\n var range = cm.curOp.scrollToPos;\n if (range) {\n cm.curOp.scrollToPos = null;\n var from = estimateCoords(cm, range.from), to = estimateCoords(cm, range.to);\n var sPos = calculateScrollPos(cm, Math.min(from.left, to.left),\n Math.min(from.top, to.top) - range.margin,\n Math.max(from.right, to.right),\n Math.max(from.bottom, to.bottom) + range.margin);\n cm.scrollTo(sPos.scrollLeft, sPos.scrollTop);\n }\n }\n\n // API UTILITIES\n\n // Indent the given line. The how parameter can be \"smart\",\n // \"add\"/null, \"subtract\", or \"prev\". When aggressive is false\n // (typically set to true for forced single-line indents), empty\n // lines are not indented, and places where the mode returns Pass\n // are left alone.\n function indentLine(cm, n, how, aggressive) {\n var doc = cm.doc, state;\n if (how == null) how = \"add\";\n if (how == \"smart\") {\n // Fall back to \"prev\" when the mode doesn't have an indentation\n // method.\n if (!doc.mode.indent) how = \"prev\";\n else state = getStateBefore(cm, n);\n }\n\n var tabSize = cm.options.tabSize;\n var line = getLine(doc, n), curSpace = countColumn(line.text, null, tabSize);\n if (line.stateAfter) line.stateAfter = null;\n var curSpaceString = line.text.match(/^\\s*/)[0], indentation;\n if (!aggressive && !/\\S/.test(line.text)) {\n indentation = 0;\n how = \"not\";\n } else if (how == \"smart\") {\n indentation = doc.mode.indent(state, line.text.slice(curSpaceString.length), line.text);\n if (indentation == Pass || indentation > 150) {\n if (!aggressive) return;\n how = \"prev\";\n }\n }\n if (how == \"prev\") {\n if (n > doc.first) indentation = countColumn(getLine(doc, n-1).text, null, tabSize);\n else indentation = 0;\n } else if (how == \"add\") {\n indentation = curSpace + cm.options.indentUnit;\n } else if (how == \"subtract\") {\n indentation = curSpace - cm.options.indentUnit;\n } else if (typeof how == \"number\") {\n indentation = curSpace + how;\n }\n indentation = Math.max(0, indentation);\n\n var indentString = \"\", pos = 0;\n if (cm.options.indentWithTabs)\n for (var i = Math.floor(indentation / tabSize); i; --i) {pos += tabSize; indentString += \"\\t\";}\n if (pos < indentation) indentString += spaceStr(indentation - pos);\n\n if (indentString != curSpaceString) {\n replaceRange(doc, indentString, Pos(n, 0), Pos(n, curSpaceString.length), \"+input\");\n line.stateAfter = null;\n return true;\n } else {\n // Ensure that, if the cursor was in the whitespace at the start\n // of the line, it is moved to the end of that space.\n for (var i = 0; i < doc.sel.ranges.length; i++) {\n var range = doc.sel.ranges[i];\n if (range.head.line == n && range.head.ch < curSpaceString.length) {\n var pos = Pos(n, curSpaceString.length);\n replaceOneSelection(doc, i, new Range(pos, pos));\n break;\n }\n }\n }\n }\n\n // Utility for applying a change to a line by handle or number,\n // returning the number and optionally registering the line as\n // changed.\n function changeLine(doc, handle, changeType, op) {\n var no = handle, line = handle;\n if (typeof handle == \"number\") line = getLine(doc, clipLine(doc, handle));\n else no = lineNo(handle);\n if (no == null) return null;\n if (op(line, no) && doc.cm) regLineChange(doc.cm, no, changeType);\n return line;\n }\n\n // Helper for deleting text near the selection(s), used to implement\n // backspace, delete, and similar functionality.\n function deleteNearSelection(cm, compute) {\n var ranges = cm.doc.sel.ranges, kill = [];\n // Build up a set of ranges to kill first, merging overlapping\n // ranges.\n for (var i = 0; i < ranges.length; i++) {\n var toKill = compute(ranges[i]);\n while (kill.length && cmp(toKill.from, lst(kill).to) <= 0) {\n var replaced = kill.pop();\n if (cmp(replaced.from, toKill.from) < 0) {\n toKill.from = replaced.from;\n break;\n }\n }\n kill.push(toKill);\n }\n // Next, remove those actual ranges.\n runInOp(cm, function() {\n for (var i = kill.length - 1; i >= 0; i--)\n replaceRange(cm.doc, \"\", kill[i].from, kill[i].to, \"+delete\");\n ensureCursorVisible(cm);\n });\n }\n\n // Used for horizontal relative motion. Dir is -1 or 1 (left or\n // right), unit can be \"char\", \"column\" (like char, but doesn't\n // cross line boundaries), \"word\" (across next word), or \"group\" (to\n // the start of next group of word or non-word-non-whitespace\n // chars). The visually param controls whether, in right-to-left\n // text, direction 1 means to move towards the next index in the\n // string, or towards the character to the right of the current\n // position. The resulting position will have a hitSide=true\n // property if it reached the end of the document.\n function findPosH(doc, pos, dir, unit, visually) {\n var line = pos.line, ch = pos.ch, origDir = dir;\n var lineObj = getLine(doc, line);\n function findNextLine() {\n var l = line + dir;\n if (l < doc.first || l >= doc.first + doc.size) return false\n line = l;\n return lineObj = getLine(doc, l);\n }\n function moveOnce(boundToLine) {\n var next = (visually ? moveVisually : moveLogically)(lineObj, ch, dir, true);\n if (next == null) {\n if (!boundToLine && findNextLine()) {\n if (visually) ch = (dir < 0 ? lineRight : lineLeft)(lineObj);\n else ch = dir < 0 ? lineObj.text.length : 0;\n } else return false\n } else ch = next;\n return true;\n }\n\n if (unit == \"char\") {\n moveOnce()\n } else if (unit == \"column\") {\n moveOnce(true)\n } else if (unit == \"word\" || unit == \"group\") {\n var sawType = null, group = unit == \"group\";\n var helper = doc.cm && doc.cm.getHelper(pos, \"wordChars\");\n for (var first = true;; first = false) {\n if (dir < 0 && !moveOnce(!first)) break;\n var cur = lineObj.text.charAt(ch) || \"\\n\";\n var type = isWordChar(cur, helper) ? \"w\"\n : group && cur == \"\\n\" ? \"n\"\n : !group || /\\s/.test(cur) ? null\n : \"p\";\n if (group && !first && !type) type = \"s\";\n if (sawType && sawType != type) {\n if (dir < 0) {dir = 1; moveOnce();}\n break;\n }\n\n if (type) sawType = type;\n if (dir > 0 && !moveOnce(!first)) break;\n }\n }\n var result = skipAtomic(doc, Pos(line, ch), pos, origDir, true);\n if (!cmp(pos, result)) result.hitSide = true;\n return result;\n }\n\n // For relative vertical movement. Dir may be -1 or 1. Unit can be\n // \"page\" or \"line\". The resulting position will have a hitSide=true\n // property if it reached the end of the document.\n function findPosV(cm, pos, dir, unit) {\n var doc = cm.doc, x = pos.left, y;\n if (unit == \"page\") {\n var pageSize = Math.min(cm.display.wrapper.clientHeight, window.innerHeight || document.documentElement.clientHeight);\n y = pos.top + dir * (pageSize - (dir < 0 ? 1.5 : .5) * textHeight(cm.display));\n } else if (unit == \"line\") {\n y = dir > 0 ? pos.bottom + 3 : pos.top - 3;\n }\n for (;;) {\n var target = coordsChar(cm, x, y);\n if (!target.outside) break;\n if (dir < 0 ? y <= 0 : y >= doc.height) { target.hitSide = true; break; }\n y += dir * 5;\n }\n return target;\n }\n\n // EDITOR METHODS\n\n // The publicly visible API. Note that methodOp(f) means\n // 'wrap f in an operation, performed on its `this` parameter'.\n\n // This is not the complete set of editor methods. Most of the\n // methods defined on the Doc type are also injected into\n // CodeMirror.prototype, for backwards compatibility and\n // convenience.\n\n CodeMirror.prototype = {\n constructor: CodeMirror,\n focus: function(){window.focus(); this.display.input.focus();},\n\n setOption: function(option, value) {\n var options = this.options, old = options[option];\n if (options[option] == value && option != \"mode\") return;\n options[option] = value;\n if (optionHandlers.hasOwnProperty(option))\n operation(this, optionHandlers[option])(this, value, old);\n },\n\n getOption: function(option) {return this.options[option];},\n getDoc: function() {return this.doc;},\n\n addKeyMap: function(map, bottom) {\n this.state.keyMaps[bottom ? \"push\" : \"unshift\"](getKeyMap(map));\n },\n removeKeyMap: function(map) {\n var maps = this.state.keyMaps;\n for (var i = 0; i < maps.length; ++i)\n if (maps[i] == map || maps[i].name == map) {\n maps.splice(i, 1);\n return true;\n }\n },\n\n addOverlay: methodOp(function(spec, options) {\n var mode = spec.token ? spec : CodeMirror.getMode(this.options, spec);\n if (mode.startState) throw new Error(\"Overlays may not be stateful.\");\n this.state.overlays.push({mode: mode, modeSpec: spec, opaque: options && options.opaque});\n this.state.modeGen++;\n regChange(this);\n }),\n removeOverlay: methodOp(function(spec) {\n var overlays = this.state.overlays;\n for (var i = 0; i < overlays.length; ++i) {\n var cur = overlays[i].modeSpec;\n if (cur == spec || typeof spec == \"string\" && cur.name == spec) {\n overlays.splice(i, 1);\n this.state.modeGen++;\n regChange(this);\n return;\n }\n }\n }),\n\n indentLine: methodOp(function(n, dir, aggressive) {\n if (typeof dir != \"string\" && typeof dir != \"number\") {\n if (dir == null) dir = this.options.smartIndent ? \"smart\" : \"prev\";\n else dir = dir ? \"add\" : \"subtract\";\n }\n if (isLine(this.doc, n)) indentLine(this, n, dir, aggressive);\n }),\n indentSelection: methodOp(function(how) {\n var ranges = this.doc.sel.ranges, end = -1;\n for (var i = 0; i < ranges.length; i++) {\n var range = ranges[i];\n if (!range.empty()) {\n var from = range.from(), to = range.to();\n var start = Math.max(end, from.line);\n end = Math.min(this.lastLine(), to.line - (to.ch ? 0 : 1)) + 1;\n for (var j = start; j < end; ++j)\n indentLine(this, j, how);\n var newRanges = this.doc.sel.ranges;\n if (from.ch == 0 && ranges.length == newRanges.length && newRanges[i].from().ch > 0)\n replaceOneSelection(this.doc, i, new Range(from, newRanges[i].to()), sel_dontScroll);\n } else if (range.head.line > end) {\n indentLine(this, range.head.line, how, true);\n end = range.head.line;\n if (i == this.doc.sel.primIndex) ensureCursorVisible(this);\n }\n }\n }),\n\n // Fetch the parser token for a given character. Useful for hacks\n // that want to inspect the mode state (say, for completion).\n getTokenAt: function(pos, precise) {\n return takeToken(this, pos, precise);\n },\n\n getLineTokens: function(line, precise) {\n return takeToken(this, Pos(line), precise, true);\n },\n\n getTokenTypeAt: function(pos) {\n pos = clipPos(this.doc, pos);\n var styles = getLineStyles(this, getLine(this.doc, pos.line));\n var before = 0, after = (styles.length - 1) / 2, ch = pos.ch;\n var type;\n if (ch == 0) type = styles[2];\n else for (;;) {\n var mid = (before + after) >> 1;\n if ((mid ? styles[mid * 2 - 1] : 0) >= ch) after = mid;\n else if (styles[mid * 2 + 1] < ch) before = mid + 1;\n else { type = styles[mid * 2 + 2]; break; }\n }\n var cut = type ? type.indexOf(\"cm-overlay \") : -1;\n return cut < 0 ? type : cut == 0 ? null : type.slice(0, cut - 1);\n },\n\n getModeAt: function(pos) {\n var mode = this.doc.mode;\n if (!mode.innerMode) return mode;\n return CodeMirror.innerMode(mode, this.getTokenAt(pos).state).mode;\n },\n\n getHelper: function(pos, type) {\n return this.getHelpers(pos, type)[0];\n },\n\n getHelpers: function(pos, type) {\n var found = [];\n if (!helpers.hasOwnProperty(type)) return found;\n var help = helpers[type], mode = this.getModeAt(pos);\n if (typeof mode[type] == \"string\") {\n if (help[mode[type]]) found.push(help[mode[type]]);\n } else if (mode[type]) {\n for (var i = 0; i < mode[type].length; i++) {\n var val = help[mode[type][i]];\n if (val) found.push(val);\n }\n } else if (mode.helperType && help[mode.helperType]) {\n found.push(help[mode.helperType]);\n } else if (help[mode.name]) {\n found.push(help[mode.name]);\n }\n for (var i = 0; i < help._global.length; i++) {\n var cur = help._global[i];\n if (cur.pred(mode, this) && indexOf(found, cur.val) == -1)\n found.push(cur.val);\n }\n return found;\n },\n\n getStateAfter: function(line, precise) {\n var doc = this.doc;\n line = clipLine(doc, line == null ? doc.first + doc.size - 1: line);\n return getStateBefore(this, line + 1, precise);\n },\n\n cursorCoords: function(start, mode) {\n var pos, range = this.doc.sel.primary();\n if (start == null) pos = range.head;\n else if (typeof start == \"object\") pos = clipPos(this.doc, start);\n else pos = start ? range.from() : range.to();\n return cursorCoords(this, pos, mode || \"page\");\n },\n\n charCoords: function(pos, mode) {\n return charCoords(this, clipPos(this.doc, pos), mode || \"page\");\n },\n\n coordsChar: function(coords, mode) {\n coords = fromCoordSystem(this, coords, mode || \"page\");\n return coordsChar(this, coords.left, coords.top);\n },\n\n lineAtHeight: function(height, mode) {\n height = fromCoordSystem(this, {top: height, left: 0}, mode || \"page\").top;\n return lineAtHeight(this.doc, height + this.display.viewOffset);\n },\n heightAtLine: function(line, mode) {\n var end = false, lineObj;\n if (typeof line == \"number\") {\n var last = this.doc.first + this.doc.size - 1;\n if (line < this.doc.first) line = this.doc.first;\n else if (line > last) { line = last; end = true; }\n lineObj = getLine(this.doc, line);\n } else {\n lineObj = line;\n }\n return intoCoordSystem(this, lineObj, {top: 0, left: 0}, mode || \"page\").top +\n (end ? this.doc.height - heightAtLine(lineObj) : 0);\n },\n\n defaultTextHeight: function() { return textHeight(this.display); },\n defaultCharWidth: function() { return charWidth(this.display); },\n\n setGutterMarker: methodOp(function(line, gutterID, value) {\n return changeLine(this.doc, line, \"gutter\", function(line) {\n var markers = line.gutterMarkers || (line.gutterMarkers = {});\n markers[gutterID] = value;\n if (!value && isEmpty(markers)) line.gutterMarkers = null;\n return true;\n });\n }),\n\n clearGutter: methodOp(function(gutterID) {\n var cm = this, doc = cm.doc, i = doc.first;\n doc.iter(function(line) {\n if (line.gutterMarkers && line.gutterMarkers[gutterID]) {\n line.gutterMarkers[gutterID] = null;\n regLineChange(cm, i, \"gutter\");\n if (isEmpty(line.gutterMarkers)) line.gutterMarkers = null;\n }\n ++i;\n });\n }),\n\n lineInfo: function(line) {\n if (typeof line == \"number\") {\n if (!isLine(this.doc, line)) return null;\n var n = line;\n line = getLine(this.doc, line);\n if (!line) return null;\n } else {\n var n = lineNo(line);\n if (n == null) return null;\n }\n return {line: n, handle: line, text: line.text, gutterMarkers: line.gutterMarkers,\n textClass: line.textClass, bgClass: line.bgClass, wrapClass: line.wrapClass,\n widgets: line.widgets};\n },\n\n getViewport: function() { return {from: this.display.viewFrom, to: this.display.viewTo};},\n\n addWidget: function(pos, node, scroll, vert, horiz) {\n var display = this.display;\n pos = cursorCoords(this, clipPos(this.doc, pos));\n var top = pos.bottom, left = pos.left;\n node.style.position = \"absolute\";\n node.setAttribute(\"cm-ignore-events\", \"true\");\n this.display.input.setUneditable(node);\n display.sizer.appendChild(node);\n if (vert == \"over\") {\n top = pos.top;\n } else if (vert == \"above\" || vert == \"near\") {\n var vspace = Math.max(display.wrapper.clientHeight, this.doc.height),\n hspace = Math.max(display.sizer.clientWidth, display.lineSpace.clientWidth);\n // Default to positioning above (if specified and possible); otherwise default to positioning below\n if ((vert == 'above' || pos.bottom + node.offsetHeight > vspace) && pos.top > node.offsetHeight)\n top = pos.top - node.offsetHeight;\n else if (pos.bottom + node.offsetHeight <= vspace)\n top = pos.bottom;\n if (left + node.offsetWidth > hspace)\n left = hspace - node.offsetWidth;\n }\n node.style.top = top + \"px\";\n node.style.left = node.style.right = \"\";\n if (horiz == \"right\") {\n left = display.sizer.clientWidth - node.offsetWidth;\n node.style.right = \"0px\";\n } else {\n if (horiz == \"left\") left = 0;\n else if (horiz == \"middle\") left = (display.sizer.clientWidth - node.offsetWidth) / 2;\n node.style.left = left + \"px\";\n }\n if (scroll)\n scrollIntoView(this, left, top, left + node.offsetWidth, top + node.offsetHeight);\n },\n\n triggerOnKeyDown: methodOp(onKeyDown),\n triggerOnKeyPress: methodOp(onKeyPress),\n triggerOnKeyUp: onKeyUp,\n\n execCommand: function(cmd) {\n if (commands.hasOwnProperty(cmd))\n return commands[cmd].call(null, this);\n },\n\n triggerElectric: methodOp(function(text) { triggerElectric(this, text); }),\n\n findPosH: function(from, amount, unit, visually) {\n var dir = 1;\n if (amount < 0) { dir = -1; amount = -amount; }\n for (var i = 0, cur = clipPos(this.doc, from); i < amount; ++i) {\n cur = findPosH(this.doc, cur, dir, unit, visually);\n if (cur.hitSide) break;\n }\n return cur;\n },\n\n moveH: methodOp(function(dir, unit) {\n var cm = this;\n cm.extendSelectionsBy(function(range) {\n if (cm.display.shift || cm.doc.extend || range.empty())\n return findPosH(cm.doc, range.head, dir, unit, cm.options.rtlMoveVisually);\n else\n return dir < 0 ? range.from() : range.to();\n }, sel_move);\n }),\n\n deleteH: methodOp(function(dir, unit) {\n var sel = this.doc.sel, doc = this.doc;\n if (sel.somethingSelected())\n doc.replaceSelection(\"\", null, \"+delete\");\n else\n deleteNearSelection(this, function(range) {\n var other = findPosH(doc, range.head, dir, unit, false);\n return dir < 0 ? {from: other, to: range.head} : {from: range.head, to: other};\n });\n }),\n\n findPosV: function(from, amount, unit, goalColumn) {\n var dir = 1, x = goalColumn;\n if (amount < 0) { dir = -1; amount = -amount; }\n for (var i = 0, cur = clipPos(this.doc, from); i < amount; ++i) {\n var coords = cursorCoords(this, cur, \"div\");\n if (x == null) x = coords.left;\n else coords.left = x;\n cur = findPosV(this, coords, dir, unit);\n if (cur.hitSide) break;\n }\n return cur;\n },\n\n moveV: methodOp(function(dir, unit) {\n var cm = this, doc = this.doc, goals = [];\n var collapse = !cm.display.shift && !doc.extend && doc.sel.somethingSelected();\n doc.extendSelectionsBy(function(range) {\n if (collapse)\n return dir < 0 ? range.from() : range.to();\n var headPos = cursorCoords(cm, range.head, \"div\");\n if (range.goalColumn != null) headPos.left = range.goalColumn;\n goals.push(headPos.left);\n var pos = findPosV(cm, headPos, dir, unit);\n if (unit == \"page\" && range == doc.sel.primary())\n addToScrollPos(cm, null, charCoords(cm, pos, \"div\").top - headPos.top);\n return pos;\n }, sel_move);\n if (goals.length) for (var i = 0; i < doc.sel.ranges.length; i++)\n doc.sel.ranges[i].goalColumn = goals[i];\n }),\n\n // Find the word at the given position (as returned by coordsChar).\n findWordAt: function(pos) {\n var doc = this.doc, line = getLine(doc, pos.line).text;\n var start = pos.ch, end = pos.ch;\n if (line) {\n var helper = this.getHelper(pos, \"wordChars\");\n if ((pos.xRel < 0 || end == line.length) && start) --start; else ++end;\n var startChar = line.charAt(start);\n var check = isWordChar(startChar, helper)\n ? function(ch) { return isWordChar(ch, helper); }\n : /\\s/.test(startChar) ? function(ch) {return /\\s/.test(ch);}\n : function(ch) {return !/\\s/.test(ch) && !isWordChar(ch);};\n while (start > 0 && check(line.charAt(start - 1))) --start;\n while (end < line.length && check(line.charAt(end))) ++end;\n }\n return new Range(Pos(pos.line, start), Pos(pos.line, end));\n },\n\n toggleOverwrite: function(value) {\n if (value != null && value == this.state.overwrite) return;\n if (this.state.overwrite = !this.state.overwrite)\n addClass(this.display.cursorDiv, \"CodeMirror-overwrite\");\n else\n rmClass(this.display.cursorDiv, \"CodeMirror-overwrite\");\n\n signal(this, \"overwriteToggle\", this, this.state.overwrite);\n },\n hasFocus: function() { return this.display.input.getField() == activeElt(); },\n isReadOnly: function() { return !!(this.options.readOnly || this.doc.cantEdit); },\n\n scrollTo: methodOp(function(x, y) {\n if (x != null || y != null) resolveScrollToPos(this);\n if (x != null) this.curOp.scrollLeft = x;\n if (y != null) this.curOp.scrollTop = y;\n }),\n getScrollInfo: function() {\n var scroller = this.display.scroller;\n return {left: scroller.scrollLeft, top: scroller.scrollTop,\n height: scroller.scrollHeight - scrollGap(this) - this.display.barHeight,\n width: scroller.scrollWidth - scrollGap(this) - this.display.barWidth,\n clientHeight: displayHeight(this), clientWidth: displayWidth(this)};\n },\n\n scrollIntoView: methodOp(function(range, margin) {\n if (range == null) {\n range = {from: this.doc.sel.primary().head, to: null};\n if (margin == null) margin = this.options.cursorScrollMargin;\n } else if (typeof range == \"number\") {\n range = {from: Pos(range, 0), to: null};\n } else if (range.from == null) {\n range = {from: range, to: null};\n }\n if (!range.to) range.to = range.from;\n range.margin = margin || 0;\n\n if (range.from.line != null) {\n resolveScrollToPos(this);\n this.curOp.scrollToPos = range;\n } else {\n var sPos = calculateScrollPos(this, Math.min(range.from.left, range.to.left),\n Math.min(range.from.top, range.to.top) - range.margin,\n Math.max(range.from.right, range.to.right),\n Math.max(range.from.bottom, range.to.bottom) + range.margin);\n this.scrollTo(sPos.scrollLeft, sPos.scrollTop);\n }\n }),\n\n setSize: methodOp(function(width, height) {\n var cm = this;\n function interpret(val) {\n return typeof val == \"number\" || /^\\d+$/.test(String(val)) ? val + \"px\" : val;\n }\n if (width != null) cm.display.wrapper.style.width = interpret(width);\n if (height != null) cm.display.wrapper.style.height = interpret(height);\n if (cm.options.lineWrapping) clearLineMeasurementCache(this);\n var lineNo = cm.display.viewFrom;\n cm.doc.iter(lineNo, cm.display.viewTo, function(line) {\n if (line.widgets) for (var i = 0; i < line.widgets.length; i++)\n if (line.widgets[i].noHScroll) { regLineChange(cm, lineNo, \"widget\"); break; }\n ++lineNo;\n });\n cm.curOp.forceUpdate = true;\n signal(cm, \"refresh\", this);\n }),\n\n operation: function(f){return runInOp(this, f);},\n\n refresh: methodOp(function() {\n var oldHeight = this.display.cachedTextHeight;\n regChange(this);\n this.curOp.forceUpdate = true;\n clearCaches(this);\n this.scrollTo(this.doc.scrollLeft, this.doc.scrollTop);\n updateGutterSpace(this);\n if (oldHeight == null || Math.abs(oldHeight - textHeight(this.display)) > .5)\n estimateLineHeights(this);\n signal(this, \"refresh\", this);\n }),\n\n swapDoc: methodOp(function(doc) {\n var old = this.doc;\n old.cm = null;\n attachDoc(this, doc);\n clearCaches(this);\n this.display.input.reset();\n this.scrollTo(doc.scrollLeft, doc.scrollTop);\n this.curOp.forceScroll = true;\n signalLater(this, \"swapDoc\", this, old);\n return old;\n }),\n\n getInputField: function(){return this.display.input.getField();},\n getWrapperElement: function(){return this.display.wrapper;},\n getScrollerElement: function(){return this.display.scroller;},\n getGutterElement: function(){return this.display.gutters;}\n };\n eventMixin(CodeMirror);\n\n // OPTION DEFAULTS\n\n // The default configuration options.\n var defaults = CodeMirror.defaults = {};\n // Functions to run when options are changed.\n var optionHandlers = CodeMirror.optionHandlers = {};\n\n function option(name, deflt, handle, notOnInit) {\n CodeMirror.defaults[name] = deflt;\n if (handle) optionHandlers[name] =\n notOnInit ? function(cm, val, old) {if (old != Init) handle(cm, val, old);} : handle;\n }\n\n // Passed to option handlers when there is no old value.\n var Init = CodeMirror.Init = {toString: function(){return \"CodeMirror.Init\";}};\n\n // These two are, on init, called from the constructor because they\n // have to be initialized before the editor can start at all.\n option(\"value\", \"\", function(cm, val) {\n cm.setValue(val);\n }, true);\n option(\"mode\", null, function(cm, val) {\n cm.doc.modeOption = val;\n loadMode(cm);\n }, true);\n\n option(\"indentUnit\", 2, loadMode, true);\n option(\"indentWithTabs\", false);\n option(\"smartIndent\", true);\n option(\"tabSize\", 4, function(cm) {\n resetModeState(cm);\n clearCaches(cm);\n regChange(cm);\n }, true);\n option(\"lineSeparator\", null, function(cm, val) {\n cm.doc.lineSep = val;\n if (!val) return;\n var newBreaks = [], lineNo = cm.doc.first;\n cm.doc.iter(function(line) {\n for (var pos = 0;;) {\n var found = line.text.indexOf(val, pos);\n if (found == -1) break;\n pos = found + val.length;\n newBreaks.push(Pos(lineNo, found));\n }\n lineNo++;\n });\n for (var i = newBreaks.length - 1; i >= 0; i--)\n replaceRange(cm.doc, val, newBreaks[i], Pos(newBreaks[i].line, newBreaks[i].ch + val.length))\n });\n option(\"specialChars\", /[\\u0000-\\u001f\\u007f\\u00ad\\u200b-\\u200f\\u2028\\u2029\\ufeff]/g, function(cm, val, old) {\n cm.state.specialChars = new RegExp(val.source + (val.test(\"\\t\") ? \"\" : \"|\\t\"), \"g\");\n if (old != CodeMirror.Init) cm.refresh();\n });\n option(\"specialCharPlaceholder\", defaultSpecialCharPlaceholder, function(cm) {cm.refresh();}, true);\n option(\"electricChars\", true);\n option(\"inputStyle\", mobile ? \"contenteditable\" : \"textarea\", function() {\n throw new Error(\"inputStyle can not (yet) be changed in a running editor\"); // FIXME\n }, true);\n option(\"rtlMoveVisually\", !windows);\n option(\"wholeLineUpdateBefore\", true);\n\n option(\"theme\", \"default\", function(cm) {\n themeChanged(cm);\n guttersChanged(cm);\n }, true);\n option(\"keyMap\", \"default\", function(cm, val, old) {\n var next = getKeyMap(val);\n var prev = old != CodeMirror.Init && getKeyMap(old);\n if (prev && prev.detach) prev.detach(cm, next);\n if (next.attach) next.attach(cm, prev || null);\n });\n option(\"extraKeys\", null);\n\n option(\"lineWrapping\", false, wrappingChanged, true);\n option(\"gutters\", [], function(cm) {\n setGuttersForLineNumbers(cm.options);\n guttersChanged(cm);\n }, true);\n option(\"fixedGutter\", true, function(cm, val) {\n cm.display.gutters.style.left = val ? compensateForHScroll(cm.display) + \"px\" : \"0\";\n cm.refresh();\n }, true);\n option(\"coverGutterNextToScrollbar\", false, function(cm) {updateScrollbars(cm);}, true);\n option(\"scrollbarStyle\", \"native\", function(cm) {\n initScrollbars(cm);\n updateScrollbars(cm);\n cm.display.scrollbars.setScrollTop(cm.doc.scrollTop);\n cm.display.scrollbars.setScrollLeft(cm.doc.scrollLeft);\n }, true);\n option(\"lineNumbers\", false, function(cm) {\n setGuttersForLineNumbers(cm.options);\n guttersChanged(cm);\n }, true);\n option(\"firstLineNumber\", 1, guttersChanged, true);\n option(\"lineNumberFormatter\", function(integer) {return integer;}, guttersChanged, true);\n option(\"showCursorWhenSelecting\", false, updateSelection, true);\n\n option(\"resetSelectionOnContextMenu\", true);\n option(\"lineWiseCopyCut\", true);\n\n option(\"readOnly\", false, function(cm, val) {\n if (val == \"nocursor\") {\n onBlur(cm);\n cm.display.input.blur();\n cm.display.disabled = true;\n } else {\n cm.display.disabled = false;\n }\n cm.display.input.readOnlyChanged(val)\n });\n option(\"disableInput\", false, function(cm, val) {if (!val) cm.display.input.reset();}, true);\n option(\"dragDrop\", true, dragDropChanged);\n option(\"allowDropFileTypes\", null);\n\n option(\"cursorBlinkRate\", 530);\n option(\"cursorScrollMargin\", 0);\n option(\"cursorHeight\", 1, updateSelection, true);\n option(\"singleCursorHeightPerLine\", true, updateSelection, true);\n option(\"workTime\", 100);\n option(\"workDelay\", 100);\n option(\"flattenSpans\", true, resetModeState, true);\n option(\"addModeClass\", false, resetModeState, true);\n option(\"pollInterval\", 100);\n option(\"undoDepth\", 200, function(cm, val){cm.doc.history.undoDepth = val;});\n option(\"historyEventDelay\", 1250);\n option(\"viewportMargin\", 10, function(cm){cm.refresh();}, true);\n option(\"maxHighlightLength\", 10000, resetModeState, true);\n option(\"moveInputWithCursor\", true, function(cm, val) {\n if (!val) cm.display.input.resetPosition();\n });\n\n option(\"tabindex\", null, function(cm, val) {\n cm.display.input.getField().tabIndex = val || \"\";\n });\n option(\"autofocus\", null);\n\n // MODE DEFINITION AND QUERYING\n\n // Known modes, by name and by MIME\n var modes = CodeMirror.modes = {}, mimeModes = CodeMirror.mimeModes = {};\n\n // Extra arguments are stored as the mode's dependencies, which is\n // used by (legacy) mechanisms like loadmode.js to automatically\n // load a mode. (Preferred mechanism is the require/define calls.)\n CodeMirror.defineMode = function(name, mode) {\n if (!CodeMirror.defaults.mode && name != \"null\") CodeMirror.defaults.mode = name;\n if (arguments.length > 2)\n mode.dependencies = Array.prototype.slice.call(arguments, 2);\n modes[name] = mode;\n };\n\n CodeMirror.defineMIME = function(mime, spec) {\n mimeModes[mime] = spec;\n };\n\n // Given a MIME type, a {name, ...options} config object, or a name\n // string, return a mode config object.\n CodeMirror.resolveMode = function(spec) {\n if (typeof spec == \"string\" && mimeModes.hasOwnProperty(spec)) {\n spec = mimeModes[spec];\n } else if (spec && typeof spec.name == \"string\" && mimeModes.hasOwnProperty(spec.name)) {\n var found = mimeModes[spec.name];\n if (typeof found == \"string\") found = {name: found};\n spec = createObj(found, spec);\n spec.name = found.name;\n } else if (typeof spec == \"string\" && /^[\\w\\-]+\\/[\\w\\-]+\\+xml$/.test(spec)) {\n return CodeMirror.resolveMode(\"application/xml\");\n }\n if (typeof spec == \"string\") return {name: spec};\n else return spec || {name: \"null\"};\n };\n\n // Given a mode spec (anything that resolveMode accepts), find and\n // initialize an actual mode object.\n CodeMirror.getMode = function(options, spec) {\n var spec = CodeMirror.resolveMode(spec);\n var mfactory = modes[spec.name];\n if (!mfactory) return CodeMirror.getMode(options, \"text/plain\");\n var modeObj = mfactory(options, spec);\n if (modeExtensions.hasOwnProperty(spec.name)) {\n var exts = modeExtensions[spec.name];\n for (var prop in exts) {\n if (!exts.hasOwnProperty(prop)) continue;\n if (modeObj.hasOwnProperty(prop)) modeObj[\"_\" + prop] = modeObj[prop];\n modeObj[prop] = exts[prop];\n }\n }\n modeObj.name = spec.name;\n if (spec.helperType) modeObj.helperType = spec.helperType;\n if (spec.modeProps) for (var prop in spec.modeProps)\n modeObj[prop] = spec.modeProps[prop];\n\n return modeObj;\n };\n\n // Minimal default mode.\n CodeMirror.defineMode(\"null\", function() {\n return {token: function(stream) {stream.skipToEnd();}};\n });\n CodeMirror.defineMIME(\"text/plain\", \"null\");\n\n // This can be used to attach properties to mode objects from\n // outside the actual mode definition.\n var modeExtensions = CodeMirror.modeExtensions = {};\n CodeMirror.extendMode = function(mode, properties) {\n var exts = modeExtensions.hasOwnProperty(mode) ? modeExtensions[mode] : (modeExtensions[mode] = {});\n copyObj(properties, exts);\n };\n\n // EXTENSIONS\n\n CodeMirror.defineExtension = function(name, func) {\n CodeMirror.prototype[name] = func;\n };\n CodeMirror.defineDocExtension = function(name, func) {\n Doc.prototype[name] = func;\n };\n CodeMirror.defineOption = option;\n\n var initHooks = [];\n CodeMirror.defineInitHook = function(f) {initHooks.push(f);};\n\n var helpers = CodeMirror.helpers = {};\n CodeMirror.registerHelper = function(type, name, value) {\n if (!helpers.hasOwnProperty(type)) helpers[type] = CodeMirror[type] = {_global: []};\n helpers[type][name] = value;\n };\n CodeMirror.registerGlobalHelper = function(type, name, predicate, value) {\n CodeMirror.registerHelper(type, name, value);\n helpers[type]._global.push({pred: predicate, val: value});\n };\n\n // MODE STATE HANDLING\n\n // Utility functions for working with state. Exported because nested\n // modes need to do this for their inner modes.\n\n var copyState = CodeMirror.copyState = function(mode, state) {\n if (state === true) return state;\n if (mode.copyState) return mode.copyState(state);\n var nstate = {};\n for (var n in state) {\n var val = state[n];\n if (val instanceof Array) val = val.concat([]);\n nstate[n] = val;\n }\n return nstate;\n };\n\n var startState = CodeMirror.startState = function(mode, a1, a2) {\n return mode.startState ? mode.startState(a1, a2) : true;\n };\n\n // Given a mode and a state (for that mode), find the inner mode and\n // state at the position that the state refers to.\n CodeMirror.innerMode = function(mode, state) {\n while (mode.innerMode) {\n var info = mode.innerMode(state);\n if (!info || info.mode == mode) break;\n state = info.state;\n mode = info.mode;\n }\n return info || {mode: mode, state: state};\n };\n\n // STANDARD COMMANDS\n\n // Commands are parameter-less actions that can be performed on an\n // editor, mostly used for keybindings.\n var commands = CodeMirror.commands = {\n selectAll: function(cm) {cm.setSelection(Pos(cm.firstLine(), 0), Pos(cm.lastLine()), sel_dontScroll);},\n singleSelection: function(cm) {\n cm.setSelection(cm.getCursor(\"anchor\"), cm.getCursor(\"head\"), sel_dontScroll);\n },\n killLine: function(cm) {\n deleteNearSelection(cm, function(range) {\n if (range.empty()) {\n var len = getLine(cm.doc, range.head.line).text.length;\n if (range.head.ch == len && range.head.line < cm.lastLine())\n return {from: range.head, to: Pos(range.head.line + 1, 0)};\n else\n return {from: range.head, to: Pos(range.head.line, len)};\n } else {\n return {from: range.from(), to: range.to()};\n }\n });\n },\n deleteLine: function(cm) {\n deleteNearSelection(cm, function(range) {\n return {from: Pos(range.from().line, 0),\n to: clipPos(cm.doc, Pos(range.to().line + 1, 0))};\n });\n },\n delLineLeft: function(cm) {\n deleteNearSelection(cm, function(range) {\n return {from: Pos(range.from().line, 0), to: range.from()};\n });\n },\n delWrappedLineLeft: function(cm) {\n deleteNearSelection(cm, function(range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n var leftPos = cm.coordsChar({left: 0, top: top}, \"div\");\n return {from: leftPos, to: range.from()};\n });\n },\n delWrappedLineRight: function(cm) {\n deleteNearSelection(cm, function(range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n var rightPos = cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, \"div\");\n return {from: range.from(), to: rightPos };\n });\n },\n undo: function(cm) {cm.undo();},\n redo: function(cm) {cm.redo();},\n undoSelection: function(cm) {cm.undoSelection();},\n redoSelection: function(cm) {cm.redoSelection();},\n goDocStart: function(cm) {cm.extendSelection(Pos(cm.firstLine(), 0));},\n goDocEnd: function(cm) {cm.extendSelection(Pos(cm.lastLine()));},\n goLineStart: function(cm) {\n cm.extendSelectionsBy(function(range) { return lineStart(cm, range.head.line); },\n {origin: \"+move\", bias: 1});\n },\n goLineStartSmart: function(cm) {\n cm.extendSelectionsBy(function(range) {\n return lineStartSmart(cm, range.head);\n }, {origin: \"+move\", bias: 1});\n },\n goLineEnd: function(cm) {\n cm.extendSelectionsBy(function(range) { return lineEnd(cm, range.head.line); },\n {origin: \"+move\", bias: -1});\n },\n goLineRight: function(cm) {\n cm.extendSelectionsBy(function(range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n return cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, \"div\");\n }, sel_move);\n },\n goLineLeft: function(cm) {\n cm.extendSelectionsBy(function(range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n return cm.coordsChar({left: 0, top: top}, \"div\");\n }, sel_move);\n },\n goLineLeftSmart: function(cm) {\n cm.extendSelectionsBy(function(range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n var pos = cm.coordsChar({left: 0, top: top}, \"div\");\n if (pos.ch < cm.getLine(pos.line).search(/\\S/)) return lineStartSmart(cm, range.head);\n return pos;\n }, sel_move);\n },\n goLineUp: function(cm) {cm.moveV(-1, \"line\");},\n goLineDown: function(cm) {cm.moveV(1, \"line\");},\n goPageUp: function(cm) {cm.moveV(-1, \"page\");},\n goPageDown: function(cm) {cm.moveV(1, \"page\");},\n goCharLeft: function(cm) {cm.moveH(-1, \"char\");},\n goCharRight: function(cm) {cm.moveH(1, \"char\");},\n goColumnLeft: function(cm) {cm.moveH(-1, \"column\");},\n goColumnRight: function(cm) {cm.moveH(1, \"column\");},\n goWordLeft: function(cm) {cm.moveH(-1, \"word\");},\n goGroupRight: function(cm) {cm.moveH(1, \"group\");},\n goGroupLeft: function(cm) {cm.moveH(-1, \"group\");},\n goWordRight: function(cm) {cm.moveH(1, \"word\");},\n delCharBefore: function(cm) {cm.deleteH(-1, \"char\");},\n delCharAfter: function(cm) {cm.deleteH(1, \"char\");},\n delWordBefore: function(cm) {cm.deleteH(-1, \"word\");},\n delWordAfter: function(cm) {cm.deleteH(1, \"word\");},\n delGroupBefore: function(cm) {cm.deleteH(-1, \"group\");},\n delGroupAfter: function(cm) {cm.deleteH(1, \"group\");},\n indentAuto: function(cm) {cm.indentSelection(\"smart\");},\n indentMore: function(cm) {cm.indentSelection(\"add\");},\n indentLess: function(cm) {cm.indentSelection(\"subtract\");},\n insertTab: function(cm) {cm.replaceSelection(\"\\t\");},\n insertSoftTab: function(cm) {\n var spaces = [], ranges = cm.listSelections(), tabSize = cm.options.tabSize;\n for (var i = 0; i < ranges.length; i++) {\n var pos = ranges[i].from();\n var col = countColumn(cm.getLine(pos.line), pos.ch, tabSize);\n spaces.push(spaceStr(tabSize - col % tabSize));\n }\n cm.replaceSelections(spaces);\n },\n defaultTab: function(cm) {\n if (cm.somethingSelected()) cm.indentSelection(\"add\");\n else cm.execCommand(\"insertTab\");\n },\n transposeChars: function(cm) {\n runInOp(cm, function() {\n var ranges = cm.listSelections(), newSel = [];\n for (var i = 0; i < ranges.length; i++) {\n var cur = ranges[i].head, line = getLine(cm.doc, cur.line).text;\n if (line) {\n if (cur.ch == line.length) cur = new Pos(cur.line, cur.ch - 1);\n if (cur.ch > 0) {\n cur = new Pos(cur.line, cur.ch + 1);\n cm.replaceRange(line.charAt(cur.ch - 1) + line.charAt(cur.ch - 2),\n Pos(cur.line, cur.ch - 2), cur, \"+transpose\");\n } else if (cur.line > cm.doc.first) {\n var prev = getLine(cm.doc, cur.line - 1).text;\n if (prev)\n cm.replaceRange(line.charAt(0) + cm.doc.lineSeparator() +\n prev.charAt(prev.length - 1),\n Pos(cur.line - 1, prev.length - 1), Pos(cur.line, 1), \"+transpose\");\n }\n }\n newSel.push(new Range(cur, cur));\n }\n cm.setSelections(newSel);\n });\n },\n newlineAndIndent: function(cm) {\n runInOp(cm, function() {\n var len = cm.listSelections().length;\n for (var i = 0; i < len; i++) {\n var range = cm.listSelections()[i];\n cm.replaceRange(cm.doc.lineSeparator(), range.anchor, range.head, \"+input\");\n cm.indentLine(range.from().line + 1, null, true);\n }\n ensureCursorVisible(cm);\n });\n },\n openLine: function(cm) {cm.replaceSelection(\"\\n\", \"start\")},\n toggleOverwrite: function(cm) {cm.toggleOverwrite();}\n };\n\n\n // STANDARD KEYMAPS\n\n var keyMap = CodeMirror.keyMap = {};\n\n keyMap.basic = {\n \"Left\": \"goCharLeft\", \"Right\": \"goCharRight\", \"Up\": \"goLineUp\", \"Down\": \"goLineDown\",\n \"End\": \"goLineEnd\", \"Home\": \"goLineStartSmart\", \"PageUp\": \"goPageUp\", \"PageDown\": \"goPageDown\",\n \"Delete\": \"delCharAfter\", \"Backspace\": \"delCharBefore\", \"Shift-Backspace\": \"delCharBefore\",\n \"Tab\": \"defaultTab\", \"Shift-Tab\": \"indentAuto\",\n \"Enter\": \"newlineAndIndent\", \"Insert\": \"toggleOverwrite\",\n \"Esc\": \"singleSelection\"\n };\n // Note that the save and find-related commands aren't defined by\n // default. User code or addons can define them. Unknown commands\n // are simply ignored.\n keyMap.pcDefault = {\n \"Ctrl-A\": \"selectAll\", \"Ctrl-D\": \"deleteLine\", \"Ctrl-Z\": \"undo\", \"Shift-Ctrl-Z\": \"redo\", \"Ctrl-Y\": \"redo\",\n \"Ctrl-Home\": \"goDocStart\", \"Ctrl-End\": \"goDocEnd\", \"Ctrl-Up\": \"goLineUp\", \"Ctrl-Down\": \"goLineDown\",\n \"Ctrl-Left\": \"goGroupLeft\", \"Ctrl-Right\": \"goGroupRight\", \"Alt-Left\": \"goLineStart\", \"Alt-Right\": \"goLineEnd\",\n \"Ctrl-Backspace\": \"delGroupBefore\", \"Ctrl-Delete\": \"delGroupAfter\", \"Ctrl-S\": \"save\", \"Ctrl-F\": \"find\",\n \"Ctrl-G\": \"findNext\", \"Shift-Ctrl-G\": \"findPrev\", \"Shift-Ctrl-F\": \"replace\", \"Shift-Ctrl-R\": \"replaceAll\",\n \"Ctrl-[\": \"indentLess\", \"Ctrl-]\": \"indentMore\",\n \"Ctrl-U\": \"undoSelection\", \"Shift-Ctrl-U\": \"redoSelection\", \"Alt-U\": \"redoSelection\",\n fallthrough: \"basic\"\n };\n // Very basic readline/emacs-style bindings, which are standard on Mac.\n keyMap.emacsy = {\n \"Ctrl-F\": \"goCharRight\", \"Ctrl-B\": \"goCharLeft\", \"Ctrl-P\": \"goLineUp\", \"Ctrl-N\": \"goLineDown\",\n \"Alt-F\": \"goWordRight\", \"Alt-B\": \"goWordLeft\", \"Ctrl-A\": \"goLineStart\", \"Ctrl-E\": \"goLineEnd\",\n \"Ctrl-V\": \"goPageDown\", \"Shift-Ctrl-V\": \"goPageUp\", \"Ctrl-D\": \"delCharAfter\", \"Ctrl-H\": \"delCharBefore\",\n \"Alt-D\": \"delWordAfter\", \"Alt-Backspace\": \"delWordBefore\", \"Ctrl-K\": \"killLine\", \"Ctrl-T\": \"transposeChars\",\n \"Ctrl-O\": \"openLine\"\n };\n keyMap.macDefault = {\n \"Cmd-A\": \"selectAll\", \"Cmd-D\": \"deleteLine\", \"Cmd-Z\": \"undo\", \"Shift-Cmd-Z\": \"redo\", \"Cmd-Y\": \"redo\",\n \"Cmd-Home\": \"goDocStart\", \"Cmd-Up\": \"goDocStart\", \"Cmd-End\": \"goDocEnd\", \"Cmd-Down\": \"goDocEnd\", \"Alt-Left\": \"goGroupLeft\",\n \"Alt-Right\": \"goGroupRight\", \"Cmd-Left\": \"goLineLeft\", \"Cmd-Right\": \"goLineRight\", \"Alt-Backspace\": \"delGroupBefore\",\n \"Ctrl-Alt-Backspace\": \"delGroupAfter\", \"Alt-Delete\": \"delGroupAfter\", \"Cmd-S\": \"save\", \"Cmd-F\": \"find\",\n \"Cmd-G\": \"findNext\", \"Shift-Cmd-G\": \"findPrev\", \"Cmd-Alt-F\": \"replace\", \"Shift-Cmd-Alt-F\": \"replaceAll\",\n \"Cmd-[\": \"indentLess\", \"Cmd-]\": \"indentMore\", \"Cmd-Backspace\": \"delWrappedLineLeft\", \"Cmd-Delete\": \"delWrappedLineRight\",\n \"Cmd-U\": \"undoSelection\", \"Shift-Cmd-U\": \"redoSelection\", \"Ctrl-Up\": \"goDocStart\", \"Ctrl-Down\": \"goDocEnd\",\n fallthrough: [\"basic\", \"emacsy\"]\n };\n keyMap[\"default\"] = mac ? keyMap.macDefault : keyMap.pcDefault;\n\n // KEYMAP DISPATCH\n\n function normalizeKeyName(name) {\n var parts = name.split(/-(?!$)/), name = parts[parts.length - 1];\n var alt, ctrl, shift, cmd;\n for (var i = 0; i < parts.length - 1; i++) {\n var mod = parts[i];\n if (/^(cmd|meta|m)$/i.test(mod)) cmd = true;\n else if (/^a(lt)?$/i.test(mod)) alt = true;\n else if (/^(c|ctrl|control)$/i.test(mod)) ctrl = true;\n else if (/^s(hift)$/i.test(mod)) shift = true;\n else throw new Error(\"Unrecognized modifier name: \" + mod);\n }\n if (alt) name = \"Alt-\" + name;\n if (ctrl) name = \"Ctrl-\" + name;\n if (cmd) name = \"Cmd-\" + name;\n if (shift) name = \"Shift-\" + name;\n return name;\n }\n\n // This is a kludge to keep keymaps mostly working as raw objects\n // (backwards compatibility) while at the same time support features\n // like normalization and multi-stroke key bindings. It compiles a\n // new normalized keymap, and then updates the old object to reflect\n // this.\n CodeMirror.normalizeKeyMap = function(keymap) {\n var copy = {};\n for (var keyname in keymap) if (keymap.hasOwnProperty(keyname)) {\n var value = keymap[keyname];\n if (/^(name|fallthrough|(de|at)tach)$/.test(keyname)) continue;\n if (value == \"...\") { delete keymap[keyname]; continue; }\n\n var keys = map(keyname.split(\" \"), normalizeKeyName);\n for (var i = 0; i < keys.length; i++) {\n var val, name;\n if (i == keys.length - 1) {\n name = keys.join(\" \");\n val = value;\n } else {\n name = keys.slice(0, i + 1).join(\" \");\n val = \"...\";\n }\n var prev = copy[name];\n if (!prev) copy[name] = val;\n else if (prev != val) throw new Error(\"Inconsistent bindings for \" + name);\n }\n delete keymap[keyname];\n }\n for (var prop in copy) keymap[prop] = copy[prop];\n return keymap;\n };\n\n var lookupKey = CodeMirror.lookupKey = function(key, map, handle, context) {\n map = getKeyMap(map);\n var found = map.call ? map.call(key, context) : map[key];\n if (found === false) return \"nothing\";\n if (found === \"...\") return \"multi\";\n if (found != null && handle(found)) return \"handled\";\n\n if (map.fallthrough) {\n if (Object.prototype.toString.call(map.fallthrough) != \"[object Array]\")\n return lookupKey(key, map.fallthrough, handle, context);\n for (var i = 0; i < map.fallthrough.length; i++) {\n var result = lookupKey(key, map.fallthrough[i], handle, context);\n if (result) return result;\n }\n }\n };\n\n // Modifier key presses don't count as 'real' key presses for the\n // purpose of keymap fallthrough.\n var isModifierKey = CodeMirror.isModifierKey = function(value) {\n var name = typeof value == \"string\" ? value : keyNames[value.keyCode];\n return name == \"Ctrl\" || name == \"Alt\" || name == \"Shift\" || name == \"Mod\";\n };\n\n // Look up the name of a key as indicated by an event object.\n var keyName = CodeMirror.keyName = function(event, noShift) {\n if (presto && event.keyCode == 34 && event[\"char\"]) return false;\n var base = keyNames[event.keyCode], name = base;\n if (name == null || event.altGraphKey) return false;\n if (event.altKey && base != \"Alt\") name = \"Alt-\" + name;\n if ((flipCtrlCmd ? event.metaKey : event.ctrlKey) && base != \"Ctrl\") name = \"Ctrl-\" + name;\n if ((flipCtrlCmd ? event.ctrlKey : event.metaKey) && base != \"Cmd\") name = \"Cmd-\" + name;\n if (!noShift && event.shiftKey && base != \"Shift\") name = \"Shift-\" + name;\n return name;\n };\n\n function getKeyMap(val) {\n return typeof val == \"string\" ? keyMap[val] : val;\n }\n\n // FROMTEXTAREA\n\n CodeMirror.fromTextArea = function(textarea, options) {\n options = options ? copyObj(options) : {};\n options.value = textarea.value;\n if (!options.tabindex && textarea.tabIndex)\n options.tabindex = textarea.tabIndex;\n if (!options.placeholder && textarea.placeholder)\n options.placeholder = textarea.placeholder;\n // Set autofocus to true if this textarea is focused, or if it has\n // autofocus and no other element is focused.\n if (options.autofocus == null) {\n var hasFocus = activeElt();\n options.autofocus = hasFocus == textarea ||\n textarea.getAttribute(\"autofocus\") != null && hasFocus == document.body;\n }\n\n function save() {textarea.value = cm.getValue();}\n if (textarea.form) {\n on(textarea.form, \"submit\", save);\n // Deplorable hack to make the submit method do the right thing.\n if (!options.leaveSubmitMethodAlone) {\n var form = textarea.form, realSubmit = form.submit;\n try {\n var wrappedSubmit = form.submit = function() {\n save();\n form.submit = realSubmit;\n form.submit();\n form.submit = wrappedSubmit;\n };\n } catch(e) {}\n }\n }\n\n options.finishInit = function(cm) {\n cm.save = save;\n cm.getTextArea = function() { return textarea; };\n cm.toTextArea = function() {\n cm.toTextArea = isNaN; // Prevent this from being ran twice\n save();\n textarea.parentNode.removeChild(cm.getWrapperElement());\n textarea.style.display = \"\";\n if (textarea.form) {\n off(textarea.form, \"submit\", save);\n if (typeof textarea.form.submit == \"function\")\n textarea.form.submit = realSubmit;\n }\n };\n };\n\n textarea.style.display = \"none\";\n var cm = CodeMirror(function(node) {\n textarea.parentNode.insertBefore(node, textarea.nextSibling);\n }, options);\n return cm;\n };\n\n // STRING STREAM\n\n // Fed to the mode parsers, provides helper functions to make\n // parsers more succinct.\n\n var StringStream = CodeMirror.StringStream = function(string, tabSize) {\n this.pos = this.start = 0;\n this.string = string;\n this.tabSize = tabSize || 8;\n this.lastColumnPos = this.lastColumnValue = 0;\n this.lineStart = 0;\n };\n\n StringStream.prototype = {\n eol: function() {return this.pos >= this.string.length;},\n sol: function() {return this.pos == this.lineStart;},\n peek: function() {return this.string.charAt(this.pos) || undefined;},\n next: function() {\n if (this.pos < this.string.length)\n return this.string.charAt(this.pos++);\n },\n eat: function(match) {\n var ch = this.string.charAt(this.pos);\n if (typeof match == \"string\") var ok = ch == match;\n else var ok = ch && (match.test ? match.test(ch) : match(ch));\n if (ok) {++this.pos; return ch;}\n },\n eatWhile: function(match) {\n var start = this.pos;\n while (this.eat(match)){}\n return this.pos > start;\n },\n eatSpace: function() {\n var start = this.pos;\n while (/[\\s\\u00a0]/.test(this.string.charAt(this.pos))) ++this.pos;\n return this.pos > start;\n },\n skipToEnd: function() {this.pos = this.string.length;},\n skipTo: function(ch) {\n var found = this.string.indexOf(ch, this.pos);\n if (found > -1) {this.pos = found; return true;}\n },\n backUp: function(n) {this.pos -= n;},\n column: function() {\n if (this.lastColumnPos < this.start) {\n this.lastColumnValue = countColumn(this.string, this.start, this.tabSize, this.lastColumnPos, this.lastColumnValue);\n this.lastColumnPos = this.start;\n }\n return this.lastColumnValue - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0);\n },\n indentation: function() {\n return countColumn(this.string, null, this.tabSize) -\n (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0);\n },\n match: function(pattern, consume, caseInsensitive) {\n if (typeof pattern == \"string\") {\n var cased = function(str) {return caseInsensitive ? str.toLowerCase() : str;};\n var substr = this.string.substr(this.pos, pattern.length);\n if (cased(substr) == cased(pattern)) {\n if (consume !== false) this.pos += pattern.length;\n return true;\n }\n } else {\n var match = this.string.slice(this.pos).match(pattern);\n if (match && match.index > 0) return null;\n if (match && consume !== false) this.pos += match[0].length;\n return match;\n }\n },\n current: function(){return this.string.slice(this.start, this.pos);},\n hideFirstChars: function(n, inner) {\n this.lineStart += n;\n try { return inner(); }\n finally { this.lineStart -= n; }\n }\n };\n\n // TEXTMARKERS\n\n // Created with markText and setBookmark methods. A TextMarker is a\n // handle that can be used to clear or find a marked position in the\n // document. Line objects hold arrays (markedSpans) containing\n // {from, to, marker} object pointing to such marker objects, and\n // indicating that such a marker is present on that line. Multiple\n // lines may point to the same marker when it spans across lines.\n // The spans will have null for their from/to properties when the\n // marker continues beyond the start/end of the line. Markers have\n // links back to the lines they currently touch.\n\n var nextMarkerId = 0;\n\n var TextMarker = CodeMirror.TextMarker = function(doc, type) {\n this.lines = [];\n this.type = type;\n this.doc = doc;\n this.id = ++nextMarkerId;\n };\n eventMixin(TextMarker);\n\n // Clear the marker.\n TextMarker.prototype.clear = function() {\n if (this.explicitlyCleared) return;\n var cm = this.doc.cm, withOp = cm && !cm.curOp;\n if (withOp) startOperation(cm);\n if (hasHandler(this, \"clear\")) {\n var found = this.find();\n if (found) signalLater(this, \"clear\", found.from, found.to);\n }\n var min = null, max = null;\n for (var i = 0; i < this.lines.length; ++i) {\n var line = this.lines[i];\n var span = getMarkedSpanFor(line.markedSpans, this);\n if (cm && !this.collapsed) regLineChange(cm, lineNo(line), \"text\");\n else if (cm) {\n if (span.to != null) max = lineNo(line);\n if (span.from != null) min = lineNo(line);\n }\n line.markedSpans = removeMarkedSpan(line.markedSpans, span);\n if (span.from == null && this.collapsed && !lineIsHidden(this.doc, line) && cm)\n updateLineHeight(line, textHeight(cm.display));\n }\n if (cm && this.collapsed && !cm.options.lineWrapping) for (var i = 0; i < this.lines.length; ++i) {\n var visual = visualLine(this.lines[i]), len = lineLength(visual);\n if (len > cm.display.maxLineLength) {\n cm.display.maxLine = visual;\n cm.display.maxLineLength = len;\n cm.display.maxLineChanged = true;\n }\n }\n\n if (min != null && cm && this.collapsed) regChange(cm, min, max + 1);\n this.lines.length = 0;\n this.explicitlyCleared = true;\n if (this.atomic && this.doc.cantEdit) {\n this.doc.cantEdit = false;\n if (cm) reCheckSelection(cm.doc);\n }\n if (cm) signalLater(cm, \"markerCleared\", cm, this);\n if (withOp) endOperation(cm);\n if (this.parent) this.parent.clear();\n };\n\n // Find the position of the marker in the document. Returns a {from,\n // to} object by default. Side can be passed to get a specific side\n // -- 0 (both), -1 (left), or 1 (right). When lineObj is true, the\n // Pos objects returned contain a line object, rather than a line\n // number (used to prevent looking up the same line twice).\n TextMarker.prototype.find = function(side, lineObj) {\n if (side == null && this.type == \"bookmark\") side = 1;\n var from, to;\n for (var i = 0; i < this.lines.length; ++i) {\n var line = this.lines[i];\n var span = getMarkedSpanFor(line.markedSpans, this);\n if (span.from != null) {\n from = Pos(lineObj ? line : lineNo(line), span.from);\n if (side == -1) return from;\n }\n if (span.to != null) {\n to = Pos(lineObj ? line : lineNo(line), span.to);\n if (side == 1) return to;\n }\n }\n return from && {from: from, to: to};\n };\n\n // Signals that the marker's widget changed, and surrounding layout\n // should be recomputed.\n TextMarker.prototype.changed = function() {\n var pos = this.find(-1, true), widget = this, cm = this.doc.cm;\n if (!pos || !cm) return;\n runInOp(cm, function() {\n var line = pos.line, lineN = lineNo(pos.line);\n var view = findViewForLine(cm, lineN);\n if (view) {\n clearLineMeasurementCacheFor(view);\n cm.curOp.selectionChanged = cm.curOp.forceUpdate = true;\n }\n cm.curOp.updateMaxLine = true;\n if (!lineIsHidden(widget.doc, line) && widget.height != null) {\n var oldHeight = widget.height;\n widget.height = null;\n var dHeight = widgetHeight(widget) - oldHeight;\n if (dHeight)\n updateLineHeight(line, line.height + dHeight);\n }\n });\n };\n\n TextMarker.prototype.attachLine = function(line) {\n if (!this.lines.length && this.doc.cm) {\n var op = this.doc.cm.curOp;\n if (!op.maybeHiddenMarkers || indexOf(op.maybeHiddenMarkers, this) == -1)\n (op.maybeUnhiddenMarkers || (op.maybeUnhiddenMarkers = [])).push(this);\n }\n this.lines.push(line);\n };\n TextMarker.prototype.detachLine = function(line) {\n this.lines.splice(indexOf(this.lines, line), 1);\n if (!this.lines.length && this.doc.cm) {\n var op = this.doc.cm.curOp;\n (op.maybeHiddenMarkers || (op.maybeHiddenMarkers = [])).push(this);\n }\n };\n\n // Collapsed markers have unique ids, in order to be able to order\n // them, which is needed for uniquely determining an outer marker\n // when they overlap (they may nest, but not partially overlap).\n var nextMarkerId = 0;\n\n // Create a marker, wire it up to the right lines, and\n function markText(doc, from, to, options, type) {\n // Shared markers (across linked documents) are handled separately\n // (markTextShared will call out to this again, once per\n // document).\n if (options && options.shared) return markTextShared(doc, from, to, options, type);\n // Ensure we are in an operation.\n if (doc.cm && !doc.cm.curOp) return operation(doc.cm, markText)(doc, from, to, options, type);\n\n var marker = new TextMarker(doc, type), diff = cmp(from, to);\n if (options) copyObj(options, marker, false);\n // Don't connect empty markers unless clearWhenEmpty is false\n if (diff > 0 || diff == 0 && marker.clearWhenEmpty !== false)\n return marker;\n if (marker.replacedWith) {\n // Showing up as a widget implies collapsed (widget replaces text)\n marker.collapsed = true;\n marker.widgetNode = elt(\"span\", [marker.replacedWith], \"CodeMirror-widget\");\n if (!options.handleMouseEvents) marker.widgetNode.setAttribute(\"cm-ignore-events\", \"true\");\n if (options.insertLeft) marker.widgetNode.insertLeft = true;\n }\n if (marker.collapsed) {\n if (conflictingCollapsedRange(doc, from.line, from, to, marker) ||\n from.line != to.line && conflictingCollapsedRange(doc, to.line, from, to, marker))\n throw new Error(\"Inserting collapsed marker partially overlapping an existing one\");\n sawCollapsedSpans = true;\n }\n\n if (marker.addToHistory)\n addChangeToHistory(doc, {from: from, to: to, origin: \"markText\"}, doc.sel, NaN);\n\n var curLine = from.line, cm = doc.cm, updateMaxLine;\n doc.iter(curLine, to.line + 1, function(line) {\n if (cm && marker.collapsed && !cm.options.lineWrapping && visualLine(line) == cm.display.maxLine)\n updateMaxLine = true;\n if (marker.collapsed && curLine != from.line) updateLineHeight(line, 0);\n addMarkedSpan(line, new MarkedSpan(marker,\n curLine == from.line ? from.ch : null,\n curLine == to.line ? to.ch : null));\n ++curLine;\n });\n // lineIsHidden depends on the presence of the spans, so needs a second pass\n if (marker.collapsed) doc.iter(from.line, to.line + 1, function(line) {\n if (lineIsHidden(doc, line)) updateLineHeight(line, 0);\n });\n\n if (marker.clearOnEnter) on(marker, \"beforeCursorEnter\", function() { marker.clear(); });\n\n if (marker.readOnly) {\n sawReadOnlySpans = true;\n if (doc.history.done.length || doc.history.undone.length)\n doc.clearHistory();\n }\n if (marker.collapsed) {\n marker.id = ++nextMarkerId;\n marker.atomic = true;\n }\n if (cm) {\n // Sync editor state\n if (updateMaxLine) cm.curOp.updateMaxLine = true;\n if (marker.collapsed)\n regChange(cm, from.line, to.line + 1);\n else if (marker.className || marker.title || marker.startStyle || marker.endStyle || marker.css)\n for (var i = from.line; i <= to.line; i++) regLineChange(cm, i, \"text\");\n if (marker.atomic) reCheckSelection(cm.doc);\n signalLater(cm, \"markerAdded\", cm, marker);\n }\n return marker;\n }\n\n // SHARED TEXTMARKERS\n\n // A shared marker spans multiple linked documents. It is\n // implemented as a meta-marker-object controlling multiple normal\n // markers.\n var SharedTextMarker = CodeMirror.SharedTextMarker = function(markers, primary) {\n this.markers = markers;\n this.primary = primary;\n for (var i = 0; i < markers.length; ++i)\n markers[i].parent = this;\n };\n eventMixin(SharedTextMarker);\n\n SharedTextMarker.prototype.clear = function() {\n if (this.explicitlyCleared) return;\n this.explicitlyCleared = true;\n for (var i = 0; i < this.markers.length; ++i)\n this.markers[i].clear();\n signalLater(this, \"clear\");\n };\n SharedTextMarker.prototype.find = function(side, lineObj) {\n return this.primary.find(side, lineObj);\n };\n\n function markTextShared(doc, from, to, options, type) {\n options = copyObj(options);\n options.shared = false;\n var markers = [markText(doc, from, to, options, type)], primary = markers[0];\n var widget = options.widgetNode;\n linkedDocs(doc, function(doc) {\n if (widget) options.widgetNode = widget.cloneNode(true);\n markers.push(markText(doc, clipPos(doc, from), clipPos(doc, to), options, type));\n for (var i = 0; i < doc.linked.length; ++i)\n if (doc.linked[i].isParent) return;\n primary = lst(markers);\n });\n return new SharedTextMarker(markers, primary);\n }\n\n function findSharedMarkers(doc) {\n return doc.findMarks(Pos(doc.first, 0), doc.clipPos(Pos(doc.lastLine())),\n function(m) { return m.parent; });\n }\n\n function copySharedMarkers(doc, markers) {\n for (var i = 0; i < markers.length; i++) {\n var marker = markers[i], pos = marker.find();\n var mFrom = doc.clipPos(pos.from), mTo = doc.clipPos(pos.to);\n if (cmp(mFrom, mTo)) {\n var subMark = markText(doc, mFrom, mTo, marker.primary, marker.primary.type);\n marker.markers.push(subMark);\n subMark.parent = marker;\n }\n }\n }\n\n function detachSharedMarkers(markers) {\n for (var i = 0; i < markers.length; i++) {\n var marker = markers[i], linked = [marker.primary.doc];;\n linkedDocs(marker.primary.doc, function(d) { linked.push(d); });\n for (var j = 0; j < marker.markers.length; j++) {\n var subMarker = marker.markers[j];\n if (indexOf(linked, subMarker.doc) == -1) {\n subMarker.parent = null;\n marker.markers.splice(j--, 1);\n }\n }\n }\n }\n\n // TEXTMARKER SPANS\n\n function MarkedSpan(marker, from, to) {\n this.marker = marker;\n this.from = from; this.to = to;\n }\n\n // Search an array of spans for a span matching the given marker.\n function getMarkedSpanFor(spans, marker) {\n if (spans) for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if (span.marker == marker) return span;\n }\n }\n // Remove a span from an array, returning undefined if no spans are\n // left (we don't store arrays for lines without spans).\n function removeMarkedSpan(spans, span) {\n for (var r, i = 0; i < spans.length; ++i)\n if (spans[i] != span) (r || (r = [])).push(spans[i]);\n return r;\n }\n // Add a span to a line.\n function addMarkedSpan(line, span) {\n line.markedSpans = line.markedSpans ? line.markedSpans.concat([span]) : [span];\n span.marker.attachLine(line);\n }\n\n // Used for the algorithm that adjusts markers for a change in the\n // document. These functions cut an array of spans at a given\n // character position, returning an array of remaining chunks (or\n // undefined if nothing remains).\n function markedSpansBefore(old, startCh, isInsert) {\n if (old) for (var i = 0, nw; i < old.length; ++i) {\n var span = old[i], marker = span.marker;\n var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= startCh : span.from < startCh);\n if (startsBefore || span.from == startCh && marker.type == \"bookmark\" && (!isInsert || !span.marker.insertLeft)) {\n var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= startCh : span.to > startCh);\n (nw || (nw = [])).push(new MarkedSpan(marker, span.from, endsAfter ? null : span.to));\n }\n }\n return nw;\n }\n function markedSpansAfter(old, endCh, isInsert) {\n if (old) for (var i = 0, nw; i < old.length; ++i) {\n var span = old[i], marker = span.marker;\n var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= endCh : span.to > endCh);\n if (endsAfter || span.from == endCh && marker.type == \"bookmark\" && (!isInsert || span.marker.insertLeft)) {\n var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= endCh : span.from < endCh);\n (nw || (nw = [])).push(new MarkedSpan(marker, startsBefore ? null : span.from - endCh,\n span.to == null ? null : span.to - endCh));\n }\n }\n return nw;\n }\n\n // Given a change object, compute the new set of marker spans that\n // cover the line in which the change took place. Removes spans\n // entirely within the change, reconnects spans belonging to the\n // same marker that appear on both sides of the change, and cuts off\n // spans partially within the change. Returns an array of span\n // arrays with one element for each line in (after) the change.\n function stretchSpansOverChange(doc, change) {\n if (change.full) return null;\n var oldFirst = isLine(doc, change.from.line) && getLine(doc, change.from.line).markedSpans;\n var oldLast = isLine(doc, change.to.line) && getLine(doc, change.to.line).markedSpans;\n if (!oldFirst && !oldLast) return null;\n\n var startCh = change.from.ch, endCh = change.to.ch, isInsert = cmp(change.from, change.to) == 0;\n // Get the spans that 'stick out' on both sides\n var first = markedSpansBefore(oldFirst, startCh, isInsert);\n var last = markedSpansAfter(oldLast, endCh, isInsert);\n\n // Next, merge those two ends\n var sameLine = change.text.length == 1, offset = lst(change.text).length + (sameLine ? startCh : 0);\n if (first) {\n // Fix up .to properties of first\n for (var i = 0; i < first.length; ++i) {\n var span = first[i];\n if (span.to == null) {\n var found = getMarkedSpanFor(last, span.marker);\n if (!found) span.to = startCh;\n else if (sameLine) span.to = found.to == null ? null : found.to + offset;\n }\n }\n }\n if (last) {\n // Fix up .from in last (or move them into first in case of sameLine)\n for (var i = 0; i < last.length; ++i) {\n var span = last[i];\n if (span.to != null) span.to += offset;\n if (span.from == null) {\n var found = getMarkedSpanFor(first, span.marker);\n if (!found) {\n span.from = offset;\n if (sameLine) (first || (first = [])).push(span);\n }\n } else {\n span.from += offset;\n if (sameLine) (first || (first = [])).push(span);\n }\n }\n }\n // Make sure we didn't create any zero-length spans\n if (first) first = clearEmptySpans(first);\n if (last && last != first) last = clearEmptySpans(last);\n\n var newMarkers = [first];\n if (!sameLine) {\n // Fill gap with whole-line-spans\n var gap = change.text.length - 2, gapMarkers;\n if (gap > 0 && first)\n for (var i = 0; i < first.length; ++i)\n if (first[i].to == null)\n (gapMarkers || (gapMarkers = [])).push(new MarkedSpan(first[i].marker, null, null));\n for (var i = 0; i < gap; ++i)\n newMarkers.push(gapMarkers);\n newMarkers.push(last);\n }\n return newMarkers;\n }\n\n // Remove spans that are empty and don't have a clearWhenEmpty\n // option of false.\n function clearEmptySpans(spans) {\n for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if (span.from != null && span.from == span.to && span.marker.clearWhenEmpty !== false)\n spans.splice(i--, 1);\n }\n if (!spans.length) return null;\n return spans;\n }\n\n // Used for un/re-doing changes from the history. Combines the\n // result of computing the existing spans with the set of spans that\n // existed in the history (so that deleting around a span and then\n // undoing brings back the span).\n function mergeOldSpans(doc, change) {\n var old = getOldSpans(doc, change);\n var stretched = stretchSpansOverChange(doc, change);\n if (!old) return stretched;\n if (!stretched) return old;\n\n for (var i = 0; i < old.length; ++i) {\n var oldCur = old[i], stretchCur = stretched[i];\n if (oldCur && stretchCur) {\n spans: for (var j = 0; j < stretchCur.length; ++j) {\n var span = stretchCur[j];\n for (var k = 0; k < oldCur.length; ++k)\n if (oldCur[k].marker == span.marker) continue spans;\n oldCur.push(span);\n }\n } else if (stretchCur) {\n old[i] = stretchCur;\n }\n }\n return old;\n }\n\n // Used to 'clip' out readOnly ranges when making a change.\n function removeReadOnlyRanges(doc, from, to) {\n var markers = null;\n doc.iter(from.line, to.line + 1, function(line) {\n if (line.markedSpans) for (var i = 0; i < line.markedSpans.length; ++i) {\n var mark = line.markedSpans[i].marker;\n if (mark.readOnly && (!markers || indexOf(markers, mark) == -1))\n (markers || (markers = [])).push(mark);\n }\n });\n if (!markers) return null;\n var parts = [{from: from, to: to}];\n for (var i = 0; i < markers.length; ++i) {\n var mk = markers[i], m = mk.find(0);\n for (var j = 0; j < parts.length; ++j) {\n var p = parts[j];\n if (cmp(p.to, m.from) < 0 || cmp(p.from, m.to) > 0) continue;\n var newParts = [j, 1], dfrom = cmp(p.from, m.from), dto = cmp(p.to, m.to);\n if (dfrom < 0 || !mk.inclusiveLeft && !dfrom)\n newParts.push({from: p.from, to: m.from});\n if (dto > 0 || !mk.inclusiveRight && !dto)\n newParts.push({from: m.to, to: p.to});\n parts.splice.apply(parts, newParts);\n j += newParts.length - 1;\n }\n }\n return parts;\n }\n\n // Connect or disconnect spans from a line.\n function detachMarkedSpans(line) {\n var spans = line.markedSpans;\n if (!spans) return;\n for (var i = 0; i < spans.length; ++i)\n spans[i].marker.detachLine(line);\n line.markedSpans = null;\n }\n function attachMarkedSpans(line, spans) {\n if (!spans) return;\n for (var i = 0; i < spans.length; ++i)\n spans[i].marker.attachLine(line);\n line.markedSpans = spans;\n }\n\n // Helpers used when computing which overlapping collapsed span\n // counts as the larger one.\n function extraLeft(marker) { return marker.inclusiveLeft ? -1 : 0; }\n function extraRight(marker) { return marker.inclusiveRight ? 1 : 0; }\n\n // Returns a number indicating which of two overlapping collapsed\n // spans is larger (and thus includes the other). Falls back to\n // comparing ids when the spans cover exactly the same range.\n function compareCollapsedMarkers(a, b) {\n var lenDiff = a.lines.length - b.lines.length;\n if (lenDiff != 0) return lenDiff;\n var aPos = a.find(), bPos = b.find();\n var fromCmp = cmp(aPos.from, bPos.from) || extraLeft(a) - extraLeft(b);\n if (fromCmp) return -fromCmp;\n var toCmp = cmp(aPos.to, bPos.to) || extraRight(a) - extraRight(b);\n if (toCmp) return toCmp;\n return b.id - a.id;\n }\n\n // Find out whether a line ends or starts in a collapsed span. If\n // so, return the marker for that span.\n function collapsedSpanAtSide(line, start) {\n var sps = sawCollapsedSpans && line.markedSpans, found;\n if (sps) for (var sp, i = 0; i < sps.length; ++i) {\n sp = sps[i];\n if (sp.marker.collapsed && (start ? sp.from : sp.to) == null &&\n (!found || compareCollapsedMarkers(found, sp.marker) < 0))\n found = sp.marker;\n }\n return found;\n }\n function collapsedSpanAtStart(line) { return collapsedSpanAtSide(line, true); }\n function collapsedSpanAtEnd(line) { return collapsedSpanAtSide(line, false); }\n\n // Test whether there exists a collapsed span that partially\n // overlaps (covers the start or end, but not both) of a new span.\n // Such overlap is not allowed.\n function conflictingCollapsedRange(doc, lineNo, from, to, marker) {\n var line = getLine(doc, lineNo);\n var sps = sawCollapsedSpans && line.markedSpans;\n if (sps) for (var i = 0; i < sps.length; ++i) {\n var sp = sps[i];\n if (!sp.marker.collapsed) continue;\n var found = sp.marker.find(0);\n var fromCmp = cmp(found.from, from) || extraLeft(sp.marker) - extraLeft(marker);\n var toCmp = cmp(found.to, to) || extraRight(sp.marker) - extraRight(marker);\n if (fromCmp >= 0 && toCmp <= 0 || fromCmp <= 0 && toCmp >= 0) continue;\n if (fromCmp <= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.to, from) >= 0 : cmp(found.to, from) > 0) ||\n fromCmp >= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.from, to) <= 0 : cmp(found.from, to) < 0))\n return true;\n }\n }\n\n // A visual line is a line as drawn on the screen. Folding, for\n // example, can cause multiple logical lines to appear on the same\n // visual line. This finds the start of the visual line that the\n // given line is part of (usually that is the line itself).\n function visualLine(line) {\n var merged;\n while (merged = collapsedSpanAtStart(line))\n line = merged.find(-1, true).line;\n return line;\n }\n\n // Returns an array of logical lines that continue the visual line\n // started by the argument, or undefined if there are no such lines.\n function visualLineContinued(line) {\n var merged, lines;\n while (merged = collapsedSpanAtEnd(line)) {\n line = merged.find(1, true).line;\n (lines || (lines = [])).push(line);\n }\n return lines;\n }\n\n // Get the line number of the start of the visual line that the\n // given line number is part of.\n function visualLineNo(doc, lineN) {\n var line = getLine(doc, lineN), vis = visualLine(line);\n if (line == vis) return lineN;\n return lineNo(vis);\n }\n // Get the line number of the start of the next visual line after\n // the given line.\n function visualLineEndNo(doc, lineN) {\n if (lineN > doc.lastLine()) return lineN;\n var line = getLine(doc, lineN), merged;\n if (!lineIsHidden(doc, line)) return lineN;\n while (merged = collapsedSpanAtEnd(line))\n line = merged.find(1, true).line;\n return lineNo(line) + 1;\n }\n\n // Compute whether a line is hidden. Lines count as hidden when they\n // are part of a visual line that starts with another line, or when\n // they are entirely covered by collapsed, non-widget span.\n function lineIsHidden(doc, line) {\n var sps = sawCollapsedSpans && line.markedSpans;\n if (sps) for (var sp, i = 0; i < sps.length; ++i) {\n sp = sps[i];\n if (!sp.marker.collapsed) continue;\n if (sp.from == null) return true;\n if (sp.marker.widgetNode) continue;\n if (sp.from == 0 && sp.marker.inclusiveLeft && lineIsHiddenInner(doc, line, sp))\n return true;\n }\n }\n function lineIsHiddenInner(doc, line, span) {\n if (span.to == null) {\n var end = span.marker.find(1, true);\n return lineIsHiddenInner(doc, end.line, getMarkedSpanFor(end.line.markedSpans, span.marker));\n }\n if (span.marker.inclusiveRight && span.to == line.text.length)\n return true;\n for (var sp, i = 0; i < line.markedSpans.length; ++i) {\n sp = line.markedSpans[i];\n if (sp.marker.collapsed && !sp.marker.widgetNode && sp.from == span.to &&\n (sp.to == null || sp.to != span.from) &&\n (sp.marker.inclusiveLeft || span.marker.inclusiveRight) &&\n lineIsHiddenInner(doc, line, sp)) return true;\n }\n }\n\n // LINE WIDGETS\n\n // Line widgets are block elements displayed above or below a line.\n\n var LineWidget = CodeMirror.LineWidget = function(doc, node, options) {\n if (options) for (var opt in options) if (options.hasOwnProperty(opt))\n this[opt] = options[opt];\n this.doc = doc;\n this.node = node;\n };\n eventMixin(LineWidget);\n\n function adjustScrollWhenAboveVisible(cm, line, diff) {\n if (heightAtLine(line) < ((cm.curOp && cm.curOp.scrollTop) || cm.doc.scrollTop))\n addToScrollPos(cm, null, diff);\n }\n\n LineWidget.prototype.clear = function() {\n var cm = this.doc.cm, ws = this.line.widgets, line = this.line, no = lineNo(line);\n if (no == null || !ws) return;\n for (var i = 0; i < ws.length; ++i) if (ws[i] == this) ws.splice(i--, 1);\n if (!ws.length) line.widgets = null;\n var height = widgetHeight(this);\n updateLineHeight(line, Math.max(0, line.height - height));\n if (cm) runInOp(cm, function() {\n adjustScrollWhenAboveVisible(cm, line, -height);\n regLineChange(cm, no, \"widget\");\n });\n };\n LineWidget.prototype.changed = function() {\n var oldH = this.height, cm = this.doc.cm, line = this.line;\n this.height = null;\n var diff = widgetHeight(this) - oldH;\n if (!diff) return;\n updateLineHeight(line, line.height + diff);\n if (cm) runInOp(cm, function() {\n cm.curOp.forceUpdate = true;\n adjustScrollWhenAboveVisible(cm, line, diff);\n });\n };\n\n function widgetHeight(widget) {\n if (widget.height != null) return widget.height;\n var cm = widget.doc.cm;\n if (!cm) return 0;\n if (!contains(document.body, widget.node)) {\n var parentStyle = \"position: relative;\";\n if (widget.coverGutter)\n parentStyle += \"margin-left: -\" + cm.display.gutters.offsetWidth + \"px;\";\n if (widget.noHScroll)\n parentStyle += \"width: \" + cm.display.wrapper.clientWidth + \"px;\";\n removeChildrenAndAdd(cm.display.measure, elt(\"div\", [widget.node], null, parentStyle));\n }\n return widget.height = widget.node.parentNode.offsetHeight;\n }\n\n function addLineWidget(doc, handle, node, options) {\n var widget = new LineWidget(doc, node, options);\n var cm = doc.cm;\n if (cm && widget.noHScroll) cm.display.alignWidgets = true;\n changeLine(doc, handle, \"widget\", function(line) {\n var widgets = line.widgets || (line.widgets = []);\n if (widget.insertAt == null) widgets.push(widget);\n else widgets.splice(Math.min(widgets.length - 1, Math.max(0, widget.insertAt)), 0, widget);\n widget.line = line;\n if (cm && !lineIsHidden(doc, line)) {\n var aboveVisible = heightAtLine(line) < doc.scrollTop;\n updateLineHeight(line, line.height + widgetHeight(widget));\n if (aboveVisible) addToScrollPos(cm, null, widget.height);\n cm.curOp.forceUpdate = true;\n }\n return true;\n });\n return widget;\n }\n\n // LINE DATA STRUCTURE\n\n // Line objects. These hold state related to a line, including\n // highlighting info (the styles array).\n var Line = CodeMirror.Line = function(text, markedSpans, estimateHeight) {\n this.text = text;\n attachMarkedSpans(this, markedSpans);\n this.height = estimateHeight ? estimateHeight(this) : 1;\n };\n eventMixin(Line);\n Line.prototype.lineNo = function() { return lineNo(this); };\n\n // Change the content (text, markers) of a line. Automatically\n // invalidates cached information and tries to re-estimate the\n // line's height.\n function updateLine(line, text, markedSpans, estimateHeight) {\n line.text = text;\n if (line.stateAfter) line.stateAfter = null;\n if (line.styles) line.styles = null;\n if (line.order != null) line.order = null;\n detachMarkedSpans(line);\n attachMarkedSpans(line, markedSpans);\n var estHeight = estimateHeight ? estimateHeight(line) : 1;\n if (estHeight != line.height) updateLineHeight(line, estHeight);\n }\n\n // Detach a line from the document tree and its markers.\n function cleanUpLine(line) {\n line.parent = null;\n detachMarkedSpans(line);\n }\n\n function extractLineClasses(type, output) {\n if (type) for (;;) {\n var lineClass = type.match(/(?:^|\\s+)line-(background-)?(\\S+)/);\n if (!lineClass) break;\n type = type.slice(0, lineClass.index) + type.slice(lineClass.index + lineClass[0].length);\n var prop = lineClass[1] ? \"bgClass\" : \"textClass\";\n if (output[prop] == null)\n output[prop] = lineClass[2];\n else if (!(new RegExp(\"(?:^|\\s)\" + lineClass[2] + \"(?:$|\\s)\")).test(output[prop]))\n output[prop] += \" \" + lineClass[2];\n }\n return type;\n }\n\n function callBlankLine(mode, state) {\n if (mode.blankLine) return mode.blankLine(state);\n if (!mode.innerMode) return;\n var inner = CodeMirror.innerMode(mode, state);\n if (inner.mode.blankLine) return inner.mode.blankLine(inner.state);\n }\n\n function readToken(mode, stream, state, inner) {\n for (var i = 0; i < 10; i++) {\n if (inner) inner[0] = CodeMirror.innerMode(mode, state).mode;\n var style = mode.token(stream, state);\n if (stream.pos > stream.start) return style;\n }\n throw new Error(\"Mode \" + mode.name + \" failed to advance stream.\");\n }\n\n // Utility for getTokenAt and getLineTokens\n function takeToken(cm, pos, precise, asArray) {\n function getObj(copy) {\n return {start: stream.start, end: stream.pos,\n string: stream.current(),\n type: style || null,\n state: copy ? copyState(doc.mode, state) : state};\n }\n\n var doc = cm.doc, mode = doc.mode, style;\n pos = clipPos(doc, pos);\n var line = getLine(doc, pos.line), state = getStateBefore(cm, pos.line, precise);\n var stream = new StringStream(line.text, cm.options.tabSize), tokens;\n if (asArray) tokens = [];\n while ((asArray || stream.pos < pos.ch) && !stream.eol()) {\n stream.start = stream.pos;\n style = readToken(mode, stream, state);\n if (asArray) tokens.push(getObj(true));\n }\n return asArray ? tokens : getObj();\n }\n\n // Run the given mode's parser over a line, calling f for each token.\n function runMode(cm, text, mode, state, f, lineClasses, forceToEnd) {\n var flattenSpans = mode.flattenSpans;\n if (flattenSpans == null) flattenSpans = cm.options.flattenSpans;\n var curStart = 0, curStyle = null;\n var stream = new StringStream(text, cm.options.tabSize), style;\n var inner = cm.options.addModeClass && [null];\n if (text == \"\") extractLineClasses(callBlankLine(mode, state), lineClasses);\n while (!stream.eol()) {\n if (stream.pos > cm.options.maxHighlightLength) {\n flattenSpans = false;\n if (forceToEnd) processLine(cm, text, state, stream.pos);\n stream.pos = text.length;\n style = null;\n } else {\n style = extractLineClasses(readToken(mode, stream, state, inner), lineClasses);\n }\n if (inner) {\n var mName = inner[0].name;\n if (mName) style = \"m-\" + (style ? mName + \" \" + style : mName);\n }\n if (!flattenSpans || curStyle != style) {\n while (curStart < stream.start) {\n curStart = Math.min(stream.start, curStart + 50000);\n f(curStart, curStyle);\n }\n curStyle = style;\n }\n stream.start = stream.pos;\n }\n while (curStart < stream.pos) {\n // Webkit seems to refuse to render text nodes longer than 57444 characters\n var pos = Math.min(stream.pos, curStart + 50000);\n f(pos, curStyle);\n curStart = pos;\n }\n }\n\n // Compute a style array (an array starting with a mode generation\n // -- for invalidation -- followed by pairs of end positions and\n // style strings), which is used to highlight the tokens on the\n // line.\n function highlightLine(cm, line, state, forceToEnd) {\n // A styles array always starts with a number identifying the\n // mode/overlays that it is based on (for easy invalidation).\n var st = [cm.state.modeGen], lineClasses = {};\n // Compute the base array of styles\n runMode(cm, line.text, cm.doc.mode, state, function(end, style) {\n st.push(end, style);\n }, lineClasses, forceToEnd);\n\n // Run overlays, adjust style array.\n for (var o = 0; o < cm.state.overlays.length; ++o) {\n var overlay = cm.state.overlays[o], i = 1, at = 0;\n runMode(cm, line.text, overlay.mode, true, function(end, style) {\n var start = i;\n // Ensure there's a token end at the current position, and that i points at it\n while (at < end) {\n var i_end = st[i];\n if (i_end > end)\n st.splice(i, 1, end, st[i+1], i_end);\n i += 2;\n at = Math.min(end, i_end);\n }\n if (!style) return;\n if (overlay.opaque) {\n st.splice(start, i - start, end, \"cm-overlay \" + style);\n i = start + 2;\n } else {\n for (; start < i; start += 2) {\n var cur = st[start+1];\n st[start+1] = (cur ? cur + \" \" : \"\") + \"cm-overlay \" + style;\n }\n }\n }, lineClasses);\n }\n\n return {styles: st, classes: lineClasses.bgClass || lineClasses.textClass ? lineClasses : null};\n }\n\n function getLineStyles(cm, line, updateFrontier) {\n if (!line.styles || line.styles[0] != cm.state.modeGen) {\n var state = getStateBefore(cm, lineNo(line));\n var result = highlightLine(cm, line, line.text.length > cm.options.maxHighlightLength ? copyState(cm.doc.mode, state) : state);\n line.stateAfter = state;\n line.styles = result.styles;\n if (result.classes) line.styleClasses = result.classes;\n else if (line.styleClasses) line.styleClasses = null;\n if (updateFrontier === cm.doc.frontier) cm.doc.frontier++;\n }\n return line.styles;\n }\n\n // Lightweight form of highlight -- proceed over this line and\n // update state, but don't save a style array. Used for lines that\n // aren't currently visible.\n function processLine(cm, text, state, startAt) {\n var mode = cm.doc.mode;\n var stream = new StringStream(text, cm.options.tabSize);\n stream.start = stream.pos = startAt || 0;\n if (text == \"\") callBlankLine(mode, state);\n while (!stream.eol()) {\n readToken(mode, stream, state);\n stream.start = stream.pos;\n }\n }\n\n // Convert a style as returned by a mode (either null, or a string\n // containing one or more styles) to a CSS style. This is cached,\n // and also looks for line-wide styles.\n var styleToClassCache = {}, styleToClassCacheWithMode = {};\n function interpretTokenStyle(style, options) {\n if (!style || /^\\s*$/.test(style)) return null;\n var cache = options.addModeClass ? styleToClassCacheWithMode : styleToClassCache;\n return cache[style] ||\n (cache[style] = style.replace(/\\S+/g, \"cm-$&\"));\n }\n\n // Render the DOM representation of the text of a line. Also builds\n // up a 'line map', which points at the DOM nodes that represent\n // specific stretches of text, and is used by the measuring code.\n // The returned object contains the DOM node, this map, and\n // information about line-wide styles that were set by the mode.\n function buildLineContent(cm, lineView) {\n // The padding-right forces the element to have a 'border', which\n // is needed on Webkit to be able to get line-level bounding\n // rectangles for it (in measureChar).\n var content = elt(\"span\", null, null, webkit ? \"padding-right: .1px\" : null);\n var builder = {pre: elt(\"pre\", [content], \"CodeMirror-line\"), content: content,\n col: 0, pos: 0, cm: cm,\n trailingSpace: false,\n splitSpaces: (ie || webkit) && cm.getOption(\"lineWrapping\")};\n lineView.measure = {};\n\n // Iterate over the logical lines that make up this visual line.\n for (var i = 0; i <= (lineView.rest ? lineView.rest.length : 0); i++) {\n var line = i ? lineView.rest[i - 1] : lineView.line, order;\n builder.pos = 0;\n builder.addToken = buildToken;\n // Optionally wire in some hacks into the token-rendering\n // algorithm, to deal with browser quirks.\n if (hasBadBidiRects(cm.display.measure) && (order = getOrder(line)))\n builder.addToken = buildTokenBadBidi(builder.addToken, order);\n builder.map = [];\n var allowFrontierUpdate = lineView != cm.display.externalMeasured && lineNo(line);\n insertLineContent(line, builder, getLineStyles(cm, line, allowFrontierUpdate));\n if (line.styleClasses) {\n if (line.styleClasses.bgClass)\n builder.bgClass = joinClasses(line.styleClasses.bgClass, builder.bgClass || \"\");\n if (line.styleClasses.textClass)\n builder.textClass = joinClasses(line.styleClasses.textClass, builder.textClass || \"\");\n }\n\n // Ensure at least a single node is present, for measuring.\n if (builder.map.length == 0)\n builder.map.push(0, 0, builder.content.appendChild(zeroWidthElement(cm.display.measure)));\n\n // Store the map and a cache object for the current logical line\n if (i == 0) {\n lineView.measure.map = builder.map;\n lineView.measure.cache = {};\n } else {\n (lineView.measure.maps || (lineView.measure.maps = [])).push(builder.map);\n (lineView.measure.caches || (lineView.measure.caches = [])).push({});\n }\n }\n\n // See issue #2901\n if (webkit) {\n var last = builder.content.lastChild\n if (/\\bcm-tab\\b/.test(last.className) || (last.querySelector && last.querySelector(\".cm-tab\")))\n builder.content.className = \"cm-tab-wrap-hack\";\n }\n\n signal(cm, \"renderLine\", cm, lineView.line, builder.pre);\n if (builder.pre.className)\n builder.textClass = joinClasses(builder.pre.className, builder.textClass || \"\");\n\n return builder;\n }\n\n function defaultSpecialCharPlaceholder(ch) {\n var token = elt(\"span\", \"\\u2022\", \"cm-invalidchar\");\n token.title = \"\\\\u\" + ch.charCodeAt(0).toString(16);\n token.setAttribute(\"aria-label\", token.title);\n return token;\n }\n\n // Build up the DOM representation for a single token, and add it to\n // the line map. Takes care to render special characters separately.\n function buildToken(builder, text, style, startStyle, endStyle, title, css) {\n if (!text) return;\n var displayText = builder.splitSpaces ? splitSpaces(text, builder.trailingSpace) : text\n var special = builder.cm.state.specialChars, mustWrap = false;\n if (!special.test(text)) {\n builder.col += text.length;\n var content = document.createTextNode(displayText);\n builder.map.push(builder.pos, builder.pos + text.length, content);\n if (ie && ie_version < 9) mustWrap = true;\n builder.pos += text.length;\n } else {\n var content = document.createDocumentFragment(), pos = 0;\n while (true) {\n special.lastIndex = pos;\n var m = special.exec(text);\n var skipped = m ? m.index - pos : text.length - pos;\n if (skipped) {\n var txt = document.createTextNode(displayText.slice(pos, pos + skipped));\n if (ie && ie_version < 9) content.appendChild(elt(\"span\", [txt]));\n else content.appendChild(txt);\n builder.map.push(builder.pos, builder.pos + skipped, txt);\n builder.col += skipped;\n builder.pos += skipped;\n }\n if (!m) break;\n pos += skipped + 1;\n if (m[0] == \"\\t\") {\n var tabSize = builder.cm.options.tabSize, tabWidth = tabSize - builder.col % tabSize;\n var txt = content.appendChild(elt(\"span\", spaceStr(tabWidth), \"cm-tab\"));\n txt.setAttribute(\"role\", \"presentation\");\n txt.setAttribute(\"cm-text\", \"\\t\");\n builder.col += tabWidth;\n } else if (m[0] == \"\\r\" || m[0] == \"\\n\") {\n var txt = content.appendChild(elt(\"span\", m[0] == \"\\r\" ? \"\\u240d\" : \"\\u2424\", \"cm-invalidchar\"));\n txt.setAttribute(\"cm-text\", m[0]);\n builder.col += 1;\n } else {\n var txt = builder.cm.options.specialCharPlaceholder(m[0]);\n txt.setAttribute(\"cm-text\", m[0]);\n if (ie && ie_version < 9) content.appendChild(elt(\"span\", [txt]));\n else content.appendChild(txt);\n builder.col += 1;\n }\n builder.map.push(builder.pos, builder.pos + 1, txt);\n builder.pos++;\n }\n }\n builder.trailingSpace = displayText.charCodeAt(text.length - 1) == 32\n if (style || startStyle || endStyle || mustWrap || css) {\n var fullStyle = style || \"\";\n if (startStyle) fullStyle += startStyle;\n if (endStyle) fullStyle += endStyle;\n var token = elt(\"span\", [content], fullStyle, css);\n if (title) token.title = title;\n return builder.content.appendChild(token);\n }\n builder.content.appendChild(content);\n }\n\n function splitSpaces(text, trailingBefore) {\n if (text.length > 1 && !/ /.test(text)) return text\n var spaceBefore = trailingBefore, result = \"\"\n for (var i = 0; i < text.length; i++) {\n var ch = text.charAt(i)\n if (ch == \" \" && spaceBefore && (i == text.length - 1 || text.charCodeAt(i + 1) == 32))\n ch = \"\\u00a0\"\n result += ch\n spaceBefore = ch == \" \"\n }\n return result\n }\n\n // Work around nonsense dimensions being reported for stretches of\n // right-to-left text.\n function buildTokenBadBidi(inner, order) {\n return function(builder, text, style, startStyle, endStyle, title, css) {\n style = style ? style + \" cm-force-border\" : \"cm-force-border\";\n var start = builder.pos, end = start + text.length;\n for (;;) {\n // Find the part that overlaps with the start of this text\n for (var i = 0; i < order.length; i++) {\n var part = order[i];\n if (part.to > start && part.from <= start) break;\n }\n if (part.to >= end) return inner(builder, text, style, startStyle, endStyle, title, css);\n inner(builder, text.slice(0, part.to - start), style, startStyle, null, title, css);\n startStyle = null;\n text = text.slice(part.to - start);\n start = part.to;\n }\n };\n }\n\n function buildCollapsedSpan(builder, size, marker, ignoreWidget) {\n var widget = !ignoreWidget && marker.widgetNode;\n if (widget) builder.map.push(builder.pos, builder.pos + size, widget);\n if (!ignoreWidget && builder.cm.display.input.needsContentAttribute) {\n if (!widget)\n widget = builder.content.appendChild(document.createElement(\"span\"));\n widget.setAttribute(\"cm-marker\", marker.id);\n }\n if (widget) {\n builder.cm.display.input.setUneditable(widget);\n builder.content.appendChild(widget);\n }\n builder.pos += size;\n builder.trailingSpace = false\n }\n\n // Outputs a number of spans to make up a line, taking highlighting\n // and marked text into account.\n function insertLineContent(line, builder, styles) {\n var spans = line.markedSpans, allText = line.text, at = 0;\n if (!spans) {\n for (var i = 1; i < styles.length; i+=2)\n builder.addToken(builder, allText.slice(at, at = styles[i]), interpretTokenStyle(styles[i+1], builder.cm.options));\n return;\n }\n\n var len = allText.length, pos = 0, i = 1, text = \"\", style, css;\n var nextChange = 0, spanStyle, spanEndStyle, spanStartStyle, title, collapsed;\n for (;;) {\n if (nextChange == pos) { // Update current marker set\n spanStyle = spanEndStyle = spanStartStyle = title = css = \"\";\n collapsed = null; nextChange = Infinity;\n var foundBookmarks = [], endStyles\n for (var j = 0; j < spans.length; ++j) {\n var sp = spans[j], m = sp.marker;\n if (m.type == \"bookmark\" && sp.from == pos && m.widgetNode) {\n foundBookmarks.push(m);\n } else if (sp.from <= pos && (sp.to == null || sp.to > pos || m.collapsed && sp.to == pos && sp.from == pos)) {\n if (sp.to != null && sp.to != pos && nextChange > sp.to) {\n nextChange = sp.to;\n spanEndStyle = \"\";\n }\n if (m.className) spanStyle += \" \" + m.className;\n if (m.css) css = (css ? css + \";\" : \"\") + m.css;\n if (m.startStyle && sp.from == pos) spanStartStyle += \" \" + m.startStyle;\n if (m.endStyle && sp.to == nextChange) (endStyles || (endStyles = [])).push(m.endStyle, sp.to)\n if (m.title && !title) title = m.title;\n if (m.collapsed && (!collapsed || compareCollapsedMarkers(collapsed.marker, m) < 0))\n collapsed = sp;\n } else if (sp.from > pos && nextChange > sp.from) {\n nextChange = sp.from;\n }\n }\n if (endStyles) for (var j = 0; j < endStyles.length; j += 2)\n if (endStyles[j + 1] == nextChange) spanEndStyle += \" \" + endStyles[j]\n\n if (!collapsed || collapsed.from == pos) for (var j = 0; j < foundBookmarks.length; ++j)\n buildCollapsedSpan(builder, 0, foundBookmarks[j]);\n if (collapsed && (collapsed.from || 0) == pos) {\n buildCollapsedSpan(builder, (collapsed.to == null ? len + 1 : collapsed.to) - pos,\n collapsed.marker, collapsed.from == null);\n if (collapsed.to == null) return;\n if (collapsed.to == pos) collapsed = false;\n }\n }\n if (pos >= len) break;\n\n var upto = Math.min(len, nextChange);\n while (true) {\n if (text) {\n var end = pos + text.length;\n if (!collapsed) {\n var tokenText = end > upto ? text.slice(0, upto - pos) : text;\n builder.addToken(builder, tokenText, style ? style + spanStyle : spanStyle,\n spanStartStyle, pos + tokenText.length == nextChange ? spanEndStyle : \"\", title, css);\n }\n if (end >= upto) {text = text.slice(upto - pos); pos = upto; break;}\n pos = end;\n spanStartStyle = \"\";\n }\n text = allText.slice(at, at = styles[i++]);\n style = interpretTokenStyle(styles[i++], builder.cm.options);\n }\n }\n }\n\n // DOCUMENT DATA STRUCTURE\n\n // By default, updates that start and end at the beginning of a line\n // are treated specially, in order to make the association of line\n // widgets and marker elements with the text behave more intuitive.\n function isWholeLineUpdate(doc, change) {\n return change.from.ch == 0 && change.to.ch == 0 && lst(change.text) == \"\" &&\n (!doc.cm || doc.cm.options.wholeLineUpdateBefore);\n }\n\n // Perform a change on the document data structure.\n function updateDoc(doc, change, markedSpans, estimateHeight) {\n function spansFor(n) {return markedSpans ? markedSpans[n] : null;}\n function update(line, text, spans) {\n updateLine(line, text, spans, estimateHeight);\n signalLater(line, \"change\", line, change);\n }\n function linesFor(start, end) {\n for (var i = start, result = []; i < end; ++i)\n result.push(new Line(text[i], spansFor(i), estimateHeight));\n return result;\n }\n\n var from = change.from, to = change.to, text = change.text;\n var firstLine = getLine(doc, from.line), lastLine = getLine(doc, to.line);\n var lastText = lst(text), lastSpans = spansFor(text.length - 1), nlines = to.line - from.line;\n\n // Adjust the line structure\n if (change.full) {\n doc.insert(0, linesFor(0, text.length));\n doc.remove(text.length, doc.size - text.length);\n } else if (isWholeLineUpdate(doc, change)) {\n // This is a whole-line replace. Treated specially to make\n // sure line objects move the way they are supposed to.\n var added = linesFor(0, text.length - 1);\n update(lastLine, lastLine.text, lastSpans);\n if (nlines) doc.remove(from.line, nlines);\n if (added.length) doc.insert(from.line, added);\n } else if (firstLine == lastLine) {\n if (text.length == 1) {\n update(firstLine, firstLine.text.slice(0, from.ch) + lastText + firstLine.text.slice(to.ch), lastSpans);\n } else {\n var added = linesFor(1, text.length - 1);\n added.push(new Line(lastText + firstLine.text.slice(to.ch), lastSpans, estimateHeight));\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));\n doc.insert(from.line + 1, added);\n }\n } else if (text.length == 1) {\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0] + lastLine.text.slice(to.ch), spansFor(0));\n doc.remove(from.line + 1, nlines);\n } else {\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));\n update(lastLine, lastText + lastLine.text.slice(to.ch), lastSpans);\n var added = linesFor(1, text.length - 1);\n if (nlines > 1) doc.remove(from.line + 1, nlines - 1);\n doc.insert(from.line + 1, added);\n }\n\n signalLater(doc, \"change\", doc, change);\n }\n\n // The document is represented as a BTree consisting of leaves, with\n // chunk of lines in them, and branches, with up to ten leaves or\n // other branch nodes below them. The top node is always a branch\n // node, and is the document object itself (meaning it has\n // additional methods and properties).\n //\n // All nodes have parent links. The tree is used both to go from\n // line numbers to line objects, and to go from objects to numbers.\n // It also indexes by height, and is used to convert between height\n // and line object, and to find the total height of the document.\n //\n // See also http://marijnhaverbeke.nl/blog/codemirror-line-tree.html\n\n function LeafChunk(lines) {\n this.lines = lines;\n this.parent = null;\n for (var i = 0, height = 0; i < lines.length; ++i) {\n lines[i].parent = this;\n height += lines[i].height;\n }\n this.height = height;\n }\n\n LeafChunk.prototype = {\n chunkSize: function() { return this.lines.length; },\n // Remove the n lines at offset 'at'.\n removeInner: function(at, n) {\n for (var i = at, e = at + n; i < e; ++i) {\n var line = this.lines[i];\n this.height -= line.height;\n cleanUpLine(line);\n signalLater(line, \"delete\");\n }\n this.lines.splice(at, n);\n },\n // Helper used to collapse a small branch into a single leaf.\n collapse: function(lines) {\n lines.push.apply(lines, this.lines);\n },\n // Insert the given array of lines at offset 'at', count them as\n // having the given height.\n insertInner: function(at, lines, height) {\n this.height += height;\n this.lines = this.lines.slice(0, at).concat(lines).concat(this.lines.slice(at));\n for (var i = 0; i < lines.length; ++i) lines[i].parent = this;\n },\n // Used to iterate over a part of the tree.\n iterN: function(at, n, op) {\n for (var e = at + n; at < e; ++at)\n if (op(this.lines[at])) return true;\n }\n };\n\n function BranchChunk(children) {\n this.children = children;\n var size = 0, height = 0;\n for (var i = 0; i < children.length; ++i) {\n var ch = children[i];\n size += ch.chunkSize(); height += ch.height;\n ch.parent = this;\n }\n this.size = size;\n this.height = height;\n this.parent = null;\n }\n\n BranchChunk.prototype = {\n chunkSize: function() { return this.size; },\n removeInner: function(at, n) {\n this.size -= n;\n for (var i = 0; i < this.children.length; ++i) {\n var child = this.children[i], sz = child.chunkSize();\n if (at < sz) {\n var rm = Math.min(n, sz - at), oldHeight = child.height;\n child.removeInner(at, rm);\n this.height -= oldHeight - child.height;\n if (sz == rm) { this.children.splice(i--, 1); child.parent = null; }\n if ((n -= rm) == 0) break;\n at = 0;\n } else at -= sz;\n }\n // If the result is smaller than 25 lines, ensure that it is a\n // single leaf node.\n if (this.size - n < 25 &&\n (this.children.length > 1 || !(this.children[0] instanceof LeafChunk))) {\n var lines = [];\n this.collapse(lines);\n this.children = [new LeafChunk(lines)];\n this.children[0].parent = this;\n }\n },\n collapse: function(lines) {\n for (var i = 0; i < this.children.length; ++i) this.children[i].collapse(lines);\n },\n insertInner: function(at, lines, height) {\n this.size += lines.length;\n this.height += height;\n for (var i = 0; i < this.children.length; ++i) {\n var child = this.children[i], sz = child.chunkSize();\n if (at <= sz) {\n child.insertInner(at, lines, height);\n if (child.lines && child.lines.length > 50) {\n // To avoid memory thrashing when child.lines is huge (e.g. first view of a large file), it's never spliced.\n // Instead, small slices are taken. They're taken in order because sequential memory accesses are fastest.\n var remaining = child.lines.length % 25 + 25\n for (var pos = remaining; pos < child.lines.length;) {\n var leaf = new LeafChunk(child.lines.slice(pos, pos += 25));\n child.height -= leaf.height;\n this.children.splice(++i, 0, leaf);\n leaf.parent = this;\n }\n child.lines = child.lines.slice(0, remaining);\n this.maybeSpill();\n }\n break;\n }\n at -= sz;\n }\n },\n // When a node has grown, check whether it should be split.\n maybeSpill: function() {\n if (this.children.length <= 10) return;\n var me = this;\n do {\n var spilled = me.children.splice(me.children.length - 5, 5);\n var sibling = new BranchChunk(spilled);\n if (!me.parent) { // Become the parent node\n var copy = new BranchChunk(me.children);\n copy.parent = me;\n me.children = [copy, sibling];\n me = copy;\n } else {\n me.size -= sibling.size;\n me.height -= sibling.height;\n var myIndex = indexOf(me.parent.children, me);\n me.parent.children.splice(myIndex + 1, 0, sibling);\n }\n sibling.parent = me.parent;\n } while (me.children.length > 10);\n me.parent.maybeSpill();\n },\n iterN: function(at, n, op) {\n for (var i = 0; i < this.children.length; ++i) {\n var child = this.children[i], sz = child.chunkSize();\n if (at < sz) {\n var used = Math.min(n, sz - at);\n if (child.iterN(at, used, op)) return true;\n if ((n -= used) == 0) break;\n at = 0;\n } else at -= sz;\n }\n }\n };\n\n var nextDocId = 0;\n var Doc = CodeMirror.Doc = function(text, mode, firstLine, lineSep) {\n if (!(this instanceof Doc)) return new Doc(text, mode, firstLine, lineSep);\n if (firstLine == null) firstLine = 0;\n\n BranchChunk.call(this, [new LeafChunk([new Line(\"\", null)])]);\n this.first = firstLine;\n this.scrollTop = this.scrollLeft = 0;\n this.cantEdit = false;\n this.cleanGeneration = 1;\n this.frontier = firstLine;\n var start = Pos(firstLine, 0);\n this.sel = simpleSelection(start);\n this.history = new History(null);\n this.id = ++nextDocId;\n this.modeOption = mode;\n this.lineSep = lineSep;\n this.extend = false;\n\n if (typeof text == \"string\") text = this.splitLines(text);\n updateDoc(this, {from: start, to: start, text: text});\n setSelection(this, simpleSelection(start), sel_dontScroll);\n };\n\n Doc.prototype = createObj(BranchChunk.prototype, {\n constructor: Doc,\n // Iterate over the document. Supports two forms -- with only one\n // argument, it calls that for each line in the document. With\n // three, it iterates over the range given by the first two (with\n // the second being non-inclusive).\n iter: function(from, to, op) {\n if (op) this.iterN(from - this.first, to - from, op);\n else this.iterN(this.first, this.first + this.size, from);\n },\n\n // Non-public interface for adding and removing lines.\n insert: function(at, lines) {\n var height = 0;\n for (var i = 0; i < lines.length; ++i) height += lines[i].height;\n this.insertInner(at - this.first, lines, height);\n },\n remove: function(at, n) { this.removeInner(at - this.first, n); },\n\n // From here, the methods are part of the public interface. Most\n // are also available from CodeMirror (editor) instances.\n\n getValue: function(lineSep) {\n var lines = getLines(this, this.first, this.first + this.size);\n if (lineSep === false) return lines;\n return lines.join(lineSep || this.lineSeparator());\n },\n setValue: docMethodOp(function(code) {\n var top = Pos(this.first, 0), last = this.first + this.size - 1;\n makeChange(this, {from: top, to: Pos(last, getLine(this, last).text.length),\n text: this.splitLines(code), origin: \"setValue\", full: true}, true);\n setSelection(this, simpleSelection(top));\n }),\n replaceRange: function(code, from, to, origin) {\n from = clipPos(this, from);\n to = to ? clipPos(this, to) : from;\n replaceRange(this, code, from, to, origin);\n },\n getRange: function(from, to, lineSep) {\n var lines = getBetween(this, clipPos(this, from), clipPos(this, to));\n if (lineSep === false) return lines;\n return lines.join(lineSep || this.lineSeparator());\n },\n\n getLine: function(line) {var l = this.getLineHandle(line); return l && l.text;},\n\n getLineHandle: function(line) {if (isLine(this, line)) return getLine(this, line);},\n getLineNumber: function(line) {return lineNo(line);},\n\n getLineHandleVisualStart: function(line) {\n if (typeof line == \"number\") line = getLine(this, line);\n return visualLine(line);\n },\n\n lineCount: function() {return this.size;},\n firstLine: function() {return this.first;},\n lastLine: function() {return this.first + this.size - 1;},\n\n clipPos: function(pos) {return clipPos(this, pos);},\n\n getCursor: function(start) {\n var range = this.sel.primary(), pos;\n if (start == null || start == \"head\") pos = range.head;\n else if (start == \"anchor\") pos = range.anchor;\n else if (start == \"end\" || start == \"to\" || start === false) pos = range.to();\n else pos = range.from();\n return pos;\n },\n listSelections: function() { return this.sel.ranges; },\n somethingSelected: function() {return this.sel.somethingSelected();},\n\n setCursor: docMethodOp(function(line, ch, options) {\n setSimpleSelection(this, clipPos(this, typeof line == \"number\" ? Pos(line, ch || 0) : line), null, options);\n }),\n setSelection: docMethodOp(function(anchor, head, options) {\n setSimpleSelection(this, clipPos(this, anchor), clipPos(this, head || anchor), options);\n }),\n extendSelection: docMethodOp(function(head, other, options) {\n extendSelection(this, clipPos(this, head), other && clipPos(this, other), options);\n }),\n extendSelections: docMethodOp(function(heads, options) {\n extendSelections(this, clipPosArray(this, heads), options);\n }),\n extendSelectionsBy: docMethodOp(function(f, options) {\n var heads = map(this.sel.ranges, f);\n extendSelections(this, clipPosArray(this, heads), options);\n }),\n setSelections: docMethodOp(function(ranges, primary, options) {\n if (!ranges.length) return;\n for (var i = 0, out = []; i < ranges.length; i++)\n out[i] = new Range(clipPos(this, ranges[i].anchor),\n clipPos(this, ranges[i].head));\n if (primary == null) primary = Math.min(ranges.length - 1, this.sel.primIndex);\n setSelection(this, normalizeSelection(out, primary), options);\n }),\n addSelection: docMethodOp(function(anchor, head, options) {\n var ranges = this.sel.ranges.slice(0);\n ranges.push(new Range(clipPos(this, anchor), clipPos(this, head || anchor)));\n setSelection(this, normalizeSelection(ranges, ranges.length - 1), options);\n }),\n\n getSelection: function(lineSep) {\n var ranges = this.sel.ranges, lines;\n for (var i = 0; i < ranges.length; i++) {\n var sel = getBetween(this, ranges[i].from(), ranges[i].to());\n lines = lines ? lines.concat(sel) : sel;\n }\n if (lineSep === false) return lines;\n else return lines.join(lineSep || this.lineSeparator());\n },\n getSelections: function(lineSep) {\n var parts = [], ranges = this.sel.ranges;\n for (var i = 0; i < ranges.length; i++) {\n var sel = getBetween(this, ranges[i].from(), ranges[i].to());\n if (lineSep !== false) sel = sel.join(lineSep || this.lineSeparator());\n parts[i] = sel;\n }\n return parts;\n },\n replaceSelection: function(code, collapse, origin) {\n var dup = [];\n for (var i = 0; i < this.sel.ranges.length; i++)\n dup[i] = code;\n this.replaceSelections(dup, collapse, origin || \"+input\");\n },\n replaceSelections: docMethodOp(function(code, collapse, origin) {\n var changes = [], sel = this.sel;\n for (var i = 0; i < sel.ranges.length; i++) {\n var range = sel.ranges[i];\n changes[i] = {from: range.from(), to: range.to(), text: this.splitLines(code[i]), origin: origin};\n }\n var newSel = collapse && collapse != \"end\" && computeReplacedSel(this, changes, collapse);\n for (var i = changes.length - 1; i >= 0; i--)\n makeChange(this, changes[i]);\n if (newSel) setSelectionReplaceHistory(this, newSel);\n else if (this.cm) ensureCursorVisible(this.cm);\n }),\n undo: docMethodOp(function() {makeChangeFromHistory(this, \"undo\");}),\n redo: docMethodOp(function() {makeChangeFromHistory(this, \"redo\");}),\n undoSelection: docMethodOp(function() {makeChangeFromHistory(this, \"undo\", true);}),\n redoSelection: docMethodOp(function() {makeChangeFromHistory(this, \"redo\", true);}),\n\n setExtending: function(val) {this.extend = val;},\n getExtending: function() {return this.extend;},\n\n historySize: function() {\n var hist = this.history, done = 0, undone = 0;\n for (var i = 0; i < hist.done.length; i++) if (!hist.done[i].ranges) ++done;\n for (var i = 0; i < hist.undone.length; i++) if (!hist.undone[i].ranges) ++undone;\n return {undo: done, redo: undone};\n },\n clearHistory: function() {this.history = new History(this.history.maxGeneration);},\n\n markClean: function() {\n this.cleanGeneration = this.changeGeneration(true);\n },\n changeGeneration: function(forceSplit) {\n if (forceSplit)\n this.history.lastOp = this.history.lastSelOp = this.history.lastOrigin = null;\n return this.history.generation;\n },\n isClean: function (gen) {\n return this.history.generation == (gen || this.cleanGeneration);\n },\n\n getHistory: function() {\n return {done: copyHistoryArray(this.history.done),\n undone: copyHistoryArray(this.history.undone)};\n },\n setHistory: function(histData) {\n var hist = this.history = new History(this.history.maxGeneration);\n hist.done = copyHistoryArray(histData.done.slice(0), null, true);\n hist.undone = copyHistoryArray(histData.undone.slice(0), null, true);\n },\n\n addLineClass: docMethodOp(function(handle, where, cls) {\n return changeLine(this, handle, where == \"gutter\" ? \"gutter\" : \"class\", function(line) {\n var prop = where == \"text\" ? \"textClass\"\n : where == \"background\" ? \"bgClass\"\n : where == \"gutter\" ? \"gutterClass\" : \"wrapClass\";\n if (!line[prop]) line[prop] = cls;\n else if (classTest(cls).test(line[prop])) return false;\n else line[prop] += \" \" + cls;\n return true;\n });\n }),\n removeLineClass: docMethodOp(function(handle, where, cls) {\n return changeLine(this, handle, where == \"gutter\" ? \"gutter\" : \"class\", function(line) {\n var prop = where == \"text\" ? \"textClass\"\n : where == \"background\" ? \"bgClass\"\n : where == \"gutter\" ? \"gutterClass\" : \"wrapClass\";\n var cur = line[prop];\n if (!cur) return false;\n else if (cls == null) line[prop] = null;\n else {\n var found = cur.match(classTest(cls));\n if (!found) return false;\n var end = found.index + found[0].length;\n line[prop] = cur.slice(0, found.index) + (!found.index || end == cur.length ? \"\" : \" \") + cur.slice(end) || null;\n }\n return true;\n });\n }),\n\n addLineWidget: docMethodOp(function(handle, node, options) {\n return addLineWidget(this, handle, node, options);\n }),\n removeLineWidget: function(widget) { widget.clear(); },\n\n markText: function(from, to, options) {\n return markText(this, clipPos(this, from), clipPos(this, to), options, options && options.type || \"range\");\n },\n setBookmark: function(pos, options) {\n var realOpts = {replacedWith: options && (options.nodeType == null ? options.widget : options),\n insertLeft: options && options.insertLeft,\n clearWhenEmpty: false, shared: options && options.shared,\n handleMouseEvents: options && options.handleMouseEvents};\n pos = clipPos(this, pos);\n return markText(this, pos, pos, realOpts, \"bookmark\");\n },\n findMarksAt: function(pos) {\n pos = clipPos(this, pos);\n var markers = [], spans = getLine(this, pos.line).markedSpans;\n if (spans) for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if ((span.from == null || span.from <= pos.ch) &&\n (span.to == null || span.to >= pos.ch))\n markers.push(span.marker.parent || span.marker);\n }\n return markers;\n },\n findMarks: function(from, to, filter) {\n from = clipPos(this, from); to = clipPos(this, to);\n var found = [], lineNo = from.line;\n this.iter(from.line, to.line + 1, function(line) {\n var spans = line.markedSpans;\n if (spans) for (var i = 0; i < spans.length; i++) {\n var span = spans[i];\n if (!(span.to != null && lineNo == from.line && from.ch >= span.to ||\n span.from == null && lineNo != from.line ||\n span.from != null && lineNo == to.line && span.from >= to.ch) &&\n (!filter || filter(span.marker)))\n found.push(span.marker.parent || span.marker);\n }\n ++lineNo;\n });\n return found;\n },\n getAllMarks: function() {\n var markers = [];\n this.iter(function(line) {\n var sps = line.markedSpans;\n if (sps) for (var i = 0; i < sps.length; ++i)\n if (sps[i].from != null) markers.push(sps[i].marker);\n });\n return markers;\n },\n\n posFromIndex: function(off) {\n var ch, lineNo = this.first, sepSize = this.lineSeparator().length;\n this.iter(function(line) {\n var sz = line.text.length + sepSize;\n if (sz > off) { ch = off; return true; }\n off -= sz;\n ++lineNo;\n });\n return clipPos(this, Pos(lineNo, ch));\n },\n indexFromPos: function (coords) {\n coords = clipPos(this, coords);\n var index = coords.ch;\n if (coords.line < this.first || coords.ch < 0) return 0;\n var sepSize = this.lineSeparator().length;\n this.iter(this.first, coords.line, function (line) {\n index += line.text.length + sepSize;\n });\n return index;\n },\n\n copy: function(copyHistory) {\n var doc = new Doc(getLines(this, this.first, this.first + this.size),\n this.modeOption, this.first, this.lineSep);\n doc.scrollTop = this.scrollTop; doc.scrollLeft = this.scrollLeft;\n doc.sel = this.sel;\n doc.extend = false;\n if (copyHistory) {\n doc.history.undoDepth = this.history.undoDepth;\n doc.setHistory(this.getHistory());\n }\n return doc;\n },\n\n linkedDoc: function(options) {\n if (!options) options = {};\n var from = this.first, to = this.first + this.size;\n if (options.from != null && options.from > from) from = options.from;\n if (options.to != null && options.to < to) to = options.to;\n var copy = new Doc(getLines(this, from, to), options.mode || this.modeOption, from, this.lineSep);\n if (options.sharedHist) copy.history = this.history;\n (this.linked || (this.linked = [])).push({doc: copy, sharedHist: options.sharedHist});\n copy.linked = [{doc: this, isParent: true, sharedHist: options.sharedHist}];\n copySharedMarkers(copy, findSharedMarkers(this));\n return copy;\n },\n unlinkDoc: function(other) {\n if (other instanceof CodeMirror) other = other.doc;\n if (this.linked) for (var i = 0; i < this.linked.length; ++i) {\n var link = this.linked[i];\n if (link.doc != other) continue;\n this.linked.splice(i, 1);\n other.unlinkDoc(this);\n detachSharedMarkers(findSharedMarkers(this));\n break;\n }\n // If the histories were shared, split them again\n if (other.history == this.history) {\n var splitIds = [other.id];\n linkedDocs(other, function(doc) {splitIds.push(doc.id);}, true);\n other.history = new History(null);\n other.history.done = copyHistoryArray(this.history.done, splitIds);\n other.history.undone = copyHistoryArray(this.history.undone, splitIds);\n }\n },\n iterLinkedDocs: function(f) {linkedDocs(this, f);},\n\n getMode: function() {return this.mode;},\n getEditor: function() {return this.cm;},\n\n splitLines: function(str) {\n if (this.lineSep) return str.split(this.lineSep);\n return splitLinesAuto(str);\n },\n lineSeparator: function() { return this.lineSep || \"\\n\"; }\n });\n\n // Public alias.\n Doc.prototype.eachLine = Doc.prototype.iter;\n\n // Set up methods on CodeMirror's prototype to redirect to the editor's document.\n var dontDelegate = \"iter insert remove copy getEditor constructor\".split(\" \");\n for (var prop in Doc.prototype) if (Doc.prototype.hasOwnProperty(prop) && indexOf(dontDelegate, prop) < 0)\n CodeMirror.prototype[prop] = (function(method) {\n return function() {return method.apply(this.doc, arguments);};\n })(Doc.prototype[prop]);\n\n eventMixin(Doc);\n\n // Call f for all linked documents.\n function linkedDocs(doc, f, sharedHistOnly) {\n function propagate(doc, skip, sharedHist) {\n if (doc.linked) for (var i = 0; i < doc.linked.length; ++i) {\n var rel = doc.linked[i];\n if (rel.doc == skip) continue;\n var shared = sharedHist && rel.sharedHist;\n if (sharedHistOnly && !shared) continue;\n f(rel.doc, shared);\n propagate(rel.doc, doc, shared);\n }\n }\n propagate(doc, null, true);\n }\n\n // Attach a document to an editor.\n function attachDoc(cm, doc) {\n if (doc.cm) throw new Error(\"This document is already in use.\");\n cm.doc = doc;\n doc.cm = cm;\n estimateLineHeights(cm);\n loadMode(cm);\n if (!cm.options.lineWrapping) findMaxLine(cm);\n cm.options.mode = doc.modeOption;\n regChange(cm);\n }\n\n // LINE UTILITIES\n\n // Find the line object corresponding to the given line number.\n function getLine(doc, n) {\n n -= doc.first;\n if (n < 0 || n >= doc.size) throw new Error(\"There is no line \" + (n + doc.first) + \" in the document.\");\n for (var chunk = doc; !chunk.lines;) {\n for (var i = 0;; ++i) {\n var child = chunk.children[i], sz = child.chunkSize();\n if (n < sz) { chunk = child; break; }\n n -= sz;\n }\n }\n return chunk.lines[n];\n }\n\n // Get the part of a document between two positions, as an array of\n // strings.\n function getBetween(doc, start, end) {\n var out = [], n = start.line;\n doc.iter(start.line, end.line + 1, function(line) {\n var text = line.text;\n if (n == end.line) text = text.slice(0, end.ch);\n if (n == start.line) text = text.slice(start.ch);\n out.push(text);\n ++n;\n });\n return out;\n }\n // Get the lines between from and to, as array of strings.\n function getLines(doc, from, to) {\n var out = [];\n doc.iter(from, to, function(line) { out.push(line.text); });\n return out;\n }\n\n // Update the height of a line, propagating the height change\n // upwards to parent nodes.\n function updateLineHeight(line, height) {\n var diff = height - line.height;\n if (diff) for (var n = line; n; n = n.parent) n.height += diff;\n }\n\n // Given a line object, find its line number by walking up through\n // its parent links.\n function lineNo(line) {\n if (line.parent == null) return null;\n var cur = line.parent, no = indexOf(cur.lines, line);\n for (var chunk = cur.parent; chunk; cur = chunk, chunk = chunk.parent) {\n for (var i = 0;; ++i) {\n if (chunk.children[i] == cur) break;\n no += chunk.children[i].chunkSize();\n }\n }\n return no + cur.first;\n }\n\n // Find the line at the given vertical position, using the height\n // information in the document tree.\n function lineAtHeight(chunk, h) {\n var n = chunk.first;\n outer: do {\n for (var i = 0; i < chunk.children.length; ++i) {\n var child = chunk.children[i], ch = child.height;\n if (h < ch) { chunk = child; continue outer; }\n h -= ch;\n n += child.chunkSize();\n }\n return n;\n } while (!chunk.lines);\n for (var i = 0; i < chunk.lines.length; ++i) {\n var line = chunk.lines[i], lh = line.height;\n if (h < lh) break;\n h -= lh;\n }\n return n + i;\n }\n\n\n // Find the height above the given line.\n function heightAtLine(lineObj) {\n lineObj = visualLine(lineObj);\n\n var h = 0, chunk = lineObj.parent;\n for (var i = 0; i < chunk.lines.length; ++i) {\n var line = chunk.lines[i];\n if (line == lineObj) break;\n else h += line.height;\n }\n for (var p = chunk.parent; p; chunk = p, p = chunk.parent) {\n for (var i = 0; i < p.children.length; ++i) {\n var cur = p.children[i];\n if (cur == chunk) break;\n else h += cur.height;\n }\n }\n return h;\n }\n\n // Get the bidi ordering for the given line (and cache it). Returns\n // false for lines that are fully left-to-right, and an array of\n // BidiSpan objects otherwise.\n function getOrder(line) {\n var order = line.order;\n if (order == null) order = line.order = bidiOrdering(line.text);\n return order;\n }\n\n // HISTORY\n\n function History(startGen) {\n // Arrays of change events and selections. Doing something adds an\n // event to done and clears undo. Undoing moves events from done\n // to undone, redoing moves them in the other direction.\n this.done = []; this.undone = [];\n this.undoDepth = Infinity;\n // Used to track when changes can be merged into a single undo\n // event\n this.lastModTime = this.lastSelTime = 0;\n this.lastOp = this.lastSelOp = null;\n this.lastOrigin = this.lastSelOrigin = null;\n // Used by the isClean() method\n this.generation = this.maxGeneration = startGen || 1;\n }\n\n // Create a history change event from an updateDoc-style change\n // object.\n function historyChangeFromChange(doc, change) {\n var histChange = {from: copyPos(change.from), to: changeEnd(change), text: getBetween(doc, change.from, change.to)};\n attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1);\n linkedDocs(doc, function(doc) {attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1);}, true);\n return histChange;\n }\n\n // Pop all selection events off the end of a history array. Stop at\n // a change event.\n function clearSelectionEvents(array) {\n while (array.length) {\n var last = lst(array);\n if (last.ranges) array.pop();\n else break;\n }\n }\n\n // Find the top change event in the history. Pop off selection\n // events that are in the way.\n function lastChangeEvent(hist, force) {\n if (force) {\n clearSelectionEvents(hist.done);\n return lst(hist.done);\n } else if (hist.done.length && !lst(hist.done).ranges) {\n return lst(hist.done);\n } else if (hist.done.length > 1 && !hist.done[hist.done.length - 2].ranges) {\n hist.done.pop();\n return lst(hist.done);\n }\n }\n\n // Register a change in the history. Merges changes that are within\n // a single operation, ore are close together with an origin that\n // allows merging (starting with \"+\") into a single event.\n function addChangeToHistory(doc, change, selAfter, opId) {\n var hist = doc.history;\n hist.undone.length = 0;\n var time = +new Date, cur;\n\n if ((hist.lastOp == opId ||\n hist.lastOrigin == change.origin && change.origin &&\n ((change.origin.charAt(0) == \"+\" && doc.cm && hist.lastModTime > time - doc.cm.options.historyEventDelay) ||\n change.origin.charAt(0) == \"*\")) &&\n (cur = lastChangeEvent(hist, hist.lastOp == opId))) {\n // Merge this change into the last event\n var last = lst(cur.changes);\n if (cmp(change.from, change.to) == 0 && cmp(change.from, last.to) == 0) {\n // Optimized case for simple insertion -- don't want to add\n // new changesets for every character typed\n last.to = changeEnd(change);\n } else {\n // Add new sub-event\n cur.changes.push(historyChangeFromChange(doc, change));\n }\n } else {\n // Can not be merged, start a new event.\n var before = lst(hist.done);\n if (!before || !before.ranges)\n pushSelectionToHistory(doc.sel, hist.done);\n cur = {changes: [historyChangeFromChange(doc, change)],\n generation: hist.generation};\n hist.done.push(cur);\n while (hist.done.length > hist.undoDepth) {\n hist.done.shift();\n if (!hist.done[0].ranges) hist.done.shift();\n }\n }\n hist.done.push(selAfter);\n hist.generation = ++hist.maxGeneration;\n hist.lastModTime = hist.lastSelTime = time;\n hist.lastOp = hist.lastSelOp = opId;\n hist.lastOrigin = hist.lastSelOrigin = change.origin;\n\n if (!last) signal(doc, \"historyAdded\");\n }\n\n function selectionEventCanBeMerged(doc, origin, prev, sel) {\n var ch = origin.charAt(0);\n return ch == \"*\" ||\n ch == \"+\" &&\n prev.ranges.length == sel.ranges.length &&\n prev.somethingSelected() == sel.somethingSelected() &&\n new Date - doc.history.lastSelTime <= (doc.cm ? doc.cm.options.historyEventDelay : 500);\n }\n\n // Called whenever the selection changes, sets the new selection as\n // the pending selection in the history, and pushes the old pending\n // selection into the 'done' array when it was significantly\n // different (in number of selected ranges, emptiness, or time).\n function addSelectionToHistory(doc, sel, opId, options) {\n var hist = doc.history, origin = options && options.origin;\n\n // A new event is started when the previous origin does not match\n // the current, or the origins don't allow matching. Origins\n // starting with * are always merged, those starting with + are\n // merged when similar and close together in time.\n if (opId == hist.lastSelOp ||\n (origin && hist.lastSelOrigin == origin &&\n (hist.lastModTime == hist.lastSelTime && hist.lastOrigin == origin ||\n selectionEventCanBeMerged(doc, origin, lst(hist.done), sel))))\n hist.done[hist.done.length - 1] = sel;\n else\n pushSelectionToHistory(sel, hist.done);\n\n hist.lastSelTime = +new Date;\n hist.lastSelOrigin = origin;\n hist.lastSelOp = opId;\n if (options && options.clearRedo !== false)\n clearSelectionEvents(hist.undone);\n }\n\n function pushSelectionToHistory(sel, dest) {\n var top = lst(dest);\n if (!(top && top.ranges && top.equals(sel)))\n dest.push(sel);\n }\n\n // Used to store marked span information in the history.\n function attachLocalSpans(doc, change, from, to) {\n var existing = change[\"spans_\" + doc.id], n = 0;\n doc.iter(Math.max(doc.first, from), Math.min(doc.first + doc.size, to), function(line) {\n if (line.markedSpans)\n (existing || (existing = change[\"spans_\" + doc.id] = {}))[n] = line.markedSpans;\n ++n;\n });\n }\n\n // When un/re-doing restores text containing marked spans, those\n // that have been explicitly cleared should not be restored.\n function removeClearedSpans(spans) {\n if (!spans) return null;\n for (var i = 0, out; i < spans.length; ++i) {\n if (spans[i].marker.explicitlyCleared) { if (!out) out = spans.slice(0, i); }\n else if (out) out.push(spans[i]);\n }\n return !out ? spans : out.length ? out : null;\n }\n\n // Retrieve and filter the old marked spans stored in a change event.\n function getOldSpans(doc, change) {\n var found = change[\"spans_\" + doc.id];\n if (!found) return null;\n for (var i = 0, nw = []; i < change.text.length; ++i)\n nw.push(removeClearedSpans(found[i]));\n return nw;\n }\n\n // Used both to provide a JSON-safe object in .getHistory, and, when\n // detaching a document, to split the history in two\n function copyHistoryArray(events, newGroup, instantiateSel) {\n for (var i = 0, copy = []; i < events.length; ++i) {\n var event = events[i];\n if (event.ranges) {\n copy.push(instantiateSel ? Selection.prototype.deepCopy.call(event) : event);\n continue;\n }\n var changes = event.changes, newChanges = [];\n copy.push({changes: newChanges});\n for (var j = 0; j < changes.length; ++j) {\n var change = changes[j], m;\n newChanges.push({from: change.from, to: change.to, text: change.text});\n if (newGroup) for (var prop in change) if (m = prop.match(/^spans_(\\d+)$/)) {\n if (indexOf(newGroup, Number(m[1])) > -1) {\n lst(newChanges)[prop] = change[prop];\n delete change[prop];\n }\n }\n }\n }\n return copy;\n }\n\n // Rebasing/resetting history to deal with externally-sourced changes\n\n function rebaseHistSelSingle(pos, from, to, diff) {\n if (to < pos.line) {\n pos.line += diff;\n } else if (from < pos.line) {\n pos.line = from;\n pos.ch = 0;\n }\n }\n\n // Tries to rebase an array of history events given a change in the\n // document. If the change touches the same lines as the event, the\n // event, and everything 'behind' it, is discarded. If the change is\n // before the event, the event's positions are updated. Uses a\n // copy-on-write scheme for the positions, to avoid having to\n // reallocate them all on every rebase, but also avoid problems with\n // shared position objects being unsafely updated.\n function rebaseHistArray(array, from, to, diff) {\n for (var i = 0; i < array.length; ++i) {\n var sub = array[i], ok = true;\n if (sub.ranges) {\n if (!sub.copied) { sub = array[i] = sub.deepCopy(); sub.copied = true; }\n for (var j = 0; j < sub.ranges.length; j++) {\n rebaseHistSelSingle(sub.ranges[j].anchor, from, to, diff);\n rebaseHistSelSingle(sub.ranges[j].head, from, to, diff);\n }\n continue;\n }\n for (var j = 0; j < sub.changes.length; ++j) {\n var cur = sub.changes[j];\n if (to < cur.from.line) {\n cur.from = Pos(cur.from.line + diff, cur.from.ch);\n cur.to = Pos(cur.to.line + diff, cur.to.ch);\n } else if (from <= cur.to.line) {\n ok = false;\n break;\n }\n }\n if (!ok) {\n array.splice(0, i + 1);\n i = 0;\n }\n }\n }\n\n function rebaseHist(hist, change) {\n var from = change.from.line, to = change.to.line, diff = change.text.length - (to - from) - 1;\n rebaseHistArray(hist.done, from, to, diff);\n rebaseHistArray(hist.undone, from, to, diff);\n }\n\n // EVENT UTILITIES\n\n // Due to the fact that we still support jurassic IE versions, some\n // compatibility wrappers are needed.\n\n var e_preventDefault = CodeMirror.e_preventDefault = function(e) {\n if (e.preventDefault) e.preventDefault();\n else e.returnValue = false;\n };\n var e_stopPropagation = CodeMirror.e_stopPropagation = function(e) {\n if (e.stopPropagation) e.stopPropagation();\n else e.cancelBubble = true;\n };\n function e_defaultPrevented(e) {\n return e.defaultPrevented != null ? e.defaultPrevented : e.returnValue == false;\n }\n var e_stop = CodeMirror.e_stop = function(e) {e_preventDefault(e); e_stopPropagation(e);};\n\n function e_target(e) {return e.target || e.srcElement;}\n function e_button(e) {\n var b = e.which;\n if (b == null) {\n if (e.button & 1) b = 1;\n else if (e.button & 2) b = 3;\n else if (e.button & 4) b = 2;\n }\n if (mac && e.ctrlKey && b == 1) b = 3;\n return b;\n }\n\n // EVENT HANDLING\n\n // Lightweight event framework. on/off also work on DOM nodes,\n // registering native DOM handlers.\n\n var on = CodeMirror.on = function(emitter, type, f) {\n if (emitter.addEventListener)\n emitter.addEventListener(type, f, false);\n else if (emitter.attachEvent)\n emitter.attachEvent(\"on\" + type, f);\n else {\n var map = emitter._handlers || (emitter._handlers = {});\n var arr = map[type] || (map[type] = []);\n arr.push(f);\n }\n };\n\n var noHandlers = []\n function getHandlers(emitter, type, copy) {\n var arr = emitter._handlers && emitter._handlers[type]\n if (copy) return arr && arr.length > 0 ? arr.slice() : noHandlers\n else return arr || noHandlers\n }\n\n var off = CodeMirror.off = function(emitter, type, f) {\n if (emitter.removeEventListener)\n emitter.removeEventListener(type, f, false);\n else if (emitter.detachEvent)\n emitter.detachEvent(\"on\" + type, f);\n else {\n var handlers = getHandlers(emitter, type, false)\n for (var i = 0; i < handlers.length; ++i)\n if (handlers[i] == f) { handlers.splice(i, 1); break; }\n }\n };\n\n var signal = CodeMirror.signal = function(emitter, type /*, values...*/) {\n var handlers = getHandlers(emitter, type, true)\n if (!handlers.length) return;\n var args = Array.prototype.slice.call(arguments, 2);\n for (var i = 0; i < handlers.length; ++i) handlers[i].apply(null, args);\n };\n\n var orphanDelayedCallbacks = null;\n\n // Often, we want to signal events at a point where we are in the\n // middle of some work, but don't want the handler to start calling\n // other methods on the editor, which might be in an inconsistent\n // state or simply not expect any other events to happen.\n // signalLater looks whether there are any handlers, and schedules\n // them to be executed when the last operation ends, or, if no\n // operation is active, when a timeout fires.\n function signalLater(emitter, type /*, values...*/) {\n var arr = getHandlers(emitter, type, false)\n if (!arr.length) return;\n var args = Array.prototype.slice.call(arguments, 2), list;\n if (operationGroup) {\n list = operationGroup.delayedCallbacks;\n } else if (orphanDelayedCallbacks) {\n list = orphanDelayedCallbacks;\n } else {\n list = orphanDelayedCallbacks = [];\n setTimeout(fireOrphanDelayed, 0);\n }\n function bnd(f) {return function(){f.apply(null, args);};};\n for (var i = 0; i < arr.length; ++i)\n list.push(bnd(arr[i]));\n }\n\n function fireOrphanDelayed() {\n var delayed = orphanDelayedCallbacks;\n orphanDelayedCallbacks = null;\n for (var i = 0; i < delayed.length; ++i) delayed[i]();\n }\n\n // The DOM events that CodeMirror handles can be overridden by\n // registering a (non-DOM) handler on the editor for the event name,\n // and preventDefault-ing the event in that handler.\n function signalDOMEvent(cm, e, override) {\n if (typeof e == \"string\")\n e = {type: e, preventDefault: function() { this.defaultPrevented = true; }};\n signal(cm, override || e.type, cm, e);\n return e_defaultPrevented(e) || e.codemirrorIgnore;\n }\n\n function signalCursorActivity(cm) {\n var arr = cm._handlers && cm._handlers.cursorActivity;\n if (!arr) return;\n var set = cm.curOp.cursorActivityHandlers || (cm.curOp.cursorActivityHandlers = []);\n for (var i = 0; i < arr.length; ++i) if (indexOf(set, arr[i]) == -1)\n set.push(arr[i]);\n }\n\n function hasHandler(emitter, type) {\n return getHandlers(emitter, type).length > 0\n }\n\n // Add on and off methods to a constructor's prototype, to make\n // registering events on such objects more convenient.\n function eventMixin(ctor) {\n ctor.prototype.on = function(type, f) {on(this, type, f);};\n ctor.prototype.off = function(type, f) {off(this, type, f);};\n }\n\n // MISC UTILITIES\n\n // Number of pixels added to scroller and sizer to hide scrollbar\n var scrollerGap = 30;\n\n // Returned or thrown by various protocols to signal 'I'm not\n // handling this'.\n var Pass = CodeMirror.Pass = {toString: function(){return \"CodeMirror.Pass\";}};\n\n // Reused option objects for setSelection & friends\n var sel_dontScroll = {scroll: false}, sel_mouse = {origin: \"*mouse\"}, sel_move = {origin: \"+move\"};\n\n function Delayed() {this.id = null;}\n Delayed.prototype.set = function(ms, f) {\n clearTimeout(this.id);\n this.id = setTimeout(f, ms);\n };\n\n // Counts the column offset in a string, taking tabs into account.\n // Used mostly to find indentation.\n var countColumn = CodeMirror.countColumn = function(string, end, tabSize, startIndex, startValue) {\n if (end == null) {\n end = string.search(/[^\\s\\u00a0]/);\n if (end == -1) end = string.length;\n }\n for (var i = startIndex || 0, n = startValue || 0;;) {\n var nextTab = string.indexOf(\"\\t\", i);\n if (nextTab < 0 || nextTab >= end)\n return n + (end - i);\n n += nextTab - i;\n n += tabSize - (n % tabSize);\n i = nextTab + 1;\n }\n };\n\n // The inverse of countColumn -- find the offset that corresponds to\n // a particular column.\n var findColumn = CodeMirror.findColumn = function(string, goal, tabSize) {\n for (var pos = 0, col = 0;;) {\n var nextTab = string.indexOf(\"\\t\", pos);\n if (nextTab == -1) nextTab = string.length;\n var skipped = nextTab - pos;\n if (nextTab == string.length || col + skipped >= goal)\n return pos + Math.min(skipped, goal - col);\n col += nextTab - pos;\n col += tabSize - (col % tabSize);\n pos = nextTab + 1;\n if (col >= goal) return pos;\n }\n }\n\n var spaceStrs = [\"\"];\n function spaceStr(n) {\n while (spaceStrs.length <= n)\n spaceStrs.push(lst(spaceStrs) + \" \");\n return spaceStrs[n];\n }\n\n function lst(arr) { return arr[arr.length-1]; }\n\n var selectInput = function(node) { node.select(); };\n if (ios) // Mobile Safari apparently has a bug where select() is broken.\n selectInput = function(node) { node.selectionStart = 0; node.selectionEnd = node.value.length; };\n else if (ie) // Suppress mysterious IE10 errors\n selectInput = function(node) { try { node.select(); } catch(_e) {} };\n\n function indexOf(array, elt) {\n for (var i = 0; i < array.length; ++i)\n if (array[i] == elt) return i;\n return -1;\n }\n function map(array, f) {\n var out = [];\n for (var i = 0; i < array.length; i++) out[i] = f(array[i], i);\n return out;\n }\n\n function nothing() {}\n\n function createObj(base, props) {\n var inst;\n if (Object.create) {\n inst = Object.create(base);\n } else {\n nothing.prototype = base;\n inst = new nothing();\n }\n if (props) copyObj(props, inst);\n return inst;\n };\n\n function copyObj(obj, target, overwrite) {\n if (!target) target = {};\n for (var prop in obj)\n if (obj.hasOwnProperty(prop) && (overwrite !== false || !target.hasOwnProperty(prop)))\n target[prop] = obj[prop];\n return target;\n }\n\n function bind(f) {\n var args = Array.prototype.slice.call(arguments, 1);\n return function(){return f.apply(null, args);};\n }\n\n var nonASCIISingleCaseWordChar = /[\\u00df\\u0587\\u0590-\\u05f4\\u0600-\\u06ff\\u3040-\\u309f\\u30a0-\\u30ff\\u3400-\\u4db5\\u4e00-\\u9fcc\\uac00-\\ud7af]/;\n var isWordCharBasic = CodeMirror.isWordChar = function(ch) {\n return /\\w/.test(ch) || ch > \"\\x80\" &&\n (ch.toUpperCase() != ch.toLowerCase() || nonASCIISingleCaseWordChar.test(ch));\n };\n function isWordChar(ch, helper) {\n if (!helper) return isWordCharBasic(ch);\n if (helper.source.indexOf(\"\\\\w\") > -1 && isWordCharBasic(ch)) return true;\n return helper.test(ch);\n }\n\n function isEmpty(obj) {\n for (var n in obj) if (obj.hasOwnProperty(n) && obj[n]) return false;\n return true;\n }\n\n // Extending unicode characters. A series of a non-extending char +\n // any number of extending chars is treated as a single unit as far\n // as editing and measuring is concerned. This is not fully correct,\n // since some scripts/fonts/browsers also treat other configurations\n // of code points as a group.\n var extendingChars = /[\\u0300-\\u036f\\u0483-\\u0489\\u0591-\\u05bd\\u05bf\\u05c1\\u05c2\\u05c4\\u05c5\\u05c7\\u0610-\\u061a\\u064b-\\u065e\\u0670\\u06d6-\\u06dc\\u06de-\\u06e4\\u06e7\\u06e8\\u06ea-\\u06ed\\u0711\\u0730-\\u074a\\u07a6-\\u07b0\\u07eb-\\u07f3\\u0816-\\u0819\\u081b-\\u0823\\u0825-\\u0827\\u0829-\\u082d\\u0900-\\u0902\\u093c\\u0941-\\u0948\\u094d\\u0951-\\u0955\\u0962\\u0963\\u0981\\u09bc\\u09be\\u09c1-\\u09c4\\u09cd\\u09d7\\u09e2\\u09e3\\u0a01\\u0a02\\u0a3c\\u0a41\\u0a42\\u0a47\\u0a48\\u0a4b-\\u0a4d\\u0a51\\u0a70\\u0a71\\u0a75\\u0a81\\u0a82\\u0abc\\u0ac1-\\u0ac5\\u0ac7\\u0ac8\\u0acd\\u0ae2\\u0ae3\\u0b01\\u0b3c\\u0b3e\\u0b3f\\u0b41-\\u0b44\\u0b4d\\u0b56\\u0b57\\u0b62\\u0b63\\u0b82\\u0bbe\\u0bc0\\u0bcd\\u0bd7\\u0c3e-\\u0c40\\u0c46-\\u0c48\\u0c4a-\\u0c4d\\u0c55\\u0c56\\u0c62\\u0c63\\u0cbc\\u0cbf\\u0cc2\\u0cc6\\u0ccc\\u0ccd\\u0cd5\\u0cd6\\u0ce2\\u0ce3\\u0d3e\\u0d41-\\u0d44\\u0d4d\\u0d57\\u0d62\\u0d63\\u0dca\\u0dcf\\u0dd2-\\u0dd4\\u0dd6\\u0ddf\\u0e31\\u0e34-\\u0e3a\\u0e47-\\u0e4e\\u0eb1\\u0eb4-\\u0eb9\\u0ebb\\u0ebc\\u0ec8-\\u0ecd\\u0f18\\u0f19\\u0f35\\u0f37\\u0f39\\u0f71-\\u0f7e\\u0f80-\\u0f84\\u0f86\\u0f87\\u0f90-\\u0f97\\u0f99-\\u0fbc\\u0fc6\\u102d-\\u1030\\u1032-\\u1037\\u1039\\u103a\\u103d\\u103e\\u1058\\u1059\\u105e-\\u1060\\u1071-\\u1074\\u1082\\u1085\\u1086\\u108d\\u109d\\u135f\\u1712-\\u1714\\u1732-\\u1734\\u1752\\u1753\\u1772\\u1773\\u17b7-\\u17bd\\u17c6\\u17c9-\\u17d3\\u17dd\\u180b-\\u180d\\u18a9\\u1920-\\u1922\\u1927\\u1928\\u1932\\u1939-\\u193b\\u1a17\\u1a18\\u1a56\\u1a58-\\u1a5e\\u1a60\\u1a62\\u1a65-\\u1a6c\\u1a73-\\u1a7c\\u1a7f\\u1b00-\\u1b03\\u1b34\\u1b36-\\u1b3a\\u1b3c\\u1b42\\u1b6b-\\u1b73\\u1b80\\u1b81\\u1ba2-\\u1ba5\\u1ba8\\u1ba9\\u1c2c-\\u1c33\\u1c36\\u1c37\\u1cd0-\\u1cd2\\u1cd4-\\u1ce0\\u1ce2-\\u1ce8\\u1ced\\u1dc0-\\u1de6\\u1dfd-\\u1dff\\u200c\\u200d\\u20d0-\\u20f0\\u2cef-\\u2cf1\\u2de0-\\u2dff\\u302a-\\u302f\\u3099\\u309a\\ua66f-\\ua672\\ua67c\\ua67d\\ua6f0\\ua6f1\\ua802\\ua806\\ua80b\\ua825\\ua826\\ua8c4\\ua8e0-\\ua8f1\\ua926-\\ua92d\\ua947-\\ua951\\ua980-\\ua982\\ua9b3\\ua9b6-\\ua9b9\\ua9bc\\uaa29-\\uaa2e\\uaa31\\uaa32\\uaa35\\uaa36\\uaa43\\uaa4c\\uaab0\\uaab2-\\uaab4\\uaab7\\uaab8\\uaabe\\uaabf\\uaac1\\uabe5\\uabe8\\uabed\\udc00-\\udfff\\ufb1e\\ufe00-\\ufe0f\\ufe20-\\ufe26\\uff9e\\uff9f]/;\n function isExtendingChar(ch) { return ch.charCodeAt(0) >= 768 && extendingChars.test(ch); }\n\n // DOM UTILITIES\n\n function elt(tag, content, className, style) {\n var e = document.createElement(tag);\n if (className) e.className = className;\n if (style) e.style.cssText = style;\n if (typeof content == \"string\") e.appendChild(document.createTextNode(content));\n else if (content) for (var i = 0; i < content.length; ++i) e.appendChild(content[i]);\n return e;\n }\n\n var range;\n if (document.createRange) range = function(node, start, end, endNode) {\n var r = document.createRange();\n r.setEnd(endNode || node, end);\n r.setStart(node, start);\n return r;\n };\n else range = function(node, start, end) {\n var r = document.body.createTextRange();\n try { r.moveToElementText(node.parentNode); }\n catch(e) { return r; }\n r.collapse(true);\n r.moveEnd(\"character\", end);\n r.moveStart(\"character\", start);\n return r;\n };\n\n function removeChildren(e) {\n for (var count = e.childNodes.length; count > 0; --count)\n e.removeChild(e.firstChild);\n return e;\n }\n\n function removeChildrenAndAdd(parent, e) {\n return removeChildren(parent).appendChild(e);\n }\n\n var contains = CodeMirror.contains = function(parent, child) {\n if (child.nodeType == 3) // Android browser always returns false when child is a textnode\n child = child.parentNode;\n if (parent.contains)\n return parent.contains(child);\n do {\n if (child.nodeType == 11) child = child.host;\n if (child == parent) return true;\n } while (child = child.parentNode);\n };\n\n function activeElt() {\n var activeElement = document.activeElement;\n while (activeElement && activeElement.root && activeElement.root.activeElement)\n activeElement = activeElement.root.activeElement;\n return activeElement;\n }\n // Older versions of IE throws unspecified error when touching\n // document.activeElement in some cases (during loading, in iframe)\n if (ie && ie_version < 11) activeElt = function() {\n try { return document.activeElement; }\n catch(e) { return document.body; }\n };\n\n function classTest(cls) { return new RegExp(\"(^|\\\\s)\" + cls + \"(?:$|\\\\s)\\\\s*\"); }\n var rmClass = CodeMirror.rmClass = function(node, cls) {\n var current = node.className;\n var match = classTest(cls).exec(current);\n if (match) {\n var after = current.slice(match.index + match[0].length);\n node.className = current.slice(0, match.index) + (after ? match[1] + after : \"\");\n }\n };\n var addClass = CodeMirror.addClass = function(node, cls) {\n var current = node.className;\n if (!classTest(cls).test(current)) node.className += (current ? \" \" : \"\") + cls;\n };\n function joinClasses(a, b) {\n var as = a.split(\" \");\n for (var i = 0; i < as.length; i++)\n if (as[i] && !classTest(as[i]).test(b)) b += \" \" + as[i];\n return b;\n }\n\n // WINDOW-WIDE EVENTS\n\n // These must be handled carefully, because naively registering a\n // handler for each editor will cause the editors to never be\n // garbage collected.\n\n function forEachCodeMirror(f) {\n if (!document.body.getElementsByClassName) return;\n var byClass = document.body.getElementsByClassName(\"CodeMirror\");\n for (var i = 0; i < byClass.length; i++) {\n var cm = byClass[i].CodeMirror;\n if (cm) f(cm);\n }\n }\n\n var globalsRegistered = false;\n function ensureGlobalHandlers() {\n if (globalsRegistered) return;\n registerGlobalHandlers();\n globalsRegistered = true;\n }\n function registerGlobalHandlers() {\n // When the window resizes, we need to refresh active editors.\n var resizeTimer;\n on(window, \"resize\", function() {\n if (resizeTimer == null) resizeTimer = setTimeout(function() {\n resizeTimer = null;\n forEachCodeMirror(onResize);\n }, 100);\n });\n // When the window loses focus, we want to show the editor as blurred\n on(window, \"blur\", function() {\n forEachCodeMirror(onBlur);\n });\n }\n\n // FEATURE DETECTION\n\n // Detect drag-and-drop\n var dragAndDrop = function() {\n // There is *some* kind of drag-and-drop support in IE6-8, but I\n // couldn't get it to work yet.\n if (ie && ie_version < 9) return false;\n var div = elt('div');\n return \"draggable\" in div || \"dragDrop\" in div;\n }();\n\n var zwspSupported;\n function zeroWidthElement(measure) {\n if (zwspSupported == null) {\n var test = elt(\"span\", \"\\u200b\");\n removeChildrenAndAdd(measure, elt(\"span\", [test, document.createTextNode(\"x\")]));\n if (measure.firstChild.offsetHeight != 0)\n zwspSupported = test.offsetWidth <= 1 && test.offsetHeight > 2 && !(ie && ie_version < 8);\n }\n var node = zwspSupported ? elt(\"span\", \"\\u200b\") :\n elt(\"span\", \"\\u00a0\", null, \"display: inline-block; width: 1px; margin-right: -1px\");\n node.setAttribute(\"cm-text\", \"\");\n return node;\n }\n\n // Feature-detect IE's crummy client rect reporting for bidi text\n var badBidiRects;\n function hasBadBidiRects(measure) {\n if (badBidiRects != null) return badBidiRects;\n var txt = removeChildrenAndAdd(measure, document.createTextNode(\"A\\u062eA\"));\n var r0 = range(txt, 0, 1).getBoundingClientRect();\n var r1 = range(txt, 1, 2).getBoundingClientRect();\n removeChildren(measure);\n if (!r0 || r0.left == r0.right) return false; // Safari returns null in some cases (#2780)\n return badBidiRects = (r1.right - r0.right < 3);\n }\n\n // See if \"\".split is the broken IE version, if so, provide an\n // alternative way to split lines.\n var splitLinesAuto = CodeMirror.splitLines = \"\\n\\nb\".split(/\\n/).length != 3 ? function(string) {\n var pos = 0, result = [], l = string.length;\n while (pos <= l) {\n var nl = string.indexOf(\"\\n\", pos);\n if (nl == -1) nl = string.length;\n var line = string.slice(pos, string.charAt(nl - 1) == \"\\r\" ? nl - 1 : nl);\n var rt = line.indexOf(\"\\r\");\n if (rt != -1) {\n result.push(line.slice(0, rt));\n pos += rt + 1;\n } else {\n result.push(line);\n pos = nl + 1;\n }\n }\n return result;\n } : function(string){return string.split(/\\r\\n?|\\n/);};\n\n var hasSelection = window.getSelection ? function(te) {\n try { return te.selectionStart != te.selectionEnd; }\n catch(e) { return false; }\n } : function(te) {\n try {var range = te.ownerDocument.selection.createRange();}\n catch(e) {}\n if (!range || range.parentElement() != te) return false;\n return range.compareEndPoints(\"StartToEnd\", range) != 0;\n };\n\n var hasCopyEvent = (function() {\n var e = elt(\"div\");\n if (\"oncopy\" in e) return true;\n e.setAttribute(\"oncopy\", \"return;\");\n return typeof e.oncopy == \"function\";\n })();\n\n var badZoomedRects = null;\n function hasBadZoomedRects(measure) {\n if (badZoomedRects != null) return badZoomedRects;\n var node = removeChildrenAndAdd(measure, elt(\"span\", \"x\"));\n var normal = node.getBoundingClientRect();\n var fromRange = range(node, 0, 1).getBoundingClientRect();\n return badZoomedRects = Math.abs(normal.left - fromRange.left) > 1;\n }\n\n // KEY NAMES\n\n var keyNames = CodeMirror.keyNames = {\n 3: \"Enter\", 8: \"Backspace\", 9: \"Tab\", 13: \"Enter\", 16: \"Shift\", 17: \"Ctrl\", 18: \"Alt\",\n 19: \"Pause\", 20: \"CapsLock\", 27: \"Esc\", 32: \"Space\", 33: \"PageUp\", 34: \"PageDown\", 35: \"End\",\n 36: \"Home\", 37: \"Left\", 38: \"Up\", 39: \"Right\", 40: \"Down\", 44: \"PrintScrn\", 45: \"Insert\",\n 46: \"Delete\", 59: \";\", 61: \"=\", 91: \"Mod\", 92: \"Mod\", 93: \"Mod\",\n 106: \"*\", 107: \"=\", 109: \"-\", 110: \".\", 111: \"/\", 127: \"Delete\",\n 173: \"-\", 186: \";\", 187: \"=\", 188: \",\", 189: \"-\", 190: \".\", 191: \"/\", 192: \"`\", 219: \"[\", 220: \"\\\\\",\n 221: \"]\", 222: \"'\", 63232: \"Up\", 63233: \"Down\", 63234: \"Left\", 63235: \"Right\", 63272: \"Delete\",\n 63273: \"Home\", 63275: \"End\", 63276: \"PageUp\", 63277: \"PageDown\", 63302: \"Insert\"\n };\n (function() {\n // Number keys\n for (var i = 0; i < 10; i++) keyNames[i + 48] = keyNames[i + 96] = String(i);\n // Alphabetic keys\n for (var i = 65; i <= 90; i++) keyNames[i] = String.fromCharCode(i);\n // Function keys\n for (var i = 1; i <= 12; i++) keyNames[i + 111] = keyNames[i + 63235] = \"F\" + i;\n })();\n\n // BIDI HELPERS\n\n function iterateBidiSections(order, from, to, f) {\n if (!order) return f(from, to, \"ltr\");\n var found = false;\n for (var i = 0; i < order.length; ++i) {\n var part = order[i];\n if (part.from < to && part.to > from || from == to && part.to == from) {\n f(Math.max(part.from, from), Math.min(part.to, to), part.level == 1 ? \"rtl\" : \"ltr\");\n found = true;\n }\n }\n if (!found) f(from, to, \"ltr\");\n }\n\n function bidiLeft(part) { return part.level % 2 ? part.to : part.from; }\n function bidiRight(part) { return part.level % 2 ? part.from : part.to; }\n\n function lineLeft(line) { var order = getOrder(line); return order ? bidiLeft(order[0]) : 0; }\n function lineRight(line) {\n var order = getOrder(line);\n if (!order) return line.text.length;\n return bidiRight(lst(order));\n }\n\n function lineStart(cm, lineN) {\n var line = getLine(cm.doc, lineN);\n var visual = visualLine(line);\n if (visual != line) lineN = lineNo(visual);\n var order = getOrder(visual);\n var ch = !order ? 0 : order[0].level % 2 ? lineRight(visual) : lineLeft(visual);\n return Pos(lineN, ch);\n }\n function lineEnd(cm, lineN) {\n var merged, line = getLine(cm.doc, lineN);\n while (merged = collapsedSpanAtEnd(line)) {\n line = merged.find(1, true).line;\n lineN = null;\n }\n var order = getOrder(line);\n var ch = !order ? line.text.length : order[0].level % 2 ? lineLeft(line) : lineRight(line);\n return Pos(lineN == null ? lineNo(line) : lineN, ch);\n }\n function lineStartSmart(cm, pos) {\n var start = lineStart(cm, pos.line);\n var line = getLine(cm.doc, start.line);\n var order = getOrder(line);\n if (!order || order[0].level == 0) {\n var firstNonWS = Math.max(0, line.text.search(/\\S/));\n var inWS = pos.line == start.line && pos.ch <= firstNonWS && pos.ch;\n return Pos(start.line, inWS ? 0 : firstNonWS);\n }\n return start;\n }\n\n function compareBidiLevel(order, a, b) {\n var linedir = order[0].level;\n if (a == linedir) return true;\n if (b == linedir) return false;\n return a < b;\n }\n var bidiOther;\n function getBidiPartAt(order, pos) {\n bidiOther = null;\n for (var i = 0, found; i < order.length; ++i) {\n var cur = order[i];\n if (cur.from < pos && cur.to > pos) return i;\n if ((cur.from == pos || cur.to == pos)) {\n if (found == null) {\n found = i;\n } else if (compareBidiLevel(order, cur.level, order[found].level)) {\n if (cur.from != cur.to) bidiOther = found;\n return i;\n } else {\n if (cur.from != cur.to) bidiOther = i;\n return found;\n }\n }\n }\n return found;\n }\n\n function moveInLine(line, pos, dir, byUnit) {\n if (!byUnit) return pos + dir;\n do pos += dir;\n while (pos > 0 && isExtendingChar(line.text.charAt(pos)));\n return pos;\n }\n\n // This is needed in order to move 'visually' through bi-directional\n // text -- i.e., pressing left should make the cursor go left, even\n // when in RTL text. The tricky part is the 'jumps', where RTL and\n // LTR text touch each other. This often requires the cursor offset\n // to move more than one unit, in order to visually move one unit.\n function moveVisually(line, start, dir, byUnit) {\n var bidi = getOrder(line);\n if (!bidi) return moveLogically(line, start, dir, byUnit);\n var pos = getBidiPartAt(bidi, start), part = bidi[pos];\n var target = moveInLine(line, start, part.level % 2 ? -dir : dir, byUnit);\n\n for (;;) {\n if (target > part.from && target < part.to) return target;\n if (target == part.from || target == part.to) {\n if (getBidiPartAt(bidi, target) == pos) return target;\n part = bidi[pos += dir];\n return (dir > 0) == part.level % 2 ? part.to : part.from;\n } else {\n part = bidi[pos += dir];\n if (!part) return null;\n if ((dir > 0) == part.level % 2)\n target = moveInLine(line, part.to, -1, byUnit);\n else\n target = moveInLine(line, part.from, 1, byUnit);\n }\n }\n }\n\n function moveLogically(line, start, dir, byUnit) {\n var target = start + dir;\n if (byUnit) while (target > 0 && isExtendingChar(line.text.charAt(target))) target += dir;\n return target < 0 || target > line.text.length ? null : target;\n }\n\n // Bidirectional ordering algorithm\n // See http://unicode.org/reports/tr9/tr9-13.html for the algorithm\n // that this (partially) implements.\n\n // One-char codes used for character types:\n // L (L): Left-to-Right\n // R (R): Right-to-Left\n // r (AL): Right-to-Left Arabic\n // 1 (EN): European Number\n // + (ES): European Number Separator\n // % (ET): European Number Terminator\n // n (AN): Arabic Number\n // , (CS): Common Number Separator\n // m (NSM): Non-Spacing Mark\n // b (BN): Boundary Neutral\n // s (B): Paragraph Separator\n // t (S): Segment Separator\n // w (WS): Whitespace\n // N (ON): Other Neutrals\n\n // Returns null if characters are ordered as they appear\n // (left-to-right), or an array of sections ({from, to, level}\n // objects) in the order in which they occur visually.\n var bidiOrdering = (function() {\n // Character types for codepoints 0 to 0xff\n var lowTypes = \"bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN\";\n // Character types for codepoints 0x600 to 0x6ff\n var arabicTypes = \"rrrrrrrrrrrr,rNNmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmrrrrrrrnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmNmmmm\";\n function charType(code) {\n if (code <= 0xf7) return lowTypes.charAt(code);\n else if (0x590 <= code && code <= 0x5f4) return \"R\";\n else if (0x600 <= code && code <= 0x6ed) return arabicTypes.charAt(code - 0x600);\n else if (0x6ee <= code && code <= 0x8ac) return \"r\";\n else if (0x2000 <= code && code <= 0x200b) return \"w\";\n else if (code == 0x200c) return \"b\";\n else return \"L\";\n }\n\n var bidiRE = /[\\u0590-\\u05f4\\u0600-\\u06ff\\u0700-\\u08ac]/;\n var isNeutral = /[stwN]/, isStrong = /[LRr]/, countsAsLeft = /[Lb1n]/, countsAsNum = /[1n]/;\n // Browsers seem to always treat the boundaries of block elements as being L.\n var outerType = \"L\";\n\n function BidiSpan(level, from, to) {\n this.level = level;\n this.from = from; this.to = to;\n }\n\n return function(str) {\n if (!bidiRE.test(str)) return false;\n var len = str.length, types = [];\n for (var i = 0, type; i < len; ++i)\n types.push(type = charType(str.charCodeAt(i)));\n\n // W1. Examine each non-spacing mark (NSM) in the level run, and\n // change the type of the NSM to the type of the previous\n // character. If the NSM is at the start of the level run, it will\n // get the type of sor.\n for (var i = 0, prev = outerType; i < len; ++i) {\n var type = types[i];\n if (type == \"m\") types[i] = prev;\n else prev = type;\n }\n\n // W2. Search backwards from each instance of a European number\n // until the first strong type (R, L, AL, or sor) is found. If an\n // AL is found, change the type of the European number to Arabic\n // number.\n // W3. Change all ALs to R.\n for (var i = 0, cur = outerType; i < len; ++i) {\n var type = types[i];\n if (type == \"1\" && cur == \"r\") types[i] = \"n\";\n else if (isStrong.test(type)) { cur = type; if (type == \"r\") types[i] = \"R\"; }\n }\n\n // W4. A single European separator between two European numbers\n // changes to a European number. A single common separator between\n // two numbers of the same type changes to that type.\n for (var i = 1, prev = types[0]; i < len - 1; ++i) {\n var type = types[i];\n if (type == \"+\" && prev == \"1\" && types[i+1] == \"1\") types[i] = \"1\";\n else if (type == \",\" && prev == types[i+1] &&\n (prev == \"1\" || prev == \"n\")) types[i] = prev;\n prev = type;\n }\n\n // W5. A sequence of European terminators adjacent to European\n // numbers changes to all European numbers.\n // W6. Otherwise, separators and terminators change to Other\n // Neutral.\n for (var i = 0; i < len; ++i) {\n var type = types[i];\n if (type == \",\") types[i] = \"N\";\n else if (type == \"%\") {\n for (var end = i + 1; end < len && types[end] == \"%\"; ++end) {}\n var replace = (i && types[i-1] == \"!\") || (end < len && types[end] == \"1\") ? \"1\" : \"N\";\n for (var j = i; j < end; ++j) types[j] = replace;\n i = end - 1;\n }\n }\n\n // W7. Search backwards from each instance of a European number\n // until the first strong type (R, L, or sor) is found. If an L is\n // found, then change the type of the European number to L.\n for (var i = 0, cur = outerType; i < len; ++i) {\n var type = types[i];\n if (cur == \"L\" && type == \"1\") types[i] = \"L\";\n else if (isStrong.test(type)) cur = type;\n }\n\n // N1. A sequence of neutrals takes the direction of the\n // surrounding strong text if the text on both sides has the same\n // direction. European and Arabic numbers act as if they were R in\n // terms of their influence on neutrals. Start-of-level-run (sor)\n // and end-of-level-run (eor) are used at level run boundaries.\n // N2. Any remaining neutrals take the embedding direction.\n for (var i = 0; i < len; ++i) {\n if (isNeutral.test(types[i])) {\n for (var end = i + 1; end < len && isNeutral.test(types[end]); ++end) {}\n var before = (i ? types[i-1] : outerType) == \"L\";\n var after = (end < len ? types[end] : outerType) == \"L\";\n var replace = before || after ? \"L\" : \"R\";\n for (var j = i; j < end; ++j) types[j] = replace;\n i = end - 1;\n }\n }\n\n // Here we depart from the documented algorithm, in order to avoid\n // building up an actual levels array. Since there are only three\n // levels (0, 1, 2) in an implementation that doesn't take\n // explicit embedding into account, we can build up the order on\n // the fly, without following the level-based algorithm.\n var order = [], m;\n for (var i = 0; i < len;) {\n if (countsAsLeft.test(types[i])) {\n var start = i;\n for (++i; i < len && countsAsLeft.test(types[i]); ++i) {}\n order.push(new BidiSpan(0, start, i));\n } else {\n var pos = i, at = order.length;\n for (++i; i < len && types[i] != \"L\"; ++i) {}\n for (var j = pos; j < i;) {\n if (countsAsNum.test(types[j])) {\n if (pos < j) order.splice(at, 0, new BidiSpan(1, pos, j));\n var nstart = j;\n for (++j; j < i && countsAsNum.test(types[j]); ++j) {}\n order.splice(at, 0, new BidiSpan(2, nstart, j));\n pos = j;\n } else ++j;\n }\n if (pos < i) order.splice(at, 0, new BidiSpan(1, pos, i));\n }\n }\n if (order[0].level == 1 && (m = str.match(/^\\s+/))) {\n order[0].from = m[0].length;\n order.unshift(new BidiSpan(0, 0, m[0].length));\n }\n if (lst(order).level == 1 && (m = str.match(/\\s+$/))) {\n lst(order).to -= m[0].length;\n order.push(new BidiSpan(0, len - m[0].length, len));\n }\n if (order[0].level == 2)\n order.unshift(new BidiSpan(1, order[0].to, order[0].to));\n if (order[0].level != lst(order).level)\n order.push(new BidiSpan(order[0].level, len, len));\n\n return order;\n };\n })();\n\n // THE END\n\n CodeMirror.version = \"5.17.0\";\n\n return CodeMirror;\n});\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n// TODO actually recognize syntax of TypeScript constructs\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n\"use strict\";\n\nfunction expressionAllowed(stream, state, backUp) {\n return /^(?:operator|sof|keyword c|case|new|[\\[{}\\(,;:]|=>)$/.test(state.lastType) ||\n (state.lastType == \"quasi\" && /\\{\\s*$/.test(stream.string.slice(0, stream.pos - (backUp || 0))))\n}\n\nCodeMirror.defineMode(\"javascript\", function(config, parserConfig) {\n var indentUnit = config.indentUnit;\n var statementIndent = parserConfig.statementIndent;\n var jsonldMode = parserConfig.jsonld;\n var jsonMode = parserConfig.json || jsonldMode;\n var isTS = parserConfig.typescript;\n var wordRE = parserConfig.wordCharacters || /[\\w$\\xa1-\\uffff]/;\n\n // Tokenizer\n\n var keywords = function(){\n function kw(type) {return {type: type, style: \"keyword\"};}\n var A = kw(\"keyword a\"), B = kw(\"keyword b\"), C = kw(\"keyword c\");\n var operator = kw(\"operator\"), atom = {type: \"atom\", style: \"atom\"};\n\n var jsKeywords = {\n \"if\": kw(\"if\"), \"while\": A, \"with\": A, \"else\": B, \"do\": B, \"try\": B, \"finally\": B,\n \"return\": C, \"break\": C, \"continue\": C, \"new\": kw(\"new\"), \"delete\": C, \"throw\": C, \"debugger\": C,\n \"var\": kw(\"var\"), \"const\": kw(\"var\"), \"let\": kw(\"var\"),\n \"function\": kw(\"function\"), \"catch\": kw(\"catch\"),\n \"for\": kw(\"for\"), \"switch\": kw(\"switch\"), \"case\": kw(\"case\"), \"default\": kw(\"default\"),\n \"in\": operator, \"typeof\": operator, \"instanceof\": operator,\n \"true\": atom, \"false\": atom, \"null\": atom, \"undefined\": atom, \"NaN\": atom, \"Infinity\": atom,\n \"this\": kw(\"this\"), \"class\": kw(\"class\"), \"super\": kw(\"atom\"),\n \"yield\": C, \"export\": kw(\"export\"), \"import\": kw(\"import\"), \"extends\": C,\n \"await\": C, \"async\": kw(\"async\")\n };\n\n // Extend the 'normal' keywords with the TypeScript language extensions\n if (isTS) {\n var type = {type: \"variable\", style: \"variable-3\"};\n var tsKeywords = {\n // object-like things\n \"interface\": kw(\"class\"),\n \"implements\": C,\n \"namespace\": C,\n \"module\": kw(\"module\"),\n \"enum\": kw(\"module\"),\n\n // scope modifiers\n \"public\": kw(\"modifier\"),\n \"private\": kw(\"modifier\"),\n \"protected\": kw(\"modifier\"),\n \"abstract\": kw(\"modifier\"),\n\n // operators\n \"as\": operator,\n\n // types\n \"string\": type, \"number\": type, \"boolean\": type, \"any\": type\n };\n\n for (var attr in tsKeywords) {\n jsKeywords[attr] = tsKeywords[attr];\n }\n }\n\n return jsKeywords;\n }();\n\n var isOperatorChar = /[+\\-*&%=<>!?|~^]/;\n var isJsonldKeyword = /^@(context|id|value|language|type|container|list|set|reverse|index|base|vocab|graph)\"/;\n\n function readRegexp(stream) {\n var escaped = false, next, inSet = false;\n while ((next = stream.next()) != null) {\n if (!escaped) {\n if (next == \"/\" && !inSet) return;\n if (next == \"[\") inSet = true;\n else if (inSet && next == \"]\") inSet = false;\n }\n escaped = !escaped && next == \"\\\\\";\n }\n }\n\n // Used as scratch variables to communicate multiple values without\n // consing up tons of objects.\n var type, content;\n function ret(tp, style, cont) {\n type = tp; content = cont;\n return style;\n }\n function tokenBase(stream, state) {\n var ch = stream.next();\n if (ch == '\"' || ch == \"'\") {\n state.tokenize = tokenString(ch);\n return state.tokenize(stream, state);\n } else if (ch == \".\" && stream.match(/^\\d+(?:[eE][+\\-]?\\d+)?/)) {\n return ret(\"number\", \"number\");\n } else if (ch == \".\" && stream.match(\"..\")) {\n return ret(\"spread\", \"meta\");\n } else if (/[\\[\\]{}\\(\\),;\\:\\.]/.test(ch)) {\n return ret(ch);\n } else if (ch == \"=\" && stream.eat(\">\")) {\n return ret(\"=>\", \"operator\");\n } else if (ch == \"0\" && stream.eat(/x/i)) {\n stream.eatWhile(/[\\da-f]/i);\n return ret(\"number\", \"number\");\n } else if (ch == \"0\" && stream.eat(/o/i)) {\n stream.eatWhile(/[0-7]/i);\n return ret(\"number\", \"number\");\n } else if (ch == \"0\" && stream.eat(/b/i)) {\n stream.eatWhile(/[01]/i);\n return ret(\"number\", \"number\");\n } else if (/\\d/.test(ch)) {\n stream.match(/^\\d*(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?/);\n return ret(\"number\", \"number\");\n } else if (ch == \"/\") {\n if (stream.eat(\"*\")) {\n state.tokenize = tokenComment;\n return tokenComment(stream, state);\n } else if (stream.eat(\"/\")) {\n stream.skipToEnd();\n return ret(\"comment\", \"comment\");\n } else if (expressionAllowed(stream, state, 1)) {\n readRegexp(stream);\n stream.match(/^\\b(([gimyu])(?![gimyu]*\\2))+\\b/);\n return ret(\"regexp\", \"string-2\");\n } else {\n stream.eatWhile(isOperatorChar);\n return ret(\"operator\", \"operator\", stream.current());\n }\n } else if (ch == \"`\") {\n state.tokenize = tokenQuasi;\n return tokenQuasi(stream, state);\n } else if (ch == \"#\") {\n stream.skipToEnd();\n return ret(\"error\", \"error\");\n } else if (isOperatorChar.test(ch)) {\n stream.eatWhile(isOperatorChar);\n return ret(\"operator\", \"operator\", stream.current());\n } else if (wordRE.test(ch)) {\n stream.eatWhile(wordRE);\n var word = stream.current(), known = keywords.propertyIsEnumerable(word) && keywords[word];\n return (known && state.lastType != \".\") ? ret(known.type, known.style, word) :\n ret(\"variable\", \"variable\", word);\n }\n }\n\n function tokenString(quote) {\n return function(stream, state) {\n var escaped = false, next;\n if (jsonldMode && stream.peek() == \"@\" && stream.match(isJsonldKeyword)){\n state.tokenize = tokenBase;\n return ret(\"jsonld-keyword\", \"meta\");\n }\n while ((next = stream.next()) != null) {\n if (next == quote && !escaped) break;\n escaped = !escaped && next == \"\\\\\";\n }\n if (!escaped) state.tokenize = tokenBase;\n return ret(\"string\", \"string\");\n };\n }\n\n function tokenComment(stream, state) {\n var maybeEnd = false, ch;\n while (ch = stream.next()) {\n if (ch == \"/\" && maybeEnd) {\n state.tokenize = tokenBase;\n break;\n }\n maybeEnd = (ch == \"*\");\n }\n return ret(\"comment\", \"comment\");\n }\n\n function tokenQuasi(stream, state) {\n var escaped = false, next;\n while ((next = stream.next()) != null) {\n if (!escaped && (next == \"`\" || next == \"$\" && stream.eat(\"{\"))) {\n state.tokenize = tokenBase;\n break;\n }\n escaped = !escaped && next == \"\\\\\";\n }\n return ret(\"quasi\", \"string-2\", stream.current());\n }\n\n var brackets = \"([{}])\";\n // This is a crude lookahead trick to try and notice that we're\n // parsing the argument patterns for a fat-arrow function before we\n // actually hit the arrow token. It only works if the arrow is on\n // the same line as the arguments and there's no strange noise\n // (comments) in between. Fallback is to only notice when we hit the\n // arrow, and not declare the arguments as locals for the arrow\n // body.\n function findFatArrow(stream, state) {\n if (state.fatArrowAt) state.fatArrowAt = null;\n var arrow = stream.string.indexOf(\"=>\", stream.start);\n if (arrow < 0) return;\n\n var depth = 0, sawSomething = false;\n for (var pos = arrow - 1; pos >= 0; --pos) {\n var ch = stream.string.charAt(pos);\n var bracket = brackets.indexOf(ch);\n if (bracket >= 0 && bracket < 3) {\n if (!depth) { ++pos; break; }\n if (--depth == 0) break;\n } else if (bracket >= 3 && bracket < 6) {\n ++depth;\n } else if (wordRE.test(ch)) {\n sawSomething = true;\n } else if (/[\"'\\/]/.test(ch)) {\n return;\n } else if (sawSomething && !depth) {\n ++pos;\n break;\n }\n }\n if (sawSomething && !depth) state.fatArrowAt = pos;\n }\n\n // Parser\n\n var atomicTypes = {\"atom\": true, \"number\": true, \"variable\": true, \"string\": true, \"regexp\": true, \"this\": true, \"jsonld-keyword\": true};\n\n function JSLexical(indented, column, type, align, prev, info) {\n this.indented = indented;\n this.column = column;\n this.type = type;\n this.prev = prev;\n this.info = info;\n if (align != null) this.align = align;\n }\n\n function inScope(state, varname) {\n for (var v = state.localVars; v; v = v.next)\n if (v.name == varname) return true;\n for (var cx = state.context; cx; cx = cx.prev) {\n for (var v = cx.vars; v; v = v.next)\n if (v.name == varname) return true;\n }\n }\n\n function parseJS(state, style, type, content, stream) {\n var cc = state.cc;\n // Communicate our context to the combinators.\n // (Less wasteful than consing up a hundred closures on every call.)\n cx.state = state; cx.stream = stream; cx.marked = null, cx.cc = cc; cx.style = style;\n\n if (!state.lexical.hasOwnProperty(\"align\"))\n state.lexical.align = true;\n\n while(true) {\n var combinator = cc.length ? cc.pop() : jsonMode ? expression : statement;\n if (combinator(type, content)) {\n while(cc.length && cc[cc.length - 1].lex)\n cc.pop()();\n if (cx.marked) return cx.marked;\n if (type == \"variable\" && inScope(state, content)) return \"variable-2\";\n return style;\n }\n }\n }\n\n // Combinator utils\n\n var cx = {state: null, column: null, marked: null, cc: null};\n function pass() {\n for (var i = arguments.length - 1; i >= 0; i--) cx.cc.push(arguments[i]);\n }\n function cont() {\n pass.apply(null, arguments);\n return true;\n }\n function register(varname) {\n function inList(list) {\n for (var v = list; v; v = v.next)\n if (v.name == varname) return true;\n return false;\n }\n var state = cx.state;\n cx.marked = \"def\";\n if (state.context) {\n if (inList(state.localVars)) return;\n state.localVars = {name: varname, next: state.localVars};\n } else {\n if (inList(state.globalVars)) return;\n if (parserConfig.globalVars)\n state.globalVars = {name: varname, next: state.globalVars};\n }\n }\n\n // Combinators\n\n var defaultVars = {name: \"this\", next: {name: \"arguments\"}};\n function pushcontext() {\n cx.state.context = {prev: cx.state.context, vars: cx.state.localVars};\n cx.state.localVars = defaultVars;\n }\n function popcontext() {\n cx.state.localVars = cx.state.context.vars;\n cx.state.context = cx.state.context.prev;\n }\n function pushlex(type, info) {\n var result = function() {\n var state = cx.state, indent = state.indented;\n if (state.lexical.type == \"stat\") indent = state.lexical.indented;\n else for (var outer = state.lexical; outer && outer.type == \")\" && outer.align; outer = outer.prev)\n indent = outer.indented;\n state.lexical = new JSLexical(indent, cx.stream.column(), type, null, state.lexical, info);\n };\n result.lex = true;\n return result;\n }\n function poplex() {\n var state = cx.state;\n if (state.lexical.prev) {\n if (state.lexical.type == \")\")\n state.indented = state.lexical.indented;\n state.lexical = state.lexical.prev;\n }\n }\n poplex.lex = true;\n\n function expect(wanted) {\n function exp(type) {\n if (type == wanted) return cont();\n else if (wanted == \";\") return pass();\n else return cont(exp);\n };\n return exp;\n }\n\n function statement(type, value) {\n if (type == \"var\") return cont(pushlex(\"vardef\", value.length), vardef, expect(\";\"), poplex);\n if (type == \"keyword a\") return cont(pushlex(\"form\"), expression, statement, poplex);\n if (type == \"keyword b\") return cont(pushlex(\"form\"), statement, poplex);\n if (type == \"{\") return cont(pushlex(\"}\"), block, poplex);\n if (type == \";\") return cont();\n if (type == \"if\") {\n if (cx.state.lexical.info == \"else\" && cx.state.cc[cx.state.cc.length - 1] == poplex)\n cx.state.cc.pop()();\n return cont(pushlex(\"form\"), expression, statement, poplex, maybeelse);\n }\n if (type == \"function\") return cont(functiondef);\n if (type == \"for\") return cont(pushlex(\"form\"), forspec, statement, poplex);\n if (type == \"variable\") return cont(pushlex(\"stat\"), maybelabel);\n if (type == \"switch\") return cont(pushlex(\"form\"), expression, pushlex(\"}\", \"switch\"), expect(\"{\"),\n block, poplex, poplex);\n if (type == \"case\") return cont(expression, expect(\":\"));\n if (type == \"default\") return cont(expect(\":\"));\n if (type == \"catch\") return cont(pushlex(\"form\"), pushcontext, expect(\"(\"), funarg, expect(\")\"),\n statement, poplex, popcontext);\n if (type == \"class\") return cont(pushlex(\"form\"), className, poplex);\n if (type == \"export\") return cont(pushlex(\"stat\"), afterExport, poplex);\n if (type == \"import\") return cont(pushlex(\"stat\"), afterImport, poplex);\n if (type == \"module\") return cont(pushlex(\"form\"), pattern, pushlex(\"}\"), expect(\"{\"), block, poplex, poplex)\n if (type == \"async\") return cont(statement)\n return pass(pushlex(\"stat\"), expression, expect(\";\"), poplex);\n }\n function expression(type) {\n return expressionInner(type, false);\n }\n function expressionNoComma(type) {\n return expressionInner(type, true);\n }\n function expressionInner(type, noComma) {\n if (cx.state.fatArrowAt == cx.stream.start) {\n var body = noComma ? arrowBodyNoComma : arrowBody;\n if (type == \"(\") return cont(pushcontext, pushlex(\")\"), commasep(pattern, \")\"), poplex, expect(\"=>\"), body, popcontext);\n else if (type == \"variable\") return pass(pushcontext, pattern, expect(\"=>\"), body, popcontext);\n }\n\n var maybeop = noComma ? maybeoperatorNoComma : maybeoperatorComma;\n if (atomicTypes.hasOwnProperty(type)) return cont(maybeop);\n if (type == \"function\") return cont(functiondef, maybeop);\n if (type == \"keyword c\" || type == \"async\") return cont(noComma ? maybeexpressionNoComma : maybeexpression);\n if (type == \"(\") return cont(pushlex(\")\"), maybeexpression, expect(\")\"), poplex, maybeop);\n if (type == \"operator\" || type == \"spread\") return cont(noComma ? expressionNoComma : expression);\n if (type == \"[\") return cont(pushlex(\"]\"), arrayLiteral, poplex, maybeop);\n if (type == \"{\") return contCommasep(objprop, \"}\", null, maybeop);\n if (type == \"quasi\") return pass(quasi, maybeop);\n if (type == \"new\") return cont(maybeTarget(noComma));\n return cont();\n }\n function maybeexpression(type) {\n if (type.match(/[;\\}\\)\\],]/)) return pass();\n return pass(expression);\n }\n function maybeexpressionNoComma(type) {\n if (type.match(/[;\\}\\)\\],]/)) return pass();\n return pass(expressionNoComma);\n }\n\n function maybeoperatorComma(type, value) {\n if (type == \",\") return cont(expression);\n return maybeoperatorNoComma(type, value, false);\n }\n function maybeoperatorNoComma(type, value, noComma) {\n var me = noComma == false ? maybeoperatorComma : maybeoperatorNoComma;\n var expr = noComma == false ? expression : expressionNoComma;\n if (type == \"=>\") return cont(pushcontext, noComma ? arrowBodyNoComma : arrowBody, popcontext);\n if (type == \"operator\") {\n if (/\\+\\+|--/.test(value)) return cont(me);\n if (value == \"?\") return cont(expression, expect(\":\"), expr);\n return cont(expr);\n }\n if (type == \"quasi\") { return pass(quasi, me); }\n if (type == \";\") return;\n if (type == \"(\") return contCommasep(expressionNoComma, \")\", \"call\", me);\n if (type == \".\") return cont(property, me);\n if (type == \"[\") return cont(pushlex(\"]\"), maybeexpression, expect(\"]\"), poplex, me);\n }\n function quasi(type, value) {\n if (type != \"quasi\") return pass();\n if (value.slice(value.length - 2) != \"${\") return cont(quasi);\n return cont(expression, continueQuasi);\n }\n function continueQuasi(type) {\n if (type == \"}\") {\n cx.marked = \"string-2\";\n cx.state.tokenize = tokenQuasi;\n return cont(quasi);\n }\n }\n function arrowBody(type) {\n findFatArrow(cx.stream, cx.state);\n return pass(type == \"{\" ? statement : expression);\n }\n function arrowBodyNoComma(type) {\n findFatArrow(cx.stream, cx.state);\n return pass(type == \"{\" ? statement : expressionNoComma);\n }\n function maybeTarget(noComma) {\n return function(type) {\n if (type == \".\") return cont(noComma ? targetNoComma : target);\n else return pass(noComma ? expressionNoComma : expression);\n };\n }\n function target(_, value) {\n if (value == \"target\") { cx.marked = \"keyword\"; return cont(maybeoperatorComma); }\n }\n function targetNoComma(_, value) {\n if (value == \"target\") { cx.marked = \"keyword\"; return cont(maybeoperatorNoComma); }\n }\n function maybelabel(type) {\n if (type == \":\") return cont(poplex, statement);\n return pass(maybeoperatorComma, expect(\";\"), poplex);\n }\n function property(type) {\n if (type == \"variable\") {cx.marked = \"property\"; return cont();}\n }\n function objprop(type, value) {\n if (type == \"async\") return cont(objprop);\n if (type == \"variable\" || cx.style == \"keyword\") {\n cx.marked = \"property\";\n if (value == \"get\" || value == \"set\") return cont(getterSetter);\n return cont(afterprop);\n } else if (type == \"number\" || type == \"string\") {\n cx.marked = jsonldMode ? \"property\" : (cx.style + \" property\");\n return cont(afterprop);\n } else if (type == \"jsonld-keyword\") {\n return cont(afterprop);\n } else if (type == \"modifier\") {\n return cont(objprop)\n } else if (type == \"[\") {\n return cont(expression, expect(\"]\"), afterprop);\n } else if (type == \"spread\") {\n return cont(expression);\n }\n }\n function getterSetter(type) {\n if (type != \"variable\") return pass(afterprop);\n cx.marked = \"property\";\n return cont(functiondef);\n }\n function afterprop(type) {\n if (type == \":\") return cont(expressionNoComma);\n if (type == \"(\") return pass(functiondef);\n }\n function commasep(what, end) {\n function proceed(type, value) {\n if (type == \",\") {\n var lex = cx.state.lexical;\n if (lex.info == \"call\") lex.pos = (lex.pos || 0) + 1;\n return cont(function(type, value) {\n if (type == end || value == end) return pass()\n return pass(what)\n }, proceed);\n }\n if (type == end || value == end) return cont();\n return cont(expect(end));\n }\n return function(type, value) {\n if (type == end || value == end) return cont();\n return pass(what, proceed);\n };\n }\n function contCommasep(what, end, info) {\n for (var i = 3; i < arguments.length; i++)\n cx.cc.push(arguments[i]);\n return cont(pushlex(end, info), commasep(what, end), poplex);\n }\n function block(type) {\n if (type == \"}\") return cont();\n return pass(statement, block);\n }\n function maybetype(type) {\n if (isTS && type == \":\") return cont(typeexpr);\n }\n function maybedefault(_, value) {\n if (value == \"=\") return cont(expressionNoComma);\n }\n function typeexpr(type) {\n if (type == \"variable\") {cx.marked = \"variable-3\"; return cont(afterType);}\n }\n function afterType(type, value) {\n if (value == \"<\") return cont(commasep(typeexpr, \">\"), afterType)\n if (type == \"[\") return cont(expect(\"]\"), afterType)\n }\n function vardef() {\n return pass(pattern, maybetype, maybeAssign, vardefCont);\n }\n function pattern(type, value) {\n if (type == \"modifier\") return cont(pattern)\n if (type == \"variable\") { register(value); return cont(); }\n if (type == \"spread\") return cont(pattern);\n if (type == \"[\") return contCommasep(pattern, \"]\");\n if (type == \"{\") return contCommasep(proppattern, \"}\");\n }\n function proppattern(type, value) {\n if (type == \"variable\" && !cx.stream.match(/^\\s*:/, false)) {\n register(value);\n return cont(maybeAssign);\n }\n if (type == \"variable\") cx.marked = \"property\";\n if (type == \"spread\") return cont(pattern);\n if (type == \"}\") return pass();\n return cont(expect(\":\"), pattern, maybeAssign);\n }\n function maybeAssign(_type, value) {\n if (value == \"=\") return cont(expressionNoComma);\n }\n function vardefCont(type) {\n if (type == \",\") return cont(vardef);\n }\n function maybeelse(type, value) {\n if (type == \"keyword b\" && value == \"else\") return cont(pushlex(\"form\", \"else\"), statement, poplex);\n }\n function forspec(type) {\n if (type == \"(\") return cont(pushlex(\")\"), forspec1, expect(\")\"), poplex);\n }\n function forspec1(type) {\n if (type == \"var\") return cont(vardef, expect(\";\"), forspec2);\n if (type == \";\") return cont(forspec2);\n if (type == \"variable\") return cont(formaybeinof);\n return pass(expression, expect(\";\"), forspec2);\n }\n function formaybeinof(_type, value) {\n if (value == \"in\" || value == \"of\") { cx.marked = \"keyword\"; return cont(expression); }\n return cont(maybeoperatorComma, forspec2);\n }\n function forspec2(type, value) {\n if (type == \";\") return cont(forspec3);\n if (value == \"in\" || value == \"of\") { cx.marked = \"keyword\"; return cont(expression); }\n return pass(expression, expect(\";\"), forspec3);\n }\n function forspec3(type) {\n if (type != \")\") cont(expression);\n }\n function functiondef(type, value) {\n if (value == \"*\") {cx.marked = \"keyword\"; return cont(functiondef);}\n if (type == \"variable\") {register(value); return cont(functiondef);}\n if (type == \"(\") return cont(pushcontext, pushlex(\")\"), commasep(funarg, \")\"), poplex, maybetype, statement, popcontext);\n }\n function funarg(type) {\n if (type == \"spread\") return cont(funarg);\n return pass(pattern, maybetype, maybedefault);\n }\n function className(type, value) {\n if (type == \"variable\") {register(value); return cont(classNameAfter);}\n }\n function classNameAfter(type, value) {\n if (value == \"extends\") return cont(expression, classNameAfter);\n if (type == \"{\") return cont(pushlex(\"}\"), classBody, poplex);\n }\n function classBody(type, value) {\n if (type == \"variable\" || cx.style == \"keyword\") {\n if (value == \"static\") {\n cx.marked = \"keyword\";\n return cont(classBody);\n }\n cx.marked = \"property\";\n if (value == \"get\" || value == \"set\") return cont(classGetterSetter, functiondef, classBody);\n return cont(functiondef, classBody);\n }\n if (value == \"*\") {\n cx.marked = \"keyword\";\n return cont(classBody);\n }\n if (type == \";\") return cont(classBody);\n if (type == \"}\") return cont();\n }\n function classGetterSetter(type) {\n if (type != \"variable\") return pass();\n cx.marked = \"property\";\n return cont();\n }\n function afterExport(_type, value) {\n if (value == \"*\") { cx.marked = \"keyword\"; return cont(maybeFrom, expect(\";\")); }\n if (value == \"default\") { cx.marked = \"keyword\"; return cont(expression, expect(\";\")); }\n return pass(statement);\n }\n function afterImport(type) {\n if (type == \"string\") return cont();\n return pass(importSpec, maybeFrom);\n }\n function importSpec(type, value) {\n if (type == \"{\") return contCommasep(importSpec, \"}\");\n if (type == \"variable\") register(value);\n if (value == \"*\") cx.marked = \"keyword\";\n return cont(maybeAs);\n }\n function maybeAs(_type, value) {\n if (value == \"as\") { cx.marked = \"keyword\"; return cont(importSpec); }\n }\n function maybeFrom(_type, value) {\n if (value == \"from\") { cx.marked = \"keyword\"; return cont(expression); }\n }\n function arrayLiteral(type) {\n if (type == \"]\") return cont();\n return pass(expressionNoComma, commasep(expressionNoComma, \"]\"));\n }\n\n function isContinuedStatement(state, textAfter) {\n return state.lastType == \"operator\" || state.lastType == \",\" ||\n isOperatorChar.test(textAfter.charAt(0)) ||\n /[,.]/.test(textAfter.charAt(0));\n }\n\n // Interface\n\n return {\n startState: function(basecolumn) {\n var state = {\n tokenize: tokenBase,\n lastType: \"sof\",\n cc: [],\n lexical: new JSLexical((basecolumn || 0) - indentUnit, 0, \"block\", false),\n localVars: parserConfig.localVars,\n context: parserConfig.localVars && {vars: parserConfig.localVars},\n indented: basecolumn || 0\n };\n if (parserConfig.globalVars && typeof parserConfig.globalVars == \"object\")\n state.globalVars = parserConfig.globalVars;\n return state;\n },\n\n token: function(stream, state) {\n if (stream.sol()) {\n if (!state.lexical.hasOwnProperty(\"align\"))\n state.lexical.align = false;\n state.indented = stream.indentation();\n findFatArrow(stream, state);\n }\n if (state.tokenize != tokenComment && stream.eatSpace()) return null;\n var style = state.tokenize(stream, state);\n if (type == \"comment\") return style;\n state.lastType = type == \"operator\" && (content == \"++\" || content == \"--\") ? \"incdec\" : type;\n return parseJS(state, style, type, content, stream);\n },\n\n indent: function(state, textAfter) {\n if (state.tokenize == tokenComment) return CodeMirror.Pass;\n if (state.tokenize != tokenBase) return 0;\n var firstChar = textAfter && textAfter.charAt(0), lexical = state.lexical;\n // Kludge to prevent 'maybelse' from blocking lexical scope pops\n if (!/^\\s*else\\b/.test(textAfter)) for (var i = state.cc.length - 1; i >= 0; --i) {\n var c = state.cc[i];\n if (c == poplex) lexical = lexical.prev;\n else if (c != maybeelse) break;\n }\n if (lexical.type == \"stat\" && firstChar == \"}\") lexical = lexical.prev;\n if (statementIndent && lexical.type == \")\" && lexical.prev.type == \"stat\")\n lexical = lexical.prev;\n var type = lexical.type, closing = firstChar == type;\n\n if (type == \"vardef\") return lexical.indented + (state.lastType == \"operator\" || state.lastType == \",\" ? lexical.info + 1 : 0);\n else if (type == \"form\" && firstChar == \"{\") return lexical.indented;\n else if (type == \"form\") return lexical.indented + indentUnit;\n else if (type == \"stat\")\n return lexical.indented + (isContinuedStatement(state, textAfter) ? statementIndent || indentUnit : 0);\n else if (lexical.info == \"switch\" && !closing && parserConfig.doubleIndentSwitch != false)\n return lexical.indented + (/^(?:case|default)\\b/.test(textAfter) ? indentUnit : 2 * indentUnit);\n else if (lexical.align) return lexical.column + (closing ? 0 : 1);\n else return lexical.indented + (closing ? 0 : indentUnit);\n },\n\n electricInput: /^\\s*(?:case .*?:|default:|\\{|\\})$/,\n blockCommentStart: jsonMode ? null : \"/*\",\n blockCommentEnd: jsonMode ? null : \"*/\",\n lineComment: jsonMode ? null : \"//\",\n fold: \"brace\",\n closeBrackets: \"()[]{}''\\\"\\\"``\",\n\n helperType: jsonMode ? \"json\" : \"javascript\",\n jsonldMode: jsonldMode,\n jsonMode: jsonMode,\n\n expressionAllowed: expressionAllowed,\n skipExpression: function(state) {\n var top = state.cc[state.cc.length - 1]\n if (top == expression || top == expressionNoComma) state.cc.pop()\n }\n };\n});\n\nCodeMirror.registerHelper(\"wordChars\", \"javascript\", /[\\w$]/);\n\nCodeMirror.defineMIME(\"text/javascript\", \"javascript\");\nCodeMirror.defineMIME(\"text/ecmascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/javascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/x-javascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/ecmascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/json\", {name: \"javascript\", json: true});\nCodeMirror.defineMIME(\"application/x-json\", {name: \"javascript\", json: true});\nCodeMirror.defineMIME(\"application/ld+json\", {name: \"javascript\", jsonld: true});\nCodeMirror.defineMIME(\"text/typescript\", { name: \"javascript\", typescript: true });\nCodeMirror.defineMIME(\"application/typescript\", { name: \"javascript\", typescript: true });\n\n});\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: http://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n\"use strict\";\n\nvar htmlConfig = {\n autoSelfClosers: {'area': true, 'base': true, 'br': true, 'col': true, 'command': true,\n 'embed': true, 'frame': true, 'hr': true, 'img': true, 'input': true,\n 'keygen': true, 'link': true, 'meta': true, 'param': true, 'source': true,\n 'track': true, 'wbr': true, 'menuitem': true},\n implicitlyClosed: {'dd': true, 'li': true, 'optgroup': true, 'option': true, 'p': true,\n 'rp': true, 'rt': true, 'tbody': true, 'td': true, 'tfoot': true,\n 'th': true, 'tr': true},\n contextGrabbers: {\n 'dd': {'dd': true, 'dt': true},\n 'dt': {'dd': true, 'dt': true},\n 'li': {'li': true},\n 'option': {'option': true, 'optgroup': true},\n 'optgroup': {'optgroup': true},\n 'p': {'address': true, 'article': true, 'aside': true, 'blockquote': true, 'dir': true,\n 'div': true, 'dl': true, 'fieldset': true, 'footer': true, 'form': true,\n 'h1': true, 'h2': true, 'h3': true, 'h4': true, 'h5': true, 'h6': true,\n 'header': true, 'hgroup': true, 'hr': true, 'menu': true, 'nav': true, 'ol': true,\n 'p': true, 'pre': true, 'section': true, 'table': true, 'ul': true},\n 'rp': {'rp': true, 'rt': true},\n 'rt': {'rp': true, 'rt': true},\n 'tbody': {'tbody': true, 'tfoot': true},\n 'td': {'td': true, 'th': true},\n 'tfoot': {'tbody': true},\n 'th': {'td': true, 'th': true},\n 'thead': {'tbody': true, 'tfoot': true},\n 'tr': {'tr': true}\n },\n doNotIndent: {\"pre\": true},\n allowUnquoted: true,\n allowMissing: true,\n caseFold: true\n}\n\nvar xmlConfig = {\n autoSelfClosers: {},\n implicitlyClosed: {},\n contextGrabbers: {},\n doNotIndent: {},\n allowUnquoted: false,\n allowMissing: false,\n caseFold: false\n}\n\nCodeMirror.defineMode(\"xml\", function(editorConf, config_) {\n var indentUnit = editorConf.indentUnit\n var config = {}\n var defaults = config_.htmlMode ? htmlConfig : xmlConfig\n for (var prop in defaults) config[prop] = defaults[prop]\n for (var prop in config_) config[prop] = config_[prop]\n\n // Return variables for tokenizers\n var type, setStyle;\n\n function inText(stream, state) {\n function chain(parser) {\n state.tokenize = parser;\n return parser(stream, state);\n }\n\n var ch = stream.next();\n if (ch == \"<\") {\n if (stream.eat(\"!\")) {\n if (stream.eat(\"[\")) {\n if (stream.match(\"CDATA[\")) return chain(inBlock(\"atom\", \"]]>\"));\n else return null;\n } else if (stream.match(\"--\")) {\n return chain(inBlock(\"comment\", \"-->\"));\n } else if (stream.match(\"DOCTYPE\", true, true)) {\n stream.eatWhile(/[\\w\\._\\-]/);\n return chain(doctype(1));\n } else {\n return null;\n }\n } else if (stream.eat(\"?\")) {\n stream.eatWhile(/[\\w\\._\\-]/);\n state.tokenize = inBlock(\"meta\", \"?>\");\n return \"meta\";\n } else {\n type = stream.eat(\"/\") ? \"closeTag\" : \"openTag\";\n state.tokenize = inTag;\n return \"tag bracket\";\n }\n } else if (ch == \"&\") {\n var ok;\n if (stream.eat(\"#\")) {\n if (stream.eat(\"x\")) {\n ok = stream.eatWhile(/[a-fA-F\\d]/) && stream.eat(\";\");\n } else {\n ok = stream.eatWhile(/[\\d]/) && stream.eat(\";\");\n }\n } else {\n ok = stream.eatWhile(/[\\w\\.\\-:]/) && stream.eat(\";\");\n }\n return ok ? \"atom\" : \"error\";\n } else {\n stream.eatWhile(/[^&<]/);\n return null;\n }\n }\n inText.isInText = true;\n\n function inTag(stream, state) {\n var ch = stream.next();\n if (ch == \">\" || (ch == \"/\" && stream.eat(\">\"))) {\n state.tokenize = inText;\n type = ch == \">\" ? \"endTag\" : \"selfcloseTag\";\n return \"tag bracket\";\n } else if (ch == \"=\") {\n type = \"equals\";\n return null;\n } else if (ch == \"<\") {\n state.tokenize = inText;\n state.state = baseState;\n state.tagName = state.tagStart = null;\n var next = state.tokenize(stream, state);\n return next ? next + \" tag error\" : \"tag error\";\n } else if (/[\\'\\\"]/.test(ch)) {\n state.tokenize = inAttribute(ch);\n state.stringStartCol = stream.column();\n return state.tokenize(stream, state);\n } else {\n stream.match(/^[^\\s\\u00a0=<>\\\"\\']*[^\\s\\u00a0=<>\\\"\\'\\/]/);\n return \"word\";\n }\n }\n\n function inAttribute(quote) {\n var closure = function(stream, state) {\n while (!stream.eol()) {\n if (stream.next() == quote) {\n state.tokenize = inTag;\n break;\n }\n }\n return \"string\";\n };\n closure.isInAttribute = true;\n return closure;\n }\n\n function inBlock(style, terminator) {\n return function(stream, state) {\n while (!stream.eol()) {\n if (stream.match(terminator)) {\n state.tokenize = inText;\n break;\n }\n stream.next();\n }\n return style;\n };\n }\n function doctype(depth) {\n return function(stream, state) {\n var ch;\n while ((ch = stream.next()) != null) {\n if (ch == \"<\") {\n state.tokenize = doctype(depth + 1);\n return state.tokenize(stream, state);\n } else if (ch == \">\") {\n if (depth == 1) {\n state.tokenize = inText;\n break;\n } else {\n state.tokenize = doctype(depth - 1);\n return state.tokenize(stream, state);\n }\n }\n }\n return \"meta\";\n };\n }\n\n function Context(state, tagName, startOfLine) {\n this.prev = state.context;\n this.tagName = tagName;\n this.indent = state.indented;\n this.startOfLine = startOfLine;\n if (config.doNotIndent.hasOwnProperty(tagName) || (state.context && state.context.noIndent))\n this.noIndent = true;\n }\n function popContext(state) {\n if (state.context) state.context = state.context.prev;\n }\n function maybePopContext(state, nextTagName) {\n var parentTagName;\n while (true) {\n if (!state.context) {\n return;\n }\n parentTagName = state.context.tagName;\n if (!config.contextGrabbers.hasOwnProperty(parentTagName) ||\n !config.contextGrabbers[parentTagName].hasOwnProperty(nextTagName)) {\n return;\n }\n popContext(state);\n }\n }\n\n function baseState(type, stream, state) {\n if (type == \"openTag\") {\n state.tagStart = stream.column();\n return tagNameState;\n } else if (type == \"closeTag\") {\n return closeTagNameState;\n } else {\n return baseState;\n }\n }\n function tagNameState(type, stream, state) {\n if (type == \"word\") {\n state.tagName = stream.current();\n setStyle = \"tag\";\n return attrState;\n } else {\n setStyle = \"error\";\n return tagNameState;\n }\n }\n function closeTagNameState(type, stream, state) {\n if (type == \"word\") {\n var tagName = stream.current();\n if (state.context && state.context.tagName != tagName &&\n config.implicitlyClosed.hasOwnProperty(state.context.tagName))\n popContext(state);\n if ((state.context && state.context.tagName == tagName) || config.matchClosing === false) {\n setStyle = \"tag\";\n return closeState;\n } else {\n setStyle = \"tag error\";\n return closeStateErr;\n }\n } else {\n setStyle = \"error\";\n return closeStateErr;\n }\n }\n\n function closeState(type, _stream, state) {\n if (type != \"endTag\") {\n setStyle = \"error\";\n return closeState;\n }\n popContext(state);\n return baseState;\n }\n function closeStateErr(type, stream, state) {\n setStyle = \"error\";\n return closeState(type, stream, state);\n }\n\n function attrState(type, _stream, state) {\n if (type == \"word\") {\n setStyle = \"attribute\";\n return attrEqState;\n } else if (type == \"endTag\" || type == \"selfcloseTag\") {\n var tagName = state.tagName, tagStart = state.tagStart;\n state.tagName = state.tagStart = null;\n if (type == \"selfcloseTag\" ||\n config.autoSelfClosers.hasOwnProperty(tagName)) {\n maybePopContext(state, tagName);\n } else {\n maybePopContext(state, tagName);\n state.context = new Context(state, tagName, tagStart == state.indented);\n }\n return baseState;\n }\n setStyle = \"error\";\n return attrState;\n }\n function attrEqState(type, stream, state) {\n if (type == \"equals\") return attrValueState;\n if (!config.allowMissing) setStyle = \"error\";\n return attrState(type, stream, state);\n }\n function attrValueState(type, stream, state) {\n if (type == \"string\") return attrContinuedState;\n if (type == \"word\" && config.allowUnquoted) {setStyle = \"string\"; return attrState;}\n setStyle = \"error\";\n return attrState(type, stream, state);\n }\n function attrContinuedState(type, stream, state) {\n if (type == \"string\") return attrContinuedState;\n return attrState(type, stream, state);\n }\n\n return {\n startState: function(baseIndent) {\n var state = {tokenize: inText,\n state: baseState,\n indented: baseIndent || 0,\n tagName: null, tagStart: null,\n context: null}\n if (baseIndent != null) state.baseIndent = baseIndent\n return state\n },\n\n token: function(stream, state) {\n if (!state.tagName && stream.sol())\n state.indented = stream.indentation();\n\n if (stream.eatSpace()) return null;\n type = null;\n var style = state.tokenize(stream, state);\n if ((style || type) && style != \"comment\") {\n setStyle = null;\n state.state = state.state(type || style, stream, state);\n if (setStyle)\n style = setStyle == \"error\" ? style + \" error\" : setStyle;\n }\n return style;\n },\n\n indent: function(state, textAfter, fullLine) {\n var context = state.context;\n // Indent multi-line strings (e.g. css).\n if (state.tokenize.isInAttribute) {\n if (state.tagStart == state.indented)\n return state.stringStartCol + 1;\n else\n return state.indented + indentUnit;\n }\n if (context && context.noIndent) return CodeMirror.Pass;\n if (state.tokenize != inTag && state.tokenize != inText)\n return fullLine ? fullLine.match(/^(\\s*)/)[0].length : 0;\n // Indent the starts of attribute names.\n if (state.tagName) {\n if (config.multilineTagIndentPastTag !== false)\n return state.tagStart + state.tagName.length + 2;\n else\n return state.tagStart + indentUnit * (config.multilineTagIndentFactor || 1);\n }\n if (config.alignCDATA && /<!\\[CDATA\\[/.test(textAfter)) return 0;\n var tagAfter = textAfter && /^<(\\/)?([\\w_:\\.-]*)/.exec(textAfter);\n if (tagAfter && tagAfter[1]) { // Closing tag spotted\n while (context) {\n if (context.tagName == tagAfter[2]) {\n context = context.prev;\n break;\n } else if (config.implicitlyClosed.hasOwnProperty(context.tagName)) {\n context = context.prev;\n } else {\n break;\n }\n }\n } else if (tagAfter) { // Opening tag spotted\n while (context) {\n var grabbers = config.contextGrabbers[context.tagName];\n if (grabbers && grabbers.hasOwnProperty(tagAfter[2]))\n context = context.prev;\n else\n break;\n }\n }\n while (context && context.prev && !context.startOfLine)\n context = context.prev;\n if (context) return context.indent + indentUnit;\n else return state.baseIndent || 0;\n },\n\n electricInput: /<\\/[\\s\\w:]+>$/,\n blockCommentStart: \"<!--\",\n blockCommentEnd: \"-->\",\n\n configuration: config.htmlMode ? \"html\" : \"xml\",\n helperType: config.htmlMode ? \"html\" : \"xml\",\n\n skipAttribute: function(state) {\n if (state.state == attrValueState)\n state.state = attrState\n }\n };\n});\n\nCodeMirror.defineMIME(\"text/xml\", \"xml\");\nCodeMirror.defineMIME(\"application/xml\", \"xml\");\nif (!CodeMirror.mimeModes.hasOwnProperty(\"text/html\"))\n CodeMirror.defineMIME(\"text/html\", {name: \"xml\", htmlMode: true});\n\n});\n","// https://d3js.org Version 4.1.1. Copyright 2016 Mike Bostock.\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :\n typeof define === 'function' && define.amd ? define(['exports'], factory) :\n (factory((global.d3 = global.d3 || {})));\n}(this, function (exports) { 'use strict';\n\n var version = \"4.1.1\";\n\n function ascending(a, b) {\n return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n }\n\n function bisector(compare) {\n if (compare.length === 1) compare = ascendingComparator(compare);\n return {\n left: function(a, x, lo, hi) {\n if (lo == null) lo = 0;\n if (hi == null) hi = a.length;\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (compare(a[mid], x) < 0) lo = mid + 1;\n else hi = mid;\n }\n return lo;\n },\n right: function(a, x, lo, hi) {\n if (lo == null) lo = 0;\n if (hi == null) hi = a.length;\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (compare(a[mid], x) > 0) hi = mid;\n else lo = mid + 1;\n }\n return lo;\n }\n };\n }\n\n function ascendingComparator(f) {\n return function(d, x) {\n return ascending(f(d), x);\n };\n }\n\n var ascendingBisect = bisector(ascending);\n var bisectRight = ascendingBisect.right;\n var bisectLeft = ascendingBisect.left;\n\n function descending(a, b) {\n return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;\n }\n\n function number(x) {\n return x === null ? NaN : +x;\n }\n\n function variance(array, f) {\n var n = array.length,\n m = 0,\n a,\n d,\n s = 0,\n i = -1,\n j = 0;\n\n if (f == null) {\n while (++i < n) {\n if (!isNaN(a = number(array[i]))) {\n d = a - m;\n m += d / ++j;\n s += d * (a - m);\n }\n }\n }\n\n else {\n while (++i < n) {\n if (!isNaN(a = number(f(array[i], i, array)))) {\n d = a - m;\n m += d / ++j;\n s += d * (a - m);\n }\n }\n }\n\n if (j > 1) return s / (j - 1);\n }\n\n function deviation(array, f) {\n var v = variance(array, f);\n return v ? Math.sqrt(v) : v;\n }\n\n function extent(array, f) {\n var i = -1,\n n = array.length,\n a,\n b,\n c;\n\n if (f == null) {\n while (++i < n) if ((b = array[i]) != null && b >= b) { a = c = b; break; }\n while (++i < n) if ((b = array[i]) != null) {\n if (a > b) a = b;\n if (c < b) c = b;\n }\n }\n\n else {\n while (++i < n) if ((b = f(array[i], i, array)) != null && b >= b) { a = c = b; break; }\n while (++i < n) if ((b = f(array[i], i, array)) != null) {\n if (a > b) a = b;\n if (c < b) c = b;\n }\n }\n\n return [a, c];\n }\n\n var array = Array.prototype;\n\n var slice = array.slice;\n var map = array.map;\n\n function constant(x) {\n return function() {\n return x;\n };\n }\n\n function identity(x) {\n return x;\n }\n\n function range(start, stop, step) {\n start = +start, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start, start = 0, 1) : n < 3 ? 1 : +step;\n\n var i = -1,\n n = Math.max(0, Math.ceil((stop - start) / step)) | 0,\n range = new Array(n);\n\n while (++i < n) {\n range[i] = start + i * step;\n }\n\n return range;\n }\n\n var e10 = Math.sqrt(50);\n var e5 = Math.sqrt(10);\n var e2 = Math.sqrt(2);\n function ticks(start, stop, count) {\n var step = tickStep(start, stop, count);\n return range(\n Math.ceil(start / step) * step,\n Math.floor(stop / step) * step + step / 2, // inclusive\n step\n );\n }\n\n function tickStep(start, stop, count) {\n var step0 = Math.abs(stop - start) / Math.max(0, count),\n step1 = Math.pow(10, Math.floor(Math.log(step0) / Math.LN10)),\n error = step0 / step1;\n if (error >= e10) step1 *= 10;\n else if (error >= e5) step1 *= 5;\n else if (error >= e2) step1 *= 2;\n return stop < start ? -step1 : step1;\n }\n\n function sturges(values) {\n return Math.ceil(Math.log(values.length) / Math.LN2) + 1;\n }\n\n function histogram() {\n var value = identity,\n domain = extent,\n threshold = sturges;\n\n function histogram(data) {\n var i,\n n = data.length,\n x,\n values = new Array(n);\n\n for (i = 0; i < n; ++i) {\n values[i] = value(data[i], i, data);\n }\n\n var xz = domain(values),\n x0 = xz[0],\n x1 = xz[1],\n tz = threshold(values, x0, x1);\n\n // Convert number of thresholds into uniform thresholds.\n if (!Array.isArray(tz)) tz = ticks(x0, x1, tz);\n\n // Remove any thresholds outside the domain.\n var m = tz.length;\n while (tz[0] <= x0) tz.shift(), --m;\n while (tz[m - 1] >= x1) tz.pop(), --m;\n\n var bins = new Array(m + 1),\n bin;\n\n // Initialize bins.\n for (i = 0; i <= m; ++i) {\n bin = bins[i] = [];\n bin.x0 = i > 0 ? tz[i - 1] : x0;\n bin.x1 = i < m ? tz[i] : x1;\n }\n\n // Assign data to bins by value, ignoring any outside the domain.\n for (i = 0; i < n; ++i) {\n x = values[i];\n if (x0 <= x && x <= x1) {\n bins[bisectRight(tz, x, 0, m)].push(data[i]);\n }\n }\n\n return bins;\n }\n\n histogram.value = function(_) {\n return arguments.length ? (value = typeof _ === \"function\" ? _ : constant(_), histogram) : value;\n };\n\n histogram.domain = function(_) {\n return arguments.length ? (domain = typeof _ === \"function\" ? _ : constant([_[0], _[1]]), histogram) : domain;\n };\n\n histogram.thresholds = function(_) {\n return arguments.length ? (threshold = typeof _ === \"function\" ? _ : Array.isArray(_) ? constant(slice.call(_)) : constant(_), histogram) : threshold;\n };\n\n return histogram;\n }\n\n function threshold(array, p, f) {\n if (f == null) f = number;\n if (!(n = array.length)) return;\n if ((p = +p) <= 0 || n < 2) return +f(array[0], 0, array);\n if (p >= 1) return +f(array[n - 1], n - 1, array);\n var n,\n h = (n - 1) * p,\n i = Math.floor(h),\n a = +f(array[i], i, array),\n b = +f(array[i + 1], i + 1, array);\n return a + (b - a) * (h - i);\n }\n\n function freedmanDiaconis(values, min, max) {\n values = map.call(values, number).sort(ascending);\n return Math.ceil((max - min) / (2 * (threshold(values, 0.75) - threshold(values, 0.25)) * Math.pow(values.length, -1 / 3)));\n }\n\n function scott(values, min, max) {\n return Math.ceil((max - min) / (3.5 * deviation(values) * Math.pow(values.length, -1 / 3)));\n }\n\n function max(array, f) {\n var i = -1,\n n = array.length,\n a,\n b;\n\n if (f == null) {\n while (++i < n) if ((b = array[i]) != null && b >= b) { a = b; break; }\n while (++i < n) if ((b = array[i]) != null && b > a) a = b;\n }\n\n else {\n while (++i < n) if ((b = f(array[i], i, array)) != null && b >= b) { a = b; break; }\n while (++i < n) if ((b = f(array[i], i, array)) != null && b > a) a = b;\n }\n\n return a;\n }\n\n function mean(array, f) {\n var s = 0,\n n = array.length,\n a,\n i = -1,\n j = n;\n\n if (f == null) {\n while (++i < n) if (!isNaN(a = number(array[i]))) s += a; else --j;\n }\n\n else {\n while (++i < n) if (!isNaN(a = number(f(array[i], i, array)))) s += a; else --j;\n }\n\n if (j) return s / j;\n }\n\n function median(array, f) {\n var numbers = [],\n n = array.length,\n a,\n i = -1;\n\n if (f == null) {\n while (++i < n) if (!isNaN(a = number(array[i]))) numbers.push(a);\n }\n\n else {\n while (++i < n) if (!isNaN(a = number(f(array[i], i, array)))) numbers.push(a);\n }\n\n return threshold(numbers.sort(ascending), 0.5);\n }\n\n function merge(arrays) {\n var n = arrays.length,\n m,\n i = -1,\n j = 0,\n merged,\n array;\n\n while (++i < n) j += arrays[i].length;\n merged = new Array(j);\n\n while (--n >= 0) {\n array = arrays[n];\n m = array.length;\n while (--m >= 0) {\n merged[--j] = array[m];\n }\n }\n\n return merged;\n }\n\n function min(array, f) {\n var i = -1,\n n = array.length,\n a,\n b;\n\n if (f == null) {\n while (++i < n) if ((b = array[i]) != null && b >= b) { a = b; break; }\n while (++i < n) if ((b = array[i]) != null && a > b) a = b;\n }\n\n else {\n while (++i < n) if ((b = f(array[i], i, array)) != null && b >= b) { a = b; break; }\n while (++i < n) if ((b = f(array[i], i, array)) != null && a > b) a = b;\n }\n\n return a;\n }\n\n function pairs(array) {\n var i = 0, n = array.length - 1, p = array[0], pairs = new Array(n < 0 ? 0 : n);\n while (i < n) pairs[i] = [p, p = array[++i]];\n return pairs;\n }\n\n function permute(array, indexes) {\n var i = indexes.length, permutes = new Array(i);\n while (i--) permutes[i] = array[indexes[i]];\n return permutes;\n }\n\n function scan(array, compare) {\n if (!(n = array.length)) return;\n var i = 0,\n n,\n j = 0,\n xi,\n xj = array[j];\n\n if (!compare) compare = ascending;\n\n while (++i < n) if (compare(xi = array[i], xj) < 0 || compare(xj, xj) !== 0) xj = xi, j = i;\n\n if (compare(xj, xj) === 0) return j;\n }\n\n function shuffle(array, i0, i1) {\n var m = (i1 == null ? array.length : i1) - (i0 = i0 == null ? 0 : +i0),\n t,\n i;\n\n while (m) {\n i = Math.random() * m-- | 0;\n t = array[m + i0];\n array[m + i0] = array[i + i0];\n array[i + i0] = t;\n }\n\n return array;\n }\n\n function sum(array, f) {\n var s = 0,\n n = array.length,\n a,\n i = -1;\n\n if (f == null) {\n while (++i < n) if (a = +array[i]) s += a; // Note: zero and null are equivalent.\n }\n\n else {\n while (++i < n) if (a = +f(array[i], i, array)) s += a;\n }\n\n return s;\n }\n\n function transpose(matrix) {\n if (!(n = matrix.length)) return [];\n for (var i = -1, m = min(matrix, length), transpose = new Array(m); ++i < m;) {\n for (var j = -1, n, row = transpose[i] = new Array(n); ++j < n;) {\n row[j] = matrix[j][i];\n }\n }\n return transpose;\n }\n\n function length(d) {\n return d.length;\n }\n\n function zip() {\n return transpose(arguments);\n }\n\n var prefix = \"$\";\n\n function Map() {}\n\n Map.prototype = map$1.prototype = {\n constructor: Map,\n has: function(key) {\n return (prefix + key) in this;\n },\n get: function(key) {\n return this[prefix + key];\n },\n set: function(key, value) {\n this[prefix + key] = value;\n return this;\n },\n remove: function(key) {\n var property = prefix + key;\n return property in this && delete this[property];\n },\n clear: function() {\n for (var property in this) if (property[0] === prefix) delete this[property];\n },\n keys: function() {\n var keys = [];\n for (var property in this) if (property[0] === prefix) keys.push(property.slice(1));\n return keys;\n },\n values: function() {\n var values = [];\n for (var property in this) if (property[0] === prefix) values.push(this[property]);\n return values;\n },\n entries: function() {\n var entries = [];\n for (var property in this) if (property[0] === prefix) entries.push({key: property.slice(1), value: this[property]});\n return entries;\n },\n size: function() {\n var size = 0;\n for (var property in this) if (property[0] === prefix) ++size;\n return size;\n },\n empty: function() {\n for (var property in this) if (property[0] === prefix) return false;\n return true;\n },\n each: function(f) {\n for (var property in this) if (property[0] === prefix) f(this[property], property.slice(1), this);\n }\n };\n\n function map$1(object, f) {\n var map = new Map;\n\n // Copy constructor.\n if (object instanceof Map) object.each(function(value, key) { map.set(key, value); });\n\n // Index array by numeric index or specified key function.\n else if (Array.isArray(object)) {\n var i = -1,\n n = object.length,\n o;\n\n if (f == null) while (++i < n) map.set(i, object[i]);\n else while (++i < n) map.set(f(o = object[i], i, object), o);\n }\n\n // Convert object to map.\n else if (object) for (var key in object) map.set(key, object[key]);\n\n return map;\n }\n\n function nest() {\n var keys = [],\n sortKeys = [],\n sortValues,\n rollup,\n nest;\n\n function apply(array, depth, createResult, setResult) {\n if (depth >= keys.length) return rollup != null\n ? rollup(array) : (sortValues != null\n ? array.sort(sortValues)\n : array);\n\n var i = -1,\n n = array.length,\n key = keys[depth++],\n keyValue,\n value,\n valuesByKey = map$1(),\n values,\n result = createResult();\n\n while (++i < n) {\n if (values = valuesByKey.get(keyValue = key(value = array[i]) + \"\")) {\n values.push(value);\n } else {\n valuesByKey.set(keyValue, [value]);\n }\n }\n\n valuesByKey.each(function(values, key) {\n setResult(result, key, apply(values, depth, createResult, setResult));\n });\n\n return result;\n }\n\n function entries(map, depth) {\n if (++depth > keys.length) return map;\n var array, sortKey = sortKeys[depth - 1];\n if (rollup != null && depth >= keys.length) array = map.entries();\n else array = [], map.each(function(v, k) { array.push({key: k, values: entries(v, depth)}); });\n return sortKey != null ? array.sort(function(a, b) { return sortKey(a.key, b.key); }) : array;\n }\n\n return nest = {\n object: function(array) { return apply(array, 0, createObject, setObject); },\n map: function(array) { return apply(array, 0, createMap, setMap); },\n entries: function(array) { return entries(apply(array, 0, createMap, setMap), 0); },\n key: function(d) { keys.push(d); return nest; },\n sortKeys: function(order) { sortKeys[keys.length - 1] = order; return nest; },\n sortValues: function(order) { sortValues = order; return nest; },\n rollup: function(f) { rollup = f; return nest; }\n };\n }\n\n function createObject() {\n return {};\n }\n\n function setObject(object, key, value) {\n object[key] = value;\n }\n\n function createMap() {\n return map$1();\n }\n\n function setMap(map, key, value) {\n map.set(key, value);\n }\n\n function Set() {}\n\n var proto = map$1.prototype;\n\n Set.prototype = set.prototype = {\n constructor: Set,\n has: proto.has,\n add: function(value) {\n value += \"\";\n this[prefix + value] = value;\n return this;\n },\n remove: proto.remove,\n clear: proto.clear,\n values: proto.keys,\n size: proto.size,\n empty: proto.empty,\n each: proto.each\n };\n\n function set(object, f) {\n var set = new Set;\n\n // Copy constructor.\n if (object instanceof Set) object.each(function(value) { set.add(value); });\n\n // Otherwise, assume it’s an array.\n else if (object) {\n var i = -1, n = object.length;\n if (f == null) while (++i < n) set.add(object[i]);\n else while (++i < n) set.add(f(object[i], i, object));\n }\n\n return set;\n }\n\n function keys(map) {\n var keys = [];\n for (var key in map) keys.push(key);\n return keys;\n }\n\n function values(map) {\n var values = [];\n for (var key in map) values.push(map[key]);\n return values;\n }\n\n function entries(map) {\n var entries = [];\n for (var key in map) entries.push({key: key, value: map[key]});\n return entries;\n }\n\n function uniform(min, max) {\n min = min == null ? 0 : +min;\n max = max == null ? 1 : +max;\n if (arguments.length === 1) max = min, min = 0;\n else max -= min;\n return function() {\n return Math.random() * max + min;\n };\n }\n\n function normal(mu, sigma) {\n var x, r;\n mu = mu == null ? 0 : +mu;\n sigma = sigma == null ? 1 : +sigma;\n return function() {\n var y;\n\n // If available, use the second previously-generated uniform random.\n if (x != null) y = x, x = null;\n\n // Otherwise, generate a new x and y.\n else do {\n x = Math.random() * 2 - 1;\n y = Math.random() * 2 - 1;\n r = x * x + y * y;\n } while (!r || r > 1);\n\n return mu + sigma * y * Math.sqrt(-2 * Math.log(r) / r);\n };\n }\n\n function logNormal() {\n var randomNormal = normal.apply(this, arguments);\n return function() {\n return Math.exp(randomNormal());\n };\n }\n\n function irwinHall(n) {\n return function() {\n for (var sum = 0, i = 0; i < n; ++i) sum += Math.random();\n return sum;\n };\n }\n\n function bates(n) {\n var randomIrwinHall = irwinHall(n);\n return function() {\n return randomIrwinHall() / n;\n };\n }\n\n function exponential(lambda) {\n return function() {\n return -Math.log(1 - Math.random()) / lambda;\n };\n }\n\n function linear(t) {\n return +t;\n }\n\n function quadIn(t) {\n return t * t;\n }\n\n function quadOut(t) {\n return t * (2 - t);\n }\n\n function quadInOut(t) {\n return ((t *= 2) <= 1 ? t * t : --t * (2 - t) + 1) / 2;\n }\n\n function cubicIn(t) {\n return t * t * t;\n }\n\n function cubicOut(t) {\n return --t * t * t + 1;\n }\n\n function easeCubicInOut(t) {\n return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;\n }\n\n var exponent = 3;\n\n var polyIn = (function custom(e) {\n e = +e;\n\n function polyIn(t) {\n return Math.pow(t, e);\n }\n\n polyIn.exponent = custom;\n\n return polyIn;\n })(exponent);\n\n var polyOut = (function custom(e) {\n e = +e;\n\n function polyOut(t) {\n return 1 - Math.pow(1 - t, e);\n }\n\n polyOut.exponent = custom;\n\n return polyOut;\n })(exponent);\n\n var polyInOut = (function custom(e) {\n e = +e;\n\n function polyInOut(t) {\n return ((t *= 2) <= 1 ? Math.pow(t, e) : 2 - Math.pow(2 - t, e)) / 2;\n }\n\n polyInOut.exponent = custom;\n\n return polyInOut;\n })(exponent);\n\n var pi = Math.PI;\n var halfPi = pi / 2;\n function sinIn(t) {\n return 1 - Math.cos(t * halfPi);\n }\n\n function sinOut(t) {\n return Math.sin(t * halfPi);\n }\n\n function sinInOut(t) {\n return (1 - Math.cos(pi * t)) / 2;\n }\n\n function expIn(t) {\n return Math.pow(2, 10 * t - 10);\n }\n\n function expOut(t) {\n return 1 - Math.pow(2, -10 * t);\n }\n\n function expInOut(t) {\n return ((t *= 2) <= 1 ? Math.pow(2, 10 * t - 10) : 2 - Math.pow(2, 10 - 10 * t)) / 2;\n }\n\n function circleIn(t) {\n return 1 - Math.sqrt(1 - t * t);\n }\n\n function circleOut(t) {\n return Math.sqrt(1 - --t * t);\n }\n\n function circleInOut(t) {\n return ((t *= 2) <= 1 ? 1 - Math.sqrt(1 - t * t) : Math.sqrt(1 - (t -= 2) * t) + 1) / 2;\n }\n\n var b1 = 4 / 11;\n var b2 = 6 / 11;\n var b3 = 8 / 11;\n var b4 = 3 / 4;\n var b5 = 9 / 11;\n var b6 = 10 / 11;\n var b7 = 15 / 16;\n var b8 = 21 / 22;\n var b9 = 63 / 64;\n var b0 = 1 / b1 / b1;\n function bounceIn(t) {\n return 1 - bounceOut(1 - t);\n }\n\n function bounceOut(t) {\n return (t = +t) < b1 ? b0 * t * t : t < b3 ? b0 * (t -= b2) * t + b4 : t < b6 ? b0 * (t -= b5) * t + b7 : b0 * (t -= b8) * t + b9;\n }\n\n function bounceInOut(t) {\n return ((t *= 2) <= 1 ? 1 - bounceOut(1 - t) : bounceOut(t - 1) + 1) / 2;\n }\n\n var overshoot = 1.70158;\n\n var backIn = (function custom(s) {\n s = +s;\n\n function backIn(t) {\n return t * t * ((s + 1) * t - s);\n }\n\n backIn.overshoot = custom;\n\n return backIn;\n })(overshoot);\n\n var backOut = (function custom(s) {\n s = +s;\n\n function backOut(t) {\n return --t * t * ((s + 1) * t + s) + 1;\n }\n\n backOut.overshoot = custom;\n\n return backOut;\n })(overshoot);\n\n var backInOut = (function custom(s) {\n s = +s;\n\n function backInOut(t) {\n return ((t *= 2) < 1 ? t * t * ((s + 1) * t - s) : (t -= 2) * t * ((s + 1) * t + s) + 2) / 2;\n }\n\n backInOut.overshoot = custom;\n\n return backInOut;\n })(overshoot);\n\n var tau = 2 * Math.PI;\n var amplitude = 1;\n var period = 0.3;\n var elasticIn = (function custom(a, p) {\n var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n function elasticIn(t) {\n return a * Math.pow(2, 10 * --t) * Math.sin((s - t) / p);\n }\n\n elasticIn.amplitude = function(a) { return custom(a, p * tau); };\n elasticIn.period = function(p) { return custom(a, p); };\n\n return elasticIn;\n })(amplitude, period);\n\n var elasticOut = (function custom(a, p) {\n var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n function elasticOut(t) {\n return 1 - a * Math.pow(2, -10 * (t = +t)) * Math.sin((t + s) / p);\n }\n\n elasticOut.amplitude = function(a) { return custom(a, p * tau); };\n elasticOut.period = function(p) { return custom(a, p); };\n\n return elasticOut;\n })(amplitude, period);\n\n var elasticInOut = (function custom(a, p) {\n var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n function elasticInOut(t) {\n return ((t = t * 2 - 1) < 0\n ? a * Math.pow(2, 10 * t) * Math.sin((s - t) / p)\n : 2 - a * Math.pow(2, -10 * t) * Math.sin((s + t) / p)) / 2;\n }\n\n elasticInOut.amplitude = function(a) { return custom(a, p * tau); };\n elasticInOut.period = function(p) { return custom(a, p); };\n\n return elasticInOut;\n })(amplitude, period);\n\n function area(polygon) {\n var i = -1,\n n = polygon.length,\n a,\n b = polygon[n - 1],\n area = 0;\n\n while (++i < n) {\n a = b;\n b = polygon[i];\n area += a[1] * b[0] - a[0] * b[1];\n }\n\n return area / 2;\n }\n\n function centroid(polygon) {\n var i = -1,\n n = polygon.length,\n x = 0,\n y = 0,\n a,\n b = polygon[n - 1],\n c,\n k = 0;\n\n while (++i < n) {\n a = b;\n b = polygon[i];\n k += c = a[0] * b[1] - b[0] * a[1];\n x += (a[0] + b[0]) * c;\n y += (a[1] + b[1]) * c;\n }\n\n return k *= 3, [x / k, y / k];\n }\n\n // Returns the 2D cross product of AB and AC vectors, i.e., the z-component of\n // the 3D cross product in a quadrant I Cartesian coordinate system (+x is\n // right, +y is up). Returns a positive value if ABC is counter-clockwise,\n // negative if clockwise, and zero if the points are collinear.\n function cross(a, b, c) {\n return (b[0] - a[0]) * (c[1] - a[1]) - (b[1] - a[1]) * (c[0] - a[0]);\n }\n\n function lexicographicOrder(a, b) {\n return a[0] - b[0] || a[1] - b[1];\n }\n\n // Computes the upper convex hull per the monotone chain algorithm.\n // Assumes points.length >= 3, is sorted by x, unique in y.\n // Returns an array of indices into points in left-to-right order.\n function computeUpperHullIndexes(points) {\n var n = points.length,\n indexes = [0, 1],\n size = 2;\n\n for (var i = 2; i < n; ++i) {\n while (size > 1 && cross(points[indexes[size - 2]], points[indexes[size - 1]], points[i]) <= 0) --size;\n indexes[size++] = i;\n }\n\n return indexes.slice(0, size); // remove popped points\n }\n\n function hull(points) {\n if ((n = points.length) < 3) return null;\n\n var i,\n n,\n sortedPoints = new Array(n),\n flippedPoints = new Array(n);\n\n for (i = 0; i < n; ++i) sortedPoints[i] = [+points[i][0], +points[i][1], i];\n sortedPoints.sort(lexicographicOrder);\n for (i = 0; i < n; ++i) flippedPoints[i] = [sortedPoints[i][0], -sortedPoints[i][1]];\n\n var upperIndexes = computeUpperHullIndexes(sortedPoints),\n lowerIndexes = computeUpperHullIndexes(flippedPoints);\n\n // Construct the hull polygon, removing possible duplicate endpoints.\n var skipLeft = lowerIndexes[0] === upperIndexes[0],\n skipRight = lowerIndexes[lowerIndexes.length - 1] === upperIndexes[upperIndexes.length - 1],\n hull = [];\n\n // Add upper hull in right-to-l order.\n // Then add lower hull in left-to-right order.\n for (i = upperIndexes.length - 1; i >= 0; --i) hull.push(points[sortedPoints[upperIndexes[i]][2]]);\n for (i = +skipLeft; i < lowerIndexes.length - skipRight; ++i) hull.push(points[sortedPoints[lowerIndexes[i]][2]]);\n\n return hull;\n }\n\n function contains(polygon, point) {\n var n = polygon.length,\n p = polygon[n - 1],\n x = point[0], y = point[1],\n x0 = p[0], y0 = p[1],\n x1, y1,\n inside = false;\n\n for (var i = 0; i < n; ++i) {\n p = polygon[i], x1 = p[0], y1 = p[1];\n if (((y1 > y) !== (y0 > y)) && (x < (x0 - x1) * (y - y1) / (y0 - y1) + x1)) inside = !inside;\n x0 = x1, y0 = y1;\n }\n\n return inside;\n }\n\n function length$1(polygon) {\n var i = -1,\n n = polygon.length,\n b = polygon[n - 1],\n xa,\n ya,\n xb = b[0],\n yb = b[1],\n perimeter = 0;\n\n while (++i < n) {\n xa = xb;\n ya = yb;\n b = polygon[i];\n xb = b[0];\n yb = b[1];\n xa -= xb;\n ya -= yb;\n perimeter += Math.sqrt(xa * xa + ya * ya);\n }\n\n return perimeter;\n }\n\nvar pi$1 = Math.PI;\nvar tau$1 = 2 * pi$1;\n var epsilon = 1e-6;\n var tauEpsilon = tau$1 - epsilon;\n function Path() {\n this._x0 = this._y0 = // start of current subpath\n this._x1 = this._y1 = null; // end of current subpath\n this._ = [];\n }\n\n function path() {\n return new Path;\n }\n\n Path.prototype = path.prototype = {\n constructor: Path,\n moveTo: function(x, y) {\n this._.push(\"M\", this._x0 = this._x1 = +x, \",\", this._y0 = this._y1 = +y);\n },\n closePath: function() {\n if (this._x1 !== null) {\n this._x1 = this._x0, this._y1 = this._y0;\n this._.push(\"Z\");\n }\n },\n lineTo: function(x, y) {\n this._.push(\"L\", this._x1 = +x, \",\", this._y1 = +y);\n },\n quadraticCurveTo: function(x1, y1, x, y) {\n this._.push(\"Q\", +x1, \",\", +y1, \",\", this._x1 = +x, \",\", this._y1 = +y);\n },\n bezierCurveTo: function(x1, y1, x2, y2, x, y) {\n this._.push(\"C\", +x1, \",\", +y1, \",\", +x2, \",\", +y2, \",\", this._x1 = +x, \",\", this._y1 = +y);\n },\n arcTo: function(x1, y1, x2, y2, r) {\n x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r;\n var x0 = this._x1,\n y0 = this._y1,\n x21 = x2 - x1,\n y21 = y2 - y1,\n x01 = x0 - x1,\n y01 = y0 - y1,\n l01_2 = x01 * x01 + y01 * y01;\n\n // Is the radius negative? Error.\n if (r < 0) throw new Error(\"negative radius: \" + r);\n\n // Is this path empty? Move to (x1,y1).\n if (this._x1 === null) {\n this._.push(\n \"M\", this._x1 = x1, \",\", this._y1 = y1\n );\n }\n\n // Or, is (x1,y1) coincident with (x0,y0)? Do nothing.\n else if (!(l01_2 > epsilon));\n\n // Or, are (x0,y0), (x1,y1) and (x2,y2) collinear?\n // Equivalently, is (x1,y1) coincident with (x2,y2)?\n // Or, is the radius zero? Line to (x1,y1).\n else if (!(Math.abs(y01 * x21 - y21 * x01) > epsilon) || !r) {\n this._.push(\n \"L\", this._x1 = x1, \",\", this._y1 = y1\n );\n }\n\n // Otherwise, draw an arc!\n else {\n var x20 = x2 - x0,\n y20 = y2 - y0,\n l21_2 = x21 * x21 + y21 * y21,\n l20_2 = x20 * x20 + y20 * y20,\n l21 = Math.sqrt(l21_2),\n l01 = Math.sqrt(l01_2),\n l = r * Math.tan((pi$1 - Math.acos((l21_2 + l01_2 - l20_2) / (2 * l21 * l01))) / 2),\n t01 = l / l01,\n t21 = l / l21;\n\n // If the start tangent is not coincident with (x0,y0), line to.\n if (Math.abs(t01 - 1) > epsilon) {\n this._.push(\n \"L\", x1 + t01 * x01, \",\", y1 + t01 * y01\n );\n }\n\n this._.push(\n \"A\", r, \",\", r, \",0,0,\", +(y01 * x20 > x01 * y20), \",\", this._x1 = x1 + t21 * x21, \",\", this._y1 = y1 + t21 * y21\n );\n }\n },\n arc: function(x, y, r, a0, a1, ccw) {\n x = +x, y = +y, r = +r;\n var dx = r * Math.cos(a0),\n dy = r * Math.sin(a0),\n x0 = x + dx,\n y0 = y + dy,\n cw = 1 ^ ccw,\n da = ccw ? a0 - a1 : a1 - a0;\n\n // Is the radius negative? Error.\n if (r < 0) throw new Error(\"negative radius: \" + r);\n\n // Is this path empty? Move to (x0,y0).\n if (this._x1 === null) {\n this._.push(\n \"M\", x0, \",\", y0\n );\n }\n\n // Or, is (x0,y0) not coincident with the previous point? Line to (x0,y0).\n else if (Math.abs(this._x1 - x0) > epsilon || Math.abs(this._y1 - y0) > epsilon) {\n this._.push(\n \"L\", x0, \",\", y0\n );\n }\n\n // Is this arc empty? We’re done.\n if (!r) return;\n\n // Is this a complete circle? Draw two arcs to complete the circle.\n if (da > tauEpsilon) {\n this._.push(\n \"A\", r, \",\", r, \",0,1,\", cw, \",\", x - dx, \",\", y - dy,\n \"A\", r, \",\", r, \",0,1,\", cw, \",\", this._x1 = x0, \",\", this._y1 = y0\n );\n }\n\n // Otherwise, draw an arc!\n else {\n if (da < 0) da = da % tau$1 + tau$1;\n this._.push(\n \"A\", r, \",\", r, \",0,\", +(da >= pi$1), \",\", cw, \",\", this._x1 = x + r * Math.cos(a1), \",\", this._y1 = y + r * Math.sin(a1)\n );\n }\n },\n rect: function(x, y, w, h) {\n this._.push(\"M\", this._x0 = this._x1 = +x, \",\", this._y0 = this._y1 = +y, \"h\", +w, \"v\", +h, \"h\", -w, \"Z\");\n },\n toString: function() {\n return this._.join(\"\");\n }\n };\n\n function tree_add(d) {\n var x = +this._x.call(null, d),\n y = +this._y.call(null, d);\n return add(this.cover(x, y), x, y, d);\n }\n\n function add(tree, x, y, d) {\n if (isNaN(x) || isNaN(y)) return tree; // ignore invalid points\n\n var parent,\n node = tree._root,\n leaf = {data: d},\n x0 = tree._x0,\n y0 = tree._y0,\n x1 = tree._x1,\n y1 = tree._y1,\n xm,\n ym,\n xp,\n yp,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return tree._root = leaf, tree;\n\n // Find the existing leaf for the new point, or add it.\n while (node.length) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (parent = node, !(node = node[i = bottom << 1 | right])) return parent[i] = leaf, tree;\n }\n\n // Is the new point is exactly coincident with the existing point?\n xp = +tree._x.call(null, node.data);\n yp = +tree._y.call(null, node.data);\n if (x === xp && y === yp) return leaf.next = node, parent ? parent[i] = leaf : tree._root = leaf, tree;\n\n // Otherwise, split the leaf node until the old and new point are separated.\n do {\n parent = parent ? parent[i] = new Array(4) : tree._root = new Array(4);\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n } while ((i = bottom << 1 | right) === (j = (yp >= ym) << 1 | (xp >= xm)));\n return parent[j] = node, parent[i] = leaf, tree;\n }\n\n function addAll(data) {\n var d, i, n = data.length,\n x,\n y,\n xz = new Array(n),\n yz = new Array(n),\n x0 = Infinity,\n y0 = Infinity,\n x1 = -Infinity,\n y1 = -Infinity;\n\n // Compute the points and their extent.\n for (i = 0; i < n; ++i) {\n if (isNaN(x = +this._x.call(null, d = data[i])) || isNaN(y = +this._y.call(null, d))) continue;\n xz[i] = x;\n yz[i] = y;\n if (x < x0) x0 = x;\n if (x > x1) x1 = x;\n if (y < y0) y0 = y;\n if (y > y1) y1 = y;\n }\n\n // If there were no (valid) points, inherit the existing extent.\n if (x1 < x0) x0 = this._x0, x1 = this._x1;\n if (y1 < y0) y0 = this._y0, y1 = this._y1;\n\n // Expand the tree to cover the new points.\n this.cover(x0, y0).cover(x1, y1);\n\n // Add the new points.\n for (i = 0; i < n; ++i) {\n add(this, xz[i], yz[i], data[i]);\n }\n\n return this;\n }\n\n function tree_cover(x, y) {\n if (isNaN(x = +x) || isNaN(y = +y)) return this; // ignore invalid points\n\n var x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1;\n\n // If the quadtree has no extent, initialize them.\n // Integer extent are necessary so that if we later double the extent,\n // the existing quadrant boundaries don’t change due to floating point error!\n if (isNaN(x0)) {\n x1 = (x0 = Math.floor(x)) + 1;\n y1 = (y0 = Math.floor(y)) + 1;\n }\n\n // Otherwise, double repeatedly to cover.\n else if (x0 > x || x > x1 || y0 > y || y > y1) {\n var z = x1 - x0,\n node = this._root,\n parent,\n i;\n\n switch (i = (y < (y0 + y1) / 2) << 1 | (x < (x0 + x1) / 2)) {\n case 0: {\n do parent = new Array(4), parent[i] = node, node = parent;\n while (z *= 2, x1 = x0 + z, y1 = y0 + z, x > x1 || y > y1);\n break;\n }\n case 1: {\n do parent = new Array(4), parent[i] = node, node = parent;\n while (z *= 2, x0 = x1 - z, y1 = y0 + z, x0 > x || y > y1);\n break;\n }\n case 2: {\n do parent = new Array(4), parent[i] = node, node = parent;\n while (z *= 2, x1 = x0 + z, y0 = y1 - z, x > x1 || y0 > y);\n break;\n }\n case 3: {\n do parent = new Array(4), parent[i] = node, node = parent;\n while (z *= 2, x0 = x1 - z, y0 = y1 - z, x0 > x || y0 > y);\n break;\n }\n }\n\n if (this._root && this._root.length) this._root = node;\n }\n\n // If the quadtree covers the point already, just return.\n else return this;\n\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n return this;\n }\n\n function tree_data() {\n var data = [];\n this.visit(function(node) {\n if (!node.length) do data.push(node.data); while (node = node.next)\n });\n return data;\n }\n\n function tree_extent(_) {\n return arguments.length\n ? this.cover(+_[0][0], +_[0][1]).cover(+_[1][0], +_[1][1])\n : isNaN(this._x0) ? undefined : [[this._x0, this._y0], [this._x1, this._y1]];\n }\n\n function Quad(node, x0, y0, x1, y1) {\n this.node = node;\n this.x0 = x0;\n this.y0 = y0;\n this.x1 = x1;\n this.y1 = y1;\n }\n\n function tree_find(x, y, radius) {\n var data,\n x0 = this._x0,\n y0 = this._y0,\n x1,\n y1,\n x2,\n y2,\n x3 = this._x1,\n y3 = this._y1,\n quads = [],\n node = this._root,\n q,\n i;\n\n if (node) quads.push(new Quad(node, x0, y0, x3, y3));\n if (radius == null) radius = Infinity;\n else {\n x0 = x - radius, y0 = y - radius;\n x3 = x + radius, y3 = y + radius;\n radius *= radius;\n }\n\n while (q = quads.pop()) {\n\n // Stop searching if this quadrant can’t contain a closer node.\n if (!(node = q.node)\n || (x1 = q.x0) > x3\n || (y1 = q.y0) > y3\n || (x2 = q.x1) < x0\n || (y2 = q.y1) < y0) continue;\n\n // Bisect the current quadrant.\n if (node.length) {\n var xm = (x1 + x2) / 2,\n ym = (y1 + y2) / 2;\n\n quads.push(\n new Quad(node[3], xm, ym, x2, y2),\n new Quad(node[2], x1, ym, xm, y2),\n new Quad(node[1], xm, y1, x2, ym),\n new Quad(node[0], x1, y1, xm, ym)\n );\n\n // Visit the closest quadrant first.\n if (i = (y >= ym) << 1 | (x >= xm)) {\n q = quads[quads.length - 1];\n quads[quads.length - 1] = quads[quads.length - 1 - i];\n quads[quads.length - 1 - i] = q;\n }\n }\n\n // Visit this point. (Visiting coincident points isn’t necessary!)\n else {\n var dx = x - +this._x.call(null, node.data),\n dy = y - +this._y.call(null, node.data),\n d2 = dx * dx + dy * dy;\n if (d2 < radius) {\n var d = Math.sqrt(radius = d2);\n x0 = x - d, y0 = y - d;\n x3 = x + d, y3 = y + d;\n data = node.data;\n }\n }\n }\n\n return data;\n }\n\n function tree_remove(d) {\n if (isNaN(x = +this._x.call(null, d)) || isNaN(y = +this._y.call(null, d))) return this; // ignore invalid points\n\n var parent,\n node = this._root,\n retainer,\n previous,\n next,\n x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1,\n x,\n y,\n xm,\n ym,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return this;\n\n // Find the leaf node for the point.\n // While descending, also retain the deepest parent with a non-removed sibling.\n if (node.length) while (true) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (!(parent = node, node = node[i = bottom << 1 | right])) return this;\n if (!node.length) break;\n if (parent[(i + 1) & 3] || parent[(i + 2) & 3] || parent[(i + 3) & 3]) retainer = parent, j = i;\n }\n\n // Find the point to remove.\n while (node.data !== d) if (!(previous = node, node = node.next)) return this;\n if (next = node.next) delete node.next;\n\n // If there are multiple coincident points, remove just the point.\n if (previous) return (next ? previous.next = next : delete previous.next), this;\n\n // If this is the root point, remove it.\n if (!parent) return this._root = next, this;\n\n // Remove this leaf.\n next ? parent[i] = next : delete parent[i];\n\n // If the parent now contains exactly one leaf, collapse superfluous parents.\n if ((node = parent[0] || parent[1] || parent[2] || parent[3])\n && node === (parent[3] || parent[2] || parent[1] || parent[0])\n && !node.length) {\n if (retainer) retainer[j] = node;\n else this._root = node;\n }\n\n return this;\n }\n\n function removeAll(data) {\n for (var i = 0, n = data.length; i < n; ++i) this.remove(data[i]);\n return this;\n }\n\n function tree_root() {\n return this._root;\n }\n\n function tree_size() {\n var size = 0;\n this.visit(function(node) {\n if (!node.length) do ++size; while (node = node.next)\n });\n return size;\n }\n\n function tree_visit(callback) {\n var quads = [], q, node = this._root, child, x0, y0, x1, y1;\n if (node) quads.push(new Quad(node, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n if (!callback(node = q.node, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1) && node.length) {\n var xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n }\n }\n return this;\n }\n\n function tree_visitAfter(callback) {\n var quads = [], next = [], q;\n if (this._root) quads.push(new Quad(this._root, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n var node = q.node;\n if (node.length) {\n var child, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1, xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n }\n next.push(q);\n }\n while (q = next.pop()) {\n callback(q.node, q.x0, q.y0, q.x1, q.y1);\n }\n return this;\n }\n\n function defaultX(d) {\n return d[0];\n }\n\n function tree_x(_) {\n return arguments.length ? (this._x = _, this) : this._x;\n }\n\n function defaultY(d) {\n return d[1];\n }\n\n function tree_y(_) {\n return arguments.length ? (this._y = _, this) : this._y;\n }\n\n function quadtree(nodes, x, y) {\n var tree = new Quadtree(x == null ? defaultX : x, y == null ? defaultY : y, NaN, NaN, NaN, NaN);\n return nodes == null ? tree : tree.addAll(nodes);\n }\n\n function Quadtree(x, y, x0, y0, x1, y1) {\n this._x = x;\n this._y = y;\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n this._root = undefined;\n }\n\n function leaf_copy(leaf) {\n var copy = {data: leaf.data}, next = copy;\n while (leaf = leaf.next) next = next.next = {data: leaf.data};\n return copy;\n }\n\n var treeProto = quadtree.prototype = Quadtree.prototype;\n\n treeProto.copy = function() {\n var copy = new Quadtree(this._x, this._y, this._x0, this._y0, this._x1, this._y1),\n node = this._root,\n nodes,\n child;\n\n if (!node) return copy;\n\n if (!node.length) return copy._root = leaf_copy(node), copy;\n\n nodes = [{source: node, target: copy._root = new Array(4)}];\n while (node = nodes.pop()) {\n for (var i = 0; i < 4; ++i) {\n if (child = node.source[i]) {\n if (child.length) nodes.push({source: child, target: node.target[i] = new Array(4)});\n else node.target[i] = leaf_copy(child);\n }\n }\n }\n\n return copy;\n };\n\n treeProto.add = tree_add;\n treeProto.addAll = addAll;\n treeProto.cover = tree_cover;\n treeProto.data = tree_data;\n treeProto.extent = tree_extent;\n treeProto.find = tree_find;\n treeProto.remove = tree_remove;\n treeProto.removeAll = removeAll;\n treeProto.root = tree_root;\n treeProto.size = tree_size;\n treeProto.visit = tree_visit;\n treeProto.visitAfter = tree_visitAfter;\n treeProto.x = tree_x;\n treeProto.y = tree_y;\n\n var slice$1 = [].slice;\n\n var noabort = {};\n\n function Queue(size) {\n if (!(size >= 1)) throw new Error;\n this._size = size;\n this._call =\n this._error = null;\n this._tasks = [];\n this._data = [];\n this._waiting =\n this._active =\n this._ended =\n this._start = 0; // inside a synchronous task callback?\n }\n\n Queue.prototype = queue.prototype = {\n constructor: Queue,\n defer: function(callback) {\n if (typeof callback !== \"function\" || this._call) throw new Error;\n if (this._error != null) return this;\n var t = slice$1.call(arguments, 1);\n t.push(callback);\n ++this._waiting, this._tasks.push(t);\n poke(this);\n return this;\n },\n abort: function() {\n if (this._error == null) abort(this, new Error(\"abort\"));\n return this;\n },\n await: function(callback) {\n if (typeof callback !== \"function\" || this._call) throw new Error;\n this._call = function(error, results) { callback.apply(null, [error].concat(results)); };\n maybeNotify(this);\n return this;\n },\n awaitAll: function(callback) {\n if (typeof callback !== \"function\" || this._call) throw new Error;\n this._call = callback;\n maybeNotify(this);\n return this;\n }\n };\n\n function poke(q) {\n if (!q._start) try { start(q); } // let the current task complete\n catch (e) { if (q._tasks[q._ended + q._active - 1]) abort(q, e); } // task errored synchronously\n }\n\n function start(q) {\n while (q._start = q._waiting && q._active < q._size) {\n var i = q._ended + q._active,\n t = q._tasks[i],\n j = t.length - 1,\n c = t[j];\n t[j] = end(q, i);\n --q._waiting, ++q._active;\n t = c.apply(null, t);\n if (!q._tasks[i]) continue; // task finished synchronously\n q._tasks[i] = t || noabort;\n }\n }\n\n function end(q, i) {\n return function(e, r) {\n if (!q._tasks[i]) return; // ignore multiple callbacks\n --q._active, ++q._ended;\n q._tasks[i] = null;\n if (q._error != null) return; // ignore secondary errors\n if (e != null) {\n abort(q, e);\n } else {\n q._data[i] = r;\n if (q._waiting) poke(q);\n else maybeNotify(q);\n }\n };\n }\n\n function abort(q, e) {\n var i = q._tasks.length, t;\n q._error = e; // ignore active callbacks\n q._data = undefined; // allow gc\n q._waiting = NaN; // prevent starting\n\n while (--i >= 0) {\n if (t = q._tasks[i]) {\n q._tasks[i] = null;\n if (t.abort) try { t.abort(); }\n catch (e) { /* ignore */ }\n }\n }\n\n q._active = NaN; // allow notification\n maybeNotify(q);\n }\n\n function maybeNotify(q) {\n if (!q._active && q._call) q._call(q._error, q._data);\n }\n\n function queue(concurrency) {\n return new Queue(arguments.length ? +concurrency : Infinity);\n }\n\n function constant$1(x) {\n return function constant() {\n return x;\n };\n }\n\n var epsilon$1 = 1e-12;\n var pi$2 = Math.PI;\n var halfPi$1 = pi$2 / 2;\n var tau$2 = 2 * pi$2;\n\n function arcInnerRadius(d) {\n return d.innerRadius;\n }\n\n function arcOuterRadius(d) {\n return d.outerRadius;\n }\n\n function arcStartAngle(d) {\n return d.startAngle;\n }\n\n function arcEndAngle(d) {\n return d.endAngle;\n }\n\n function arcPadAngle(d) {\n return d && d.padAngle; // Note: optional!\n }\n\n function asin(x) {\n return x >= 1 ? halfPi$1 : x <= -1 ? -halfPi$1 : Math.asin(x);\n }\n\n function intersect(x0, y0, x1, y1, x2, y2, x3, y3) {\n var x10 = x1 - x0, y10 = y1 - y0,\n x32 = x3 - x2, y32 = y3 - y2,\n t = (x32 * (y0 - y2) - y32 * (x0 - x2)) / (y32 * x10 - x32 * y10);\n return [x0 + t * x10, y0 + t * y10];\n }\n\n // Compute perpendicular offset line of length rc.\n // http://mathworld.wolfram.com/Circle-LineIntersection.html\n function cornerTangents(x0, y0, x1, y1, r1, rc, cw) {\n var x01 = x0 - x1,\n y01 = y0 - y1,\n lo = (cw ? rc : -rc) / Math.sqrt(x01 * x01 + y01 * y01),\n ox = lo * y01,\n oy = -lo * x01,\n x11 = x0 + ox,\n y11 = y0 + oy,\n x10 = x1 + ox,\n y10 = y1 + oy,\n x00 = (x11 + x10) / 2,\n y00 = (y11 + y10) / 2,\n dx = x10 - x11,\n dy = y10 - y11,\n d2 = dx * dx + dy * dy,\n r = r1 - rc,\n D = x11 * y10 - x10 * y11,\n d = (dy < 0 ? -1 : 1) * Math.sqrt(Math.max(0, r * r * d2 - D * D)),\n cx0 = (D * dy - dx * d) / d2,\n cy0 = (-D * dx - dy * d) / d2,\n cx1 = (D * dy + dx * d) / d2,\n cy1 = (-D * dx + dy * d) / d2,\n dx0 = cx0 - x00,\n dy0 = cy0 - y00,\n dx1 = cx1 - x00,\n dy1 = cy1 - y00;\n\n // Pick the closer of the two intersection points.\n // TODO Is there a faster way to determine which intersection to use?\n if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1) cx0 = cx1, cy0 = cy1;\n\n return {\n cx: cx0,\n cy: cy0,\n x01: -ox,\n y01: -oy,\n x11: cx0 * (r1 / r - 1),\n y11: cy0 * (r1 / r - 1)\n };\n }\n\n function arc() {\n var innerRadius = arcInnerRadius,\n outerRadius = arcOuterRadius,\n cornerRadius = constant$1(0),\n padRadius = null,\n startAngle = arcStartAngle,\n endAngle = arcEndAngle,\n padAngle = arcPadAngle,\n context = null;\n\n function arc() {\n var buffer,\n r,\n r0 = +innerRadius.apply(this, arguments),\n r1 = +outerRadius.apply(this, arguments),\n a0 = startAngle.apply(this, arguments) - halfPi$1,\n a1 = endAngle.apply(this, arguments) - halfPi$1,\n da = Math.abs(a1 - a0),\n cw = a1 > a0;\n\n if (!context) context = buffer = path();\n\n // Ensure that the outer radius is always larger than the inner radius.\n if (r1 < r0) r = r1, r1 = r0, r0 = r;\n\n // Is it a point?\n if (!(r1 > epsilon$1)) context.moveTo(0, 0);\n\n // Or is it a circle or annulus?\n else if (da > tau$2 - epsilon$1) {\n context.moveTo(r1 * Math.cos(a0), r1 * Math.sin(a0));\n context.arc(0, 0, r1, a0, a1, !cw);\n if (r0 > epsilon$1) {\n context.moveTo(r0 * Math.cos(a1), r0 * Math.sin(a1));\n context.arc(0, 0, r0, a1, a0, cw);\n }\n }\n\n // Or is it a circular or annular sector?\n else {\n var a01 = a0,\n a11 = a1,\n a00 = a0,\n a10 = a1,\n da0 = da,\n da1 = da,\n ap = padAngle.apply(this, arguments) / 2,\n rp = (ap > epsilon$1) && (padRadius ? +padRadius.apply(this, arguments) : Math.sqrt(r0 * r0 + r1 * r1)),\n rc = Math.min(Math.abs(r1 - r0) / 2, +cornerRadius.apply(this, arguments)),\n rc0 = rc,\n rc1 = rc,\n t0,\n t1;\n\n // Apply padding? Note that since r1 ≥ r0, da1 ≥ da0.\n if (rp > epsilon$1) {\n var p0 = asin(rp / r0 * Math.sin(ap)),\n p1 = asin(rp / r1 * Math.sin(ap));\n if ((da0 -= p0 * 2) > epsilon$1) p0 *= (cw ? 1 : -1), a00 += p0, a10 -= p0;\n else da0 = 0, a00 = a10 = (a0 + a1) / 2;\n if ((da1 -= p1 * 2) > epsilon$1) p1 *= (cw ? 1 : -1), a01 += p1, a11 -= p1;\n else da1 = 0, a01 = a11 = (a0 + a1) / 2;\n }\n\n var x01 = r1 * Math.cos(a01),\n y01 = r1 * Math.sin(a01),\n x10 = r0 * Math.cos(a10),\n y10 = r0 * Math.sin(a10);\n\n // Apply rounded corners?\n if (rc > epsilon$1) {\n var x11 = r1 * Math.cos(a11),\n y11 = r1 * Math.sin(a11),\n x00 = r0 * Math.cos(a00),\n y00 = r0 * Math.sin(a00);\n\n // Restrict the corner radius according to the sector angle.\n if (da < pi$2) {\n var oc = da0 > epsilon$1 ? intersect(x01, y01, x00, y00, x11, y11, x10, y10) : [x10, y10],\n ax = x01 - oc[0],\n ay = y01 - oc[1],\n bx = x11 - oc[0],\n by = y11 - oc[1],\n kc = 1 / Math.sin(Math.acos((ax * bx + ay * by) / (Math.sqrt(ax * ax + ay * ay) * Math.sqrt(bx * bx + by * by))) / 2),\n lc = Math.sqrt(oc[0] * oc[0] + oc[1] * oc[1]);\n rc0 = Math.min(rc, (r0 - lc) / (kc - 1));\n rc1 = Math.min(rc, (r1 - lc) / (kc + 1));\n }\n }\n\n // Is the sector collapsed to a line?\n if (!(da1 > epsilon$1)) context.moveTo(x01, y01);\n\n // Does the sector’s outer ring have rounded corners?\n else if (rc1 > epsilon$1) {\n t0 = cornerTangents(x00, y00, x01, y01, r1, rc1, cw);\n t1 = cornerTangents(x11, y11, x10, y10, r1, rc1, cw);\n\n context.moveTo(t0.cx + t0.x01, t0.cy + t0.y01);\n\n // Have the corners merged?\n if (rc1 < rc) context.arc(t0.cx, t0.cy, rc1, Math.atan2(t0.y01, t0.x01), Math.atan2(t1.y01, t1.x01), !cw);\n\n // Otherwise, draw the two corners and the ring.\n else {\n context.arc(t0.cx, t0.cy, rc1, Math.atan2(t0.y01, t0.x01), Math.atan2(t0.y11, t0.x11), !cw);\n context.arc(0, 0, r1, Math.atan2(t0.cy + t0.y11, t0.cx + t0.x11), Math.atan2(t1.cy + t1.y11, t1.cx + t1.x11), !cw);\n context.arc(t1.cx, t1.cy, rc1, Math.atan2(t1.y11, t1.x11), Math.atan2(t1.y01, t1.x01), !cw);\n }\n }\n\n // Or is the outer ring just a circular arc?\n else context.moveTo(x01, y01), context.arc(0, 0, r1, a01, a11, !cw);\n\n // Is there no inner ring, and it’s a circular sector?\n // Or perhaps it’s an annular sector collapsed due to padding?\n if (!(r0 > epsilon$1) || !(da0 > epsilon$1)) context.lineTo(x10, y10);\n\n // Does the sector’s inner ring (or point) have rounded corners?\n else if (rc0 > epsilon$1) {\n t0 = cornerTangents(x10, y10, x11, y11, r0, -rc0, cw);\n t1 = cornerTangents(x01, y01, x00, y00, r0, -rc0, cw);\n\n context.lineTo(t0.cx + t0.x01, t0.cy + t0.y01);\n\n // Have the corners merged?\n if (rc0 < rc) context.arc(t0.cx, t0.cy, rc0, Math.atan2(t0.y01, t0.x01), Math.atan2(t1.y01, t1.x01), !cw);\n\n // Otherwise, draw the two corners and the ring.\n else {\n context.arc(t0.cx, t0.cy, rc0, Math.atan2(t0.y01, t0.x01), Math.atan2(t0.y11, t0.x11), !cw);\n context.arc(0, 0, r0, Math.atan2(t0.cy + t0.y11, t0.cx + t0.x11), Math.atan2(t1.cy + t1.y11, t1.cx + t1.x11), cw);\n context.arc(t1.cx, t1.cy, rc0, Math.atan2(t1.y11, t1.x11), Math.atan2(t1.y01, t1.x01), !cw);\n }\n }\n\n // Or is the inner ring just a circular arc?\n else context.arc(0, 0, r0, a10, a00, cw);\n }\n\n context.closePath();\n\n if (buffer) return context = null, buffer + \"\" || null;\n }\n\n arc.centroid = function() {\n var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2,\n a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - pi$2 / 2;\n return [Math.cos(a) * r, Math.sin(a) * r];\n };\n\n arc.innerRadius = function(_) {\n return arguments.length ? (innerRadius = typeof _ === \"function\" ? _ : constant$1(+_), arc) : innerRadius;\n };\n\n arc.outerRadius = function(_) {\n return arguments.length ? (outerRadius = typeof _ === \"function\" ? _ : constant$1(+_), arc) : outerRadius;\n };\n\n arc.cornerRadius = function(_) {\n return arguments.length ? (cornerRadius = typeof _ === \"function\" ? _ : constant$1(+_), arc) : cornerRadius;\n };\n\n arc.padRadius = function(_) {\n return arguments.length ? (padRadius = _ == null ? null : typeof _ === \"function\" ? _ : constant$1(+_), arc) : padRadius;\n };\n\n arc.startAngle = function(_) {\n return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant$1(+_), arc) : startAngle;\n };\n\n arc.endAngle = function(_) {\n return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant$1(+_), arc) : endAngle;\n };\n\n arc.padAngle = function(_) {\n return arguments.length ? (padAngle = typeof _ === \"function\" ? _ : constant$1(+_), arc) : padAngle;\n };\n\n arc.context = function(_) {\n return arguments.length ? ((context = _ == null ? null : _), arc) : context;\n };\n\n return arc;\n }\n\n function Linear(context) {\n this._context = context;\n }\n\n Linear.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; // proceed\n default: this._context.lineTo(x, y); break;\n }\n }\n };\n\n function curveLinear(context) {\n return new Linear(context);\n }\n\n function x(p) {\n return p[0];\n }\n\n function y(p) {\n return p[1];\n }\n\n function line() {\n var x$$ = x,\n y$$ = y,\n defined = constant$1(true),\n context = null,\n curve = curveLinear,\n output = null;\n\n function line(data) {\n var i,\n n = data.length,\n d,\n defined0 = false,\n buffer;\n\n if (context == null) output = curve(buffer = path());\n\n for (i = 0; i <= n; ++i) {\n if (!(i < n && defined(d = data[i], i, data)) === defined0) {\n if (defined0 = !defined0) output.lineStart();\n else output.lineEnd();\n }\n if (defined0) output.point(+x$$(d, i, data), +y$$(d, i, data));\n }\n\n if (buffer) return output = null, buffer + \"\" || null;\n }\n\n line.x = function(_) {\n return arguments.length ? (x$$ = typeof _ === \"function\" ? _ : constant$1(+_), line) : x$$;\n };\n\n line.y = function(_) {\n return arguments.length ? (y$$ = typeof _ === \"function\" ? _ : constant$1(+_), line) : y$$;\n };\n\n line.defined = function(_) {\n return arguments.length ? (defined = typeof _ === \"function\" ? _ : constant$1(!!_), line) : defined;\n };\n\n line.curve = function(_) {\n return arguments.length ? (curve = _, context != null && (output = curve(context)), line) : curve;\n };\n\n line.context = function(_) {\n return arguments.length ? (_ == null ? context = output = null : output = curve(context = _), line) : context;\n };\n\n return line;\n }\n\n function area$1() {\n var x0 = x,\n x1 = null,\n y0 = constant$1(0),\n y1 = y,\n defined = constant$1(true),\n context = null,\n curve = curveLinear,\n output = null;\n\n function area(data) {\n var i,\n j,\n k,\n n = data.length,\n d,\n defined0 = false,\n buffer,\n x0z = new Array(n),\n y0z = new Array(n);\n\n if (context == null) output = curve(buffer = path());\n\n for (i = 0; i <= n; ++i) {\n if (!(i < n && defined(d = data[i], i, data)) === defined0) {\n if (defined0 = !defined0) {\n j = i;\n output.areaStart();\n output.lineStart();\n } else {\n output.lineEnd();\n output.lineStart();\n for (k = i - 1; k >= j; --k) {\n output.point(x0z[k], y0z[k]);\n }\n output.lineEnd();\n output.areaEnd();\n }\n }\n if (defined0) {\n x0z[i] = +x0(d, i, data), y0z[i] = +y0(d, i, data);\n output.point(x1 ? +x1(d, i, data) : x0z[i], y1 ? +y1(d, i, data) : y0z[i]);\n }\n }\n\n if (buffer) return output = null, buffer + \"\" || null;\n }\n\n function arealine() {\n return line().defined(defined).curve(curve).context(context);\n }\n\n area.x = function(_) {\n return arguments.length ? (x0 = typeof _ === \"function\" ? _ : constant$1(+_), x1 = null, area) : x0;\n };\n\n area.x0 = function(_) {\n return arguments.length ? (x0 = typeof _ === \"function\" ? _ : constant$1(+_), area) : x0;\n };\n\n area.x1 = function(_) {\n return arguments.length ? (x1 = _ == null ? null : typeof _ === \"function\" ? _ : constant$1(+_), area) : x1;\n };\n\n area.y = function(_) {\n return arguments.length ? (y0 = typeof _ === \"function\" ? _ : constant$1(+_), y1 = null, area) : y0;\n };\n\n area.y0 = function(_) {\n return arguments.length ? (y0 = typeof _ === \"function\" ? _ : constant$1(+_), area) : y0;\n };\n\n area.y1 = function(_) {\n return arguments.length ? (y1 = _ == null ? null : typeof _ === \"function\" ? _ : constant$1(+_), area) : y1;\n };\n\n area.lineX0 =\n area.lineY0 = function() {\n return arealine().x(x0).y(y0);\n };\n\n area.lineY1 = function() {\n return arealine().x(x0).y(y1);\n };\n\n area.lineX1 = function() {\n return arealine().x(x1).y(y0);\n };\n\n area.defined = function(_) {\n return arguments.length ? (defined = typeof _ === \"function\" ? _ : constant$1(!!_), area) : defined;\n };\n\n area.curve = function(_) {\n return arguments.length ? (curve = _, context != null && (output = curve(context)), area) : curve;\n };\n\n area.context = function(_) {\n return arguments.length ? (_ == null ? context = output = null : output = curve(context = _), area) : context;\n };\n\n return area;\n }\n\n function descending$1(a, b) {\n return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;\n }\n\n function identity$1(d) {\n return d;\n }\n\n function pie() {\n var value = identity$1,\n sortValues = descending$1,\n sort = null,\n startAngle = constant$1(0),\n endAngle = constant$1(tau$2),\n padAngle = constant$1(0);\n\n function pie(data) {\n var i,\n n = data.length,\n j,\n k,\n sum = 0,\n index = new Array(n),\n arcs = new Array(n),\n a0 = +startAngle.apply(this, arguments),\n da = Math.min(tau$2, Math.max(-tau$2, endAngle.apply(this, arguments) - a0)),\n a1,\n p = Math.min(Math.abs(da) / n, padAngle.apply(this, arguments)),\n pa = p * (da < 0 ? -1 : 1),\n v;\n\n for (i = 0; i < n; ++i) {\n if ((v = arcs[index[i] = i] = +value(data[i], i, data)) > 0) {\n sum += v;\n }\n }\n\n // Optionally sort the arcs by previously-computed values or by data.\n if (sortValues != null) index.sort(function(i, j) { return sortValues(arcs[i], arcs[j]); });\n else if (sort != null) index.sort(function(i, j) { return sort(data[i], data[j]); });\n\n // Compute the arcs! They are stored in the original data's order.\n for (i = 0, k = sum ? (da - n * pa) / sum : 0; i < n; ++i, a0 = a1) {\n j = index[i], v = arcs[j], a1 = a0 + (v > 0 ? v * k : 0) + pa, arcs[j] = {\n data: data[j],\n index: i,\n value: v,\n startAngle: a0,\n endAngle: a1,\n padAngle: p\n };\n }\n\n return arcs;\n }\n\n pie.value = function(_) {\n return arguments.length ? (value = typeof _ === \"function\" ? _ : constant$1(+_), pie) : value;\n };\n\n pie.sortValues = function(_) {\n return arguments.length ? (sortValues = _, sort = null, pie) : sortValues;\n };\n\n pie.sort = function(_) {\n return arguments.length ? (sort = _, sortValues = null, pie) : sort;\n };\n\n pie.startAngle = function(_) {\n return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant$1(+_), pie) : startAngle;\n };\n\n pie.endAngle = function(_) {\n return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant$1(+_), pie) : endAngle;\n };\n\n pie.padAngle = function(_) {\n return arguments.length ? (padAngle = typeof _ === \"function\" ? _ : constant$1(+_), pie) : padAngle;\n };\n\n return pie;\n }\n\n var curveRadialLinear = curveRadial(curveLinear);\n\n function Radial(curve) {\n this._curve = curve;\n }\n\n Radial.prototype = {\n areaStart: function() {\n this._curve.areaStart();\n },\n areaEnd: function() {\n this._curve.areaEnd();\n },\n lineStart: function() {\n this._curve.lineStart();\n },\n lineEnd: function() {\n this._curve.lineEnd();\n },\n point: function(a, r) {\n this._curve.point(r * Math.sin(a), r * -Math.cos(a));\n }\n };\n\n function curveRadial(curve) {\n\n function radial(context) {\n return new Radial(curve(context));\n }\n\n radial._curve = curve;\n\n return radial;\n }\n\n function radialLine(l) {\n var c = l.curve;\n\n l.angle = l.x, delete l.x;\n l.radius = l.y, delete l.y;\n\n l.curve = function(_) {\n return arguments.length ? c(curveRadial(_)) : c()._curve;\n };\n\n return l;\n }\n\n function radialLine$1() {\n return radialLine(line().curve(curveRadialLinear));\n }\n\n function radialArea() {\n var a = area$1().curve(curveRadialLinear),\n c = a.curve,\n x0 = a.lineX0,\n x1 = a.lineX1,\n y0 = a.lineY0,\n y1 = a.lineY1;\n\n a.angle = a.x, delete a.x;\n a.startAngle = a.x0, delete a.x0;\n a.endAngle = a.x1, delete a.x1;\n a.radius = a.y, delete a.y;\n a.innerRadius = a.y0, delete a.y0;\n a.outerRadius = a.y1, delete a.y1;\n a.lineStartAngle = function() { return radialLine(x0()); }, delete a.lineX0;\n a.lineEndAngle = function() { return radialLine(x1()); }, delete a.lineX1;\n a.lineInnerRadius = function() { return radialLine(y0()); }, delete a.lineY0;\n a.lineOuterRadius = function() { return radialLine(y1()); }, delete a.lineY1;\n\n a.curve = function(_) {\n return arguments.length ? c(curveRadial(_)) : c()._curve;\n };\n\n return a;\n }\n\n var circle = {\n draw: function(context, size) {\n var r = Math.sqrt(size / pi$2);\n context.moveTo(r, 0);\n context.arc(0, 0, r, 0, tau$2);\n }\n };\n\n var cross$1 = {\n draw: function(context, size) {\n var r = Math.sqrt(size / 5) / 2;\n context.moveTo(-3 * r, -r);\n context.lineTo(-r, -r);\n context.lineTo(-r, -3 * r);\n context.lineTo(r, -3 * r);\n context.lineTo(r, -r);\n context.lineTo(3 * r, -r);\n context.lineTo(3 * r, r);\n context.lineTo(r, r);\n context.lineTo(r, 3 * r);\n context.lineTo(-r, 3 * r);\n context.lineTo(-r, r);\n context.lineTo(-3 * r, r);\n context.closePath();\n }\n };\n\n var tan30 = Math.sqrt(1 / 3);\n var tan30_2 = tan30 * 2;\n var diamond = {\n draw: function(context, size) {\n var y = Math.sqrt(size / tan30_2),\n x = y * tan30;\n context.moveTo(0, -y);\n context.lineTo(x, 0);\n context.lineTo(0, y);\n context.lineTo(-x, 0);\n context.closePath();\n }\n };\n\n var ka = 0.89081309152928522810;\n var kr = Math.sin(pi$2 / 10) / Math.sin(7 * pi$2 / 10);\n var kx = Math.sin(tau$2 / 10) * kr;\n var ky = -Math.cos(tau$2 / 10) * kr;\n var star = {\n draw: function(context, size) {\n var r = Math.sqrt(size * ka),\n x = kx * r,\n y = ky * r;\n context.moveTo(0, -r);\n context.lineTo(x, y);\n for (var i = 1; i < 5; ++i) {\n var a = tau$2 * i / 5,\n c = Math.cos(a),\n s = Math.sin(a);\n context.lineTo(s * r, -c * r);\n context.lineTo(c * x - s * y, s * x + c * y);\n }\n context.closePath();\n }\n };\n\n var square = {\n draw: function(context, size) {\n var w = Math.sqrt(size),\n x = -w / 2;\n context.rect(x, x, w, w);\n }\n };\n\n var sqrt3 = Math.sqrt(3);\n\n var triangle = {\n draw: function(context, size) {\n var y = -Math.sqrt(size / (sqrt3 * 3));\n context.moveTo(0, y * 2);\n context.lineTo(-sqrt3 * y, -y);\n context.lineTo(sqrt3 * y, -y);\n context.closePath();\n }\n };\n\n var c = -0.5;\n var s = Math.sqrt(3) / 2;\n var k = 1 / Math.sqrt(12);\n var a = (k / 2 + 1) * 3;\n var wye = {\n draw: function(context, size) {\n var r = Math.sqrt(size / a),\n x0 = r / 2,\n y0 = r * k,\n x1 = x0,\n y1 = r * k + r,\n x2 = -x1,\n y2 = y1;\n context.moveTo(x0, y0);\n context.lineTo(x1, y1);\n context.lineTo(x2, y2);\n context.lineTo(c * x0 - s * y0, s * x0 + c * y0);\n context.lineTo(c * x1 - s * y1, s * x1 + c * y1);\n context.lineTo(c * x2 - s * y2, s * x2 + c * y2);\n context.lineTo(c * x0 + s * y0, c * y0 - s * x0);\n context.lineTo(c * x1 + s * y1, c * y1 - s * x1);\n context.lineTo(c * x2 + s * y2, c * y2 - s * x2);\n context.closePath();\n }\n };\n\n var symbols = [\n circle,\n cross$1,\n diamond,\n square,\n star,\n triangle,\n wye\n ];\n\n function symbol() {\n var type = constant$1(circle),\n size = constant$1(64),\n context = null;\n\n function symbol() {\n var buffer;\n if (!context) context = buffer = path();\n type.apply(this, arguments).draw(context, +size.apply(this, arguments));\n if (buffer) return context = null, buffer + \"\" || null;\n }\n\n symbol.type = function(_) {\n return arguments.length ? (type = typeof _ === \"function\" ? _ : constant$1(_), symbol) : type;\n };\n\n symbol.size = function(_) {\n return arguments.length ? (size = typeof _ === \"function\" ? _ : constant$1(+_), symbol) : size;\n };\n\n symbol.context = function(_) {\n return arguments.length ? (context = _ == null ? null : _, symbol) : context;\n };\n\n return symbol;\n }\n\n function noop() {}\n\n function point(that, x, y) {\n that._context.bezierCurveTo(\n (2 * that._x0 + that._x1) / 3,\n (2 * that._y0 + that._y1) / 3,\n (that._x0 + 2 * that._x1) / 3,\n (that._y0 + 2 * that._y1) / 3,\n (that._x0 + 4 * that._x1 + x) / 6,\n (that._y0 + 4 * that._y1 + y) / 6\n );\n }\n\n function Basis(context) {\n this._context = context;\n }\n\n Basis.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 3: point(this, this._x1, this._y1); // proceed\n case 2: this._context.lineTo(this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._context.lineTo((5 * this._x0 + this._x1) / 6, (5 * this._y0 + this._y1) / 6); // proceed\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n };\n\n function basis(context) {\n return new Basis(context);\n }\n\n function BasisClosed(context) {\n this._context = context;\n }\n\n BasisClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x2, this._y2);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.moveTo((this._x2 + 2 * this._x3) / 3, (this._y2 + 2 * this._y3) / 3);\n this._context.lineTo((this._x3 + 2 * this._x2) / 3, (this._y3 + 2 * this._y2) / 3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x2, this._y2);\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x2 = x, this._y2 = y; break;\n case 1: this._point = 2; this._x3 = x, this._y3 = y; break;\n case 2: this._point = 3; this._x4 = x, this._y4 = y; this._context.moveTo((this._x0 + 4 * this._x1 + x) / 6, (this._y0 + 4 * this._y1 + y) / 6); break;\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n };\n\n function basisClosed(context) {\n return new BasisClosed(context);\n }\n\n function BasisOpen(context) {\n this._context = context;\n }\n\n BasisOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; var x0 = (this._x0 + 4 * this._x1 + x) / 6, y0 = (this._y0 + 4 * this._y1 + y) / 6; this._line ? this._context.lineTo(x0, y0) : this._context.moveTo(x0, y0); break;\n case 3: this._point = 4; // proceed\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n };\n\n function basisOpen(context) {\n return new BasisOpen(context);\n }\n\n function Bundle(context, beta) {\n this._basis = new Basis(context);\n this._beta = beta;\n }\n\n Bundle.prototype = {\n lineStart: function() {\n this._x = [];\n this._y = [];\n this._basis.lineStart();\n },\n lineEnd: function() {\n var x = this._x,\n y = this._y,\n j = x.length - 1;\n\n if (j > 0) {\n var x0 = x[0],\n y0 = y[0],\n dx = x[j] - x0,\n dy = y[j] - y0,\n i = -1,\n t;\n\n while (++i <= j) {\n t = i / j;\n this._basis.point(\n this._beta * x[i] + (1 - this._beta) * (x0 + t * dx),\n this._beta * y[i] + (1 - this._beta) * (y0 + t * dy)\n );\n }\n }\n\n this._x = this._y = null;\n this._basis.lineEnd();\n },\n point: function(x, y) {\n this._x.push(+x);\n this._y.push(+y);\n }\n };\n\n var bundle = (function custom(beta) {\n\n function bundle(context) {\n return beta === 1 ? new Basis(context) : new Bundle(context, beta);\n }\n\n bundle.beta = function(beta) {\n return custom(+beta);\n };\n\n return bundle;\n })(0.85);\n\n function point$1(that, x, y) {\n that._context.bezierCurveTo(\n that._x1 + that._k * (that._x2 - that._x0),\n that._y1 + that._k * (that._y2 - that._y0),\n that._x2 + that._k * (that._x1 - x),\n that._y2 + that._k * (that._y1 - y),\n that._x2,\n that._y2\n );\n }\n\n function Cardinal(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n }\n\n Cardinal.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: point$1(this, this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; this._x1 = x, this._y1 = y; break;\n case 2: this._point = 3; // proceed\n default: point$1(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var cardinal = (function custom(tension) {\n\n function cardinal(context) {\n return new Cardinal(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n })(0);\n\n function CardinalClosed(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n }\n\n CardinalClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point$1(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var cardinalClosed = (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalClosed(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n })(0);\n\n function CardinalOpen(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n }\n\n CardinalOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;\n case 3: this._point = 4; // proceed\n default: point$1(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var cardinalOpen = (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalOpen(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n })(0);\n\n function point$2(that, x, y) {\n var x1 = that._x1,\n y1 = that._y1,\n x2 = that._x2,\n y2 = that._y2;\n\n if (that._l01_a > epsilon$1) {\n var a = 2 * that._l01_2a + 3 * that._l01_a * that._l12_a + that._l12_2a,\n n = 3 * that._l01_a * (that._l01_a + that._l12_a);\n x1 = (x1 * a - that._x0 * that._l12_2a + that._x2 * that._l01_2a) / n;\n y1 = (y1 * a - that._y0 * that._l12_2a + that._y2 * that._l01_2a) / n;\n }\n\n if (that._l23_a > epsilon$1) {\n var b = 2 * that._l23_2a + 3 * that._l23_a * that._l12_a + that._l12_2a,\n m = 3 * that._l23_a * (that._l23_a + that._l12_a);\n x2 = (x2 * b + that._x1 * that._l23_2a - x * that._l12_2a) / m;\n y2 = (y2 * b + that._y1 * that._l23_2a - y * that._l12_2a) / m;\n }\n\n that._context.bezierCurveTo(x1, y1, x2, y2, that._x2, that._y2);\n }\n\n function CatmullRom(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n }\n\n CatmullRom.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: this.point(this, this._x2, this._y2); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; // proceed\n default: point$2(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var catmullRom = (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRom(context, alpha) : new Cardinal(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n })(0.5);\n\n function CatmullRomClosed(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n }\n\n CatmullRomClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point$2(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var catmullRomClosed = (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRomClosed(context, alpha) : new CardinalClosed(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n })(0.5);\n\n function CatmullRomOpen(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n }\n\n CatmullRomOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;\n case 3: this._point = 4; // proceed\n default: point$2(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n };\n\n var catmullRomOpen = (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRomOpen(context, alpha) : new CardinalOpen(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n })(0.5);\n\n function LinearClosed(context) {\n this._context = context;\n }\n\n LinearClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._point) this._context.closePath();\n },\n point: function(x, y) {\n x = +x, y = +y;\n if (this._point) this._context.lineTo(x, y);\n else this._point = 1, this._context.moveTo(x, y);\n }\n };\n\n function linearClosed(context) {\n return new LinearClosed(context);\n }\n\n function sign(x) {\n return x < 0 ? -1 : 1;\n }\n\n // Calculate the slopes of the tangents (Hermite-type interpolation) based on\n // the following paper: Steffen, M. 1990. A Simple Method for Monotonic\n // Interpolation in One Dimension. Astronomy and Astrophysics, Vol. 239, NO.\n // NOV(II), P. 443, 1990.\n function slope3(that, x2, y2) {\n var h0 = that._x1 - that._x0,\n h1 = x2 - that._x1,\n s0 = (that._y1 - that._y0) / (h0 || h1 < 0 && -0),\n s1 = (y2 - that._y1) / (h1 || h0 < 0 && -0),\n p = (s0 * h1 + s1 * h0) / (h0 + h1);\n return (sign(s0) + sign(s1)) * Math.min(Math.abs(s0), Math.abs(s1), 0.5 * Math.abs(p)) || 0;\n }\n\n // Calculate a one-sided slope.\n function slope2(that, t) {\n var h = that._x1 - that._x0;\n return h ? (3 * (that._y1 - that._y0) / h - t) / 2 : t;\n }\n\n // According to https://en.wikipedia.org/wiki/Cubic_Hermite_spline#Representations\n // \"you can express cubic Hermite interpolation in terms of cubic Bézier curves\n // with respect to the four values p0, p0 + m0 / 3, p1 - m1 / 3, p1\".\n function point$3(that, t0, t1) {\n var x0 = that._x0,\n y0 = that._y0,\n x1 = that._x1,\n y1 = that._y1,\n dx = (x1 - x0) / 3;\n that._context.bezierCurveTo(x0 + dx, y0 + dx * t0, x1 - dx, y1 - dx * t1, x1, y1);\n }\n\n function MonotoneX(context) {\n this._context = context;\n }\n\n MonotoneX.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 =\n this._t0 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x1, this._y1); break;\n case 3: point$3(this, this._t0, slope2(this, this._t0)); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n var t1 = NaN;\n\n x = +x, y = +y;\n if (x === this._x1 && y === this._y1) return; // Ignore coincident points.\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; point$3(this, slope2(this, t1 = slope3(this, x, y)), t1); break;\n default: point$3(this, this._t0, t1 = slope3(this, x, y)); break;\n }\n\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n this._t0 = t1;\n }\n }\n\n function MonotoneY(context) {\n this._context = new ReflectContext(context);\n }\n\n (MonotoneY.prototype = Object.create(MonotoneX.prototype)).point = function(x, y) {\n MonotoneX.prototype.point.call(this, y, x);\n };\n\n function ReflectContext(context) {\n this._context = context;\n }\n\n ReflectContext.prototype = {\n moveTo: function(x, y) { this._context.moveTo(y, x); },\n closePath: function() { this._context.closePath(); },\n lineTo: function(x, y) { this._context.lineTo(y, x); },\n bezierCurveTo: function(x1, y1, x2, y2, x, y) { this._context.bezierCurveTo(y1, x1, y2, x2, y, x); }\n };\n\n function monotoneX(context) {\n return new MonotoneX(context);\n }\n\n function monotoneY(context) {\n return new MonotoneY(context);\n }\n\n function Natural(context) {\n this._context = context;\n }\n\n Natural.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x = [];\n this._y = [];\n },\n lineEnd: function() {\n var x = this._x,\n y = this._y,\n n = x.length;\n\n if (n) {\n this._line ? this._context.lineTo(x[0], y[0]) : this._context.moveTo(x[0], y[0]);\n if (n === 2) {\n this._context.lineTo(x[1], y[1]);\n } else {\n var px = controlPoints(x),\n py = controlPoints(y);\n for (var i0 = 0, i1 = 1; i1 < n; ++i0, ++i1) {\n this._context.bezierCurveTo(px[0][i0], py[0][i0], px[1][i0], py[1][i0], x[i1], y[i1]);\n }\n }\n }\n\n if (this._line || (this._line !== 0 && n === 1)) this._context.closePath();\n this._line = 1 - this._line;\n this._x = this._y = null;\n },\n point: function(x, y) {\n this._x.push(+x);\n this._y.push(+y);\n }\n };\n\n // See https://www.particleincell.com/2012/bezier-splines/ for derivation.\n function controlPoints(x) {\n var i,\n n = x.length - 1,\n m,\n a = new Array(n),\n b = new Array(n),\n r = new Array(n);\n a[0] = 0, b[0] = 2, r[0] = x[0] + 2 * x[1];\n for (i = 1; i < n - 1; ++i) a[i] = 1, b[i] = 4, r[i] = 4 * x[i] + 2 * x[i + 1];\n a[n - 1] = 2, b[n - 1] = 7, r[n - 1] = 8 * x[n - 1] + x[n];\n for (i = 1; i < n; ++i) m = a[i] / b[i - 1], b[i] -= m, r[i] -= m * r[i - 1];\n a[n - 1] = r[n - 1] / b[n - 1];\n for (i = n - 2; i >= 0; --i) a[i] = (r[i] - a[i + 1]) / b[i];\n b[n - 1] = (x[n] + a[n - 1]) / 2;\n for (i = 0; i < n - 1; ++i) b[i] = 2 * x[i + 1] - a[i + 1];\n return [a, b];\n }\n\n function natural(context) {\n return new Natural(context);\n }\n\n function Step(context, t) {\n this._context = context;\n this._t = t;\n }\n\n Step.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x = this._y = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (0 < this._t && this._t < 1 && this._point === 2) this._context.lineTo(this._x, this._y);\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n if (this._line >= 0) this._t = 1 - this._t, this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; // proceed\n default: {\n if (this._t <= 0) {\n this._context.lineTo(this._x, y);\n this._context.lineTo(x, y);\n } else {\n var x1 = this._x * (1 - this._t) + x * this._t;\n this._context.lineTo(x1, this._y);\n this._context.lineTo(x1, y);\n }\n break;\n }\n }\n this._x = x, this._y = y;\n }\n };\n\n function step(context) {\n return new Step(context, 0.5);\n }\n\n function stepBefore(context) {\n return new Step(context, 0);\n }\n\n function stepAfter(context) {\n return new Step(context, 1);\n }\n\n var slice$2 = Array.prototype.slice;\n\n function none(series, order) {\n if (!((n = series.length) > 1)) return;\n for (var i = 1, s0, s1 = series[order[0]], n, m = s1.length; i < n; ++i) {\n s0 = s1, s1 = series[order[i]];\n for (var j = 0; j < m; ++j) {\n s1[j][1] += s1[j][0] = isNaN(s0[j][1]) ? s0[j][0] : s0[j][1];\n }\n }\n }\n\n function none$1(series) {\n var n = series.length, o = new Array(n);\n while (--n >= 0) o[n] = n;\n return o;\n }\n\n function stackValue(d, key) {\n return d[key];\n }\n\n function stack() {\n var keys = constant$1([]),\n order = none$1,\n offset = none,\n value = stackValue;\n\n function stack(data) {\n var kz = keys.apply(this, arguments),\n i,\n m = data.length,\n n = kz.length,\n sz = new Array(n),\n oz;\n\n for (i = 0; i < n; ++i) {\n for (var ki = kz[i], si = sz[i] = new Array(m), j = 0, sij; j < m; ++j) {\n si[j] = sij = [0, +value(data[j], ki, j, data)];\n sij.data = data[j];\n }\n si.key = ki;\n }\n\n for (i = 0, oz = order(sz); i < n; ++i) {\n sz[oz[i]].index = i;\n }\n\n offset(sz, oz);\n return sz;\n }\n\n stack.keys = function(_) {\n return arguments.length ? (keys = typeof _ === \"function\" ? _ : constant$1(slice$2.call(_)), stack) : keys;\n };\n\n stack.value = function(_) {\n return arguments.length ? (value = typeof _ === \"function\" ? _ : constant$1(+_), stack) : value;\n };\n\n stack.order = function(_) {\n return arguments.length ? (order = _ == null ? none$1 : typeof _ === \"function\" ? _ : constant$1(slice$2.call(_)), stack) : order;\n };\n\n stack.offset = function(_) {\n return arguments.length ? (offset = _ == null ? none : _, stack) : offset;\n };\n\n return stack;\n }\n\n function expand(series, order) {\n if (!((n = series.length) > 0)) return;\n for (var i, n, j = 0, m = series[0].length, y; j < m; ++j) {\n for (y = i = 0; i < n; ++i) y += series[i][j][1] || 0;\n if (y) for (i = 0; i < n; ++i) series[i][j][1] /= y;\n }\n none(series, order);\n }\n\n function silhouette(series, order) {\n if (!((n = series.length) > 0)) return;\n for (var j = 0, s0 = series[order[0]], n, m = s0.length; j < m; ++j) {\n for (var i = 0, y = 0; i < n; ++i) y += series[i][j][1] || 0;\n s0[j][1] += s0[j][0] = -y / 2;\n }\n none(series, order);\n }\n\n function wiggle(series, order) {\n if (!((n = series.length) > 0) || !((m = (s0 = series[order[0]]).length) > 0)) return;\n for (var y = 0, j = 1, s0, m, n; j < m; ++j) {\n for (var i = 0, s1 = 0, s2 = 0; i < n; ++i) {\n var si = series[order[i]],\n sij0 = si[j][1] || 0,\n sij1 = si[j - 1][1] || 0,\n s3 = (sij0 - sij1) / 2;\n for (var k = 0; k < i; ++k) {\n var sk = series[order[k]],\n skj0 = sk[j][1] || 0,\n skj1 = sk[j - 1][1] || 0;\n s3 += skj0 - skj1;\n }\n s1 += sij0, s2 += s3 * sij0;\n }\n s0[j - 1][1] += s0[j - 1][0] = y;\n if (s1) y -= s2 / s1;\n }\n s0[j - 1][1] += s0[j - 1][0] = y;\n none(series, order);\n }\n\n function ascending$1(series) {\n var sums = series.map(sum$1);\n return none$1(series).sort(function(a, b) { return sums[a] - sums[b]; });\n }\n\n function sum$1(series) {\n var s = 0, i = -1, n = series.length, v;\n while (++i < n) if (v = +series[i][1]) s += v;\n return s;\n }\n\n function descending$2(series) {\n return ascending$1(series).reverse();\n }\n\n function insideOut(series) {\n var n = series.length,\n i,\n j,\n sums = series.map(sum$1),\n order = none$1(series).sort(function(a, b) { return sums[b] - sums[a]; }),\n top = 0,\n bottom = 0,\n tops = [],\n bottoms = [];\n\n for (i = 0; i < n; ++i) {\n j = order[i];\n if (top < bottom) {\n top += sums[j];\n tops.push(j);\n } else {\n bottom += sums[j];\n bottoms.push(j);\n }\n }\n\n return bottoms.reverse().concat(tops);\n }\n\n function reverse(series) {\n return none$1(series).reverse();\n }\n\n function define(constructor, factory, prototype) {\n constructor.prototype = factory.prototype = prototype;\n prototype.constructor = constructor;\n }\n\n function extend(parent, definition) {\n var prototype = Object.create(parent.prototype);\n for (var key in definition) prototype[key] = definition[key];\n return prototype;\n }\n\n function Color() {}\n\n var darker = 0.7;\n var brighter = 1 / darker;\n\n var reHex3 = /^#([0-9a-f]{3})$/;\n var reHex6 = /^#([0-9a-f]{6})$/;\n var reRgbInteger = /^rgb\\(\\s*([-+]?\\d+)\\s*,\\s*([-+]?\\d+)\\s*,\\s*([-+]?\\d+)\\s*\\)$/;\n var reRgbPercent = /^rgb\\(\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*\\)$/;\n var reRgbaInteger = /^rgba\\(\\s*([-+]?\\d+)\\s*,\\s*([-+]?\\d+)\\s*,\\s*([-+]?\\d+)\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)\\s*\\)$/;\n var reRgbaPercent = /^rgba\\(\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)\\s*\\)$/;\n var reHslPercent = /^hsl\\(\\s*([-+]?\\d+(?:\\.\\d+)?)\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*\\)$/;\n var reHslaPercent = /^hsla\\(\\s*([-+]?\\d+(?:\\.\\d+)?)\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)%\\s*,\\s*([-+]?\\d+(?:\\.\\d+)?)\\s*\\)$/;\n var named = {\n aliceblue: 0xf0f8ff,\n antiquewhite: 0xfaebd7,\n aqua: 0x00ffff,\n aquamarine: 0x7fffd4,\n azure: 0xf0ffff,\n beige: 0xf5f5dc,\n bisque: 0xffe4c4,\n black: 0x000000,\n blanchedalmond: 0xffebcd,\n blue: 0x0000ff,\n blueviolet: 0x8a2be2,\n brown: 0xa52a2a,\n burlywood: 0xdeb887,\n cadetblue: 0x5f9ea0,\n chartreuse: 0x7fff00,\n chocolate: 0xd2691e,\n coral: 0xff7f50,\n cornflowerblue: 0x6495ed,\n cornsilk: 0xfff8dc,\n crimson: 0xdc143c,\n cyan: 0x00ffff,\n darkblue: 0x00008b,\n darkcyan: 0x008b8b,\n darkgoldenrod: 0xb8860b,\n darkgray: 0xa9a9a9,\n darkgreen: 0x006400,\n darkgrey: 0xa9a9a9,\n darkkhaki: 0xbdb76b,\n darkmagenta: 0x8b008b,\n darkolivegreen: 0x556b2f,\n darkorange: 0xff8c00,\n darkorchid: 0x9932cc,\n darkred: 0x8b0000,\n darksalmon: 0xe9967a,\n darkseagreen: 0x8fbc8f,\n darkslateblue: 0x483d8b,\n darkslategray: 0x2f4f4f,\n darkslategrey: 0x2f4f4f,\n darkturquoise: 0x00ced1,\n darkviolet: 0x9400d3,\n deeppink: 0xff1493,\n deepskyblue: 0x00bfff,\n dimgray: 0x696969,\n dimgrey: 0x696969,\n dodgerblue: 0x1e90ff,\n firebrick: 0xb22222,\n floralwhite: 0xfffaf0,\n forestgreen: 0x228b22,\n fuchsia: 0xff00ff,\n gainsboro: 0xdcdcdc,\n ghostwhite: 0xf8f8ff,\n gold: 0xffd700,\n goldenrod: 0xdaa520,\n gray: 0x808080,\n green: 0x008000,\n greenyellow: 0xadff2f,\n grey: 0x808080,\n honeydew: 0xf0fff0,\n hotpink: 0xff69b4,\n indianred: 0xcd5c5c,\n indigo: 0x4b0082,\n ivory: 0xfffff0,\n khaki: 0xf0e68c,\n lavender: 0xe6e6fa,\n lavenderblush: 0xfff0f5,\n lawngreen: 0x7cfc00,\n lemonchiffon: 0xfffacd,\n lightblue: 0xadd8e6,\n lightcoral: 0xf08080,\n lightcyan: 0xe0ffff,\n lightgoldenrodyellow: 0xfafad2,\n lightgray: 0xd3d3d3,\n lightgreen: 0x90ee90,\n lightgrey: 0xd3d3d3,\n lightpink: 0xffb6c1,\n lightsalmon: 0xffa07a,\n lightseagreen: 0x20b2aa,\n lightskyblue: 0x87cefa,\n lightslategray: 0x778899,\n lightslategrey: 0x778899,\n lightsteelblue: 0xb0c4de,\n lightyellow: 0xffffe0,\n lime: 0x00ff00,\n limegreen: 0x32cd32,\n linen: 0xfaf0e6,\n magenta: 0xff00ff,\n maroon: 0x800000,\n mediumaquamarine: 0x66cdaa,\n mediumblue: 0x0000cd,\n mediumorchid: 0xba55d3,\n mediumpurple: 0x9370db,\n mediumseagreen: 0x3cb371,\n mediumslateblue: 0x7b68ee,\n mediumspringgreen: 0x00fa9a,\n mediumturquoise: 0x48d1cc,\n mediumvioletred: 0xc71585,\n midnightblue: 0x191970,\n mintcream: 0xf5fffa,\n mistyrose: 0xffe4e1,\n moccasin: 0xffe4b5,\n navajowhite: 0xffdead,\n navy: 0x000080,\n oldlace: 0xfdf5e6,\n olive: 0x808000,\n olivedrab: 0x6b8e23,\n orange: 0xffa500,\n orangered: 0xff4500,\n orchid: 0xda70d6,\n palegoldenrod: 0xeee8aa,\n palegreen: 0x98fb98,\n paleturquoise: 0xafeeee,\n palevioletred: 0xdb7093,\n papayawhip: 0xffefd5,\n peachpuff: 0xffdab9,\n peru: 0xcd853f,\n pink: 0xffc0cb,\n plum: 0xdda0dd,\n powderblue: 0xb0e0e6,\n purple: 0x800080,\n rebeccapurple: 0x663399,\n red: 0xff0000,\n rosybrown: 0xbc8f8f,\n royalblue: 0x4169e1,\n saddlebrown: 0x8b4513,\n salmon: 0xfa8072,\n sandybrown: 0xf4a460,\n seagreen: 0x2e8b57,\n seashell: 0xfff5ee,\n sienna: 0xa0522d,\n silver: 0xc0c0c0,\n skyblue: 0x87ceeb,\n slateblue: 0x6a5acd,\n slategray: 0x708090,\n slategrey: 0x708090,\n snow: 0xfffafa,\n springgreen: 0x00ff7f,\n steelblue: 0x4682b4,\n tan: 0xd2b48c,\n teal: 0x008080,\n thistle: 0xd8bfd8,\n tomato: 0xff6347,\n turquoise: 0x40e0d0,\n violet: 0xee82ee,\n wheat: 0xf5deb3,\n white: 0xffffff,\n whitesmoke: 0xf5f5f5,\n yellow: 0xffff00,\n yellowgreen: 0x9acd32\n };\n\n define(Color, color, {\n displayable: function() {\n return this.rgb().displayable();\n },\n toString: function() {\n return this.rgb() + \"\";\n }\n });\n\n function color(format) {\n var m;\n format = (format + \"\").trim().toLowerCase();\n return (m = reHex3.exec(format)) ? (m = parseInt(m[1], 16), new Rgb((m >> 8 & 0xf) | (m >> 4 & 0x0f0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1)) // #f00\n : (m = reHex6.exec(format)) ? rgbn(parseInt(m[1], 16)) // #ff0000\n : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)\n : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)\n : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)\n : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)\n : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)\n : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)\n : named.hasOwnProperty(format) ? rgbn(named[format])\n : format === \"transparent\" ? new Rgb(NaN, NaN, NaN, 0)\n : null;\n }\n\n function rgbn(n) {\n return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);\n }\n\n function rgba(r, g, b, a) {\n if (a <= 0) r = g = b = NaN;\n return new Rgb(r, g, b, a);\n }\n\n function rgbConvert(o) {\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Rgb;\n o = o.rgb();\n return new Rgb(o.r, o.g, o.b, o.opacity);\n }\n\n function colorRgb(r, g, b, opacity) {\n return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);\n }\n\n function Rgb(r, g, b, opacity) {\n this.r = +r;\n this.g = +g;\n this.b = +b;\n this.opacity = +opacity;\n }\n\n define(Rgb, colorRgb, extend(Color, {\n brighter: function(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n darker: function(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n rgb: function() {\n return this;\n },\n displayable: function() {\n return (0 <= this.r && this.r <= 255)\n && (0 <= this.g && this.g <= 255)\n && (0 <= this.b && this.b <= 255)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n toString: function() {\n var a = this.opacity; a = isNaN(a) ? 1 : Math.max(0, Math.min(1, a));\n return (a === 1 ? \"rgb(\" : \"rgba(\")\n + Math.max(0, Math.min(255, Math.round(this.r) || 0)) + \", \"\n + Math.max(0, Math.min(255, Math.round(this.g) || 0)) + \", \"\n + Math.max(0, Math.min(255, Math.round(this.b) || 0))\n + (a === 1 ? \")\" : \", \" + a + \")\");\n }\n }));\n\n function hsla(h, s, l, a) {\n if (a <= 0) h = s = l = NaN;\n else if (l <= 0 || l >= 1) h = s = NaN;\n else if (s <= 0) h = NaN;\n return new Hsl(h, s, l, a);\n }\n\n function hslConvert(o) {\n if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Hsl;\n if (o instanceof Hsl) return o;\n o = o.rgb();\n var r = o.r / 255,\n g = o.g / 255,\n b = o.b / 255,\n min = Math.min(r, g, b),\n max = Math.max(r, g, b),\n h = NaN,\n s = max - min,\n l = (max + min) / 2;\n if (s) {\n if (r === max) h = (g - b) / s + (g < b) * 6;\n else if (g === max) h = (b - r) / s + 2;\n else h = (r - g) / s + 4;\n s /= l < 0.5 ? max + min : 2 - max - min;\n h *= 60;\n } else {\n s = l > 0 && l < 1 ? 0 : h;\n }\n return new Hsl(h, s, l, o.opacity);\n }\n\n function colorHsl(h, s, l, opacity) {\n return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);\n }\n\n function Hsl(h, s, l, opacity) {\n this.h = +h;\n this.s = +s;\n this.l = +l;\n this.opacity = +opacity;\n }\n\n define(Hsl, colorHsl, extend(Color, {\n brighter: function(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n darker: function(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n rgb: function() {\n var h = this.h % 360 + (this.h < 0) * 360,\n s = isNaN(h) || isNaN(this.s) ? 0 : this.s,\n l = this.l,\n m2 = l + (l < 0.5 ? l : 1 - l) * s,\n m1 = 2 * l - m2;\n return new Rgb(\n hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),\n hsl2rgb(h, m1, m2),\n hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),\n this.opacity\n );\n },\n displayable: function() {\n return (0 <= this.s && this.s <= 1 || isNaN(this.s))\n && (0 <= this.l && this.l <= 1)\n && (0 <= this.opacity && this.opacity <= 1);\n }\n }));\n\n /* From FvD 13.37, CSS Color Module Level 3 */\n function hsl2rgb(h, m1, m2) {\n return (h < 60 ? m1 + (m2 - m1) * h / 60\n : h < 180 ? m2\n : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60\n : m1) * 255;\n }\n\n var deg2rad = Math.PI / 180;\n var rad2deg = 180 / Math.PI;\n\n var Kn = 18;\n var Xn = 0.950470;\n var Yn = 1;\n var Zn = 1.088830;\n var t0 = 4 / 29;\n var t1 = 6 / 29;\n var t2 = 3 * t1 * t1;\n var t3 = t1 * t1 * t1;\n function labConvert(o) {\n if (o instanceof Lab) return new Lab(o.l, o.a, o.b, o.opacity);\n if (o instanceof Hcl) {\n var h = o.h * deg2rad;\n return new Lab(o.l, Math.cos(h) * o.c, Math.sin(h) * o.c, o.opacity);\n }\n if (!(o instanceof Rgb)) o = rgbConvert(o);\n var b = rgb2xyz(o.r),\n a = rgb2xyz(o.g),\n l = rgb2xyz(o.b),\n x = xyz2lab((0.4124564 * b + 0.3575761 * a + 0.1804375 * l) / Xn),\n y = xyz2lab((0.2126729 * b + 0.7151522 * a + 0.0721750 * l) / Yn),\n z = xyz2lab((0.0193339 * b + 0.1191920 * a + 0.9503041 * l) / Zn);\n return new Lab(116 * y - 16, 500 * (x - y), 200 * (y - z), o.opacity);\n }\n\n function lab(l, a, b, opacity) {\n return arguments.length === 1 ? labConvert(l) : new Lab(l, a, b, opacity == null ? 1 : opacity);\n }\n\n function Lab(l, a, b, opacity) {\n this.l = +l;\n this.a = +a;\n this.b = +b;\n this.opacity = +opacity;\n }\n\n define(Lab, lab, extend(Color, {\n brighter: function(k) {\n return new Lab(this.l + Kn * (k == null ? 1 : k), this.a, this.b, this.opacity);\n },\n darker: function(k) {\n return new Lab(this.l - Kn * (k == null ? 1 : k), this.a, this.b, this.opacity);\n },\n rgb: function() {\n var y = (this.l + 16) / 116,\n x = isNaN(this.a) ? y : y + this.a / 500,\n z = isNaN(this.b) ? y : y - this.b / 200;\n y = Yn * lab2xyz(y);\n x = Xn * lab2xyz(x);\n z = Zn * lab2xyz(z);\n return new Rgb(\n xyz2rgb( 3.2404542 * x - 1.5371385 * y - 0.4985314 * z), // D65 -> sRGB\n xyz2rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z),\n xyz2rgb( 0.0556434 * x - 0.2040259 * y + 1.0572252 * z),\n this.opacity\n );\n }\n }));\n\n function xyz2lab(t) {\n return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0;\n }\n\n function lab2xyz(t) {\n return t > t1 ? t * t * t : t2 * (t - t0);\n }\n\n function xyz2rgb(x) {\n return 255 * (x <= 0.0031308 ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055);\n }\n\n function rgb2xyz(x) {\n return (x /= 255) <= 0.04045 ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4);\n }\n\n function hclConvert(o) {\n if (o instanceof Hcl) return new Hcl(o.h, o.c, o.l, o.opacity);\n if (!(o instanceof Lab)) o = labConvert(o);\n var h = Math.atan2(o.b, o.a) * rad2deg;\n return new Hcl(h < 0 ? h + 360 : h, Math.sqrt(o.a * o.a + o.b * o.b), o.l, o.opacity);\n }\n\n function colorHcl(h, c, l, opacity) {\n return arguments.length === 1 ? hclConvert(h) : new Hcl(h, c, l, opacity == null ? 1 : opacity);\n }\n\n function Hcl(h, c, l, opacity) {\n this.h = +h;\n this.c = +c;\n this.l = +l;\n this.opacity = +opacity;\n }\n\n define(Hcl, colorHcl, extend(Color, {\n brighter: function(k) {\n return new Hcl(this.h, this.c, this.l + Kn * (k == null ? 1 : k), this.opacity);\n },\n darker: function(k) {\n return new Hcl(this.h, this.c, this.l - Kn * (k == null ? 1 : k), this.opacity);\n },\n rgb: function() {\n return labConvert(this).rgb();\n }\n }));\n\n var A = -0.14861;\n var B = +1.78277;\n var C = -0.29227;\n var D = -0.90649;\n var E = +1.97294;\n var ED = E * D;\n var EB = E * B;\n var BC_DA = B * C - D * A;\n function cubehelixConvert(o) {\n if (o instanceof Cubehelix) return new Cubehelix(o.h, o.s, o.l, o.opacity);\n if (!(o instanceof Rgb)) o = rgbConvert(o);\n var r = o.r / 255,\n g = o.g / 255,\n b = o.b / 255,\n l = (BC_DA * b + ED * r - EB * g) / (BC_DA + ED - EB),\n bl = b - l,\n k = (E * (g - l) - C * bl) / D,\n s = Math.sqrt(k * k + bl * bl) / (E * l * (1 - l)), // NaN if l=0 or l=1\n h = s ? Math.atan2(k, bl) * rad2deg - 120 : NaN;\n return new Cubehelix(h < 0 ? h + 360 : h, s, l, o.opacity);\n }\n\n function cubehelix(h, s, l, opacity) {\n return arguments.length === 1 ? cubehelixConvert(h) : new Cubehelix(h, s, l, opacity == null ? 1 : opacity);\n }\n\n function Cubehelix(h, s, l, opacity) {\n this.h = +h;\n this.s = +s;\n this.l = +l;\n this.opacity = +opacity;\n }\n\n define(Cubehelix, cubehelix, extend(Color, {\n brighter: function(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Cubehelix(this.h, this.s, this.l * k, this.opacity);\n },\n darker: function(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Cubehelix(this.h, this.s, this.l * k, this.opacity);\n },\n rgb: function() {\n var h = isNaN(this.h) ? 0 : (this.h + 120) * deg2rad,\n l = +this.l,\n a = isNaN(this.s) ? 0 : this.s * l * (1 - l),\n cosh = Math.cos(h),\n sinh = Math.sin(h);\n return new Rgb(\n 255 * (l + a * (A * cosh + B * sinh)),\n 255 * (l + a * (C * cosh + D * sinh)),\n 255 * (l + a * (E * cosh)),\n this.opacity\n );\n }\n }));\n\n function basis$1(t1, v0, v1, v2, v3) {\n var t2 = t1 * t1, t3 = t2 * t1;\n return ((1 - 3 * t1 + 3 * t2 - t3) * v0\n + (4 - 6 * t2 + 3 * t3) * v1\n + (1 + 3 * t1 + 3 * t2 - 3 * t3) * v2\n + t3 * v3) / 6;\n }\n\n function basis$2(values) {\n var n = values.length - 1;\n return function(t) {\n var i = t <= 0 ? (t = 0) : t >= 1 ? (t = 1, n - 1) : Math.floor(t * n),\n v1 = values[i],\n v2 = values[i + 1],\n v0 = i > 0 ? values[i - 1] : 2 * v1 - v2,\n v3 = i < n - 1 ? values[i + 2] : 2 * v2 - v1;\n return basis$1((t - i / n) * n, v0, v1, v2, v3);\n };\n }\n\n function basisClosed$1(values) {\n var n = values.length;\n return function(t) {\n var i = Math.floor(((t %= 1) < 0 ? ++t : t) * n),\n v0 = values[(i + n - 1) % n],\n v1 = values[i % n],\n v2 = values[(i + 1) % n],\n v3 = values[(i + 2) % n];\n return basis$1((t - i / n) * n, v0, v1, v2, v3);\n };\n }\n\n function constant$2(x) {\n return function() {\n return x;\n };\n }\n\n function linear$1(a, d) {\n return function(t) {\n return a + t * d;\n };\n }\n\n function exponential$1(a, b, y) {\n return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {\n return Math.pow(a + t * b, y);\n };\n }\n\n function hue(a, b) {\n var d = b - a;\n return d ? linear$1(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant$2(isNaN(a) ? b : a);\n }\n\n function gamma(y) {\n return (y = +y) === 1 ? nogamma : function(a, b) {\n return b - a ? exponential$1(a, b, y) : constant$2(isNaN(a) ? b : a);\n };\n }\n\n function nogamma(a, b) {\n var d = b - a;\n return d ? linear$1(a, d) : constant$2(isNaN(a) ? b : a);\n }\n\n var interpolateRgb = (function rgbGamma(y) {\n var color = gamma(y);\n\n function rgb(start, end) {\n var r = color((start = colorRgb(start)).r, (end = colorRgb(end)).r),\n g = color(start.g, end.g),\n b = color(start.b, end.b),\n opacity = color(start.opacity, end.opacity);\n return function(t) {\n start.r = r(t);\n start.g = g(t);\n start.b = b(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n rgb.gamma = rgbGamma;\n\n return rgb;\n })(1);\n\n function rgbSpline(spline) {\n return function(colors) {\n var n = colors.length,\n r = new Array(n),\n g = new Array(n),\n b = new Array(n),\n i, color;\n for (i = 0; i < n; ++i) {\n color = colorRgb(colors[i]);\n r[i] = color.r || 0;\n g[i] = color.g || 0;\n b[i] = color.b || 0;\n }\n r = spline(r);\n g = spline(g);\n b = spline(b);\n color.opacity = 1;\n return function(t) {\n color.r = r(t);\n color.g = g(t);\n color.b = b(t);\n return color + \"\";\n };\n };\n }\n\n var rgbBasis = rgbSpline(basis$2);\n var rgbBasisClosed = rgbSpline(basisClosed$1);\n\n function array$1(a, b) {\n var nb = b ? b.length : 0,\n na = a ? Math.min(nb, a.length) : 0,\n x = new Array(nb),\n c = new Array(nb),\n i;\n\n for (i = 0; i < na; ++i) x[i] = interpolate(a[i], b[i]);\n for (; i < nb; ++i) c[i] = b[i];\n\n return function(t) {\n for (i = 0; i < na; ++i) c[i] = x[i](t);\n return c;\n };\n }\n\n function date(a, b) {\n var d = new Date;\n return a = +a, b -= a, function(t) {\n return d.setTime(a + b * t), d;\n };\n }\n\n function interpolateNumber(a, b) {\n return a = +a, b -= a, function(t) {\n return a + b * t;\n };\n }\n\n function object(a, b) {\n var i = {},\n c = {},\n k;\n\n if (a === null || typeof a !== \"object\") a = {};\n if (b === null || typeof b !== \"object\") b = {};\n\n for (k in b) {\n if (k in a) {\n i[k] = interpolate(a[k], b[k]);\n } else {\n c[k] = b[k];\n }\n }\n\n return function(t) {\n for (k in i) c[k] = i[k](t);\n return c;\n };\n }\n\n var reA = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g;\n var reB = new RegExp(reA.source, \"g\");\n function zero(b) {\n return function() {\n return b;\n };\n }\n\n function one(b) {\n return function(t) {\n return b(t) + \"\";\n };\n }\n\n function interpolateString(a, b) {\n var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b\n am, // current match in a\n bm, // current match in b\n bs, // string preceding current number in b, if any\n i = -1, // index in s\n s = [], // string constants and placeholders\n q = []; // number interpolators\n\n // Coerce inputs to strings.\n a = a + \"\", b = b + \"\";\n\n // Interpolate pairs of numbers in a & b.\n while ((am = reA.exec(a))\n && (bm = reB.exec(b))) {\n if ((bs = bm.index) > bi) { // a string precedes the next number in b\n bs = b.slice(bi, bs);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match\n if (s[i]) s[i] += bm; // coalesce with previous string\n else s[++i] = bm;\n } else { // interpolate non-matching numbers\n s[++i] = null;\n q.push({i: i, x: interpolateNumber(am, bm)});\n }\n bi = reB.lastIndex;\n }\n\n // Add remains of b.\n if (bi < b.length) {\n bs = b.slice(bi);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n\n // Special optimization for only a single match.\n // Otherwise, interpolate each of the numbers and rejoin the string.\n return s.length < 2 ? (q[0]\n ? one(q[0].x)\n : zero(b))\n : (b = q.length, function(t) {\n for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n });\n }\n\n function interpolate(a, b) {\n var t = typeof b, c;\n return b == null || t === \"boolean\" ? constant$2(b)\n : (t === \"number\" ? interpolateNumber\n : t === \"string\" ? ((c = color(b)) ? (b = c, interpolateRgb) : interpolateString)\n : b instanceof color ? interpolateRgb\n : b instanceof Date ? date\n : Array.isArray(b) ? array$1\n : isNaN(b) ? object\n : interpolateNumber)(a, b);\n }\n\n function interpolateRound(a, b) {\n return a = +a, b -= a, function(t) {\n return Math.round(a + b * t);\n };\n }\n\n var degrees = 180 / Math.PI;\n\n var identity$2 = {\n translateX: 0,\n translateY: 0,\n rotate: 0,\n skewX: 0,\n scaleX: 1,\n scaleY: 1\n };\n\n function decompose(a, b, c, d, e, f) {\n var scaleX, scaleY, skewX;\n if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;\n if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;\n if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;\n if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;\n return {\n translateX: e,\n translateY: f,\n rotate: Math.atan2(b, a) * degrees,\n skewX: Math.atan(skewX) * degrees,\n scaleX: scaleX,\n scaleY: scaleY\n };\n }\n\n var cssNode;\n var cssRoot;\n var cssView;\n var svgNode;\n function parseCss(value) {\n if (value === \"none\") return identity$2;\n if (!cssNode) cssNode = document.createElement(\"DIV\"), cssRoot = document.documentElement, cssView = document.defaultView;\n cssNode.style.transform = value;\n value = cssView.getComputedStyle(cssRoot.appendChild(cssNode), null).getPropertyValue(\"transform\");\n cssRoot.removeChild(cssNode);\n value = value.slice(7, -1).split(\",\");\n return decompose(+value[0], +value[1], +value[2], +value[3], +value[4], +value[5]);\n }\n\n function parseSvg(value) {\n if (value == null) return identity$2;\n if (!svgNode) svgNode = document.createElementNS(\"http://www.w3.org/2000/svg\", \"g\");\n svgNode.setAttribute(\"transform\", value);\n if (!(value = svgNode.transform.baseVal.consolidate())) return identity$2;\n value = value.matrix;\n return decompose(value.a, value.b, value.c, value.d, value.e, value.f);\n }\n\n function interpolateTransform(parse, pxComma, pxParen, degParen) {\n\n function pop(s) {\n return s.length ? s.pop() + \" \" : \"\";\n }\n\n function translate(xa, ya, xb, yb, s, q) {\n if (xa !== xb || ya !== yb) {\n var i = s.push(\"translate(\", null, pxComma, null, pxParen);\n q.push({i: i - 4, x: interpolateNumber(xa, xb)}, {i: i - 2, x: interpolateNumber(ya, yb)});\n } else if (xb || yb) {\n s.push(\"translate(\" + xb + pxComma + yb + pxParen);\n }\n }\n\n function rotate(a, b, s, q) {\n if (a !== b) {\n if (a - b > 180) b += 360; else if (b - a > 180) a += 360; // shortest path\n q.push({i: s.push(pop(s) + \"rotate(\", null, degParen) - 2, x: interpolateNumber(a, b)});\n } else if (b) {\n s.push(pop(s) + \"rotate(\" + b + degParen);\n }\n }\n\n function skewX(a, b, s, q) {\n if (a !== b) {\n q.push({i: s.push(pop(s) + \"skewX(\", null, degParen) - 2, x: interpolateNumber(a, b)});\n } else if (b) {\n s.push(pop(s) + \"skewX(\" + b + degParen);\n }\n }\n\n function scale(xa, ya, xb, yb, s, q) {\n if (xa !== xb || ya !== yb) {\n var i = s.push(pop(s) + \"scale(\", null, \",\", null, \")\");\n q.push({i: i - 4, x: interpolateNumber(xa, xb)}, {i: i - 2, x: interpolateNumber(ya, yb)});\n } else if (xb !== 1 || yb !== 1) {\n s.push(pop(s) + \"scale(\" + xb + \",\" + yb + \")\");\n }\n }\n\n return function(a, b) {\n var s = [], // string constants and placeholders\n q = []; // number interpolators\n a = parse(a), b = parse(b);\n translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q);\n rotate(a.rotate, b.rotate, s, q);\n skewX(a.skewX, b.skewX, s, q);\n scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q);\n a = b = null; // gc\n return function(t) {\n var i = -1, n = q.length, o;\n while (++i < n) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n };\n };\n }\n\n var interpolateTransform$1 = interpolateTransform(parseCss, \"px, \", \"px)\", \"deg)\");\n var interpolateTransform$2 = interpolateTransform(parseSvg, \", \", \")\", \")\");\n\n var rho = Math.SQRT2;\n var rho2 = 2;\n var rho4 = 4;\n var epsilon2 = 1e-12;\n function cosh(x) {\n return ((x = Math.exp(x)) + 1 / x) / 2;\n }\n\n function sinh(x) {\n return ((x = Math.exp(x)) - 1 / x) / 2;\n }\n\n function tanh(x) {\n return ((x = Math.exp(2 * x)) - 1) / (x + 1);\n }\n\n // p0 = [ux0, uy0, w0]\n // p1 = [ux1, uy1, w1]\n function interpolateZoom(p0, p1) {\n var ux0 = p0[0], uy0 = p0[1], w0 = p0[2],\n ux1 = p1[0], uy1 = p1[1], w1 = p1[2],\n dx = ux1 - ux0,\n dy = uy1 - uy0,\n d2 = dx * dx + dy * dy,\n i,\n S;\n\n // Special case for u0 ≅ u1.\n if (d2 < epsilon2) {\n S = Math.log(w1 / w0) / rho;\n i = function(t) {\n return [\n ux0 + t * dx,\n uy0 + t * dy,\n w0 * Math.exp(rho * t * S)\n ];\n }\n }\n\n // General case.\n else {\n var d1 = Math.sqrt(d2),\n b0 = (w1 * w1 - w0 * w0 + rho4 * d2) / (2 * w0 * rho2 * d1),\n b1 = (w1 * w1 - w0 * w0 - rho4 * d2) / (2 * w1 * rho2 * d1),\n r0 = Math.log(Math.sqrt(b0 * b0 + 1) - b0),\n r1 = Math.log(Math.sqrt(b1 * b1 + 1) - b1);\n S = (r1 - r0) / rho;\n i = function(t) {\n var s = t * S,\n coshr0 = cosh(r0),\n u = w0 / (rho2 * d1) * (coshr0 * tanh(rho * s + r0) - sinh(r0));\n return [\n ux0 + u * dx,\n uy0 + u * dy,\n w0 * coshr0 / cosh(rho * s + r0)\n ];\n }\n }\n\n i.duration = S * 1000;\n\n return i;\n }\n\n function hsl(hue) {\n return function(start, end) {\n var h = hue((start = colorHsl(start)).h, (end = colorHsl(end)).h),\n s = nogamma(start.s, end.s),\n l = nogamma(start.l, end.l),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.h = h(t);\n start.s = s(t);\n start.l = l(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n }\n\n var hsl$1 = hsl(hue);\n var hslLong = hsl(nogamma);\n\n function lab$1(start, end) {\n var l = nogamma((start = lab(start)).l, (end = lab(end)).l),\n a = nogamma(start.a, end.a),\n b = nogamma(start.b, end.b),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.l = l(t);\n start.a = a(t);\n start.b = b(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n function hcl(hue) {\n return function(start, end) {\n var h = hue((start = colorHcl(start)).h, (end = colorHcl(end)).h),\n c = nogamma(start.c, end.c),\n l = nogamma(start.l, end.l),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.h = h(t);\n start.c = c(t);\n start.l = l(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n }\n\n var hcl$1 = hcl(hue);\n var hclLong = hcl(nogamma);\n\n function cubehelix$1(hue) {\n return (function cubehelixGamma(y) {\n y = +y;\n\n function cubehelix$$(start, end) {\n var h = hue((start = cubehelix(start)).h, (end = cubehelix(end)).h),\n s = nogamma(start.s, end.s),\n l = nogamma(start.l, end.l),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.h = h(t);\n start.s = s(t);\n start.l = l(Math.pow(t, y));\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n cubehelix$$.gamma = cubehelixGamma;\n\n return cubehelix$$;\n })(1);\n }\n\n var cubehelix$2 = cubehelix$1(hue);\n var interpolateCubehelixLong = cubehelix$1(nogamma);\n\n function quantize(interpolator, n) {\n var samples = new Array(n);\n for (var i = 0; i < n; ++i) samples[i] = interpolator(i / (n - 1));\n return samples;\n }\n\n var noop$1 = {value: function() {}};\n\n function dispatch() {\n for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {\n if (!(t = arguments[i] + \"\") || (t in _)) throw new Error(\"illegal type: \" + t);\n _[t] = [];\n }\n return new Dispatch(_);\n }\n\n function Dispatch(_) {\n this._ = _;\n }\n\n function parseTypenames(typenames, types) {\n return typenames.trim().split(/^|\\s+/).map(function(t) {\n var name = \"\", i = t.indexOf(\".\");\n if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n if (t && !types.hasOwnProperty(t)) throw new Error(\"unknown type: \" + t);\n return {type: t, name: name};\n });\n }\n\n Dispatch.prototype = dispatch.prototype = {\n constructor: Dispatch,\n on: function(typename, callback) {\n var _ = this._,\n T = parseTypenames(typename + \"\", _),\n t,\n i = -1,\n n = T.length;\n\n // If no callback was specified, return the callback of the given type and name.\n if (arguments.length < 2) {\n while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;\n return;\n }\n\n // If a type was specified, set the callback for the given type and name.\n // Otherwise, if a null callback was specified, remove callbacks of the given name.\n if (callback != null && typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n while (++i < n) {\n if (t = (typename = T[i]).type) _[t] = set$1(_[t], typename.name, callback);\n else if (callback == null) for (t in _) _[t] = set$1(_[t], typename.name, null);\n }\n\n return this;\n },\n copy: function() {\n var copy = {}, _ = this._;\n for (var t in _) copy[t] = _[t].slice();\n return new Dispatch(copy);\n },\n call: function(type, that) {\n if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n },\n apply: function(type, that, args) {\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n }\n };\n\n function get(type, name) {\n for (var i = 0, n = type.length, c; i < n; ++i) {\n if ((c = type[i]).name === name) {\n return c.value;\n }\n }\n }\n\n function set$1(type, name, callback) {\n for (var i = 0, n = type.length; i < n; ++i) {\n if (type[i].name === name) {\n type[i] = noop$1, type = type.slice(0, i).concat(type.slice(i + 1));\n break;\n }\n }\n if (callback != null) type.push({name: name, value: callback});\n return type;\n }\n\n function objectConverter(columns) {\n return new Function(\"d\", \"return {\" + columns.map(function(name, i) {\n return JSON.stringify(name) + \": d[\" + i + \"]\";\n }).join(\",\") + \"}\");\n }\n\n function customConverter(columns, f) {\n var object = objectConverter(columns);\n return function(row, i) {\n return f(object(row), i, columns);\n };\n }\n\n // Compute unique columns in order of discovery.\n function inferColumns(rows) {\n var columnSet = Object.create(null),\n columns = [];\n\n rows.forEach(function(row) {\n for (var column in row) {\n if (!(column in columnSet)) {\n columns.push(columnSet[column] = column);\n }\n }\n });\n\n return columns;\n }\n\n function dsv(delimiter) {\n var reFormat = new RegExp(\"[\\\"\" + delimiter + \"\\n]\"),\n delimiterCode = delimiter.charCodeAt(0);\n\n function parse(text, f) {\n var convert, columns, rows = parseRows(text, function(row, i) {\n if (convert) return convert(row, i - 1);\n columns = row, convert = f ? customConverter(row, f) : objectConverter(row);\n });\n rows.columns = columns;\n return rows;\n }\n\n function parseRows(text, f) {\n var EOL = {}, // sentinel value for end-of-line\n EOF = {}, // sentinel value for end-of-file\n rows = [], // output rows\n N = text.length,\n I = 0, // current character index\n n = 0, // the current line number\n t, // the current token\n eol; // is the current token followed by EOL?\n\n function token() {\n if (I >= N) return EOF; // special case: end of file\n if (eol) return eol = false, EOL; // special case: end of line\n\n // special case: quotes\n var j = I, c;\n if (text.charCodeAt(j) === 34) {\n var i = j;\n while (i++ < N) {\n if (text.charCodeAt(i) === 34) {\n if (text.charCodeAt(i + 1) !== 34) break;\n ++i;\n }\n }\n I = i + 2;\n c = text.charCodeAt(i + 1);\n if (c === 13) {\n eol = true;\n if (text.charCodeAt(i + 2) === 10) ++I;\n } else if (c === 10) {\n eol = true;\n }\n return text.slice(j + 1, i).replace(/\"\"/g, \"\\\"\");\n }\n\n // common case: find next delimiter or newline\n while (I < N) {\n var k = 1;\n c = text.charCodeAt(I++);\n if (c === 10) eol = true; // \\n\n else if (c === 13) { eol = true; if (text.charCodeAt(I) === 10) ++I, ++k; } // \\r|\\r\\n\n else if (c !== delimiterCode) continue;\n return text.slice(j, I - k);\n }\n\n // special case: last token before EOF\n return text.slice(j);\n }\n\n while ((t = token()) !== EOF) {\n var a = [];\n while (t !== EOL && t !== EOF) {\n a.push(t);\n t = token();\n }\n if (f && (a = f(a, n++)) == null) continue;\n rows.push(a);\n }\n\n return rows;\n }\n\n function format(rows, columns) {\n if (columns == null) columns = inferColumns(rows);\n return [columns.map(formatValue).join(delimiter)].concat(rows.map(function(row) {\n return columns.map(function(column) {\n return formatValue(row[column]);\n }).join(delimiter);\n })).join(\"\\n\");\n }\n\n function formatRows(rows) {\n return rows.map(formatRow).join(\"\\n\");\n }\n\n function formatRow(row) {\n return row.map(formatValue).join(delimiter);\n }\n\n function formatValue(text) {\n return text == null ? \"\"\n : reFormat.test(text += \"\") ? \"\\\"\" + text.replace(/\\\"/g, \"\\\"\\\"\") + \"\\\"\"\n : text;\n }\n\n return {\n parse: parse,\n parseRows: parseRows,\n format: format,\n formatRows: formatRows\n };\n }\n\n var csv = dsv(\",\");\n\n var csvParse = csv.parse;\n var csvParseRows = csv.parseRows;\n var csvFormat = csv.format;\n var csvFormatRows = csv.formatRows;\n\n var tsv = dsv(\"\\t\");\n\n var tsvParse = tsv.parse;\n var tsvParseRows = tsv.parseRows;\n var tsvFormat = tsv.format;\n var tsvFormatRows = tsv.formatRows;\n\n function request(url, callback) {\n var request,\n event = dispatch(\"beforesend\", \"progress\", \"load\", \"error\"),\n mimeType,\n headers = map$1(),\n xhr = new XMLHttpRequest,\n user = null,\n password = null,\n response,\n responseType,\n timeout = 0;\n\n // If IE does not support CORS, use XDomainRequest.\n if (typeof XDomainRequest !== \"undefined\"\n && !(\"withCredentials\" in xhr)\n && /^(http(s)?:)?\\/\\//.test(url)) xhr = new XDomainRequest;\n\n \"onload\" in xhr\n ? xhr.onload = xhr.onerror = xhr.ontimeout = respond\n : xhr.onreadystatechange = function(o) { xhr.readyState > 3 && respond(o); };\n\n function respond(o) {\n var status = xhr.status, result;\n if (!status && hasResponse(xhr)\n || status >= 200 && status < 300\n || status === 304) {\n if (response) {\n try {\n result = response.call(request, xhr);\n } catch (e) {\n event.call(\"error\", request, e);\n return;\n }\n } else {\n result = xhr;\n }\n event.call(\"load\", request, result);\n } else {\n event.call(\"error\", request, o);\n }\n }\n\n xhr.onprogress = function(e) {\n event.call(\"progress\", request, e);\n };\n\n request = {\n header: function(name, value) {\n name = (name + \"\").toLowerCase();\n if (arguments.length < 2) return headers.get(name);\n if (value == null) headers.remove(name);\n else headers.set(name, value + \"\");\n return request;\n },\n\n // If mimeType is non-null and no Accept header is set, a default is used.\n mimeType: function(value) {\n if (!arguments.length) return mimeType;\n mimeType = value == null ? null : value + \"\";\n return request;\n },\n\n // Specifies what type the response value should take;\n // for instance, arraybuffer, blob, document, or text.\n responseType: function(value) {\n if (!arguments.length) return responseType;\n responseType = value;\n return request;\n },\n\n timeout: function(value) {\n if (!arguments.length) return timeout;\n timeout = +value;\n return request;\n },\n\n user: function(value) {\n return arguments.length < 1 ? user : (user = value == null ? null : value + \"\", request);\n },\n\n password: function(value) {\n return arguments.length < 1 ? password : (password = value == null ? null : value + \"\", request);\n },\n\n // Specify how to convert the response content to a specific type;\n // changes the callback value on \"load\" events.\n response: function(value) {\n response = value;\n return request;\n },\n\n // Alias for send(\"GET\", …).\n get: function(data, callback) {\n return request.send(\"GET\", data, callback);\n },\n\n // Alias for send(\"POST\", …).\n post: function(data, callback) {\n return request.send(\"POST\", data, callback);\n },\n\n // If callback is non-null, it will be used for error and load events.\n send: function(method, data, callback) {\n xhr.open(method, url, true, user, password);\n if (mimeType != null && !headers.has(\"accept\")) headers.set(\"accept\", mimeType + \",*/*\");\n if (xhr.setRequestHeader) headers.each(function(value, name) { xhr.setRequestHeader(name, value); });\n if (mimeType != null && xhr.overrideMimeType) xhr.overrideMimeType(mimeType);\n if (responseType != null) xhr.responseType = responseType;\n if (timeout > 0) xhr.timeout = timeout;\n if (callback == null && typeof data === \"function\") callback = data, data = null;\n if (callback != null && callback.length === 1) callback = fixCallback(callback);\n if (callback != null) request.on(\"error\", callback).on(\"load\", function(xhr) { callback(null, xhr); });\n event.call(\"beforesend\", request, xhr);\n xhr.send(data == null ? null : data);\n return request;\n },\n\n abort: function() {\n xhr.abort();\n return request;\n },\n\n on: function() {\n var value = event.on.apply(event, arguments);\n return value === event ? request : value;\n }\n };\n\n if (callback != null) {\n if (typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n return request.get(callback);\n }\n\n return request;\n }\n\n function fixCallback(callback) {\n return function(error, xhr) {\n callback(error == null ? xhr : null);\n };\n }\n\n function hasResponse(xhr) {\n var type = xhr.responseType;\n return type && type !== \"text\"\n ? xhr.response // null on error\n : xhr.responseText; // \"\" on error\n }\n\n function type(defaultMimeType, response) {\n return function(url, callback) {\n var r = request(url).mimeType(defaultMimeType).response(response);\n if (callback != null) {\n if (typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n return r.get(callback);\n }\n return r;\n };\n }\n\n var html = type(\"text/html\", function(xhr) {\n return document.createRange().createContextualFragment(xhr.responseText);\n });\n\n var json = type(\"application/json\", function(xhr) {\n return JSON.parse(xhr.responseText);\n });\n\n var text = type(\"text/plain\", function(xhr) {\n return xhr.responseText;\n });\n\n var xml = type(\"application/xml\", function(xhr) {\n var xml = xhr.responseXML;\n if (!xml) throw new Error(\"parse error\");\n return xml;\n });\n\n function dsv$1(defaultMimeType, parse) {\n return function(url, row, callback) {\n if (arguments.length < 3) callback = row, row = null;\n var r = request(url).mimeType(defaultMimeType);\n r.row = function(_) { return arguments.length ? r.response(responseOf(parse, row = _)) : row; };\n r.row(row);\n return callback ? r.get(callback) : r;\n };\n }\n\n function responseOf(parse, row) {\n return function(request) {\n return parse(request.responseText, row);\n };\n }\n\n var csv$1 = dsv$1(\"text/csv\", csvParse);\n\n var tsv$1 = dsv$1(\"text/tab-separated-values\", tsvParse);\n\n var frame = 0;\n var timeout = 0;\n var interval = 0;\n var pokeDelay = 1000;\n var taskHead;\n var taskTail;\n var clockLast = 0;\n var clockNow = 0;\n var clockSkew = 0;\n var clock = typeof performance === \"object\" && performance.now ? performance : Date;\n var setFrame = typeof requestAnimationFrame === \"function\"\n ? (clock === Date ? function(f) { requestAnimationFrame(function() { f(clock.now()); }); } : requestAnimationFrame)\n : function(f) { setTimeout(f, 17); };\n function now() {\n return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);\n }\n\n function clearNow() {\n clockNow = 0;\n }\n\n function Timer() {\n this._call =\n this._time =\n this._next = null;\n }\n\n Timer.prototype = timer.prototype = {\n constructor: Timer,\n restart: function(callback, delay, time) {\n if (typeof callback !== \"function\") throw new TypeError(\"callback is not a function\");\n time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);\n if (!this._next && taskTail !== this) {\n if (taskTail) taskTail._next = this;\n else taskHead = this;\n taskTail = this;\n }\n this._call = callback;\n this._time = time;\n sleep();\n },\n stop: function() {\n if (this._call) {\n this._call = null;\n this._time = Infinity;\n sleep();\n }\n }\n };\n\n function timer(callback, delay, time) {\n var t = new Timer;\n t.restart(callback, delay, time);\n return t;\n }\n\n function timerFlush() {\n now(); // Get the current time, if not already set.\n ++frame; // Pretend we’ve set an alarm, if we haven’t already.\n var t = taskHead, e;\n while (t) {\n if ((e = clockNow - t._time) >= 0) t._call.call(null, e);\n t = t._next;\n }\n --frame;\n }\n\n function wake(time) {\n clockNow = (clockLast = time || clock.now()) + clockSkew;\n frame = timeout = 0;\n try {\n timerFlush();\n } finally {\n frame = 0;\n nap();\n clockNow = 0;\n }\n }\n\n function poke$1() {\n var now = clock.now(), delay = now - clockLast;\n if (delay > pokeDelay) clockSkew -= delay, clockLast = now;\n }\n\n function nap() {\n var t0, t1 = taskHead, t2, time = Infinity;\n while (t1) {\n if (t1._call) {\n if (time > t1._time) time = t1._time;\n t0 = t1, t1 = t1._next;\n } else {\n t2 = t1._next, t1._next = null;\n t1 = t0 ? t0._next = t2 : taskHead = t2;\n }\n }\n taskTail = t0;\n sleep(time);\n }\n\n function sleep(time) {\n if (frame) return; // Soonest alarm already set, or will be.\n if (timeout) timeout = clearTimeout(timeout);\n var delay = time - clockNow;\n if (delay > 24) {\n if (time < Infinity) timeout = setTimeout(wake, delay);\n if (interval) interval = clearInterval(interval);\n } else {\n if (!interval) interval = setInterval(poke$1, pokeDelay);\n frame = 1, setFrame(wake);\n }\n }\n\n function timeout$1(callback, delay, time) {\n var t = new Timer;\n delay = delay == null ? 0 : +delay;\n t.restart(function(elapsed) {\n t.stop();\n callback(elapsed + delay);\n }, delay, time);\n return t;\n }\n\n function interval$1(callback, delay, time) {\n var t = new Timer, total = delay;\n if (delay == null) return t.restart(callback, delay, time), t;\n delay = +delay, time = time == null ? now() : +time;\n t.restart(function tick(elapsed) {\n elapsed += total;\n t.restart(tick, total += delay, time);\n callback(elapsed);\n }, delay, time);\n return t;\n }\n\nvar t0$1 = new Date;\nvar t1$1 = new Date;\n function newInterval(floori, offseti, count, field) {\n\n function interval(date) {\n return floori(date = new Date(+date)), date;\n }\n\n interval.floor = interval;\n\n interval.ceil = function(date) {\n return floori(date = new Date(date - 1)), offseti(date, 1), floori(date), date;\n };\n\n interval.round = function(date) {\n var d0 = interval(date),\n d1 = interval.ceil(date);\n return date - d0 < d1 - date ? d0 : d1;\n };\n\n interval.offset = function(date, step) {\n return offseti(date = new Date(+date), step == null ? 1 : Math.floor(step)), date;\n };\n\n interval.range = function(start, stop, step) {\n var range = [];\n start = interval.ceil(start);\n step = step == null ? 1 : Math.floor(step);\n if (!(start < stop) || !(step > 0)) return range; // also handles Invalid Date\n do range.push(new Date(+start)); while (offseti(start, step), floori(start), start < stop)\n return range;\n };\n\n interval.filter = function(test) {\n return newInterval(function(date) {\n while (floori(date), !test(date)) date.setTime(date - 1);\n }, function(date, step) {\n while (--step >= 0) while (offseti(date, 1), !test(date));\n });\n };\n\n if (count) {\n interval.count = function(start, end) {\n t0$1.setTime(+start), t1$1.setTime(+end);\n floori(t0$1), floori(t1$1);\n return Math.floor(count(t0$1, t1$1));\n };\n\n interval.every = function(step) {\n step = Math.floor(step);\n return !isFinite(step) || !(step > 0) ? null\n : !(step > 1) ? interval\n : interval.filter(field\n ? function(d) { return field(d) % step === 0; }\n : function(d) { return interval.count(0, d) % step === 0; });\n };\n }\n\n return interval;\n }\n\n var millisecond = newInterval(function() {\n // noop\n }, function(date, step) {\n date.setTime(+date + step);\n }, function(start, end) {\n return end - start;\n });\n\n // An optimized implementation for this simple case.\n millisecond.every = function(k) {\n k = Math.floor(k);\n if (!isFinite(k) || !(k > 0)) return null;\n if (!(k > 1)) return millisecond;\n return newInterval(function(date) {\n date.setTime(Math.floor(date / k) * k);\n }, function(date, step) {\n date.setTime(+date + step * k);\n }, function(start, end) {\n return (end - start) / k;\n });\n };\n\n var milliseconds = millisecond.range;\n\n var durationSecond = 1e3;\n var durationMinute = 6e4;\n var durationHour = 36e5;\n var durationDay = 864e5;\n var durationWeek = 6048e5;\n\n var second = newInterval(function(date) {\n date.setTime(Math.floor(date / durationSecond) * durationSecond);\n }, function(date, step) {\n date.setTime(+date + step * durationSecond);\n }, function(start, end) {\n return (end - start) / durationSecond;\n }, function(date) {\n return date.getUTCSeconds();\n });\n\n var seconds = second.range;\n\n var minute = newInterval(function(date) {\n date.setTime(Math.floor(date / durationMinute) * durationMinute);\n }, function(date, step) {\n date.setTime(+date + step * durationMinute);\n }, function(start, end) {\n return (end - start) / durationMinute;\n }, function(date) {\n return date.getMinutes();\n });\n\n var minutes = minute.range;\n\n var hour = newInterval(function(date) {\n var offset = date.getTimezoneOffset() * durationMinute % durationHour;\n if (offset < 0) offset += durationHour;\n date.setTime(Math.floor((+date - offset) / durationHour) * durationHour + offset);\n }, function(date, step) {\n date.setTime(+date + step * durationHour);\n }, function(start, end) {\n return (end - start) / durationHour;\n }, function(date) {\n return date.getHours();\n });\n\n var hours = hour.range;\n\n var day = newInterval(function(date) {\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setDate(date.getDate() + step);\n }, function(start, end) {\n return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationDay;\n }, function(date) {\n return date.getDate() - 1;\n });\n\n var days = day.range;\n\n function weekday(i) {\n return newInterval(function(date) {\n date.setDate(date.getDate() - (date.getDay() + 7 - i) % 7);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setDate(date.getDate() + step * 7);\n }, function(start, end) {\n return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationWeek;\n });\n }\n\n var timeWeek = weekday(0);\n var timeMonday = weekday(1);\n var tuesday = weekday(2);\n var wednesday = weekday(3);\n var thursday = weekday(4);\n var friday = weekday(5);\n var saturday = weekday(6);\n\n var sundays = timeWeek.range;\n var mondays = timeMonday.range;\n var tuesdays = tuesday.range;\n var wednesdays = wednesday.range;\n var thursdays = thursday.range;\n var fridays = friday.range;\n var saturdays = saturday.range;\n\n var month = newInterval(function(date) {\n date.setDate(1);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setMonth(date.getMonth() + step);\n }, function(start, end) {\n return end.getMonth() - start.getMonth() + (end.getFullYear() - start.getFullYear()) * 12;\n }, function(date) {\n return date.getMonth();\n });\n\n var months = month.range;\n\n var year = newInterval(function(date) {\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setFullYear(date.getFullYear() + step);\n }, function(start, end) {\n return end.getFullYear() - start.getFullYear();\n }, function(date) {\n return date.getFullYear();\n });\n\n // An optimized implementation for this simple case.\n year.every = function(k) {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : newInterval(function(date) {\n date.setFullYear(Math.floor(date.getFullYear() / k) * k);\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setFullYear(date.getFullYear() + step * k);\n });\n };\n\n var years = year.range;\n\n var utcMinute = newInterval(function(date) {\n date.setUTCSeconds(0, 0);\n }, function(date, step) {\n date.setTime(+date + step * durationMinute);\n }, function(start, end) {\n return (end - start) / durationMinute;\n }, function(date) {\n return date.getUTCMinutes();\n });\n\n var utcMinutes = utcMinute.range;\n\n var utcHour = newInterval(function(date) {\n date.setUTCMinutes(0, 0, 0);\n }, function(date, step) {\n date.setTime(+date + step * durationHour);\n }, function(start, end) {\n return (end - start) / durationHour;\n }, function(date) {\n return date.getUTCHours();\n });\n\n var utcHours = utcHour.range;\n\n var utcDay = newInterval(function(date) {\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCDate(date.getUTCDate() + step);\n }, function(start, end) {\n return (end - start) / durationDay;\n }, function(date) {\n return date.getUTCDate() - 1;\n });\n\n var utcDays = utcDay.range;\n\n function utcWeekday(i) {\n return newInterval(function(date) {\n date.setUTCDate(date.getUTCDate() - (date.getUTCDay() + 7 - i) % 7);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCDate(date.getUTCDate() + step * 7);\n }, function(start, end) {\n return (end - start) / durationWeek;\n });\n }\n\n var utcWeek = utcWeekday(0);\n var utcMonday = utcWeekday(1);\n var utcTuesday = utcWeekday(2);\n var utcWednesday = utcWeekday(3);\n var utcThursday = utcWeekday(4);\n var utcFriday = utcWeekday(5);\n var utcSaturday = utcWeekday(6);\n\n var utcSundays = utcWeek.range;\n var utcMondays = utcMonday.range;\n var utcTuesdays = utcTuesday.range;\n var utcWednesdays = utcWednesday.range;\n var utcThursdays = utcThursday.range;\n var utcFridays = utcFriday.range;\n var utcSaturdays = utcSaturday.range;\n\n var utcMonth = newInterval(function(date) {\n date.setUTCDate(1);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCMonth(date.getUTCMonth() + step);\n }, function(start, end) {\n return end.getUTCMonth() - start.getUTCMonth() + (end.getUTCFullYear() - start.getUTCFullYear()) * 12;\n }, function(date) {\n return date.getUTCMonth();\n });\n\n var utcMonths = utcMonth.range;\n\n var utcYear = newInterval(function(date) {\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCFullYear(date.getUTCFullYear() + step);\n }, function(start, end) {\n return end.getUTCFullYear() - start.getUTCFullYear();\n }, function(date) {\n return date.getUTCFullYear();\n });\n\n // An optimized implementation for this simple case.\n utcYear.every = function(k) {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : newInterval(function(date) {\n date.setUTCFullYear(Math.floor(date.getUTCFullYear() / k) * k);\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCFullYear(date.getUTCFullYear() + step * k);\n });\n };\n\n var utcYears = utcYear.range;\n\n // Computes the decimal coefficient and exponent of the specified number x with\n // significant digits p, where x is positive and p is in [1, 21] or undefined.\n // For example, formatDecimal(1.23) returns [\"123\", 0].\n function formatDecimal(x, p) {\n if ((i = (x = p ? x.toExponential(p - 1) : x.toExponential()).indexOf(\"e\")) < 0) return null; // NaN, ±Infinity\n var i, coefficient = x.slice(0, i);\n\n // The string returned by toExponential either has the form \\d\\.\\d+e[-+]\\d+\n // (e.g., 1.2e+3) or the form \\de[-+]\\d+ (e.g., 1e+3).\n return [\n coefficient.length > 1 ? coefficient[0] + coefficient.slice(2) : coefficient,\n +x.slice(i + 1)\n ];\n }\n\n function exponent$1(x) {\n return x = formatDecimal(Math.abs(x)), x ? x[1] : NaN;\n }\n\n function formatGroup(grouping, thousands) {\n return function(value, width) {\n var i = value.length,\n t = [],\n j = 0,\n g = grouping[0],\n length = 0;\n\n while (i > 0 && g > 0) {\n if (length + g + 1 > width) g = Math.max(1, width - length);\n t.push(value.substring(i -= g, i + g));\n if ((length += g + 1) > width) break;\n g = grouping[j = (j + 1) % grouping.length];\n }\n\n return t.reverse().join(thousands);\n };\n }\n\n function formatDefault(x, p) {\n x = x.toPrecision(p);\n\n out: for (var n = x.length, i = 1, i0 = -1, i1; i < n; ++i) {\n switch (x[i]) {\n case \".\": i0 = i1 = i; break;\n case \"0\": if (i0 === 0) i0 = i; i1 = i; break;\n case \"e\": break out;\n default: if (i0 > 0) i0 = 0; break;\n }\n }\n\n return i0 > 0 ? x.slice(0, i0) + x.slice(i1 + 1) : x;\n }\n\n var prefixExponent;\n\n function formatPrefixAuto(x, p) {\n var d = formatDecimal(x, p);\n if (!d) return x + \"\";\n var coefficient = d[0],\n exponent = d[1],\n i = exponent - (prefixExponent = Math.max(-8, Math.min(8, Math.floor(exponent / 3))) * 3) + 1,\n n = coefficient.length;\n return i === n ? coefficient\n : i > n ? coefficient + new Array(i - n + 1).join(\"0\")\n : i > 0 ? coefficient.slice(0, i) + \".\" + coefficient.slice(i)\n : \"0.\" + new Array(1 - i).join(\"0\") + formatDecimal(x, Math.max(0, p + i - 1))[0]; // less than 1y!\n }\n\n function formatRounded(x, p) {\n var d = formatDecimal(x, p);\n if (!d) return x + \"\";\n var coefficient = d[0],\n exponent = d[1];\n return exponent < 0 ? \"0.\" + new Array(-exponent).join(\"0\") + coefficient\n : coefficient.length > exponent + 1 ? coefficient.slice(0, exponent + 1) + \".\" + coefficient.slice(exponent + 1)\n : coefficient + new Array(exponent - coefficient.length + 2).join(\"0\");\n }\n\n var formatTypes = {\n \"\": formatDefault,\n \"%\": function(x, p) { return (x * 100).toFixed(p); },\n \"b\": function(x) { return Math.round(x).toString(2); },\n \"c\": function(x) { return x + \"\"; },\n \"d\": function(x) { return Math.round(x).toString(10); },\n \"e\": function(x, p) { return x.toExponential(p); },\n \"f\": function(x, p) { return x.toFixed(p); },\n \"g\": function(x, p) { return x.toPrecision(p); },\n \"o\": function(x) { return Math.round(x).toString(8); },\n \"p\": function(x, p) { return formatRounded(x * 100, p); },\n \"r\": formatRounded,\n \"s\": formatPrefixAuto,\n \"X\": function(x) { return Math.round(x).toString(16).toUpperCase(); },\n \"x\": function(x) { return Math.round(x).toString(16); }\n };\n\n // [[fill]align][sign][symbol][0][width][,][.precision][type]\n var re = /^(?:(.)?([<>=^]))?([+\\-\\( ])?([$#])?(0)?(\\d+)?(,)?(\\.\\d+)?([a-z%])?$/i;\n\n function formatSpecifier(specifier) {\n return new FormatSpecifier(specifier);\n }\n\n function FormatSpecifier(specifier) {\n if (!(match = re.exec(specifier))) throw new Error(\"invalid format: \" + specifier);\n\n var match,\n fill = match[1] || \" \",\n align = match[2] || \">\",\n sign = match[3] || \"-\",\n symbol = match[4] || \"\",\n zero = !!match[5],\n width = match[6] && +match[6],\n comma = !!match[7],\n precision = match[8] && +match[8].slice(1),\n type = match[9] || \"\";\n\n // The \"n\" type is an alias for \",g\".\n if (type === \"n\") comma = true, type = \"g\";\n\n // Map invalid types to the default format.\n else if (!formatTypes[type]) type = \"\";\n\n // If zero fill is specified, padding goes after sign and before digits.\n if (zero || (fill === \"0\" && align === \"=\")) zero = true, fill = \"0\", align = \"=\";\n\n this.fill = fill;\n this.align = align;\n this.sign = sign;\n this.symbol = symbol;\n this.zero = zero;\n this.width = width;\n this.comma = comma;\n this.precision = precision;\n this.type = type;\n }\n\n FormatSpecifier.prototype.toString = function() {\n return this.fill\n + this.align\n + this.sign\n + this.symbol\n + (this.zero ? \"0\" : \"\")\n + (this.width == null ? \"\" : Math.max(1, this.width | 0))\n + (this.comma ? \",\" : \"\")\n + (this.precision == null ? \"\" : \".\" + Math.max(0, this.precision | 0))\n + this.type;\n };\n\n var prefixes = [\"y\",\"z\",\"a\",\"f\",\"p\",\"n\",\"\\xB5\",\"m\",\"\",\"k\",\"M\",\"G\",\"T\",\"P\",\"E\",\"Z\",\"Y\"];\n\n function identity$3(x) {\n return x;\n }\n\n function formatLocale(locale) {\n var group = locale.grouping && locale.thousands ? formatGroup(locale.grouping, locale.thousands) : identity$3,\n currency = locale.currency,\n decimal = locale.decimal;\n\n function newFormat(specifier) {\n specifier = formatSpecifier(specifier);\n\n var fill = specifier.fill,\n align = specifier.align,\n sign = specifier.sign,\n symbol = specifier.symbol,\n zero = specifier.zero,\n width = specifier.width,\n comma = specifier.comma,\n precision = specifier.precision,\n type = specifier.type;\n\n // Compute the prefix and suffix.\n // For SI-prefix, the suffix is lazily computed.\n var prefix = symbol === \"$\" ? currency[0] : symbol === \"#\" && /[boxX]/.test(type) ? \"0\" + type.toLowerCase() : \"\",\n suffix = symbol === \"$\" ? currency[1] : /[%p]/.test(type) ? \"%\" : \"\";\n\n // What format function should we use?\n // Is this an integer type?\n // Can this type generate exponential notation?\n var formatType = formatTypes[type],\n maybeSuffix = !type || /[defgprs%]/.test(type);\n\n // Set the default precision if not specified,\n // or clamp the specified precision to the supported range.\n // For significant precision, it must be in [1, 21].\n // For fixed precision, it must be in [0, 20].\n precision = precision == null ? (type ? 6 : 12)\n : /[gprs]/.test(type) ? Math.max(1, Math.min(21, precision))\n : Math.max(0, Math.min(20, precision));\n\n function format(value) {\n var valuePrefix = prefix,\n valueSuffix = suffix,\n i, n, c;\n\n if (type === \"c\") {\n valueSuffix = formatType(value) + valueSuffix;\n value = \"\";\n } else {\n value = +value;\n\n // Convert negative to positive, and compute the prefix.\n // Note that -0 is not less than 0, but 1 / -0 is!\n var valueNegative = (value < 0 || 1 / value < 0) && (value *= -1, true);\n\n // Perform the initial formatting.\n value = formatType(value, precision);\n\n // If the original value was negative, it may be rounded to zero during\n // formatting; treat this as (positive) zero.\n if (valueNegative) {\n i = -1, n = value.length;\n valueNegative = false;\n while (++i < n) {\n if (c = value.charCodeAt(i), (48 < c && c < 58)\n || (type === \"x\" && 96 < c && c < 103)\n || (type === \"X\" && 64 < c && c < 71)) {\n valueNegative = true;\n break;\n }\n }\n }\n\n // Compute the prefix and suffix.\n valuePrefix = (valueNegative ? (sign === \"(\" ? sign : \"-\") : sign === \"-\" || sign === \"(\" ? \"\" : sign) + valuePrefix;\n valueSuffix = valueSuffix + (type === \"s\" ? prefixes[8 + prefixExponent / 3] : \"\") + (valueNegative && sign === \"(\" ? \")\" : \"\");\n\n // Break the formatted value into the integer “value†part that can be\n // grouped, and fractional or exponential “suffix†part that is not.\n if (maybeSuffix) {\n i = -1, n = value.length;\n while (++i < n) {\n if (c = value.charCodeAt(i), 48 > c || c > 57) {\n valueSuffix = (c === 46 ? decimal + value.slice(i + 1) : value.slice(i)) + valueSuffix;\n value = value.slice(0, i);\n break;\n }\n }\n }\n }\n\n // If the fill character is not \"0\", grouping is applied before padding.\n if (comma && !zero) value = group(value, Infinity);\n\n // Compute the padding.\n var length = valuePrefix.length + value.length + valueSuffix.length,\n padding = length < width ? new Array(width - length + 1).join(fill) : \"\";\n\n // If the fill character is \"0\", grouping is applied after padding.\n if (comma && zero) value = group(padding + value, padding.length ? width - valueSuffix.length : Infinity), padding = \"\";\n\n // Reconstruct the final output based on the desired alignment.\n switch (align) {\n case \"<\": return valuePrefix + value + valueSuffix + padding;\n case \"=\": return valuePrefix + padding + value + valueSuffix;\n case \"^\": return padding.slice(0, length = padding.length >> 1) + valuePrefix + value + valueSuffix + padding.slice(length);\n }\n return padding + valuePrefix + value + valueSuffix;\n }\n\n format.toString = function() {\n return specifier + \"\";\n };\n\n return format;\n }\n\n function formatPrefix(specifier, value) {\n var f = newFormat((specifier = formatSpecifier(specifier), specifier.type = \"f\", specifier)),\n e = Math.max(-8, Math.min(8, Math.floor(exponent$1(value) / 3))) * 3,\n k = Math.pow(10, -e),\n prefix = prefixes[8 + e / 3];\n return function(value) {\n return f(k * value) + prefix;\n };\n }\n\n return {\n format: newFormat,\n formatPrefix: formatPrefix\n };\n }\n\n var locale;\n exports.format;\n exports.formatPrefix;\n\n defaultLocale({\n decimal: \".\",\n thousands: \",\",\n grouping: [3],\n currency: [\"$\", \"\"]\n });\n\n function defaultLocale(definition) {\n locale = formatLocale(definition);\n exports.format = locale.format;\n exports.formatPrefix = locale.formatPrefix;\n return locale;\n }\n\n function precisionFixed(step) {\n return Math.max(0, -exponent$1(Math.abs(step)));\n }\n\n function precisionPrefix(step, value) {\n return Math.max(0, Math.max(-8, Math.min(8, Math.floor(exponent$1(value) / 3))) * 3 - exponent$1(Math.abs(step)));\n }\n\n function precisionRound(step, max) {\n step = Math.abs(step), max = Math.abs(max) - step;\n return Math.max(0, exponent$1(max) - exponent$1(step)) + 1;\n }\n\n function localDate(d) {\n if (0 <= d.y && d.y < 100) {\n var date = new Date(-1, d.m, d.d, d.H, d.M, d.S, d.L);\n date.setFullYear(d.y);\n return date;\n }\n return new Date(d.y, d.m, d.d, d.H, d.M, d.S, d.L);\n }\n\n function utcDate(d) {\n if (0 <= d.y && d.y < 100) {\n var date = new Date(Date.UTC(-1, d.m, d.d, d.H, d.M, d.S, d.L));\n date.setUTCFullYear(d.y);\n return date;\n }\n return new Date(Date.UTC(d.y, d.m, d.d, d.H, d.M, d.S, d.L));\n }\n\n function newYear(y) {\n return {y: y, m: 0, d: 1, H: 0, M: 0, S: 0, L: 0};\n }\n\n function formatLocale$1(locale) {\n var locale_dateTime = locale.dateTime,\n locale_date = locale.date,\n locale_time = locale.time,\n locale_periods = locale.periods,\n locale_weekdays = locale.days,\n locale_shortWeekdays = locale.shortDays,\n locale_months = locale.months,\n locale_shortMonths = locale.shortMonths;\n\n var periodRe = formatRe(locale_periods),\n periodLookup = formatLookup(locale_periods),\n weekdayRe = formatRe(locale_weekdays),\n weekdayLookup = formatLookup(locale_weekdays),\n shortWeekdayRe = formatRe(locale_shortWeekdays),\n shortWeekdayLookup = formatLookup(locale_shortWeekdays),\n monthRe = formatRe(locale_months),\n monthLookup = formatLookup(locale_months),\n shortMonthRe = formatRe(locale_shortMonths),\n shortMonthLookup = formatLookup(locale_shortMonths);\n\n var formats = {\n \"a\": formatShortWeekday,\n \"A\": formatWeekday,\n \"b\": formatShortMonth,\n \"B\": formatMonth,\n \"c\": null,\n \"d\": formatDayOfMonth,\n \"e\": formatDayOfMonth,\n \"H\": formatHour24,\n \"I\": formatHour12,\n \"j\": formatDayOfYear,\n \"L\": formatMilliseconds,\n \"m\": formatMonthNumber,\n \"M\": formatMinutes,\n \"p\": formatPeriod,\n \"S\": formatSeconds,\n \"U\": formatWeekNumberSunday,\n \"w\": formatWeekdayNumber,\n \"W\": formatWeekNumberMonday,\n \"x\": null,\n \"X\": null,\n \"y\": formatYear,\n \"Y\": formatFullYear,\n \"Z\": formatZone,\n \"%\": formatLiteralPercent\n };\n\n var utcFormats = {\n \"a\": formatUTCShortWeekday,\n \"A\": formatUTCWeekday,\n \"b\": formatUTCShortMonth,\n \"B\": formatUTCMonth,\n \"c\": null,\n \"d\": formatUTCDayOfMonth,\n \"e\": formatUTCDayOfMonth,\n \"H\": formatUTCHour24,\n \"I\": formatUTCHour12,\n \"j\": formatUTCDayOfYear,\n \"L\": formatUTCMilliseconds,\n \"m\": formatUTCMonthNumber,\n \"M\": formatUTCMinutes,\n \"p\": formatUTCPeriod,\n \"S\": formatUTCSeconds,\n \"U\": formatUTCWeekNumberSunday,\n \"w\": formatUTCWeekdayNumber,\n \"W\": formatUTCWeekNumberMonday,\n \"x\": null,\n \"X\": null,\n \"y\": formatUTCYear,\n \"Y\": formatUTCFullYear,\n \"Z\": formatUTCZone,\n \"%\": formatLiteralPercent\n };\n\n var parses = {\n \"a\": parseShortWeekday,\n \"A\": parseWeekday,\n \"b\": parseShortMonth,\n \"B\": parseMonth,\n \"c\": parseLocaleDateTime,\n \"d\": parseDayOfMonth,\n \"e\": parseDayOfMonth,\n \"H\": parseHour24,\n \"I\": parseHour24,\n \"j\": parseDayOfYear,\n \"L\": parseMilliseconds,\n \"m\": parseMonthNumber,\n \"M\": parseMinutes,\n \"p\": parsePeriod,\n \"S\": parseSeconds,\n \"U\": parseWeekNumberSunday,\n \"w\": parseWeekdayNumber,\n \"W\": parseWeekNumberMonday,\n \"x\": parseLocaleDate,\n \"X\": parseLocaleTime,\n \"y\": parseYear,\n \"Y\": parseFullYear,\n \"Z\": parseZone,\n \"%\": parseLiteralPercent\n };\n\n // These recursive directive definitions must be deferred.\n formats.x = newFormat(locale_date, formats);\n formats.X = newFormat(locale_time, formats);\n formats.c = newFormat(locale_dateTime, formats);\n utcFormats.x = newFormat(locale_date, utcFormats);\n utcFormats.X = newFormat(locale_time, utcFormats);\n utcFormats.c = newFormat(locale_dateTime, utcFormats);\n\n function newFormat(specifier, formats) {\n return function(date) {\n var string = [],\n i = -1,\n j = 0,\n n = specifier.length,\n c,\n pad,\n format;\n\n if (!(date instanceof Date)) date = new Date(+date);\n\n while (++i < n) {\n if (specifier.charCodeAt(i) === 37) {\n string.push(specifier.slice(j, i));\n if ((pad = pads[c = specifier.charAt(++i)]) != null) c = specifier.charAt(++i);\n else pad = c === \"e\" ? \" \" : \"0\";\n if (format = formats[c]) c = format(date, pad);\n string.push(c);\n j = i + 1;\n }\n }\n\n string.push(specifier.slice(j, i));\n return string.join(\"\");\n };\n }\n\n function newParse(specifier, newDate) {\n return function(string) {\n var d = newYear(1900),\n i = parseSpecifier(d, specifier, string += \"\", 0);\n if (i != string.length) return null;\n\n // The am-pm flag is 0 for AM, and 1 for PM.\n if (\"p\" in d) d.H = d.H % 12 + d.p * 12;\n\n // Convert day-of-week and week-of-year to day-of-year.\n if (\"W\" in d || \"U\" in d) {\n if (!(\"w\" in d)) d.w = \"W\" in d ? 1 : 0;\n var day = \"Z\" in d ? utcDate(newYear(d.y)).getUTCDay() : newDate(newYear(d.y)).getDay();\n d.m = 0;\n d.d = \"W\" in d ? (d.w + 6) % 7 + d.W * 7 - (day + 5) % 7 : d.w + d.U * 7 - (day + 6) % 7;\n }\n\n // If a time zone is specified, all fields are interpreted as UTC and then\n // offset according to the specified time zone.\n if (\"Z\" in d) {\n d.H += d.Z / 100 | 0;\n d.M += d.Z % 100;\n return utcDate(d);\n }\n\n // Otherwise, all fields are in local time.\n return newDate(d);\n };\n }\n\n function parseSpecifier(d, specifier, string, j) {\n var i = 0,\n n = specifier.length,\n m = string.length,\n c,\n parse;\n\n while (i < n) {\n if (j >= m) return -1;\n c = specifier.charCodeAt(i++);\n if (c === 37) {\n c = specifier.charAt(i++);\n parse = parses[c in pads ? specifier.charAt(i++) : c];\n if (!parse || ((j = parse(d, string, j)) < 0)) return -1;\n } else if (c != string.charCodeAt(j++)) {\n return -1;\n }\n }\n\n return j;\n }\n\n function parsePeriod(d, string, i) {\n var n = periodRe.exec(string.slice(i));\n return n ? (d.p = periodLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseShortWeekday(d, string, i) {\n var n = shortWeekdayRe.exec(string.slice(i));\n return n ? (d.w = shortWeekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseWeekday(d, string, i) {\n var n = weekdayRe.exec(string.slice(i));\n return n ? (d.w = weekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseShortMonth(d, string, i) {\n var n = shortMonthRe.exec(string.slice(i));\n return n ? (d.m = shortMonthLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseMonth(d, string, i) {\n var n = monthRe.exec(string.slice(i));\n return n ? (d.m = monthLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseLocaleDateTime(d, string, i) {\n return parseSpecifier(d, locale_dateTime, string, i);\n }\n\n function parseLocaleDate(d, string, i) {\n return parseSpecifier(d, locale_date, string, i);\n }\n\n function parseLocaleTime(d, string, i) {\n return parseSpecifier(d, locale_time, string, i);\n }\n\n function formatShortWeekday(d) {\n return locale_shortWeekdays[d.getDay()];\n }\n\n function formatWeekday(d) {\n return locale_weekdays[d.getDay()];\n }\n\n function formatShortMonth(d) {\n return locale_shortMonths[d.getMonth()];\n }\n\n function formatMonth(d) {\n return locale_months[d.getMonth()];\n }\n\n function formatPeriod(d) {\n return locale_periods[+(d.getHours() >= 12)];\n }\n\n function formatUTCShortWeekday(d) {\n return locale_shortWeekdays[d.getUTCDay()];\n }\n\n function formatUTCWeekday(d) {\n return locale_weekdays[d.getUTCDay()];\n }\n\n function formatUTCShortMonth(d) {\n return locale_shortMonths[d.getUTCMonth()];\n }\n\n function formatUTCMonth(d) {\n return locale_months[d.getUTCMonth()];\n }\n\n function formatUTCPeriod(d) {\n return locale_periods[+(d.getUTCHours() >= 12)];\n }\n\n return {\n format: function(specifier) {\n var f = newFormat(specifier += \"\", formats);\n f.toString = function() { return specifier; };\n return f;\n },\n parse: function(specifier) {\n var p = newParse(specifier += \"\", localDate);\n p.toString = function() { return specifier; };\n return p;\n },\n utcFormat: function(specifier) {\n var f = newFormat(specifier += \"\", utcFormats);\n f.toString = function() { return specifier; };\n return f;\n },\n utcParse: function(specifier) {\n var p = newParse(specifier, utcDate);\n p.toString = function() { return specifier; };\n return p;\n }\n };\n }\n\n var pads = {\"-\": \"\", \"_\": \" \", \"0\": \"0\"};\n var numberRe = /^\\s*\\d+/;\n var percentRe = /^%/;\n var requoteRe = /[\\\\\\^\\$\\*\\+\\?\\|\\[\\]\\(\\)\\.\\{\\}]/g;\n function pad(value, fill, width) {\n var sign = value < 0 ? \"-\" : \"\",\n string = (sign ? -value : value) + \"\",\n length = string.length;\n return sign + (length < width ? new Array(width - length + 1).join(fill) + string : string);\n }\n\n function requote(s) {\n return s.replace(requoteRe, \"\\\\$&\");\n }\n\n function formatRe(names) {\n return new RegExp(\"^(?:\" + names.map(requote).join(\"|\") + \")\", \"i\");\n }\n\n function formatLookup(names) {\n var map = {}, i = -1, n = names.length;\n while (++i < n) map[names[i].toLowerCase()] = i;\n return map;\n }\n\n function parseWeekdayNumber(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 1));\n return n ? (d.w = +n[0], i + n[0].length) : -1;\n }\n\n function parseWeekNumberSunday(d, string, i) {\n var n = numberRe.exec(string.slice(i));\n return n ? (d.U = +n[0], i + n[0].length) : -1;\n }\n\n function parseWeekNumberMonday(d, string, i) {\n var n = numberRe.exec(string.slice(i));\n return n ? (d.W = +n[0], i + n[0].length) : -1;\n }\n\n function parseFullYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 4));\n return n ? (d.y = +n[0], i + n[0].length) : -1;\n }\n\n function parseYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.y = +n[0] + (+n[0] > 68 ? 1900 : 2000), i + n[0].length) : -1;\n }\n\n function parseZone(d, string, i) {\n var n = /^(Z)|([+-]\\d\\d)(?:\\:?(\\d\\d))?/.exec(string.slice(i, i + 6));\n return n ? (d.Z = n[1] ? 0 : -(n[2] + (n[3] || \"00\")), i + n[0].length) : -1;\n }\n\n function parseMonthNumber(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.m = n[0] - 1, i + n[0].length) : -1;\n }\n\n function parseDayOfMonth(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.d = +n[0], i + n[0].length) : -1;\n }\n\n function parseDayOfYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 3));\n return n ? (d.m = 0, d.d = +n[0], i + n[0].length) : -1;\n }\n\n function parseHour24(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.H = +n[0], i + n[0].length) : -1;\n }\n\n function parseMinutes(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.M = +n[0], i + n[0].length) : -1;\n }\n\n function parseSeconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.S = +n[0], i + n[0].length) : -1;\n }\n\n function parseMilliseconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 3));\n return n ? (d.L = +n[0], i + n[0].length) : -1;\n }\n\n function parseLiteralPercent(d, string, i) {\n var n = percentRe.exec(string.slice(i, i + 1));\n return n ? i + n[0].length : -1;\n }\n\n function formatDayOfMonth(d, p) {\n return pad(d.getDate(), p, 2);\n }\n\n function formatHour24(d, p) {\n return pad(d.getHours(), p, 2);\n }\n\n function formatHour12(d, p) {\n return pad(d.getHours() % 12 || 12, p, 2);\n }\n\n function formatDayOfYear(d, p) {\n return pad(1 + day.count(year(d), d), p, 3);\n }\n\n function formatMilliseconds(d, p) {\n return pad(d.getMilliseconds(), p, 3);\n }\n\n function formatMonthNumber(d, p) {\n return pad(d.getMonth() + 1, p, 2);\n }\n\n function formatMinutes(d, p) {\n return pad(d.getMinutes(), p, 2);\n }\n\n function formatSeconds(d, p) {\n return pad(d.getSeconds(), p, 2);\n }\n\n function formatWeekNumberSunday(d, p) {\n return pad(timeWeek.count(year(d), d), p, 2);\n }\n\n function formatWeekdayNumber(d) {\n return d.getDay();\n }\n\n function formatWeekNumberMonday(d, p) {\n return pad(timeMonday.count(year(d), d), p, 2);\n }\n\n function formatYear(d, p) {\n return pad(d.getFullYear() % 100, p, 2);\n }\n\n function formatFullYear(d, p) {\n return pad(d.getFullYear() % 10000, p, 4);\n }\n\n function formatZone(d) {\n var z = d.getTimezoneOffset();\n return (z > 0 ? \"-\" : (z *= -1, \"+\"))\n + pad(z / 60 | 0, \"0\", 2)\n + pad(z % 60, \"0\", 2);\n }\n\n function formatUTCDayOfMonth(d, p) {\n return pad(d.getUTCDate(), p, 2);\n }\n\n function formatUTCHour24(d, p) {\n return pad(d.getUTCHours(), p, 2);\n }\n\n function formatUTCHour12(d, p) {\n return pad(d.getUTCHours() % 12 || 12, p, 2);\n }\n\n function formatUTCDayOfYear(d, p) {\n return pad(1 + utcDay.count(utcYear(d), d), p, 3);\n }\n\n function formatUTCMilliseconds(d, p) {\n return pad(d.getUTCMilliseconds(), p, 3);\n }\n\n function formatUTCMonthNumber(d, p) {\n return pad(d.getUTCMonth() + 1, p, 2);\n }\n\n function formatUTCMinutes(d, p) {\n return pad(d.getUTCMinutes(), p, 2);\n }\n\n function formatUTCSeconds(d, p) {\n return pad(d.getUTCSeconds(), p, 2);\n }\n\n function formatUTCWeekNumberSunday(d, p) {\n return pad(utcWeek.count(utcYear(d), d), p, 2);\n }\n\n function formatUTCWeekdayNumber(d) {\n return d.getUTCDay();\n }\n\n function formatUTCWeekNumberMonday(d, p) {\n return pad(utcMonday.count(utcYear(d), d), p, 2);\n }\n\n function formatUTCYear(d, p) {\n return pad(d.getUTCFullYear() % 100, p, 2);\n }\n\n function formatUTCFullYear(d, p) {\n return pad(d.getUTCFullYear() % 10000, p, 4);\n }\n\n function formatUTCZone() {\n return \"+0000\";\n }\n\n function formatLiteralPercent() {\n return \"%\";\n }\n\n var locale$1;\n exports.timeFormat;\n exports.timeParse;\n exports.utcFormat;\n exports.utcParse;\n\n defaultLocale$1({\n dateTime: \"%x, %X\",\n date: \"%-m/%-d/%Y\",\n time: \"%-I:%M:%S %p\",\n periods: [\"AM\", \"PM\"],\n days: [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\"],\n shortDays: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n months: [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"],\n shortMonths: [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"]\n });\n\n function defaultLocale$1(definition) {\n locale$1 = formatLocale$1(definition);\n exports.timeFormat = locale$1.format;\n exports.timeParse = locale$1.parse;\n exports.utcFormat = locale$1.utcFormat;\n exports.utcParse = locale$1.utcParse;\n return locale$1;\n }\n\n var isoSpecifier = \"%Y-%m-%dT%H:%M:%S.%LZ\";\n\n function formatIsoNative(date) {\n return date.toISOString();\n }\n\n var formatIso = Date.prototype.toISOString\n ? formatIsoNative\n : exports.utcFormat(isoSpecifier);\n\n function parseIsoNative(string) {\n var date = new Date(string);\n return isNaN(date) ? null : date;\n }\n\n var parseIso = +new Date(\"2000-01-01T00:00:00.000Z\")\n ? parseIsoNative\n : exports.utcParse(isoSpecifier);\n\n var array$2 = Array.prototype;\n\n var map$2 = array$2.map;\n var slice$3 = array$2.slice;\n\n var implicit = {name: \"implicit\"};\n\n function ordinal(range) {\n var index = map$1(),\n domain = [],\n unknown = implicit;\n\n range = range == null ? [] : slice$3.call(range);\n\n function scale(d) {\n var key = d + \"\", i = index.get(key);\n if (!i) {\n if (unknown !== implicit) return unknown;\n index.set(key, i = domain.push(d));\n }\n return range[(i - 1) % range.length];\n }\n\n scale.domain = function(_) {\n if (!arguments.length) return domain.slice();\n domain = [], index = map$1();\n var i = -1, n = _.length, d, key;\n while (++i < n) if (!index.has(key = (d = _[i]) + \"\")) index.set(key, domain.push(d));\n return scale;\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = slice$3.call(_), scale) : range.slice();\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n scale.copy = function() {\n return ordinal()\n .domain(domain)\n .range(range)\n .unknown(unknown);\n };\n\n return scale;\n }\n\n function band() {\n var scale = ordinal().unknown(undefined),\n domain = scale.domain,\n ordinalRange = scale.range,\n range$$ = [0, 1],\n step,\n bandwidth,\n round = false,\n paddingInner = 0,\n paddingOuter = 0,\n align = 0.5;\n\n delete scale.unknown;\n\n function rescale() {\n var n = domain().length,\n reverse = range$$[1] < range$$[0],\n start = range$$[reverse - 0],\n stop = range$$[1 - reverse];\n step = (stop - start) / Math.max(1, n - paddingInner + paddingOuter * 2);\n if (round) step = Math.floor(step);\n start += (stop - start - step * (n - paddingInner)) * align;\n bandwidth = step * (1 - paddingInner);\n if (round) start = Math.round(start), bandwidth = Math.round(bandwidth);\n var values = range(n).map(function(i) { return start + step * i; });\n return ordinalRange(reverse ? values.reverse() : values);\n }\n\n scale.domain = function(_) {\n return arguments.length ? (domain(_), rescale()) : domain();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range$$ = [+_[0], +_[1]], rescale()) : range$$.slice();\n };\n\n scale.rangeRound = function(_) {\n return range$$ = [+_[0], +_[1]], round = true, rescale();\n };\n\n scale.bandwidth = function() {\n return bandwidth;\n };\n\n scale.step = function() {\n return step;\n };\n\n scale.round = function(_) {\n return arguments.length ? (round = !!_, rescale()) : round;\n };\n\n scale.padding = function(_) {\n return arguments.length ? (paddingInner = paddingOuter = Math.max(0, Math.min(1, _)), rescale()) : paddingInner;\n };\n\n scale.paddingInner = function(_) {\n return arguments.length ? (paddingInner = Math.max(0, Math.min(1, _)), rescale()) : paddingInner;\n };\n\n scale.paddingOuter = function(_) {\n return arguments.length ? (paddingOuter = Math.max(0, Math.min(1, _)), rescale()) : paddingOuter;\n };\n\n scale.align = function(_) {\n return arguments.length ? (align = Math.max(0, Math.min(1, _)), rescale()) : align;\n };\n\n scale.copy = function() {\n return band()\n .domain(domain())\n .range(range$$)\n .round(round)\n .paddingInner(paddingInner)\n .paddingOuter(paddingOuter)\n .align(align);\n };\n\n return rescale();\n }\n\n function pointish(scale) {\n var copy = scale.copy;\n\n scale.padding = scale.paddingOuter;\n delete scale.paddingInner;\n delete scale.paddingOuter;\n\n scale.copy = function() {\n return pointish(copy());\n };\n\n return scale;\n }\n\n function point$4() {\n return pointish(band().paddingInner(1));\n }\n\n function constant$3(x) {\n return function() {\n return x;\n };\n }\n\n function number$1(x) {\n return +x;\n }\n\n var unit = [0, 1];\n\n function deinterpolate(a, b) {\n return (b -= (a = +a))\n ? function(x) { return (x - a) / b; }\n : constant$3(b);\n }\n\n function deinterpolateClamp(deinterpolate) {\n return function(a, b) {\n var d = deinterpolate(a = +a, b = +b);\n return function(x) { return x <= a ? 0 : x >= b ? 1 : d(x); };\n };\n }\n\n function reinterpolateClamp(reinterpolate) {\n return function(a, b) {\n var r = reinterpolate(a = +a, b = +b);\n return function(t) { return t <= 0 ? a : t >= 1 ? b : r(t); };\n };\n }\n\n function bimap(domain, range, deinterpolate, reinterpolate) {\n var d0 = domain[0], d1 = domain[1], r0 = range[0], r1 = range[1];\n if (d1 < d0) d0 = deinterpolate(d1, d0), r0 = reinterpolate(r1, r0);\n else d0 = deinterpolate(d0, d1), r0 = reinterpolate(r0, r1);\n return function(x) { return r0(d0(x)); };\n }\n\n function polymap(domain, range, deinterpolate, reinterpolate) {\n var j = Math.min(domain.length, range.length) - 1,\n d = new Array(j),\n r = new Array(j),\n i = -1;\n\n // Reverse descending domains.\n if (domain[j] < domain[0]) {\n domain = domain.slice().reverse();\n range = range.slice().reverse();\n }\n\n while (++i < j) {\n d[i] = deinterpolate(domain[i], domain[i + 1]);\n r[i] = reinterpolate(range[i], range[i + 1]);\n }\n\n return function(x) {\n var i = bisectRight(domain, x, 1, j) - 1;\n return r[i](d[i](x));\n };\n }\n\n function copy(source, target) {\n return target\n .domain(source.domain())\n .range(source.range())\n .interpolate(source.interpolate())\n .clamp(source.clamp());\n }\n\n // deinterpolate(a, b)(x) takes a domain value x in [a,b] and returns the corresponding parameter t in [0,1].\n // reinterpolate(a, b)(t) takes a parameter t in [0,1] and returns the corresponding domain value x in [a,b].\n function continuous(deinterpolate$$, reinterpolate) {\n var domain = unit,\n range = unit,\n interpolate$$ = interpolate,\n clamp = false,\n piecewise,\n output,\n input;\n\n function rescale() {\n piecewise = Math.min(domain.length, range.length) > 2 ? polymap : bimap;\n output = input = null;\n return scale;\n }\n\n function scale(x) {\n return (output || (output = piecewise(domain, range, clamp ? deinterpolateClamp(deinterpolate$$) : deinterpolate$$, interpolate$$)))(+x);\n }\n\n scale.invert = function(y) {\n return (input || (input = piecewise(range, domain, deinterpolate, clamp ? reinterpolateClamp(reinterpolate) : reinterpolate)))(+y);\n };\n\n scale.domain = function(_) {\n return arguments.length ? (domain = map$2.call(_, number$1), rescale()) : domain.slice();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = slice$3.call(_), rescale()) : range.slice();\n };\n\n scale.rangeRound = function(_) {\n return range = slice$3.call(_), interpolate$$ = interpolateRound, rescale();\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (clamp = !!_, rescale()) : clamp;\n };\n\n scale.interpolate = function(_) {\n return arguments.length ? (interpolate$$ = _, rescale()) : interpolate$$;\n };\n\n return rescale();\n }\n\n function tickFormat(domain, count, specifier) {\n var start = domain[0],\n stop = domain[domain.length - 1],\n step = tickStep(start, stop, count == null ? 10 : count),\n precision;\n specifier = formatSpecifier(specifier == null ? \",f\" : specifier);\n switch (specifier.type) {\n case \"s\": {\n var value = Math.max(Math.abs(start), Math.abs(stop));\n if (specifier.precision == null && !isNaN(precision = precisionPrefix(step, value))) specifier.precision = precision;\n return exports.formatPrefix(specifier, value);\n }\n case \"\":\n case \"e\":\n case \"g\":\n case \"p\":\n case \"r\": {\n if (specifier.precision == null && !isNaN(precision = precisionRound(step, Math.max(Math.abs(start), Math.abs(stop))))) specifier.precision = precision - (specifier.type === \"e\");\n break;\n }\n case \"f\":\n case \"%\": {\n if (specifier.precision == null && !isNaN(precision = precisionFixed(step))) specifier.precision = precision - (specifier.type === \"%\") * 2;\n break;\n }\n }\n return exports.format(specifier);\n }\n\n function linearish(scale) {\n var domain = scale.domain;\n\n scale.ticks = function(count) {\n var d = domain();\n return ticks(d[0], d[d.length - 1], count == null ? 10 : count);\n };\n\n scale.tickFormat = function(count, specifier) {\n return tickFormat(domain(), count, specifier);\n };\n\n scale.nice = function(count) {\n var d = domain(),\n i = d.length - 1,\n n = count == null ? 10 : count,\n start = d[0],\n stop = d[i],\n step = tickStep(start, stop, n);\n\n if (step) {\n step = tickStep(Math.floor(start / step) * step, Math.ceil(stop / step) * step, n);\n d[0] = Math.floor(start / step) * step;\n d[i] = Math.ceil(stop / step) * step;\n domain(d);\n }\n\n return scale;\n };\n\n return scale;\n }\n\n function linear$2() {\n var scale = continuous(deinterpolate, interpolateNumber);\n\n scale.copy = function() {\n return copy(scale, linear$2());\n };\n\n return linearish(scale);\n }\n\n function identity$4() {\n var domain = [0, 1];\n\n function scale(x) {\n return +x;\n }\n\n scale.invert = scale;\n\n scale.domain = scale.range = function(_) {\n return arguments.length ? (domain = map$2.call(_, number$1), scale) : domain.slice();\n };\n\n scale.copy = function() {\n return identity$4().domain(domain);\n };\n\n return linearish(scale);\n }\n\n function nice(domain, interval) {\n domain = domain.slice();\n\n var i0 = 0,\n i1 = domain.length - 1,\n x0 = domain[i0],\n x1 = domain[i1],\n t;\n\n if (x1 < x0) {\n t = i0, i0 = i1, i1 = t;\n t = x0, x0 = x1, x1 = t;\n }\n\n domain[i0] = interval.floor(x0);\n domain[i1] = interval.ceil(x1);\n return domain;\n }\n\n function deinterpolate$1(a, b) {\n return (b = Math.log(b / a))\n ? function(x) { return Math.log(x / a) / b; }\n : constant$3(b);\n }\n\n function reinterpolate(a, b) {\n return a < 0\n ? function(t) { return -Math.pow(-b, t) * Math.pow(-a, 1 - t); }\n : function(t) { return Math.pow(b, t) * Math.pow(a, 1 - t); };\n }\n\n function pow10(x) {\n return isFinite(x) ? +(\"1e\" + x) : x < 0 ? 0 : x;\n }\n\n function powp(base) {\n return base === 10 ? pow10\n : base === Math.E ? Math.exp\n : function(x) { return Math.pow(base, x); };\n }\n\n function logp(base) {\n return base === Math.E ? Math.log\n : base === 10 && Math.log10\n || base === 2 && Math.log2\n || (base = Math.log(base), function(x) { return Math.log(x) / base; });\n }\n\n function reflect(f) {\n return function(x) {\n return -f(-x);\n };\n }\n\n function log() {\n var scale = continuous(deinterpolate$1, reinterpolate).domain([1, 10]),\n domain = scale.domain,\n base = 10,\n logs = logp(10),\n pows = powp(10);\n\n function rescale() {\n logs = logp(base), pows = powp(base);\n if (domain()[0] < 0) logs = reflect(logs), pows = reflect(pows);\n return scale;\n }\n\n scale.base = function(_) {\n return arguments.length ? (base = +_, rescale()) : base;\n };\n\n scale.domain = function(_) {\n return arguments.length ? (domain(_), rescale()) : domain();\n };\n\n scale.ticks = function(count) {\n var d = domain(),\n u = d[0],\n v = d[d.length - 1],\n r;\n\n if (r = v < u) i = u, u = v, v = i;\n\n var i = logs(u),\n j = logs(v),\n p,\n k,\n t,\n n = count == null ? 10 : +count,\n z = [];\n\n if (!(base % 1) && j - i < n) {\n i = Math.round(i) - 1, j = Math.round(j) + 1;\n if (u > 0) for (; i < j; ++i) {\n for (k = 1, p = pows(i); k < base; ++k) {\n t = p * k;\n if (t < u) continue;\n if (t > v) break;\n z.push(t);\n }\n } else for (; i < j; ++i) {\n for (k = base - 1, p = pows(i); k >= 1; --k) {\n t = p * k;\n if (t < u) continue;\n if (t > v) break;\n z.push(t);\n }\n }\n } else {\n z = ticks(i, j, Math.min(j - i, n)).map(pows);\n }\n\n return r ? z.reverse() : z;\n };\n\n scale.tickFormat = function(count, specifier) {\n if (specifier == null) specifier = base === 10 ? \".0e\" : \",\";\n if (typeof specifier !== \"function\") specifier = exports.format(specifier);\n if (count === Infinity) return specifier;\n if (count == null) count = 10;\n var k = Math.max(1, base * count / scale.ticks().length); // TODO fast estimate?\n return function(d) {\n var i = d / pows(Math.round(logs(d)));\n if (i * base < base - 0.5) i *= base;\n return i <= k ? specifier(d) : \"\";\n };\n };\n\n scale.nice = function() {\n return domain(nice(domain(), {\n floor: function(x) { return pows(Math.floor(logs(x))); },\n ceil: function(x) { return pows(Math.ceil(logs(x))); }\n }));\n };\n\n scale.copy = function() {\n return copy(scale, log().base(base));\n };\n\n return scale;\n }\n\n function raise(x, exponent) {\n return x < 0 ? -Math.pow(-x, exponent) : Math.pow(x, exponent);\n }\n\n function pow() {\n var exponent = 1,\n scale = continuous(deinterpolate, reinterpolate),\n domain = scale.domain;\n\n function deinterpolate(a, b) {\n return (b = raise(b, exponent) - (a = raise(a, exponent)))\n ? function(x) { return (raise(x, exponent) - a) / b; }\n : constant$3(b);\n }\n\n function reinterpolate(a, b) {\n b = raise(b, exponent) - (a = raise(a, exponent));\n return function(t) { return raise(a + b * t, 1 / exponent); };\n }\n\n scale.exponent = function(_) {\n return arguments.length ? (exponent = +_, domain(domain())) : exponent;\n };\n\n scale.copy = function() {\n return copy(scale, pow().exponent(exponent));\n };\n\n return linearish(scale);\n }\n\n function sqrt() {\n return pow().exponent(0.5);\n }\n\n function quantile() {\n var domain = [],\n range = [],\n thresholds = [];\n\n function rescale() {\n var i = 0, n = Math.max(1, range.length);\n thresholds = new Array(n - 1);\n while (++i < n) thresholds[i - 1] = threshold(domain, i / n);\n return scale;\n }\n\n function scale(x) {\n if (!isNaN(x = +x)) return range[bisectRight(thresholds, x)];\n }\n\n scale.invertExtent = function(y) {\n var i = range.indexOf(y);\n return i < 0 ? [NaN, NaN] : [\n i > 0 ? thresholds[i - 1] : domain[0],\n i < thresholds.length ? thresholds[i] : domain[domain.length - 1]\n ];\n };\n\n scale.domain = function(_) {\n if (!arguments.length) return domain.slice();\n domain = [];\n for (var i = 0, n = _.length, d; i < n; ++i) if (d = _[i], d != null && !isNaN(d = +d)) domain.push(d);\n domain.sort(ascending);\n return rescale();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = slice$3.call(_), rescale()) : range.slice();\n };\n\n scale.quantiles = function() {\n return thresholds.slice();\n };\n\n scale.copy = function() {\n return quantile()\n .domain(domain)\n .range(range);\n };\n\n return scale;\n }\n\n function quantize$1() {\n var x0 = 0,\n x1 = 1,\n n = 1,\n domain = [0.5],\n range = [0, 1];\n\n function scale(x) {\n if (x <= x) return range[bisectRight(domain, x, 0, n)];\n }\n\n function rescale() {\n var i = -1;\n domain = new Array(n);\n while (++i < n) domain[i] = ((i + 1) * x1 - (i - n) * x0) / (n + 1);\n return scale;\n }\n\n scale.domain = function(_) {\n return arguments.length ? (x0 = +_[0], x1 = +_[1], rescale()) : [x0, x1];\n };\n\n scale.range = function(_) {\n return arguments.length ? (n = (range = slice$3.call(_)).length - 1, rescale()) : range.slice();\n };\n\n scale.invertExtent = function(y) {\n var i = range.indexOf(y);\n return i < 0 ? [NaN, NaN]\n : i < 1 ? [x0, domain[0]]\n : i >= n ? [domain[n - 1], x1]\n : [domain[i - 1], domain[i]];\n };\n\n scale.copy = function() {\n return quantize$1()\n .domain([x0, x1])\n .range(range);\n };\n\n return linearish(scale);\n }\n\n function threshold$1() {\n var domain = [0.5],\n range = [0, 1],\n n = 1;\n\n function scale(x) {\n if (x <= x) return range[bisectRight(domain, x, 0, n)];\n }\n\n scale.domain = function(_) {\n return arguments.length ? (domain = slice$3.call(_), n = Math.min(domain.length, range.length - 1), scale) : domain.slice();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = slice$3.call(_), n = Math.min(domain.length, range.length - 1), scale) : range.slice();\n };\n\n scale.invertExtent = function(y) {\n var i = range.indexOf(y);\n return [domain[i - 1], domain[i]];\n };\n\n scale.copy = function() {\n return threshold$1()\n .domain(domain)\n .range(range);\n };\n\n return scale;\n }\n\nvar durationSecond$1 = 1000;\nvar durationMinute$1 = durationSecond$1 * 60;\nvar durationHour$1 = durationMinute$1 * 60;\nvar durationDay$1 = durationHour$1 * 24;\nvar durationWeek$1 = durationDay$1 * 7;\n var durationMonth = durationDay$1 * 30;\n var durationYear = durationDay$1 * 365;\n function date$1(t) {\n return new Date(t);\n }\n\n function number$2(t) {\n return t instanceof Date ? +t : +new Date(+t);\n }\n\n function calendar(year, month, week, day, hour, minute, second, millisecond, format) {\n var scale = continuous(deinterpolate, interpolateNumber),\n invert = scale.invert,\n domain = scale.domain;\n\n var formatMillisecond = format(\".%L\"),\n formatSecond = format(\":%S\"),\n formatMinute = format(\"%I:%M\"),\n formatHour = format(\"%I %p\"),\n formatDay = format(\"%a %d\"),\n formatWeek = format(\"%b %d\"),\n formatMonth = format(\"%B\"),\n formatYear = format(\"%Y\");\n\n var tickIntervals = [\n [second, 1, durationSecond$1],\n [second, 5, 5 * durationSecond$1],\n [second, 15, 15 * durationSecond$1],\n [second, 30, 30 * durationSecond$1],\n [minute, 1, durationMinute$1],\n [minute, 5, 5 * durationMinute$1],\n [minute, 15, 15 * durationMinute$1],\n [minute, 30, 30 * durationMinute$1],\n [ hour, 1, durationHour$1 ],\n [ hour, 3, 3 * durationHour$1 ],\n [ hour, 6, 6 * durationHour$1 ],\n [ hour, 12, 12 * durationHour$1 ],\n [ day, 1, durationDay$1 ],\n [ day, 2, 2 * durationDay$1 ],\n [ week, 1, durationWeek$1 ],\n [ month, 1, durationMonth ],\n [ month, 3, 3 * durationMonth ],\n [ year, 1, durationYear ]\n ];\n\n function tickFormat(date) {\n return (second(date) < date ? formatMillisecond\n : minute(date) < date ? formatSecond\n : hour(date) < date ? formatMinute\n : day(date) < date ? formatHour\n : month(date) < date ? (week(date) < date ? formatDay : formatWeek)\n : year(date) < date ? formatMonth\n : formatYear)(date);\n }\n\n function tickInterval(interval, start, stop, step) {\n if (interval == null) interval = 10;\n\n // If a desired tick count is specified, pick a reasonable tick interval\n // based on the extent of the domain and a rough estimate of tick size.\n // Otherwise, assume interval is already a time interval and use it.\n if (typeof interval === \"number\") {\n var target = Math.abs(stop - start) / interval,\n i = bisector(function(i) { return i[2]; }).right(tickIntervals, target);\n if (i === tickIntervals.length) {\n step = tickStep(start / durationYear, stop / durationYear, interval);\n interval = year;\n } else if (i) {\n i = tickIntervals[target / tickIntervals[i - 1][2] < tickIntervals[i][2] / target ? i - 1 : i];\n step = i[1];\n interval = i[0];\n } else {\n step = tickStep(start, stop, interval);\n interval = millisecond;\n }\n }\n\n return step == null ? interval : interval.every(step);\n }\n\n scale.invert = function(y) {\n return new Date(invert(y));\n };\n\n scale.domain = function(_) {\n return arguments.length ? domain(map$2.call(_, number$2)) : domain().map(date$1);\n };\n\n scale.ticks = function(interval, step) {\n var d = domain(),\n t0 = d[0],\n t1 = d[d.length - 1],\n r = t1 < t0,\n t;\n if (r) t = t0, t0 = t1, t1 = t;\n t = tickInterval(interval, t0, t1, step);\n t = t ? t.range(t0, t1 + 1) : []; // inclusive stop\n return r ? t.reverse() : t;\n };\n\n scale.tickFormat = function(count, specifier) {\n return specifier == null ? tickFormat : format(specifier);\n };\n\n scale.nice = function(interval, step) {\n var d = domain();\n return (interval = tickInterval(interval, d[0], d[d.length - 1], step))\n ? domain(nice(d, interval))\n : scale;\n };\n\n scale.copy = function() {\n return copy(scale, calendar(year, month, week, day, hour, minute, second, millisecond, format));\n };\n\n return scale;\n }\n\n function time() {\n return calendar(year, month, timeWeek, day, hour, minute, second, millisecond, exports.timeFormat).domain([new Date(2000, 0, 1), new Date(2000, 0, 2)]);\n }\n\n function utcTime() {\n return calendar(utcYear, utcMonth, utcWeek, utcDay, utcHour, utcMinute, second, millisecond, exports.utcFormat).domain([Date.UTC(2000, 0, 1), Date.UTC(2000, 0, 2)]);\n }\n\n function colors(s) {\n return s.match(/.{6}/g).map(function(x) {\n return \"#\" + x;\n });\n }\n\n var category10 = colors(\"1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf\");\n\n var category20b = colors(\"393b795254a36b6ecf9c9ede6379398ca252b5cf6bcedb9c8c6d31bd9e39e7ba52e7cb94843c39ad494ad6616be7969c7b4173a55194ce6dbdde9ed6\");\n\n var category20c = colors(\"3182bd6baed69ecae1c6dbefe6550dfd8d3cfdae6bfdd0a231a35474c476a1d99bc7e9c0756bb19e9ac8bcbddcdadaeb636363969696bdbdbdd9d9d9\");\n\n var category20 = colors(\"1f77b4aec7e8ff7f0effbb782ca02c98df8ad62728ff98969467bdc5b0d58c564bc49c94e377c2f7b6d27f7f7fc7c7c7bcbd22dbdb8d17becf9edae5\");\n\n var cubehelix$3 = interpolateCubehelixLong(cubehelix(300, 0.5, 0.0), cubehelix(-240, 0.5, 1.0));\n\n var warm = interpolateCubehelixLong(cubehelix(-100, 0.75, 0.35), cubehelix(80, 1.50, 0.8));\n\n var cool = interpolateCubehelixLong(cubehelix(260, 0.75, 0.35), cubehelix(80, 1.50, 0.8));\n\n var rainbow = cubehelix();\n\n function rainbow$1(t) {\n if (t < 0 || t > 1) t -= Math.floor(t);\n var ts = Math.abs(t - 0.5);\n rainbow.h = 360 * t - 100;\n rainbow.s = 1.5 - 1.5 * ts;\n rainbow.l = 0.8 - 0.9 * ts;\n return rainbow + \"\";\n }\n\n function ramp(range) {\n var n = range.length;\n return function(t) {\n return range[Math.max(0, Math.min(n - 1, Math.floor(t * n)))];\n };\n }\n\n var viridis = ramp(colors(\"44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725\"));\n\n var magma = ramp(colors(\"00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf\"));\n\n var inferno = ramp(colors(\"00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4\"));\n\n var plasma = ramp(colors(\"0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921\"));\n\n function sequential(interpolator) {\n var x0 = 0,\n x1 = 1,\n clamp = false;\n\n function scale(x) {\n var t = (x - x0) / (x1 - x0);\n return interpolator(clamp ? Math.max(0, Math.min(1, t)) : t);\n }\n\n scale.domain = function(_) {\n return arguments.length ? (x0 = +_[0], x1 = +_[1], scale) : [x0, x1];\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (clamp = !!_, scale) : clamp;\n };\n\n scale.interpolator = function(_) {\n return arguments.length ? (interpolator = _, scale) : interpolator;\n };\n\n scale.copy = function() {\n return sequential(interpolator).domain([x0, x1]).clamp(clamp);\n };\n\n return linearish(scale);\n }\n\n var xhtml = \"http://www.w3.org/1999/xhtml\";\n\n var namespaces = {\n svg: \"http://www.w3.org/2000/svg\",\n xhtml: xhtml,\n xlink: \"http://www.w3.org/1999/xlink\",\n xml: \"http://www.w3.org/XML/1998/namespace\",\n xmlns: \"http://www.w3.org/2000/xmlns/\"\n };\n\n function namespace(name) {\n var prefix = name += \"\", i = prefix.indexOf(\":\");\n if (i >= 0 && (prefix = name.slice(0, i)) !== \"xmlns\") name = name.slice(i + 1);\n return namespaces.hasOwnProperty(prefix) ? {space: namespaces[prefix], local: name} : name;\n }\n\n function creatorInherit(name) {\n return function() {\n var document = this.ownerDocument,\n uri = this.namespaceURI;\n return uri === xhtml && document.documentElement.namespaceURI === xhtml\n ? document.createElement(name)\n : document.createElementNS(uri, name);\n };\n }\n\n function creatorFixed(fullname) {\n return function() {\n return this.ownerDocument.createElementNS(fullname.space, fullname.local);\n };\n }\n\n function creator(name) {\n var fullname = namespace(name);\n return (fullname.local\n ? creatorFixed\n : creatorInherit)(fullname);\n }\n\n var nextId = 0;\n\n function local() {\n return new Local;\n }\n\n function Local() {\n this._ = \"@\" + (++nextId).toString(36);\n }\n\n Local.prototype = local.prototype = {\n constructor: Local,\n get: function(node) {\n var id = this._;\n while (!(id in node)) if (!(node = node.parentNode)) return;\n return node[id];\n },\n set: function(node, value) {\n return node[this._] = value;\n },\n remove: function(node) {\n return this._ in node && delete node[this._];\n },\n toString: function() {\n return this._;\n }\n };\n\n var matcher = function(selector) {\n return function() {\n return this.matches(selector);\n };\n };\n\n if (typeof document !== \"undefined\") {\n var element = document.documentElement;\n if (!element.matches) {\n var vendorMatches = element.webkitMatchesSelector\n || element.msMatchesSelector\n || element.mozMatchesSelector\n || element.oMatchesSelector;\n matcher = function(selector) {\n return function() {\n return vendorMatches.call(this, selector);\n };\n };\n }\n }\n\n var matcher$1 = matcher;\n\n var filterEvents = {};\n\n exports.event = null;\n\n if (typeof document !== \"undefined\") {\n var element$1 = document.documentElement;\n if (!(\"onmouseenter\" in element$1)) {\n filterEvents = {mouseenter: \"mouseover\", mouseleave: \"mouseout\"};\n }\n }\n\n function filterContextListener(listener, index, group) {\n listener = contextListener(listener, index, group);\n return function(event) {\n var related = event.relatedTarget;\n if (!related || (related !== this && !(related.compareDocumentPosition(this) & 8))) {\n listener.call(this, event);\n }\n };\n }\n\n function contextListener(listener, index, group) {\n return function(event1) {\n var event0 = exports.event; // Events can be reentrant (e.g., focus).\n exports.event = event1;\n try {\n listener.call(this, this.__data__, index, group);\n } finally {\n exports.event = event0;\n }\n };\n }\n\n function parseTypenames$1(typenames) {\n return typenames.trim().split(/^|\\s+/).map(function(t) {\n var name = \"\", i = t.indexOf(\".\");\n if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n return {type: t, name: name};\n });\n }\n\n function onRemove(typename) {\n return function() {\n var on = this.__on;\n if (!on) return;\n for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {\n if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {\n this.removeEventListener(o.type, o.listener, o.capture);\n } else {\n on[++i] = o;\n }\n }\n if (++i) on.length = i;\n else delete this.__on;\n };\n }\n\n function onAdd(typename, value, capture) {\n var wrap = filterEvents.hasOwnProperty(typename.type) ? filterContextListener : contextListener;\n return function(d, i, group) {\n var on = this.__on, o, listener = wrap(value, i, group);\n if (on) for (var j = 0, m = on.length; j < m; ++j) {\n if ((o = on[j]).type === typename.type && o.name === typename.name) {\n this.removeEventListener(o.type, o.listener, o.capture);\n this.addEventListener(o.type, o.listener = listener, o.capture = capture);\n o.value = value;\n return;\n }\n }\n this.addEventListener(typename.type, listener, capture);\n o = {type: typename.type, name: typename.name, value: value, listener: listener, capture: capture};\n if (!on) this.__on = [o];\n else on.push(o);\n };\n }\n\n function selection_on(typename, value, capture) {\n var typenames = parseTypenames$1(typename + \"\"), i, n = typenames.length, t;\n\n if (arguments.length < 2) {\n var on = this.node().__on;\n if (on) for (var j = 0, m = on.length, o; j < m; ++j) {\n for (i = 0, o = on[j]; i < n; ++i) {\n if ((t = typenames[i]).type === o.type && t.name === o.name) {\n return o.value;\n }\n }\n }\n return;\n }\n\n on = value ? onAdd : onRemove;\n if (capture == null) capture = false;\n for (i = 0; i < n; ++i) this.each(on(typenames[i], value, capture));\n return this;\n }\n\n function customEvent(event1, listener, that, args) {\n var event0 = exports.event;\n event1.sourceEvent = exports.event;\n exports.event = event1;\n try {\n return listener.apply(that, args);\n } finally {\n exports.event = event0;\n }\n }\n\n function sourceEvent() {\n var current = exports.event, source;\n while (source = current.sourceEvent) current = source;\n return current;\n }\n\n function point$5(node, event) {\n var svg = node.ownerSVGElement || node;\n\n if (svg.createSVGPoint) {\n var point = svg.createSVGPoint();\n point.x = event.clientX, point.y = event.clientY;\n point = point.matrixTransform(node.getScreenCTM().inverse());\n return [point.x, point.y];\n }\n\n var rect = node.getBoundingClientRect();\n return [event.clientX - rect.left - node.clientLeft, event.clientY - rect.top - node.clientTop];\n }\n\n function mouse(node) {\n var event = sourceEvent();\n if (event.changedTouches) event = event.changedTouches[0];\n return point$5(node, event);\n }\n\n function none$2() {}\n\n function selector(selector) {\n return selector == null ? none$2 : function() {\n return this.querySelector(selector);\n };\n }\n\n function selection_select(select) {\n if (typeof select !== \"function\") select = selector(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n if (\"__data__\" in node) subnode.__data__ = node.__data__;\n subgroup[i] = subnode;\n }\n }\n }\n\n return new Selection(subgroups, this._parents);\n }\n\n function empty() {\n return [];\n }\n\n function selectorAll(selector) {\n return selector == null ? empty : function() {\n return this.querySelectorAll(selector);\n };\n }\n\n function selection_selectAll(select) {\n if (typeof select !== \"function\") select = selectorAll(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n subgroups.push(select.call(node, node.__data__, i, group));\n parents.push(node);\n }\n }\n }\n\n return new Selection(subgroups, parents);\n }\n\n function selection_filter(match) {\n if (typeof match !== \"function\") match = matcher$1(match);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n subgroup.push(node);\n }\n }\n }\n\n return new Selection(subgroups, this._parents);\n }\n\n function sparse(update) {\n return new Array(update.length);\n }\n\n function selection_enter() {\n return new Selection(this._enter || this._groups.map(sparse), this._parents);\n }\n\n function EnterNode(parent, datum) {\n this.ownerDocument = parent.ownerDocument;\n this.namespaceURI = parent.namespaceURI;\n this._next = null;\n this._parent = parent;\n this.__data__ = datum;\n }\n\n EnterNode.prototype = {\n constructor: EnterNode,\n appendChild: function(child) { return this._parent.insertBefore(child, this._next); },\n insertBefore: function(child, next) { return this._parent.insertBefore(child, next); },\n querySelector: function(selector) { return this._parent.querySelector(selector); },\n querySelectorAll: function(selector) { return this._parent.querySelectorAll(selector); }\n };\n\n function constant$4(x) {\n return function() {\n return x;\n };\n }\n\n var keyPrefix = \"$\"; // Protect against keys like “__proto__â€.\n\n function bindIndex(parent, group, enter, update, exit, data) {\n var i = 0,\n node,\n groupLength = group.length,\n dataLength = data.length;\n\n // Put any non-null nodes that fit into update.\n // Put any null nodes into enter.\n // Put any remaining data into enter.\n for (; i < dataLength; ++i) {\n if (node = group[i]) {\n node.__data__ = data[i];\n update[i] = node;\n } else {\n enter[i] = new EnterNode(parent, data[i]);\n }\n }\n\n // Put any non-null nodes that don’t fit into exit.\n for (; i < groupLength; ++i) {\n if (node = group[i]) {\n exit[i] = node;\n }\n }\n }\n\n function bindKey(parent, group, enter, update, exit, data, key) {\n var i,\n node,\n nodeByKeyValue = {},\n groupLength = group.length,\n dataLength = data.length,\n keyValues = new Array(groupLength),\n keyValue;\n\n // Compute the key for each node.\n // If multiple nodes have the same key, the duplicates are added to exit.\n for (i = 0; i < groupLength; ++i) {\n if (node = group[i]) {\n keyValues[i] = keyValue = keyPrefix + key.call(node, node.__data__, i, group);\n if (keyValue in nodeByKeyValue) {\n exit[i] = node;\n } else {\n nodeByKeyValue[keyValue] = node;\n }\n }\n }\n\n // Compute the key for each datum.\n // If there a node associated with this key, join and add it to update.\n // If there is not (or the key is a duplicate), add it to enter.\n for (i = 0; i < dataLength; ++i) {\n keyValue = keyPrefix + key.call(parent, data[i], i, data);\n if (node = nodeByKeyValue[keyValue]) {\n update[i] = node;\n node.__data__ = data[i];\n nodeByKeyValue[keyValue] = null;\n } else {\n enter[i] = new EnterNode(parent, data[i]);\n }\n }\n\n // Add any remaining nodes that were not bound to data to exit.\n for (i = 0; i < groupLength; ++i) {\n if ((node = group[i]) && (nodeByKeyValue[keyValues[i]] === node)) {\n exit[i] = node;\n }\n }\n }\n\n function selection_data(value, key) {\n if (!value) {\n data = new Array(this.size()), j = -1;\n this.each(function(d) { data[++j] = d; });\n return data;\n }\n\n var bind = key ? bindKey : bindIndex,\n parents = this._parents,\n groups = this._groups;\n\n if (typeof value !== \"function\") value = constant$4(value);\n\n for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {\n var parent = parents[j],\n group = groups[j],\n groupLength = group.length,\n data = value.call(parent, parent && parent.__data__, j, parents),\n dataLength = data.length,\n enterGroup = enter[j] = new Array(dataLength),\n updateGroup = update[j] = new Array(dataLength),\n exitGroup = exit[j] = new Array(groupLength);\n\n bind(parent, group, enterGroup, updateGroup, exitGroup, data, key);\n\n // Now connect the enter nodes to their following update node, such that\n // appendChild can insert the materialized enter node before this node,\n // rather than at the end of the parent node.\n for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {\n if (previous = enterGroup[i0]) {\n if (i0 >= i1) i1 = i0 + 1;\n while (!(next = updateGroup[i1]) && ++i1 < dataLength);\n previous._next = next || null;\n }\n }\n }\n\n update = new Selection(update, parents);\n update._enter = enter;\n update._exit = exit;\n return update;\n }\n\n function selection_exit() {\n return new Selection(this._exit || this._groups.map(sparse), this._parents);\n }\n\n function selection_merge(selection) {\n\n for (var groups0 = this._groups, groups1 = selection._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group0[i] || group1[i]) {\n merge[i] = node;\n }\n }\n }\n\n for (; j < m0; ++j) {\n merges[j] = groups0[j];\n }\n\n return new Selection(merges, this._parents);\n }\n\n function selection_order() {\n\n for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {\n for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {\n if (node = group[i]) {\n if (next && next !== node.nextSibling) next.parentNode.insertBefore(node, next);\n next = node;\n }\n }\n }\n\n return this;\n }\n\n function selection_sort(compare) {\n if (!compare) compare = ascending$2;\n\n function compareNode(a, b) {\n return a && b ? compare(a.__data__, b.__data__) : !a - !b;\n }\n\n for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n sortgroup[i] = node;\n }\n }\n sortgroup.sort(compareNode);\n }\n\n return new Selection(sortgroups, this._parents).order();\n }\n\n function ascending$2(a, b) {\n return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n }\n\n function selection_call() {\n var callback = arguments[0];\n arguments[0] = this;\n callback.apply(null, arguments);\n return this;\n }\n\n function selection_nodes() {\n var nodes = new Array(this.size()), i = -1;\n this.each(function() { nodes[++i] = this; });\n return nodes;\n }\n\n function selection_node() {\n\n for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {\n var node = group[i];\n if (node) return node;\n }\n }\n\n return null;\n }\n\n function selection_size() {\n var size = 0;\n this.each(function() { ++size; });\n return size;\n }\n\n function selection_empty() {\n return !this.node();\n }\n\n function selection_each(callback) {\n\n for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {\n if (node = group[i]) callback.call(node, node.__data__, i, group);\n }\n }\n\n return this;\n }\n\n function attrRemove(name) {\n return function() {\n this.removeAttribute(name);\n };\n }\n\n function attrRemoveNS(fullname) {\n return function() {\n this.removeAttributeNS(fullname.space, fullname.local);\n };\n }\n\n function attrConstant(name, value) {\n return function() {\n this.setAttribute(name, value);\n };\n }\n\n function attrConstantNS(fullname, value) {\n return function() {\n this.setAttributeNS(fullname.space, fullname.local, value);\n };\n }\n\n function attrFunction(name, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.removeAttribute(name);\n else this.setAttribute(name, v);\n };\n }\n\n function attrFunctionNS(fullname, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.removeAttributeNS(fullname.space, fullname.local);\n else this.setAttributeNS(fullname.space, fullname.local, v);\n };\n }\n\n function selection_attr(name, value) {\n var fullname = namespace(name);\n\n if (arguments.length < 2) {\n var node = this.node();\n return fullname.local\n ? node.getAttributeNS(fullname.space, fullname.local)\n : node.getAttribute(fullname);\n }\n\n return this.each((value == null\n ? (fullname.local ? attrRemoveNS : attrRemove) : (typeof value === \"function\"\n ? (fullname.local ? attrFunctionNS : attrFunction)\n : (fullname.local ? attrConstantNS : attrConstant)))(fullname, value));\n }\n\n function window(node) {\n return (node.ownerDocument && node.ownerDocument.defaultView) // node is a Node\n || (node.document && node) // node is a Window\n || node.defaultView; // node is a Document\n }\n\n function styleRemove(name) {\n return function() {\n this.style.removeProperty(name);\n };\n }\n\n function styleConstant(name, value, priority) {\n return function() {\n this.style.setProperty(name, value, priority);\n };\n }\n\n function styleFunction(name, value, priority) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.style.removeProperty(name);\n else this.style.setProperty(name, v, priority);\n };\n }\n\n function selection_style(name, value, priority) {\n var node;\n return arguments.length > 1\n ? this.each((value == null\n ? styleRemove : typeof value === \"function\"\n ? styleFunction\n : styleConstant)(name, value, priority == null ? \"\" : priority))\n : window(node = this.node())\n .getComputedStyle(node, null)\n .getPropertyValue(name);\n }\n\n function propertyRemove(name) {\n return function() {\n delete this[name];\n };\n }\n\n function propertyConstant(name, value) {\n return function() {\n this[name] = value;\n };\n }\n\n function propertyFunction(name, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) delete this[name];\n else this[name] = v;\n };\n }\n\n function selection_property(name, value) {\n return arguments.length > 1\n ? this.each((value == null\n ? propertyRemove : typeof value === \"function\"\n ? propertyFunction\n : propertyConstant)(name, value))\n : this.node()[name];\n }\n\n function classArray(string) {\n return string.trim().split(/^|\\s+/);\n }\n\n function classList(node) {\n return node.classList || new ClassList(node);\n }\n\n function ClassList(node) {\n this._node = node;\n this._names = classArray(node.getAttribute(\"class\") || \"\");\n }\n\n ClassList.prototype = {\n add: function(name) {\n var i = this._names.indexOf(name);\n if (i < 0) {\n this._names.push(name);\n this._node.setAttribute(\"class\", this._names.join(\" \"));\n }\n },\n remove: function(name) {\n var i = this._names.indexOf(name);\n if (i >= 0) {\n this._names.splice(i, 1);\n this._node.setAttribute(\"class\", this._names.join(\" \"));\n }\n },\n contains: function(name) {\n return this._names.indexOf(name) >= 0;\n }\n };\n\n function classedAdd(node, names) {\n var list = classList(node), i = -1, n = names.length;\n while (++i < n) list.add(names[i]);\n }\n\n function classedRemove(node, names) {\n var list = classList(node), i = -1, n = names.length;\n while (++i < n) list.remove(names[i]);\n }\n\n function classedTrue(names) {\n return function() {\n classedAdd(this, names);\n };\n }\n\n function classedFalse(names) {\n return function() {\n classedRemove(this, names);\n };\n }\n\n function classedFunction(names, value) {\n return function() {\n (value.apply(this, arguments) ? classedAdd : classedRemove)(this, names);\n };\n }\n\n function selection_classed(name, value) {\n var names = classArray(name + \"\");\n\n if (arguments.length < 2) {\n var list = classList(this.node()), i = -1, n = names.length;\n while (++i < n) if (!list.contains(names[i])) return false;\n return true;\n }\n\n return this.each((typeof value === \"function\"\n ? classedFunction : value\n ? classedTrue\n : classedFalse)(names, value));\n }\n\n function textRemove() {\n this.textContent = \"\";\n }\n\n function textConstant(value) {\n return function() {\n this.textContent = value;\n };\n }\n\n function textFunction(value) {\n return function() {\n var v = value.apply(this, arguments);\n this.textContent = v == null ? \"\" : v;\n };\n }\n\n function selection_text(value) {\n return arguments.length\n ? this.each(value == null\n ? textRemove : (typeof value === \"function\"\n ? textFunction\n : textConstant)(value))\n : this.node().textContent;\n }\n\n function htmlRemove() {\n this.innerHTML = \"\";\n }\n\n function htmlConstant(value) {\n return function() {\n this.innerHTML = value;\n };\n }\n\n function htmlFunction(value) {\n return function() {\n var v = value.apply(this, arguments);\n this.innerHTML = v == null ? \"\" : v;\n };\n }\n\n function selection_html(value) {\n return arguments.length\n ? this.each(value == null\n ? htmlRemove : (typeof value === \"function\"\n ? htmlFunction\n : htmlConstant)(value))\n : this.node().innerHTML;\n }\n\n function raise$1() {\n if (this.nextSibling) this.parentNode.appendChild(this);\n }\n\n function selection_raise() {\n return this.each(raise$1);\n }\n\n function lower() {\n if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);\n }\n\n function selection_lower() {\n return this.each(lower);\n }\n\n function selection_append(name) {\n var create = typeof name === \"function\" ? name : creator(name);\n return this.select(function() {\n return this.appendChild(create.apply(this, arguments));\n });\n }\n\n function constantNull() {\n return null;\n }\n\n function selection_insert(name, before) {\n var create = typeof name === \"function\" ? name : creator(name),\n select = before == null ? constantNull : typeof before === \"function\" ? before : selector(before);\n return this.select(function() {\n return this.insertBefore(create.apply(this, arguments), select.apply(this, arguments) || null);\n });\n }\n\n function remove() {\n var parent = this.parentNode;\n if (parent) parent.removeChild(this);\n }\n\n function selection_remove() {\n return this.each(remove);\n }\n\n function selection_datum(value) {\n return arguments.length\n ? this.property(\"__data__\", value)\n : this.node().__data__;\n }\n\n function dispatchEvent(node, type, params) {\n var window$$ = window(node),\n event = window$$.CustomEvent;\n\n if (event) {\n event = new event(type, params);\n } else {\n event = window$$.document.createEvent(\"Event\");\n if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;\n else event.initEvent(type, false, false);\n }\n\n node.dispatchEvent(event);\n }\n\n function dispatchConstant(type, params) {\n return function() {\n return dispatchEvent(this, type, params);\n };\n }\n\n function dispatchFunction(type, params) {\n return function() {\n return dispatchEvent(this, type, params.apply(this, arguments));\n };\n }\n\n function selection_dispatch(type, params) {\n return this.each((typeof params === \"function\"\n ? dispatchFunction\n : dispatchConstant)(type, params));\n }\n\n var root = [null];\n\n function Selection(groups, parents) {\n this._groups = groups;\n this._parents = parents;\n }\n\n function selection() {\n return new Selection([[document.documentElement]], root);\n }\n\n Selection.prototype = selection.prototype = {\n constructor: Selection,\n select: selection_select,\n selectAll: selection_selectAll,\n filter: selection_filter,\n data: selection_data,\n enter: selection_enter,\n exit: selection_exit,\n merge: selection_merge,\n order: selection_order,\n sort: selection_sort,\n call: selection_call,\n nodes: selection_nodes,\n node: selection_node,\n size: selection_size,\n empty: selection_empty,\n each: selection_each,\n attr: selection_attr,\n style: selection_style,\n property: selection_property,\n classed: selection_classed,\n text: selection_text,\n html: selection_html,\n raise: selection_raise,\n lower: selection_lower,\n append: selection_append,\n insert: selection_insert,\n remove: selection_remove,\n datum: selection_datum,\n on: selection_on,\n dispatch: selection_dispatch\n };\n\n function select(selector) {\n return typeof selector === \"string\"\n ? new Selection([[document.querySelector(selector)]], [document.documentElement])\n : new Selection([[selector]], root);\n }\n\n function selectAll(selector) {\n return typeof selector === \"string\"\n ? new Selection([document.querySelectorAll(selector)], [document.documentElement])\n : new Selection([selector == null ? [] : selector], root);\n }\n\n function touch(node, touches, identifier) {\n if (arguments.length < 3) identifier = touches, touches = sourceEvent().changedTouches;\n\n for (var i = 0, n = touches ? touches.length : 0, touch; i < n; ++i) {\n if ((touch = touches[i]).identifier === identifier) {\n return point$5(node, touch);\n }\n }\n\n return null;\n }\n\n function touches(node, touches) {\n if (touches == null) touches = sourceEvent().touches;\n\n for (var i = 0, n = touches ? touches.length : 0, points = new Array(n); i < n; ++i) {\n points[i] = point$5(node, touches[i]);\n }\n\n return points;\n }\n\n var emptyOn = dispatch(\"start\", \"end\", \"interrupt\");\n var emptyTween = [];\n\n var CREATED = 0;\n var SCHEDULED = 1;\n var STARTING = 2;\n var STARTED = 3;\n var ENDING = 4;\n var ENDED = 5;\n\n function schedule(node, name, id, index, group, timing) {\n var schedules = node.__transition;\n if (!schedules) node.__transition = {};\n else if (id in schedules) return;\n create(node, id, {\n name: name,\n index: index, // For context during callback.\n group: group, // For context during callback.\n on: emptyOn,\n tween: emptyTween,\n time: timing.time,\n delay: timing.delay,\n duration: timing.duration,\n ease: timing.ease,\n timer: null,\n state: CREATED\n });\n }\n\n function init(node, id) {\n var schedule = node.__transition;\n if (!schedule || !(schedule = schedule[id]) || schedule.state > CREATED) throw new Error(\"too late\");\n return schedule;\n }\n\n function set$2(node, id) {\n var schedule = node.__transition;\n if (!schedule || !(schedule = schedule[id]) || schedule.state > STARTING) throw new Error(\"too late\");\n return schedule;\n }\n\n function get$1(node, id) {\n var schedule = node.__transition;\n if (!schedule || !(schedule = schedule[id])) throw new Error(\"too late\");\n return schedule;\n }\n\n function create(node, id, self) {\n var schedules = node.__transition,\n tween;\n\n // Initialize the self timer when the transition is created.\n // Note the actual delay is not known until the first callback!\n schedules[id] = self;\n self.timer = timer(schedule, 0, self.time);\n\n // If the delay is greater than this first sleep, sleep some more;\n // otherwise, start immediately.\n function schedule(elapsed) {\n self.state = SCHEDULED;\n if (self.delay <= elapsed) start(elapsed - self.delay);\n else self.timer.restart(start, self.delay, self.time);\n }\n\n function start(elapsed) {\n var i, j, n, o;\n\n for (i in schedules) {\n o = schedules[i];\n if (o.name !== self.name) continue;\n\n // Interrupt the active transition, if any.\n // Dispatch the interrupt event.\n if (o.state === STARTED) {\n o.state = ENDED;\n o.timer.stop();\n o.on.call(\"interrupt\", node, node.__data__, o.index, o.group);\n delete schedules[i];\n }\n\n // Cancel any pre-empted transitions. No interrupt event is dispatched\n // because the cancelled transitions never started. Note that this also\n // removes this transition from the pending list!\n else if (+i < id) {\n o.state = ENDED;\n o.timer.stop();\n delete schedules[i];\n }\n }\n\n // Defer the first tick to end of the current frame; see mbostock/d3#1576.\n // Note the transition may be canceled after start and before the first tick!\n // Note this must be scheduled before the start event; see d3/d3-transition#16!\n // Assuming this is successful, subsequent callbacks go straight to tick.\n timeout$1(function() {\n if (self.state === STARTED) {\n self.timer.restart(tick, self.delay, self.time);\n tick(elapsed);\n }\n });\n\n // Dispatch the start event.\n // Note this must be done before the tween are initialized.\n self.state = STARTING;\n self.on.call(\"start\", node, node.__data__, self.index, self.group);\n if (self.state !== STARTING) return; // interrupted\n self.state = STARTED;\n\n // Initialize the tween, deleting null tween.\n tween = new Array(n = self.tween.length);\n for (i = 0, j = -1; i < n; ++i) {\n if (o = self.tween[i].value.call(node, node.__data__, self.index, self.group)) {\n tween[++j] = o;\n }\n }\n tween.length = j + 1;\n }\n\n function tick(elapsed) {\n var t = elapsed < self.duration ? self.ease.call(null, elapsed / self.duration) : (self.state = ENDING, 1),\n i = -1,\n n = tween.length;\n\n while (++i < n) {\n tween[i].call(null, t);\n }\n\n // Dispatch the end event.\n if (self.state === ENDING) {\n self.state = ENDED;\n self.timer.stop();\n self.on.call(\"end\", node, node.__data__, self.index, self.group);\n for (i in schedules) if (+i !== id) return void delete schedules[id];\n delete node.__transition;\n }\n }\n }\n\n function interrupt(node, name) {\n var schedules = node.__transition,\n schedule,\n active,\n empty = true,\n i;\n\n if (!schedules) return;\n\n name = name == null ? null : name + \"\";\n\n for (i in schedules) {\n if ((schedule = schedules[i]).name !== name) { empty = false; continue; }\n active = schedule.state === STARTED;\n schedule.state = ENDED;\n schedule.timer.stop();\n if (active) schedule.on.call(\"interrupt\", node, node.__data__, schedule.index, schedule.group);\n delete schedules[i];\n }\n\n if (empty) delete node.__transition;\n }\n\n function selection_interrupt(name) {\n return this.each(function() {\n interrupt(this, name);\n });\n }\n\n function tweenRemove(id, name) {\n var tween0, tween1;\n return function() {\n var schedule = set$2(this, id),\n tween = schedule.tween;\n\n // If this node shared tween with the previous node,\n // just assign the updated shared tween and we’re done!\n // Otherwise, copy-on-write.\n if (tween !== tween0) {\n tween1 = tween0 = tween;\n for (var i = 0, n = tween1.length; i < n; ++i) {\n if (tween1[i].name === name) {\n tween1 = tween1.slice();\n tween1.splice(i, 1);\n break;\n }\n }\n }\n\n schedule.tween = tween1;\n };\n }\n\n function tweenFunction(id, name, value) {\n var tween0, tween1;\n if (typeof value !== \"function\") throw new Error;\n return function() {\n var schedule = set$2(this, id),\n tween = schedule.tween;\n\n // If this node shared tween with the previous node,\n // just assign the updated shared tween and we’re done!\n // Otherwise, copy-on-write.\n if (tween !== tween0) {\n tween1 = (tween0 = tween).slice();\n for (var t = {name: name, value: value}, i = 0, n = tween1.length; i < n; ++i) {\n if (tween1[i].name === name) {\n tween1[i] = t;\n break;\n }\n }\n if (i === n) tween1.push(t);\n }\n\n schedule.tween = tween1;\n };\n }\n\n function transition_tween(name, value) {\n var id = this._id;\n\n name += \"\";\n\n if (arguments.length < 2) {\n var tween = get$1(this.node(), id).tween;\n for (var i = 0, n = tween.length, t; i < n; ++i) {\n if ((t = tween[i]).name === name) {\n return t.value;\n }\n }\n return null;\n }\n\n return this.each((value == null ? tweenRemove : tweenFunction)(id, name, value));\n }\n\n function tweenValue(transition, name, value) {\n var id = transition._id;\n\n transition.each(function() {\n var schedule = set$2(this, id);\n (schedule.value || (schedule.value = {}))[name] = value.apply(this, arguments);\n });\n\n return function(node) {\n return get$1(node, id).value[name];\n };\n }\n\n function interpolate$1(a, b) {\n var c;\n return (typeof b === \"number\" ? interpolateNumber\n : b instanceof color ? interpolateRgb\n : (c = color(b)) ? (b = c, interpolateRgb)\n : interpolateString)(a, b);\n }\n\n function attrRemove$1(name) {\n return function() {\n this.removeAttribute(name);\n };\n }\n\n function attrRemoveNS$1(fullname) {\n return function() {\n this.removeAttributeNS(fullname.space, fullname.local);\n };\n }\n\n function attrConstant$1(name, interpolate, value1) {\n var value00,\n interpolate0;\n return function() {\n var value0 = this.getAttribute(name);\n return value0 === value1 ? null\n : value0 === value00 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value1);\n };\n }\n\n function attrConstantNS$1(fullname, interpolate, value1) {\n var value00,\n interpolate0;\n return function() {\n var value0 = this.getAttributeNS(fullname.space, fullname.local);\n return value0 === value1 ? null\n : value0 === value00 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value1);\n };\n }\n\n function attrFunction$1(name, interpolate, value) {\n var value00,\n value10,\n interpolate0;\n return function() {\n var value0, value1 = value(this);\n if (value1 == null) return void this.removeAttribute(name);\n value0 = this.getAttribute(name);\n return value0 === value1 ? null\n : value0 === value00 && value1 === value10 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value10 = value1);\n };\n }\n\n function attrFunctionNS$1(fullname, interpolate, value) {\n var value00,\n value10,\n interpolate0;\n return function() {\n var value0, value1 = value(this);\n if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);\n value0 = this.getAttributeNS(fullname.space, fullname.local);\n return value0 === value1 ? null\n : value0 === value00 && value1 === value10 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value10 = value1);\n };\n }\n\n function transition_attr(name, value) {\n var fullname = namespace(name), i = fullname === \"transform\" ? interpolateTransform$2 : interpolate$1;\n return this.attrTween(name, typeof value === \"function\"\n ? (fullname.local ? attrFunctionNS$1 : attrFunction$1)(fullname, i, tweenValue(this, \"attr.\" + name, value))\n : value == null ? (fullname.local ? attrRemoveNS$1 : attrRemove$1)(fullname)\n : (fullname.local ? attrConstantNS$1 : attrConstant$1)(fullname, i, value));\n }\n\n function attrTweenNS(fullname, value) {\n function tween() {\n var node = this, i = value.apply(node, arguments);\n return i && function(t) {\n node.setAttributeNS(fullname.space, fullname.local, i(t));\n };\n }\n tween._value = value;\n return tween;\n }\n\n function attrTween(name, value) {\n function tween() {\n var node = this, i = value.apply(node, arguments);\n return i && function(t) {\n node.setAttribute(name, i(t));\n };\n }\n tween._value = value;\n return tween;\n }\n\n function transition_attrTween(name, value) {\n var key = \"attr.\" + name;\n if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n if (value == null) return this.tween(key, null);\n if (typeof value !== \"function\") throw new Error;\n var fullname = namespace(name);\n return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));\n }\n\n function delayFunction(id, value) {\n return function() {\n init(this, id).delay = +value.apply(this, arguments);\n };\n }\n\n function delayConstant(id, value) {\n return value = +value, function() {\n init(this, id).delay = value;\n };\n }\n\n function transition_delay(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each((typeof value === \"function\"\n ? delayFunction\n : delayConstant)(id, value))\n : get$1(this.node(), id).delay;\n }\n\n function durationFunction(id, value) {\n return function() {\n set$2(this, id).duration = +value.apply(this, arguments);\n };\n }\n\n function durationConstant(id, value) {\n return value = +value, function() {\n set$2(this, id).duration = value;\n };\n }\n\n function transition_duration(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each((typeof value === \"function\"\n ? durationFunction\n : durationConstant)(id, value))\n : get$1(this.node(), id).duration;\n }\n\n function easeConstant(id, value) {\n if (typeof value !== \"function\") throw new Error;\n return function() {\n set$2(this, id).ease = value;\n };\n }\n\n function transition_ease(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each(easeConstant(id, value))\n : get$1(this.node(), id).ease;\n }\n\n function transition_filter(match) {\n if (typeof match !== \"function\") match = matcher$1(match);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n subgroup.push(node);\n }\n }\n }\n\n return new Transition(subgroups, this._parents, this._name, this._id);\n }\n\n function transition_merge(transition) {\n if (transition._id !== this._id) throw new Error;\n\n for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group0[i] || group1[i]) {\n merge[i] = node;\n }\n }\n }\n\n for (; j < m0; ++j) {\n merges[j] = groups0[j];\n }\n\n return new Transition(merges, this._parents, this._name, this._id);\n }\n\n function start$1(name) {\n return (name + \"\").trim().split(/^|\\s+/).every(function(t) {\n var i = t.indexOf(\".\");\n if (i >= 0) t = t.slice(0, i);\n return !t || t === \"start\";\n });\n }\n\n function onFunction(id, name, listener) {\n var on0, on1, sit = start$1(name) ? init : set$2;\n return function() {\n var schedule = sit(this, id),\n on = schedule.on;\n\n // If this node shared a dispatch with the previous node,\n // just assign the updated shared dispatch and we’re done!\n // Otherwise, copy-on-write.\n if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);\n\n schedule.on = on1;\n };\n }\n\n function transition_on(name, listener) {\n var id = this._id;\n\n return arguments.length < 2\n ? get$1(this.node(), id).on.on(name)\n : this.each(onFunction(id, name, listener));\n }\n\n function removeFunction(id) {\n return function() {\n var parent = this.parentNode;\n for (var i in this.__transition) if (+i !== id) return;\n if (parent) parent.removeChild(this);\n };\n }\n\n function transition_remove() {\n return this.on(\"end.remove\", removeFunction(this._id));\n }\n\n function transition_select(select) {\n var name = this._name,\n id = this._id;\n\n if (typeof select !== \"function\") select = selector(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n if (\"__data__\" in node) subnode.__data__ = node.__data__;\n subgroup[i] = subnode;\n schedule(subgroup[i], name, id, i, subgroup, get$1(node, id));\n }\n }\n }\n\n return new Transition(subgroups, this._parents, name, id);\n }\n\n function transition_selectAll(select) {\n var name = this._name,\n id = this._id;\n\n if (typeof select !== \"function\") select = selectorAll(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n for (var children = select.call(node, node.__data__, i, group), child, inherit = get$1(node, id), k = 0, l = children.length; k < l; ++k) {\n if (child = children[k]) {\n schedule(child, name, id, k, children, inherit);\n }\n }\n subgroups.push(children);\n parents.push(node);\n }\n }\n }\n\n return new Transition(subgroups, parents, name, id);\n }\n\n var Selection$1 = selection.prototype.constructor;\n\n function transition_selection() {\n return new Selection$1(this._groups, this._parents);\n }\n\n function styleRemove$1(name, interpolate) {\n var value00,\n value10,\n interpolate0;\n return function() {\n var style = window(this).getComputedStyle(this, null),\n value0 = style.getPropertyValue(name),\n value1 = (this.style.removeProperty(name), style.getPropertyValue(name));\n return value0 === value1 ? null\n : value0 === value00 && value1 === value10 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value10 = value1);\n };\n }\n\n function styleRemoveEnd(name) {\n return function() {\n this.style.removeProperty(name);\n };\n }\n\n function styleConstant$1(name, interpolate, value1) {\n var value00,\n interpolate0;\n return function() {\n var value0 = window(this).getComputedStyle(this, null).getPropertyValue(name);\n return value0 === value1 ? null\n : value0 === value00 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value1);\n };\n }\n\n function styleFunction$1(name, interpolate, value) {\n var value00,\n value10,\n interpolate0;\n return function() {\n var style = window(this).getComputedStyle(this, null),\n value0 = style.getPropertyValue(name),\n value1 = value(this);\n if (value1 == null) value1 = (this.style.removeProperty(name), style.getPropertyValue(name));\n return value0 === value1 ? null\n : value0 === value00 && value1 === value10 ? interpolate0\n : interpolate0 = interpolate(value00 = value0, value10 = value1);\n };\n }\n\n function transition_style(name, value, priority) {\n var i = (name += \"\") === \"transform\" ? interpolateTransform$1 : interpolate$1;\n return value == null ? this\n .styleTween(name, styleRemove$1(name, i))\n .on(\"end.style.\" + name, styleRemoveEnd(name))\n : this.styleTween(name, typeof value === \"function\"\n ? styleFunction$1(name, i, tweenValue(this, \"style.\" + name, value))\n : styleConstant$1(name, i, value), priority);\n }\n\n function styleTween(name, value, priority) {\n function tween() {\n var node = this, i = value.apply(node, arguments);\n return i && function(t) {\n node.style.setProperty(name, i(t), priority);\n };\n }\n tween._value = value;\n return tween;\n }\n\n function transition_styleTween(name, value, priority) {\n var key = \"style.\" + (name += \"\");\n if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n if (value == null) return this.tween(key, null);\n if (typeof value !== \"function\") throw new Error;\n return this.tween(key, styleTween(name, value, priority == null ? \"\" : priority));\n }\n\n function textConstant$1(value) {\n return function() {\n this.textContent = value;\n };\n }\n\n function textFunction$1(value) {\n return function() {\n var value1 = value(this);\n this.textContent = value1 == null ? \"\" : value1;\n };\n }\n\n function transition_text(value) {\n return this.tween(\"text\", typeof value === \"function\"\n ? textFunction$1(tweenValue(this, \"text\", value))\n : textConstant$1(value == null ? \"\" : value + \"\"));\n }\n\n function transition_transition() {\n var name = this._name,\n id0 = this._id,\n id1 = newId();\n\n for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n var inherit = get$1(node, id0);\n schedule(node, name, id1, i, group, {\n time: inherit.time + inherit.delay + inherit.duration,\n delay: 0,\n duration: inherit.duration,\n ease: inherit.ease\n });\n }\n }\n }\n\n return new Transition(groups, this._parents, name, id1);\n }\n\n var id = 0;\n\n function Transition(groups, parents, name, id) {\n this._groups = groups;\n this._parents = parents;\n this._name = name;\n this._id = id;\n }\n\n function transition(name) {\n return selection().transition(name);\n }\n\n function newId() {\n return ++id;\n }\n\n var selection_prototype = selection.prototype;\n\n Transition.prototype = transition.prototype = {\n constructor: Transition,\n select: transition_select,\n selectAll: transition_selectAll,\n filter: transition_filter,\n merge: transition_merge,\n selection: transition_selection,\n transition: transition_transition,\n call: selection_prototype.call,\n nodes: selection_prototype.nodes,\n node: selection_prototype.node,\n size: selection_prototype.size,\n empty: selection_prototype.empty,\n each: selection_prototype.each,\n on: transition_on,\n attr: transition_attr,\n attrTween: transition_attrTween,\n style: transition_style,\n styleTween: transition_styleTween,\n text: transition_text,\n remove: transition_remove,\n tween: transition_tween,\n delay: transition_delay,\n duration: transition_duration,\n ease: transition_ease\n };\n\n var defaultTiming = {\n time: null, // Set on use.\n delay: 0,\n duration: 250,\n ease: easeCubicInOut\n };\n\n function inherit(node, id) {\n var timing;\n while (!(timing = node.__transition) || !(timing = timing[id])) {\n if (!(node = node.parentNode)) {\n return defaultTiming.time = now(), defaultTiming;\n }\n }\n return timing;\n }\n\n function selection_transition(name) {\n var id,\n timing;\n\n if (name instanceof Transition) {\n id = name._id, name = name._name;\n } else {\n id = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + \"\";\n }\n\n for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n schedule(node, name, id, i, group, timing || inherit(node, id));\n }\n }\n }\n\n return new Transition(groups, this._parents, name, id);\n }\n\n selection.prototype.interrupt = selection_interrupt;\n selection.prototype.transition = selection_transition;\n\n var root$1 = [null];\n\n function active(node, name) {\n var schedules = node.__transition,\n schedule,\n i;\n\n if (schedules) {\n name = name == null ? null : name + \"\";\n for (i in schedules) {\n if ((schedule = schedules[i]).state > SCHEDULED && schedule.name === name) {\n return new Transition([[node]], root$1, name, +i);\n }\n }\n }\n\n return null;\n }\n\n var slice$4 = Array.prototype.slice;\n\n function identity$5(x) {\n return x;\n }\n\n var top = 1;\n var right = 2;\n var bottom = 3;\n var left = 4;\nvar epsilon$2 = 1e-6;\n function translateX(scale0, scale1, d) {\n var x = scale0(d);\n return \"translate(\" + (isFinite(x) ? x : scale1(d)) + \",0)\";\n }\n\n function translateY(scale0, scale1, d) {\n var y = scale0(d);\n return \"translate(0,\" + (isFinite(y) ? y : scale1(d)) + \")\";\n }\n\n function center(scale) {\n var width = scale.bandwidth() / 2;\n return function(d) {\n return scale(d) + width;\n };\n }\n\n function entering() {\n return !this.__axis;\n }\n\n function axis(orient, scale) {\n var tickArguments = [],\n tickValues = null,\n tickFormat = null,\n tickSizeInner = 6,\n tickSizeOuter = 6,\n tickPadding = 3;\n\n function axis(context) {\n var values = tickValues == null ? (scale.ticks ? scale.ticks.apply(scale, tickArguments) : scale.domain()) : tickValues,\n format = tickFormat == null ? (scale.tickFormat ? scale.tickFormat.apply(scale, tickArguments) : identity$5) : tickFormat,\n spacing = Math.max(tickSizeInner, 0) + tickPadding,\n transform = orient === top || orient === bottom ? translateX : translateY,\n range = scale.range(),\n range0 = range[0] + 0.5,\n range1 = range[range.length - 1] + 0.5,\n position = (scale.bandwidth ? center : identity$5)(scale.copy()),\n selection = context.selection ? context.selection() : context,\n path = selection.selectAll(\".domain\").data([null]),\n tick = selection.selectAll(\".tick\").data(values, scale).order(),\n tickExit = tick.exit(),\n tickEnter = tick.enter().append(\"g\").attr(\"class\", \"tick\"),\n line = tick.select(\"line\"),\n text = tick.select(\"text\"),\n k = orient === top || orient === left ? -1 : 1,\n x, y = orient === left || orient === right ? (x = \"x\", \"y\") : (x = \"y\", \"x\");\n\n path = path.merge(path.enter().insert(\"path\", \".tick\")\n .attr(\"class\", \"domain\")\n .attr(\"stroke\", \"#000\"));\n\n tick = tick.merge(tickEnter);\n\n line = line.merge(tickEnter.append(\"line\")\n .attr(\"stroke\", \"#000\")\n .attr(x + \"2\", k * tickSizeInner)\n .attr(y + \"1\", 0.5)\n .attr(y + \"2\", 0.5));\n\n text = text.merge(tickEnter.append(\"text\")\n .attr(\"fill\", \"#000\")\n .attr(x, k * spacing)\n .attr(y, 0.5)\n .attr(\"dy\", orient === top ? \"0em\" : orient === bottom ? \".71em\" : \".32em\"));\n\n if (context !== selection) {\n path = path.transition(context);\n tick = tick.transition(context);\n line = line.transition(context);\n text = text.transition(context);\n\n tickExit = tickExit.transition(context)\n .attr(\"opacity\", epsilon$2)\n .attr(\"transform\", function(d) { return transform(position, this.parentNode.__axis || position, d); });\n\n tickEnter\n .attr(\"opacity\", epsilon$2)\n .attr(\"transform\", function(d) { return transform(this.parentNode.__axis || position, position, d); });\n }\n\n tickExit.remove();\n\n path\n .attr(\"d\", orient === left || orient == right\n ? \"M\" + k * tickSizeOuter + \",\" + range0 + \"H0.5V\" + range1 + \"H\" + k * tickSizeOuter\n : \"M\" + range0 + \",\" + k * tickSizeOuter + \"V0.5H\" + range1 + \"V\" + k * tickSizeOuter);\n\n tick\n .attr(\"opacity\", 1)\n .attr(\"transform\", function(d) { return transform(position, position, d); });\n\n line\n .attr(x + \"2\", k * tickSizeInner);\n\n text\n .attr(x, k * spacing)\n .text(format);\n\n selection.filter(entering)\n .attr(\"fill\", \"none\")\n .attr(\"font-size\", 10)\n .attr(\"font-family\", \"sans-serif\")\n .attr(\"text-anchor\", orient === right ? \"start\" : orient === left ? \"end\" : \"middle\");\n\n selection\n .each(function() { this.__axis = position; });\n }\n\n axis.scale = function(_) {\n return arguments.length ? (scale = _, axis) : scale;\n };\n\n axis.ticks = function() {\n return tickArguments = slice$4.call(arguments), axis;\n };\n\n axis.tickArguments = function(_) {\n return arguments.length ? (tickArguments = _ == null ? [] : slice$4.call(_), axis) : tickArguments.slice();\n };\n\n axis.tickValues = function(_) {\n return arguments.length ? (tickValues = _ == null ? null : slice$4.call(_), axis) : tickValues && tickValues.slice();\n };\n\n axis.tickFormat = function(_) {\n return arguments.length ? (tickFormat = _, axis) : tickFormat;\n };\n\n axis.tickSize = function(_) {\n return arguments.length ? (tickSizeInner = tickSizeOuter = +_, axis) : tickSizeInner;\n };\n\n axis.tickSizeInner = function(_) {\n return arguments.length ? (tickSizeInner = +_, axis) : tickSizeInner;\n };\n\n axis.tickSizeOuter = function(_) {\n return arguments.length ? (tickSizeOuter = +_, axis) : tickSizeOuter;\n };\n\n axis.tickPadding = function(_) {\n return arguments.length ? (tickPadding = +_, axis) : tickPadding;\n };\n\n return axis;\n }\n\n function axisTop(scale) {\n return axis(top, scale);\n }\n\n function axisRight(scale) {\n return axis(right, scale);\n }\n\n function axisBottom(scale) {\n return axis(bottom, scale);\n }\n\n function axisLeft(scale) {\n return axis(left, scale);\n }\n\n function defaultSeparation(a, b) {\n return a.parent === b.parent ? 1 : 2;\n }\n\n function meanX(children) {\n return children.reduce(meanXReduce, 0) / children.length;\n }\n\n function meanXReduce(x, c) {\n return x + c.x;\n }\n\n function maxY(children) {\n return 1 + children.reduce(maxYReduce, 0);\n }\n\n function maxYReduce(y, c) {\n return Math.max(y, c.y);\n }\n\n function leafLeft(node) {\n var children;\n while (children = node.children) node = children[0];\n return node;\n }\n\n function leafRight(node) {\n var children;\n while (children = node.children) node = children[children.length - 1];\n return node;\n }\n\n function cluster() {\n var separation = defaultSeparation,\n dx = 1,\n dy = 1,\n nodeSize = false;\n\n function cluster(root) {\n var previousNode,\n x = 0;\n\n // First walk, computing the initial x & y values.\n root.eachAfter(function(node) {\n var children = node.children;\n if (children) {\n node.x = meanX(children);\n node.y = maxY(children);\n } else {\n node.x = previousNode ? x += separation(node, previousNode) : 0;\n node.y = 0;\n previousNode = node;\n }\n });\n\n var left = leafLeft(root),\n right = leafRight(root),\n x0 = left.x - separation(left, right) / 2,\n x1 = right.x + separation(right, left) / 2;\n\n // Second walk, normalizing x & y to the desired size.\n return root.eachAfter(nodeSize ? function(node) {\n node.x = (node.x - root.x) * dx;\n node.y = (root.y - node.y) * dy;\n } : function(node) {\n node.x = (node.x - x0) / (x1 - x0) * dx;\n node.y = (1 - (root.y ? node.y / root.y : 1)) * dy;\n });\n }\n\n cluster.separation = function(x) {\n return arguments.length ? (separation = x, cluster) : separation;\n };\n\n cluster.size = function(x) {\n return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? null : [dx, dy]);\n };\n\n cluster.nodeSize = function(x) {\n return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? [dx, dy] : null);\n };\n\n return cluster;\n }\n\n function node_each(callback) {\n var node = this, current, next = [node], children, i, n;\n do {\n current = next.reverse(), next = [];\n while (node = current.pop()) {\n callback(node), children = node.children;\n if (children) for (i = 0, n = children.length; i < n; ++i) {\n next.push(children[i]);\n }\n }\n } while (next.length);\n return this;\n }\n\n function node_eachBefore(callback) {\n var node = this, nodes = [node], children, i;\n while (node = nodes.pop()) {\n callback(node), children = node.children;\n if (children) for (i = children.length - 1; i >= 0; --i) {\n nodes.push(children[i]);\n }\n }\n return this;\n }\n\n function node_eachAfter(callback) {\n var node = this, nodes = [node], next = [], children, i, n;\n while (node = nodes.pop()) {\n next.push(node), children = node.children;\n if (children) for (i = 0, n = children.length; i < n; ++i) {\n nodes.push(children[i]);\n }\n }\n while (node = next.pop()) {\n callback(node);\n }\n return this;\n }\n\n function node_sum(value) {\n return this.eachAfter(function(node) {\n var sum = +value(node.data) || 0,\n children = node.children,\n i = children && children.length;\n while (--i >= 0) sum += children[i].value;\n node.value = sum;\n });\n }\n\n function node_sort(compare) {\n return this.eachBefore(function(node) {\n if (node.children) {\n node.children.sort(compare);\n }\n });\n }\n\n function node_path(end) {\n var start = this,\n ancestor = leastCommonAncestor(start, end),\n nodes = [start];\n while (start !== ancestor) {\n start = start.parent;\n nodes.push(start);\n }\n var k = nodes.length;\n while (end !== ancestor) {\n nodes.splice(k, 0, end);\n end = end.parent;\n }\n return nodes;\n }\n\n function leastCommonAncestor(a, b) {\n if (a === b) return a;\n var aNodes = a.ancestors(),\n bNodes = b.ancestors(),\n c = null;\n a = aNodes.pop();\n b = bNodes.pop();\n while (a === b) {\n c = a;\n a = aNodes.pop();\n b = bNodes.pop();\n }\n return c;\n }\n\n function node_ancestors() {\n var node = this, nodes = [node];\n while (node = node.parent) {\n nodes.push(node);\n }\n return nodes;\n }\n\n function node_descendants() {\n var nodes = [];\n this.each(function(node) {\n nodes.push(node);\n });\n return nodes;\n }\n\n function node_leaves() {\n var leaves = [];\n this.eachBefore(function(node) {\n if (!node.children) {\n leaves.push(node);\n }\n });\n return leaves;\n }\n\n function node_links() {\n var root = this, links = [];\n root.each(function(node) {\n if (node !== root) { // Don’t include the root’s parent, if any.\n links.push({source: node.parent, target: node});\n }\n });\n return links;\n }\n\n function hierarchy(data, children) {\n var root = new Node(data),\n valued = +data.value && (root.value = data.value),\n node,\n nodes = [root],\n child,\n childs,\n i,\n n;\n\n if (children == null) children = defaultChildren;\n\n while (node = nodes.pop()) {\n if (valued) node.value = +node.data.value;\n if ((childs = children(node.data)) && (n = childs.length)) {\n node.children = new Array(n);\n for (i = n - 1; i >= 0; --i) {\n nodes.push(child = node.children[i] = new Node(childs[i]));\n child.parent = node;\n child.depth = node.depth + 1;\n }\n }\n }\n\n return root.eachBefore(computeHeight);\n }\n\n function node_copy() {\n return hierarchy(this).eachBefore(copyData);\n }\n\n function defaultChildren(d) {\n return d.children;\n }\n\n function copyData(node) {\n node.data = node.data.data;\n }\n\n function computeHeight(node) {\n var height = 0;\n do node.height = height;\n while ((node = node.parent) && (node.height < ++height));\n }\n\n function Node(data) {\n this.data = data;\n this.depth =\n this.height = 0;\n this.parent = null;\n }\n\n Node.prototype = hierarchy.prototype = {\n constructor: Node,\n each: node_each,\n eachAfter: node_eachAfter,\n eachBefore: node_eachBefore,\n sum: node_sum,\n sort: node_sort,\n path: node_path,\n ancestors: node_ancestors,\n descendants: node_descendants,\n leaves: node_leaves,\n links: node_links,\n copy: node_copy\n };\n\n function Node$2(value) {\n this._ = value;\n this.next = null;\n }\n\n function shuffle$1(array) {\n var i,\n n = (array = array.slice()).length,\n head = null,\n node = head;\n\n while (n) {\n var next = new Node$2(array[n - 1]);\n if (node) node = node.next = next;\n else node = head = next;\n array[i] = array[--n];\n }\n\n return {\n head: head,\n tail: node\n };\n }\n\n function enclose(circles) {\n return encloseN(shuffle$1(circles), []);\n }\n\n function encloses(a, b) {\n var dx = b.x - a.x,\n dy = b.y - a.y,\n dr = a.r - b.r;\n return dr * dr + 1e-6 > dx * dx + dy * dy;\n }\n\n // Returns the smallest circle that contains circles L and intersects circles B.\n function encloseN(L, B) {\n var circle,\n l0 = null,\n l1 = L.head,\n l2,\n p1;\n\n switch (B.length) {\n case 1: circle = enclose1(B[0]); break;\n case 2: circle = enclose2(B[0], B[1]); break;\n case 3: circle = enclose3(B[0], B[1], B[2]); break;\n }\n\n while (l1) {\n p1 = l1._, l2 = l1.next;\n if (!circle || !encloses(circle, p1)) {\n\n // Temporarily truncate L before l1.\n if (l0) L.tail = l0, l0.next = null;\n else L.head = L.tail = null;\n\n B.push(p1);\n circle = encloseN(L, B); // Note: reorders L!\n B.pop();\n\n // Move l1 to the front of L and reconnect the truncated list L.\n if (L.head) l1.next = L.head, L.head = l1;\n else l1.next = null, L.head = L.tail = l1;\n l0 = L.tail, l0.next = l2;\n\n } else {\n l0 = l1;\n }\n l1 = l2;\n }\n\n L.tail = l0;\n return circle;\n }\n\n function enclose1(a) {\n return {\n x: a.x,\n y: a.y,\n r: a.r\n };\n }\n\n function enclose2(a, b) {\n var x1 = a.x, y1 = a.y, r1 = a.r,\n x2 = b.x, y2 = b.y, r2 = b.r,\n x21 = x2 - x1, y21 = y2 - y1, r21 = r2 - r1,\n l = Math.sqrt(x21 * x21 + y21 * y21);\n return {\n x: (x1 + x2 + x21 / l * r21) / 2,\n y: (y1 + y2 + y21 / l * r21) / 2,\n r: (l + r1 + r2) / 2\n };\n }\n\n function enclose3(a, b, c) {\n var x1 = a.x, y1 = a.y, r1 = a.r,\n x2 = b.x, y2 = b.y, r2 = b.r,\n x3 = c.x, y3 = c.y, r3 = c.r,\n a2 = 2 * (x1 - x2),\n b2 = 2 * (y1 - y2),\n c2 = 2 * (r2 - r1),\n d2 = x1 * x1 + y1 * y1 - r1 * r1 - x2 * x2 - y2 * y2 + r2 * r2,\n a3 = 2 * (x1 - x3),\n b3 = 2 * (y1 - y3),\n c3 = 2 * (r3 - r1),\n d3 = x1 * x1 + y1 * y1 - r1 * r1 - x3 * x3 - y3 * y3 + r3 * r3,\n ab = a3 * b2 - a2 * b3,\n xa = (b2 * d3 - b3 * d2) / ab - x1,\n xb = (b3 * c2 - b2 * c3) / ab,\n ya = (a3 * d2 - a2 * d3) / ab - y1,\n yb = (a2 * c3 - a3 * c2) / ab,\n A = xb * xb + yb * yb - 1,\n B = 2 * (xa * xb + ya * yb + r1),\n C = xa * xa + ya * ya - r1 * r1,\n r = (-B - Math.sqrt(B * B - 4 * A * C)) / (2 * A);\n return {\n x: xa + xb * r + x1,\n y: ya + yb * r + y1,\n r: r\n };\n }\n\n function place(a, b, c) {\n var ax = a.x,\n ay = a.y,\n da = b.r + c.r,\n db = a.r + c.r,\n dx = b.x - ax,\n dy = b.y - ay,\n dc = dx * dx + dy * dy;\n if (dc) {\n var x = 0.5 + ((db *= db) - (da *= da)) / (2 * dc),\n y = Math.sqrt(Math.max(0, 2 * da * (db + dc) - (db -= dc) * db - da * da)) / (2 * dc);\n c.x = ax + x * dx + y * dy;\n c.y = ay + x * dy - y * dx;\n } else {\n c.x = ax + db;\n c.y = ay;\n }\n }\n\n function intersects(a, b) {\n var dx = b.x - a.x,\n dy = b.y - a.y,\n dr = a.r + b.r;\n return dr * dr > dx * dx + dy * dy;\n }\n\n function distance2(circle, x, y) {\n var dx = circle.x - x,\n dy = circle.y - y;\n return dx * dx + dy * dy;\n }\n\n function Node$1(circle) {\n this._ = circle;\n this.next = null;\n this.previous = null;\n }\n\n function packEnclose(circles) {\n if (!(n = circles.length)) return 0;\n\n var a, b, c, n;\n\n // Place the first circle.\n a = circles[0], a.x = 0, a.y = 0;\n if (!(n > 1)) return a.r;\n\n // Place the second circle.\n b = circles[1], a.x = -b.r, b.x = a.r, b.y = 0;\n if (!(n > 2)) return a.r + b.r;\n\n // Place the third circle.\n place(b, a, c = circles[2]);\n\n // Initialize the weighted centroid.\n var aa = a.r * a.r,\n ba = b.r * b.r,\n ca = c.r * c.r,\n oa = aa + ba + ca,\n ox = aa * a.x + ba * b.x + ca * c.x,\n oy = aa * a.y + ba * b.y + ca * c.y,\n cx, cy, i, j, k, sj, sk;\n\n // Initialize the front-chain using the first three circles a, b and c.\n a = new Node$1(a), b = new Node$1(b), c = new Node$1(c);\n a.next = c.previous = b;\n b.next = a.previous = c;\n c.next = b.previous = a;\n\n // Attempt to place each remaining circle…\n pack: for (i = 3; i < n; ++i) {\n place(a._, b._, c = circles[i]), c = new Node$1(c);\n\n // If there are only three elements in the front-chain…\n if ((k = a.previous) === (j = b.next)) {\n // If the new circle intersects the third circle,\n // rotate the front chain to try the next position.\n if (intersects(j._, c._)) {\n a = b, b = j, --i;\n continue pack;\n }\n }\n\n // Find the closest intersecting circle on the front-chain, if any.\n else {\n sj = j._.r, sk = k._.r;\n do {\n if (sj <= sk) {\n if (intersects(j._, c._)) {\n b = j, a.next = b, b.previous = a, --i;\n continue pack;\n }\n j = j.next, sj += j._.r;\n } else {\n if (intersects(k._, c._)) {\n a = k, a.next = b, b.previous = a, --i;\n continue pack;\n }\n k = k.previous, sk += k._.r;\n }\n } while (j !== k.next);\n }\n\n // Success! Insert the new circle c between a and b.\n c.previous = a, c.next = b, a.next = b.previous = b = c;\n\n // Update the weighted centroid.\n oa += ca = c._.r * c._.r;\n ox += ca * c._.x;\n oy += ca * c._.y;\n\n // Compute the new closest circle a to centroid.\n aa = distance2(a._, cx = ox / oa, cy = oy / oa);\n while ((c = c.next) !== b) {\n if ((ca = distance2(c._, cx, cy)) < aa) {\n a = c, aa = ca;\n }\n }\n b = a.next;\n }\n\n // Compute the enclosing circle of the front chain.\n a = [b._], c = b; while ((c = c.next) !== b) a.push(c._); c = enclose(a);\n\n // Translate the circles to put the enclosing circle around the origin.\n for (i = 0; i < n; ++i) a = circles[i], a.x -= c.x, a.y -= c.y;\n\n return c.r;\n }\n\n function siblings(circles) {\n packEnclose(circles);\n return circles;\n }\n\n function optional(f) {\n return f == null ? null : required(f);\n }\n\n function required(f) {\n if (typeof f !== \"function\") throw new Error;\n return f;\n }\n\n function constantZero() {\n return 0;\n }\n\n function constant$5(x) {\n return function() {\n return x;\n };\n }\n\n function defaultRadius(d) {\n return Math.sqrt(d.value);\n }\n\n function index() {\n var radius = null,\n dx = 1,\n dy = 1,\n padding = constantZero;\n\n function pack(root) {\n root.x = dx / 2, root.y = dy / 2;\n if (radius) {\n root.eachBefore(radiusLeaf(radius))\n .eachAfter(packChildren(padding, 0.5))\n .eachBefore(translateChild(1));\n } else {\n root.eachBefore(radiusLeaf(defaultRadius))\n .eachAfter(packChildren(constantZero, 1))\n .eachAfter(packChildren(padding, root.r / Math.min(dx, dy)))\n .eachBefore(translateChild(Math.min(dx, dy) / (2 * root.r)));\n }\n return root;\n }\n\n pack.radius = function(x) {\n return arguments.length ? (radius = optional(x), pack) : radius;\n };\n\n pack.size = function(x) {\n return arguments.length ? (dx = +x[0], dy = +x[1], pack) : [dx, dy];\n };\n\n pack.padding = function(x) {\n return arguments.length ? (padding = typeof x === \"function\" ? x : constant$5(+x), pack) : padding;\n };\n\n return pack;\n }\n\n function radiusLeaf(radius) {\n return function(node) {\n if (!node.children) {\n node.r = Math.max(0, +radius(node) || 0);\n }\n };\n }\n\n function packChildren(padding, k) {\n return function(node) {\n if (children = node.children) {\n var children,\n i,\n n = children.length,\n r = padding(node) * k || 0,\n e;\n\n if (r) for (i = 0; i < n; ++i) children[i].r += r;\n e = packEnclose(children);\n if (r) for (i = 0; i < n; ++i) children[i].r -= r;\n node.r = e + r;\n }\n };\n }\n\n function translateChild(k) {\n return function(node) {\n var parent = node.parent;\n node.r *= k;\n if (parent) {\n node.x = parent.x + k * node.x;\n node.y = parent.y + k * node.y;\n }\n };\n }\n\n function roundNode(node) {\n node.x0 = Math.round(node.x0);\n node.y0 = Math.round(node.y0);\n node.x1 = Math.round(node.x1);\n node.y1 = Math.round(node.y1);\n }\n\n function treemapDice(parent, x0, y0, x1, y1) {\n var nodes = parent.children,\n node,\n i = -1,\n n = nodes.length,\n k = parent.value && (x1 - x0) / parent.value;\n\n while (++i < n) {\n node = nodes[i], node.y0 = y0, node.y1 = y1;\n node.x0 = x0, node.x1 = x0 += node.value * k;\n }\n }\n\n function partition() {\n var dx = 1,\n dy = 1,\n padding = 0,\n round = false;\n\n function partition(root) {\n var n = root.height + 1;\n root.x0 =\n root.y0 = padding;\n root.x1 = dx;\n root.y1 = dy / n;\n root.eachBefore(positionNode(dy, n));\n if (round) root.eachBefore(roundNode);\n return root;\n }\n\n function positionNode(dy, n) {\n return function(node) {\n if (node.children) {\n treemapDice(node, node.x0, dy * (node.depth + 1) / n, node.x1, dy * (node.depth + 2) / n);\n }\n var x0 = node.x0,\n y0 = node.y0,\n x1 = node.x1 - padding,\n y1 = node.y1 - padding;\n if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n node.x0 = x0;\n node.y0 = y0;\n node.x1 = x1;\n node.y1 = y1;\n };\n }\n\n partition.round = function(x) {\n return arguments.length ? (round = !!x, partition) : round;\n };\n\n partition.size = function(x) {\n return arguments.length ? (dx = +x[0], dy = +x[1], partition) : [dx, dy];\n };\n\n partition.padding = function(x) {\n return arguments.length ? (padding = +x, partition) : padding;\n };\n\n return partition;\n }\n\nvar keyPrefix$1 = \"$\";\n var preroot = {depth: -1};\n var ambiguous = {};\n function defaultId(d) {\n return d.id;\n }\n\n function defaultParentId(d) {\n return d.parentId;\n }\n\n function stratify() {\n var id = defaultId,\n parentId = defaultParentId;\n\n function stratify(data) {\n var d,\n i,\n n = data.length,\n root,\n parent,\n node,\n nodes = new Array(n),\n nodeId,\n nodeKey,\n nodeByKey = {};\n\n for (i = 0; i < n; ++i) {\n d = data[i], node = nodes[i] = new Node(d);\n if ((nodeId = id(d, i, data)) != null && (nodeId += \"\")) {\n nodeKey = keyPrefix$1 + (node.id = nodeId);\n nodeByKey[nodeKey] = nodeKey in nodeByKey ? ambiguous : node;\n }\n }\n\n for (i = 0; i < n; ++i) {\n node = nodes[i], nodeId = parentId(data[i], i, data);\n if (nodeId == null || !(nodeId += \"\")) {\n if (root) throw new Error(\"multiple roots\");\n root = node;\n } else {\n parent = nodeByKey[keyPrefix$1 + nodeId];\n if (!parent) throw new Error(\"missing: \" + nodeId);\n if (parent === ambiguous) throw new Error(\"ambiguous: \" + nodeId);\n if (parent.children) parent.children.push(node);\n else parent.children = [node];\n node.parent = parent;\n }\n }\n\n if (!root) throw new Error(\"no root\");\n root.parent = preroot;\n root.eachBefore(function(node) { node.depth = node.parent.depth + 1; --n; }).eachBefore(computeHeight);\n root.parent = null;\n if (n > 0) throw new Error(\"cycle\");\n\n return root;\n }\n\n stratify.id = function(x) {\n return arguments.length ? (id = required(x), stratify) : id;\n };\n\n stratify.parentId = function(x) {\n return arguments.length ? (parentId = required(x), stratify) : parentId;\n };\n\n return stratify;\n }\n\n function defaultSeparation$1(a, b) {\n return a.parent === b.parent ? 1 : 2;\n }\n\n // function radialSeparation(a, b) {\n // return (a.parent === b.parent ? 1 : 2) / a.depth;\n // }\n\n // This function is used to traverse the left contour of a subtree (or\n // subforest). It returns the successor of v on this contour. This successor is\n // either given by the leftmost child of v or by the thread of v. The function\n // returns null if and only if v is on the highest level of its subtree.\n function nextLeft(v) {\n var children = v.children;\n return children ? children[0] : v.t;\n }\n\n // This function works analogously to nextLeft.\n function nextRight(v) {\n var children = v.children;\n return children ? children[children.length - 1] : v.t;\n }\n\n // Shifts the current subtree rooted at w+. This is done by increasing\n // prelim(w+) and mod(w+) by shift.\n function moveSubtree(wm, wp, shift) {\n var change = shift / (wp.i - wm.i);\n wp.c -= change;\n wp.s += shift;\n wm.c += change;\n wp.z += shift;\n wp.m += shift;\n }\n\n // All other shifts, applied to the smaller subtrees between w- and w+, are\n // performed by this function. To prepare the shifts, we have to adjust\n // change(w+), shift(w+), and change(w-).\n function executeShifts(v) {\n var shift = 0,\n change = 0,\n children = v.children,\n i = children.length,\n w;\n while (--i >= 0) {\n w = children[i];\n w.z += shift;\n w.m += shift;\n shift += w.s + (change += w.c);\n }\n }\n\n // If vi-’s ancestor is a sibling of v, returns vi-’s ancestor. Otherwise,\n // returns the specified (default) ancestor.\n function nextAncestor(vim, v, ancestor) {\n return vim.a.parent === v.parent ? vim.a : ancestor;\n }\n\n function TreeNode(node, i) {\n this._ = node;\n this.parent = null;\n this.children = null;\n this.A = null; // default ancestor\n this.a = this; // ancestor\n this.z = 0; // prelim\n this.m = 0; // mod\n this.c = 0; // change\n this.s = 0; // shift\n this.t = null; // thread\n this.i = i; // number\n }\n\n TreeNode.prototype = Object.create(Node.prototype);\n\n function treeRoot(root) {\n var tree = new TreeNode(root, 0),\n node,\n nodes = [tree],\n child,\n children,\n i,\n n;\n\n while (node = nodes.pop()) {\n if (children = node._.children) {\n node.children = new Array(n = children.length);\n for (i = n - 1; i >= 0; --i) {\n nodes.push(child = node.children[i] = new TreeNode(children[i], i));\n child.parent = node;\n }\n }\n }\n\n (tree.parent = new TreeNode(null, 0)).children = [tree];\n return tree;\n }\n\n // Node-link tree diagram using the Reingold-Tilford \"tidy\" algorithm\n function tree() {\n var separation = defaultSeparation$1,\n dx = 1,\n dy = 1,\n nodeSize = null;\n\n function tree(root) {\n var t = treeRoot(root);\n\n // Compute the layout using Buchheim et al.’s algorithm.\n t.eachAfter(firstWalk), t.parent.m = -t.z;\n t.eachBefore(secondWalk);\n\n // If a fixed node size is specified, scale x and y.\n if (nodeSize) root.eachBefore(sizeNode);\n\n // If a fixed tree size is specified, scale x and y based on the extent.\n // Compute the left-most, right-most, and depth-most nodes for extents.\n else {\n var left = root,\n right = root,\n bottom = root;\n root.eachBefore(function(node) {\n if (node.x < left.x) left = node;\n if (node.x > right.x) right = node;\n if (node.depth > bottom.depth) bottom = node;\n });\n var s = left === right ? 1 : separation(left, right) / 2,\n tx = s - left.x,\n kx = dx / (right.x + s + tx),\n ky = dy / (bottom.depth || 1);\n root.eachBefore(function(node) {\n node.x = (node.x + tx) * kx;\n node.y = node.depth * ky;\n });\n }\n\n return root;\n }\n\n // Computes a preliminary x-coordinate for v. Before that, FIRST WALK is\n // applied recursively to the children of v, as well as the function\n // APPORTION. After spacing out the children by calling EXECUTE SHIFTS, the\n // node v is placed to the midpoint of its outermost children.\n function firstWalk(v) {\n var children = v.children,\n siblings = v.parent.children,\n w = v.i ? siblings[v.i - 1] : null;\n if (children) {\n executeShifts(v);\n var midpoint = (children[0].z + children[children.length - 1].z) / 2;\n if (w) {\n v.z = w.z + separation(v._, w._);\n v.m = v.z - midpoint;\n } else {\n v.z = midpoint;\n }\n } else if (w) {\n v.z = w.z + separation(v._, w._);\n }\n v.parent.A = apportion(v, w, v.parent.A || siblings[0]);\n }\n\n // Computes all real x-coordinates by summing up the modifiers recursively.\n function secondWalk(v) {\n v._.x = v.z + v.parent.m;\n v.m += v.parent.m;\n }\n\n // The core of the algorithm. Here, a new subtree is combined with the\n // previous subtrees. Threads are used to traverse the inside and outside\n // contours of the left and right subtree up to the highest common level. The\n // vertices used for the traversals are vi+, vi-, vo-, and vo+, where the\n // superscript o means outside and i means inside, the subscript - means left\n // subtree and + means right subtree. For summing up the modifiers along the\n // contour, we use respective variables si+, si-, so-, and so+. Whenever two\n // nodes of the inside contours conflict, we compute the left one of the\n // greatest uncommon ancestors using the function ANCESTOR and call MOVE\n // SUBTREE to shift the subtree and prepare the shifts of smaller subtrees.\n // Finally, we add a new thread (if necessary).\n function apportion(v, w, ancestor) {\n if (w) {\n var vip = v,\n vop = v,\n vim = w,\n vom = vip.parent.children[0],\n sip = vip.m,\n sop = vop.m,\n sim = vim.m,\n som = vom.m,\n shift;\n while (vim = nextRight(vim), vip = nextLeft(vip), vim && vip) {\n vom = nextLeft(vom);\n vop = nextRight(vop);\n vop.a = v;\n shift = vim.z + sim - vip.z - sip + separation(vim._, vip._);\n if (shift > 0) {\n moveSubtree(nextAncestor(vim, v, ancestor), v, shift);\n sip += shift;\n sop += shift;\n }\n sim += vim.m;\n sip += vip.m;\n som += vom.m;\n sop += vop.m;\n }\n if (vim && !nextRight(vop)) {\n vop.t = vim;\n vop.m += sim - sop;\n }\n if (vip && !nextLeft(vom)) {\n vom.t = vip;\n vom.m += sip - som;\n ancestor = v;\n }\n }\n return ancestor;\n }\n\n function sizeNode(node) {\n node.x *= dx;\n node.y = node.depth * dy;\n }\n\n tree.separation = function(x) {\n return arguments.length ? (separation = x, tree) : separation;\n };\n\n tree.size = function(x) {\n return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], tree) : (nodeSize ? null : [dx, dy]);\n };\n\n tree.nodeSize = function(x) {\n return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], tree) : (nodeSize ? [dx, dy] : null);\n };\n\n return tree;\n }\n\n function treemapSlice(parent, x0, y0, x1, y1) {\n var nodes = parent.children,\n node,\n i = -1,\n n = nodes.length,\n k = parent.value && (y1 - y0) / parent.value;\n\n while (++i < n) {\n node = nodes[i], node.x0 = x0, node.x1 = x1;\n node.y0 = y0, node.y1 = y0 += node.value * k;\n }\n }\n\n var phi = (1 + Math.sqrt(5)) / 2;\n\n function squarifyRatio(ratio, parent, x0, y0, x1, y1) {\n var rows = [],\n nodes = parent.children,\n row,\n nodeValue,\n i0 = 0,\n i1,\n n = nodes.length,\n dx, dy,\n value = parent.value,\n sumValue,\n minValue,\n maxValue,\n newRatio,\n minRatio,\n alpha,\n beta;\n\n while (i0 < n) {\n dx = x1 - x0, dy = y1 - y0;\n minValue = maxValue = sumValue = nodes[i0].value;\n alpha = Math.max(dy / dx, dx / dy) / (value * ratio);\n beta = sumValue * sumValue * alpha;\n minRatio = Math.max(maxValue / beta, beta / minValue);\n\n // Keep adding nodes while the aspect ratio maintains or improves.\n for (i1 = i0 + 1; i1 < n; ++i1) {\n sumValue += nodeValue = nodes[i1].value;\n if (nodeValue < minValue) minValue = nodeValue;\n if (nodeValue > maxValue) maxValue = nodeValue;\n beta = sumValue * sumValue * alpha;\n newRatio = Math.max(maxValue / beta, beta / minValue);\n if (newRatio > minRatio) { sumValue -= nodeValue; break; }\n minRatio = newRatio;\n }\n\n // Position and record the row orientation.\n rows.push(row = {value: sumValue, dice: dx < dy, children: nodes.slice(i0, i1)});\n if (row.dice) treemapDice(row, x0, y0, x1, value ? y0 += dy * sumValue / value : y1);\n else treemapSlice(row, x0, y0, value ? x0 += dx * sumValue / value : x1, y1);\n value -= sumValue, i0 = i1;\n }\n\n return rows;\n }\n\n var squarify = (function custom(ratio) {\n\n function squarify(parent, x0, y0, x1, y1) {\n squarifyRatio(ratio, parent, x0, y0, x1, y1);\n }\n\n squarify.ratio = function(x) {\n return custom((x = +x) > 1 ? x : 1);\n };\n\n return squarify;\n })(phi);\n\n function index$1() {\n var tile = squarify,\n round = false,\n dx = 1,\n dy = 1,\n paddingStack = [0],\n paddingInner = constantZero,\n paddingTop = constantZero,\n paddingRight = constantZero,\n paddingBottom = constantZero,\n paddingLeft = constantZero;\n\n function treemap(root) {\n root.x0 =\n root.y0 = 0;\n root.x1 = dx;\n root.y1 = dy;\n root.eachBefore(positionNode);\n paddingStack = [0];\n if (round) root.eachBefore(roundNode);\n return root;\n }\n\n function positionNode(node) {\n var p = paddingStack[node.depth],\n x0 = node.x0 + p,\n y0 = node.y0 + p,\n x1 = node.x1 - p,\n y1 = node.y1 - p;\n if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n node.x0 = x0;\n node.y0 = y0;\n node.x1 = x1;\n node.y1 = y1;\n if (node.children) {\n p = paddingStack[node.depth + 1] = paddingInner(node) / 2;\n x0 += paddingLeft(node) - p;\n y0 += paddingTop(node) - p;\n x1 -= paddingRight(node) - p;\n y1 -= paddingBottom(node) - p;\n if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n tile(node, x0, y0, x1, y1);\n }\n }\n\n treemap.round = function(x) {\n return arguments.length ? (round = !!x, treemap) : round;\n };\n\n treemap.size = function(x) {\n return arguments.length ? (dx = +x[0], dy = +x[1], treemap) : [dx, dy];\n };\n\n treemap.tile = function(x) {\n return arguments.length ? (tile = required(x), treemap) : tile;\n };\n\n treemap.padding = function(x) {\n return arguments.length ? treemap.paddingInner(x).paddingOuter(x) : treemap.paddingInner();\n };\n\n treemap.paddingInner = function(x) {\n return arguments.length ? (paddingInner = typeof x === \"function\" ? x : constant$5(+x), treemap) : paddingInner;\n };\n\n treemap.paddingOuter = function(x) {\n return arguments.length ? treemap.paddingTop(x).paddingRight(x).paddingBottom(x).paddingLeft(x) : treemap.paddingTop();\n };\n\n treemap.paddingTop = function(x) {\n return arguments.length ? (paddingTop = typeof x === \"function\" ? x : constant$5(+x), treemap) : paddingTop;\n };\n\n treemap.paddingRight = function(x) {\n return arguments.length ? (paddingRight = typeof x === \"function\" ? x : constant$5(+x), treemap) : paddingRight;\n };\n\n treemap.paddingBottom = function(x) {\n return arguments.length ? (paddingBottom = typeof x === \"function\" ? x : constant$5(+x), treemap) : paddingBottom;\n };\n\n treemap.paddingLeft = function(x) {\n return arguments.length ? (paddingLeft = typeof x === \"function\" ? x : constant$5(+x), treemap) : paddingLeft;\n };\n\n return treemap;\n }\n\n function binary(parent, x0, y0, x1, y1) {\n var nodes = parent.children,\n i, n = nodes.length,\n sum, sums = new Array(n + 1);\n\n for (sums[0] = sum = i = 0; i < n; ++i) {\n sums[i + 1] = sum += nodes[i].value;\n }\n\n partition(0, n, parent.value, x0, y0, x1, y1);\n\n function partition(i, j, value, x0, y0, x1, y1) {\n if (i >= j - 1) {\n var node = nodes[i];\n node.x0 = x0, node.y0 = y0;\n node.x1 = x1, node.y1 = y1;\n return;\n }\n\n var valueOffset = sums[i],\n valueTarget = (value / 2) + valueOffset,\n k = i + 1,\n hi = j - 1;\n\n while (k < hi) {\n var mid = k + hi >>> 1;\n if (sums[mid] < valueTarget) k = mid + 1;\n else hi = mid;\n }\n\n var valueLeft = sums[k] - valueOffset,\n valueRight = value - valueLeft;\n\n if ((y1 - y0) > (x1 - x0)) {\n var yk = (y0 * valueRight + y1 * valueLeft) / value;\n partition(i, k, valueLeft, x0, y0, x1, yk);\n partition(k, j, valueRight, x0, yk, x1, y1);\n } else {\n var xk = (x0 * valueRight + x1 * valueLeft) / value;\n partition(i, k, valueLeft, x0, y0, xk, y1);\n partition(k, j, valueRight, xk, y0, x1, y1);\n }\n }\n }\n\n function sliceDice(parent, x0, y0, x1, y1) {\n (parent.depth & 1 ? treemapSlice : treemapDice)(parent, x0, y0, x1, y1);\n }\n\n var resquarify = (function custom(ratio) {\n\n function resquarify(parent, x0, y0, x1, y1) {\n if ((rows = parent._squarify) && (rows.ratio === ratio)) {\n var rows,\n row,\n nodes,\n i,\n j = -1,\n n,\n m = rows.length,\n value = parent.value;\n\n while (++j < m) {\n row = rows[j], nodes = row.children;\n for (i = row.value = 0, n = nodes.length; i < n; ++i) row.value += nodes[i].value;\n if (row.dice) treemapDice(row, x0, y0, x1, y0 += (y1 - y0) * row.value / value);\n else treemapSlice(row, x0, y0, x0 += (x1 - x0) * row.value / value, y1);\n value -= row.value;\n }\n } else {\n parent._squarify = rows = squarifyRatio(ratio, parent, x0, y0, x1, y1);\n rows.ratio = ratio;\n }\n }\n\n resquarify.ratio = function(x) {\n return custom((x = +x) > 1 ? x : 1);\n };\n\n return resquarify;\n })(phi);\n\n function center$1(x, y) {\n var nodes;\n\n if (x == null) x = 0;\n if (y == null) y = 0;\n\n function force() {\n var i,\n n = nodes.length,\n node,\n sx = 0,\n sy = 0;\n\n for (i = 0; i < n; ++i) {\n node = nodes[i], sx += node.x, sy += node.y;\n }\n\n for (sx = sx / n - x, sy = sy / n - y, i = 0; i < n; ++i) {\n node = nodes[i], node.x -= sx, node.y -= sy;\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n };\n\n force.x = function(_) {\n return arguments.length ? (x = +_, force) : x;\n };\n\n force.y = function(_) {\n return arguments.length ? (y = +_, force) : y;\n };\n\n return force;\n }\n\n function constant$6(x) {\n return function() {\n return x;\n };\n }\n\n function jiggle() {\n return (Math.random() - 0.5) * 1e-6;\n }\n\n function x$1(d) {\n return d.x + d.vx;\n }\n\n function y$1(d) {\n return d.y + d.vy;\n }\n\n function collide(radius) {\n var nodes,\n radii,\n strength = 1,\n iterations = 1;\n\n if (typeof radius !== \"function\") radius = constant$6(radius == null ? 1 : +radius);\n\n function force() {\n var i, n = nodes.length,\n tree,\n node,\n xi,\n yi,\n ri,\n ri2;\n\n for (var k = 0; k < iterations; ++k) {\n tree = quadtree(nodes, x$1, y$1).visitAfter(prepare);\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n ri = radii[i], ri2 = ri * ri;\n xi = node.x + node.vx;\n yi = node.y + node.vy;\n tree.visit(apply);\n }\n }\n\n function apply(quad, x0, y0, x1, y1) {\n var data = quad.data, rj = quad.r, r = ri + rj;\n if (data) {\n if (data.index > i) {\n var x = xi - data.x - data.vx,\n y = yi - data.y - data.vy,\n l = x * x + y * y;\n if (l < r * r) {\n if (x === 0) x = jiggle(), l += x * x;\n if (y === 0) y = jiggle(), l += y * y;\n l = (r - (l = Math.sqrt(l))) / l * strength;\n node.vx += (x *= l) * (r = (rj *= rj) / (ri2 + rj));\n node.vy += (y *= l) * r;\n data.vx -= x * (r = 1 - r);\n data.vy -= y * r;\n }\n }\n return;\n }\n return x0 > xi + r || x1 < xi - r || y0 > yi + r || y1 < yi - r;\n }\n }\n\n function prepare(quad) {\n if (quad.data) return quad.r = radii[quad.data.index];\n for (var i = quad.r = 0; i < 4; ++i) {\n if (quad[i] && quad[i].r > quad.r) {\n quad.r = quad[i].r;\n }\n }\n }\n\n force.initialize = function(_) {\n var i, n = (nodes = _).length; radii = new Array(n);\n for (i = 0; i < n; ++i) radii[i] = +radius(nodes[i], i, nodes);\n };\n\n force.iterations = function(_) {\n return arguments.length ? (iterations = +_, force) : iterations;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = +_, force) : strength;\n };\n\n force.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant$6(+_), force) : radius;\n };\n\n return force;\n }\n\n function index$2(d, i) {\n return i;\n }\n\n function link(links) {\n var id = index$2,\n strength = defaultStrength,\n strengths,\n distance = constant$6(30),\n distances,\n nodes,\n count,\n bias,\n iterations = 1;\n\n if (links == null) links = [];\n\n function defaultStrength(link) {\n return 1 / Math.min(count[link.source.index], count[link.target.index]);\n }\n\n function force(alpha) {\n for (var k = 0, n = links.length; k < iterations; ++k) {\n for (var i = 0, link, source, target, x, y, l, b; i < n; ++i) {\n link = links[i], source = link.source, target = link.target;\n x = target.x + target.vx - source.x - source.vx || jiggle();\n y = target.y + target.vy - source.y - source.vy || jiggle();\n l = Math.sqrt(x * x + y * y);\n l = (l - distances[i]) / l * alpha * strengths[i];\n x *= l, y *= l;\n target.vx -= x * (b = bias[i]);\n target.vy -= y * b;\n source.vx += x * (b = 1 - b);\n source.vy += y * b;\n }\n }\n }\n\n function initialize() {\n if (!nodes) return;\n\n var i,\n n = nodes.length,\n m = links.length,\n nodeById = map$1(nodes, id),\n link;\n\n for (i = 0, count = new Array(n); i < n; ++i) {\n count[i] = 0;\n }\n\n for (i = 0; i < m; ++i) {\n link = links[i], link.index = i;\n if (typeof link.source !== \"object\") link.source = nodeById.get(link.source);\n if (typeof link.target !== \"object\") link.target = nodeById.get(link.target);\n ++count[link.source.index], ++count[link.target.index];\n }\n\n for (i = 0, bias = new Array(m); i < m; ++i) {\n link = links[i], bias[i] = count[link.source.index] / (count[link.source.index] + count[link.target.index]);\n }\n\n strengths = new Array(m), initializeStrength();\n distances = new Array(m), initializeDistance();\n }\n\n function initializeStrength() {\n if (!nodes) return;\n\n for (var i = 0, n = links.length; i < n; ++i) {\n strengths[i] = +strength(links[i], i, links);\n }\n }\n\n function initializeDistance() {\n if (!nodes) return;\n\n for (var i = 0, n = links.length; i < n; ++i) {\n distances[i] = +distance(links[i], i, links);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.links = function(_) {\n return arguments.length ? (links = _, initialize(), force) : links;\n };\n\n force.id = function(_) {\n return arguments.length ? (id = _, force) : id;\n };\n\n force.iterations = function(_) {\n return arguments.length ? (iterations = +_, force) : iterations;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initializeStrength(), force) : strength;\n };\n\n force.distance = function(_) {\n return arguments.length ? (distance = typeof _ === \"function\" ? _ : constant$6(+_), initializeDistance(), force) : distance;\n };\n\n return force;\n }\n\n function x$2(d) {\n return d.x;\n }\n\n function y$2(d) {\n return d.y;\n }\n\n var initialRadius = 10;\n var initialAngle = Math.PI * (3 - Math.sqrt(5));\n function simulation(nodes) {\n var simulation,\n alpha = 1,\n alphaMin = 0.001,\n alphaDecay = 1 - Math.pow(alphaMin, 1 / 300),\n alphaTarget = 0,\n velocityDecay = 0.6,\n forces = map$1(),\n stepper = timer(step),\n event = dispatch(\"tick\", \"end\");\n\n if (nodes == null) nodes = [];\n\n function step() {\n tick();\n event.call(\"tick\", simulation);\n if (alpha < alphaMin) {\n stepper.stop();\n event.call(\"end\", simulation);\n }\n }\n\n function tick() {\n var i, n = nodes.length, node;\n\n alpha += (alphaTarget - alpha) * alphaDecay;\n\n forces.each(function(force) {\n force(alpha);\n });\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n if (node.fx == null) node.x += node.vx *= velocityDecay;\n else node.x = node.fx, node.vx = 0;\n if (node.fy == null) node.y += node.vy *= velocityDecay;\n else node.y = node.fy, node.vy = 0;\n }\n }\n\n function initializeNodes() {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.index = i;\n if (isNaN(node.x) || isNaN(node.y)) {\n var radius = initialRadius * Math.sqrt(i), angle = i * initialAngle;\n node.x = radius * Math.cos(angle);\n node.y = radius * Math.sin(angle);\n }\n if (isNaN(node.vx) || isNaN(node.vy)) {\n node.vx = node.vy = 0;\n }\n }\n }\n\n function initializeForce(force) {\n if (force.initialize) force.initialize(nodes);\n return force;\n }\n\n initializeNodes();\n\n return simulation = {\n tick: tick,\n\n restart: function() {\n return stepper.restart(step), simulation;\n },\n\n stop: function() {\n return stepper.stop(), simulation;\n },\n\n nodes: function(_) {\n return arguments.length ? (nodes = _, initializeNodes(), forces.each(initializeForce), simulation) : nodes;\n },\n\n alpha: function(_) {\n return arguments.length ? (alpha = +_, simulation) : alpha;\n },\n\n alphaMin: function(_) {\n return arguments.length ? (alphaMin = +_, simulation) : alphaMin;\n },\n\n alphaDecay: function(_) {\n return arguments.length ? (alphaDecay = +_, simulation) : +alphaDecay;\n },\n\n alphaTarget: function(_) {\n return arguments.length ? (alphaTarget = +_, simulation) : alphaTarget;\n },\n\n velocityDecay: function(_) {\n return arguments.length ? (velocityDecay = 1 - _, simulation) : 1 - velocityDecay;\n },\n\n force: function(name, _) {\n return arguments.length > 1 ? ((_ == null ? forces.remove(name) : forces.set(name, initializeForce(_))), simulation) : forces.get(name);\n },\n\n find: function(x, y, radius) {\n var i = 0,\n n = nodes.length,\n dx,\n dy,\n d2,\n node,\n closest;\n\n if (radius == null) radius = Infinity;\n else radius *= radius;\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n dx = x - node.x;\n dy = y - node.y;\n d2 = dx * dx + dy * dy;\n if (d2 < radius) closest = node, radius = d2;\n }\n\n return closest;\n },\n\n on: function(name, _) {\n return arguments.length > 1 ? (event.on(name, _), simulation) : event.on(name);\n }\n };\n }\n\n function manyBody() {\n var nodes,\n node,\n alpha,\n strength = constant$6(-30),\n strengths,\n distanceMin2 = 1,\n distanceMax2 = Infinity,\n theta2 = 0.81;\n\n function force(_) {\n var i, n = nodes.length, tree = quadtree(nodes, x$2, y$2).visitAfter(accumulate);\n for (alpha = _, i = 0; i < n; ++i) node = nodes[i], tree.visit(apply);\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n for (i = 0; i < n; ++i) strengths[i] = +strength(nodes[i], i, nodes);\n }\n\n function accumulate(quad) {\n var strength = 0, q, c, x, y, i;\n\n // For internal nodes, accumulate forces from child quadrants.\n if (quad.length) {\n for (x = y = i = 0; i < 4; ++i) {\n if ((q = quad[i]) && (c = q.value)) {\n strength += c, x += c * q.x, y += c * q.y;\n }\n }\n quad.x = x / strength;\n quad.y = y / strength;\n }\n\n // For leaf nodes, accumulate forces from coincident quadrants.\n else {\n q = quad;\n q.x = q.data.x;\n q.y = q.data.y;\n do strength += strengths[q.data.index];\n while (q = q.next);\n }\n\n quad.value = strength;\n }\n\n function apply(quad, x1, _, x2) {\n if (!quad.value) return true;\n\n var x = quad.x - node.x,\n y = quad.y - node.y,\n w = x2 - x1,\n l = x * x + y * y;\n\n // Apply the Barnes-Hut approximation if possible.\n // Limit forces for very close nodes; randomize direction if coincident.\n if (w * w / theta2 < l) {\n if (l < distanceMax2) {\n if (x === 0) x = jiggle(), l += x * x;\n if (y === 0) y = jiggle(), l += y * y;\n if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n node.vx += x * quad.value * alpha / l;\n node.vy += y * quad.value * alpha / l;\n }\n return true;\n }\n\n // Otherwise, process points directly.\n else if (quad.length || l >= distanceMax2) return;\n\n // Limit forces for very close nodes; randomize direction if coincident.\n if (quad.data !== node || quad.next) {\n if (x === 0) x = jiggle(), l += x * x;\n if (y === 0) y = jiggle(), l += y * y;\n if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n }\n\n do if (quad.data !== node) {\n w = strengths[quad.data.index] * alpha / l;\n node.vx += x * w;\n node.vy += y * w;\n } while (quad = quad.next);\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : strength;\n };\n\n force.distanceMin = function(_) {\n return arguments.length ? (distanceMin2 = _ * _, force) : Math.sqrt(distanceMin2);\n };\n\n force.distanceMax = function(_) {\n return arguments.length ? (distanceMax2 = _ * _, force) : Math.sqrt(distanceMax2);\n };\n\n force.theta = function(_) {\n return arguments.length ? (theta2 = _ * _, force) : Math.sqrt(theta2);\n };\n\n return force;\n }\n\n function x$3(x) {\n var strength = constant$6(0.1),\n nodes,\n strengths,\n xz;\n\n if (typeof x !== \"function\") x = constant$6(x == null ? 0 : +x);\n\n function force(alpha) {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.vx += (xz[i] - node.x) * strengths[i] * alpha;\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n xz = new Array(n);\n for (i = 0; i < n; ++i) {\n strengths[i] = isNaN(xz[i] = +x(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : strength;\n };\n\n force.x = function(_) {\n return arguments.length ? (x = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : x;\n };\n\n return force;\n }\n\n function y$3(y) {\n var strength = constant$6(0.1),\n nodes,\n strengths,\n yz;\n\n if (typeof y !== \"function\") y = constant$6(y == null ? 0 : +y);\n\n function force(alpha) {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.vy += (yz[i] - node.y) * strengths[i] * alpha;\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n yz = new Array(n);\n for (i = 0; i < n; ++i) {\n strengths[i] = isNaN(yz[i] = +y(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : strength;\n };\n\n force.y = function(_) {\n return arguments.length ? (y = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : y;\n };\n\n return force;\n }\n\n function nopropagation() {\n exports.event.stopImmediatePropagation();\n }\n\n function noevent() {\n exports.event.preventDefault();\n exports.event.stopImmediatePropagation();\n }\n\n function dragDisable(view) {\n var root = view.document.documentElement,\n selection = select(view).on(\"dragstart.drag\", noevent, true);\n if (\"onselectstart\" in root) {\n selection.on(\"selectstart.drag\", noevent, true);\n } else {\n root.__noselect = root.style.MozUserSelect;\n root.style.MozUserSelect = \"none\";\n }\n }\n\n function dragEnable(view, noclick) {\n var root = view.document.documentElement,\n selection = select(view).on(\"dragstart.drag\", null);\n if (noclick) {\n selection.on(\"click.drag\", noevent, true);\n setTimeout(function() { selection.on(\"click.drag\", null); }, 0);\n }\n if (\"onselectstart\" in root) {\n selection.on(\"selectstart.drag\", null);\n } else {\n root.style.MozUserSelect = root.__noselect;\n delete root.__noselect;\n }\n }\n\n function constant$7(x) {\n return function() {\n return x;\n };\n }\n\n function DragEvent(target, type, subject, id, active, x, y, dx, dy, dispatch) {\n this.target = target;\n this.type = type;\n this.subject = subject;\n this.identifier = id;\n this.active = active;\n this.x = x;\n this.y = y;\n this.dx = dx;\n this.dy = dy;\n this._ = dispatch;\n }\n\n DragEvent.prototype.on = function() {\n var value = this._.on.apply(this._, arguments);\n return value === this._ ? this : value;\n };\n\n // Ignore right-click, since that should open the context menu.\n function defaultFilter() {\n return !exports.event.button;\n }\n\n function defaultContainer() {\n return this.parentNode;\n }\n\n function defaultSubject(d) {\n return d == null ? {x: exports.event.x, y: exports.event.y} : d;\n }\n\n function drag() {\n var filter = defaultFilter,\n container = defaultContainer,\n subject = defaultSubject,\n gestures = {},\n listeners = dispatch(\"start\", \"drag\", \"end\"),\n active = 0,\n mousemoving,\n touchending;\n\n function drag(selection) {\n selection\n .on(\"mousedown.drag\", mousedowned)\n .on(\"touchstart.drag\", touchstarted)\n .on(\"touchmove.drag\", touchmoved)\n .on(\"touchend.drag touchcancel.drag\", touchended)\n .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\");\n }\n\n function mousedowned() {\n if (touchending || !filter.apply(this, arguments)) return;\n var gesture = beforestart(\"mouse\", container.apply(this, arguments), mouse, this, arguments);\n if (!gesture) return;\n select(exports.event.view).on(\"mousemove.drag\", mousemoved, true).on(\"mouseup.drag\", mouseupped, true);\n dragDisable(exports.event.view);\n nopropagation();\n mousemoving = false;\n gesture(\"start\");\n }\n\n function mousemoved() {\n noevent();\n mousemoving = true;\n gestures.mouse(\"drag\");\n }\n\n function mouseupped() {\n select(exports.event.view).on(\"mousemove.drag mouseup.drag\", null);\n dragEnable(exports.event.view, mousemoving);\n noevent();\n gestures.mouse(\"end\");\n }\n\n function touchstarted() {\n if (!filter.apply(this, arguments)) return;\n var touches = exports.event.changedTouches,\n c = container.apply(this, arguments),\n n = touches.length, i, gesture;\n\n for (i = 0; i < n; ++i) {\n if (gesture = beforestart(touches[i].identifier, c, touch, this, arguments)) {\n nopropagation();\n gesture(\"start\");\n }\n }\n }\n\n function touchmoved() {\n var touches = exports.event.changedTouches,\n n = touches.length, i, gesture;\n\n for (i = 0; i < n; ++i) {\n if (gesture = gestures[touches[i].identifier]) {\n noevent();\n gesture(\"drag\");\n }\n }\n }\n\n function touchended() {\n var touches = exports.event.changedTouches,\n n = touches.length, i, gesture;\n\n if (touchending) clearTimeout(touchending);\n touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!\n for (i = 0; i < n; ++i) {\n if (gesture = gestures[touches[i].identifier]) {\n nopropagation();\n gesture(\"end\");\n }\n }\n }\n\n function beforestart(id, container, point, that, args) {\n var p = point(container, id), s, dx, dy,\n sublisteners = listeners.copy();\n\n if (!customEvent(new DragEvent(drag, \"beforestart\", s, id, active, p[0], p[1], 0, 0, sublisteners), function() {\n if ((exports.event.subject = s = subject.apply(that, args)) == null) return false;\n dx = s.x - p[0] || 0;\n dy = s.y - p[1] || 0;\n return true;\n })) return;\n\n return function gesture(type) {\n var p0 = p, n;\n switch (type) {\n case \"start\": gestures[id] = gesture, n = active++; break;\n case \"end\": delete gestures[id], --active; // nobreak\n case \"drag\": p = point(container, id), n = active; break;\n }\n customEvent(new DragEvent(drag, type, s, id, n, p[0] + dx, p[1] + dy, p[0] - p0[0], p[1] - p0[1], sublisteners), sublisteners.apply, sublisteners, [type, that, args]);\n };\n }\n\n drag.filter = function(_) {\n return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant$7(!!_), drag) : filter;\n };\n\n drag.container = function(_) {\n return arguments.length ? (container = typeof _ === \"function\" ? _ : constant$7(_), drag) : container;\n };\n\n drag.subject = function(_) {\n return arguments.length ? (subject = typeof _ === \"function\" ? _ : constant$7(_), drag) : subject;\n };\n\n drag.on = function() {\n var value = listeners.on.apply(listeners, arguments);\n return value === listeners ? drag : value;\n };\n\n return drag;\n }\n\n function constant$8(x) {\n return function() {\n return x;\n };\n }\n\n function x$4(d) {\n return d[0];\n }\n\n function y$4(d) {\n return d[1];\n }\n\n function RedBlackTree() {\n this._ = null; // root node\n }\n\n function RedBlackNode(node) {\n node.U = // parent node\n node.C = // color - true for red, false for black\n node.L = // left node\n node.R = // right node\n node.P = // previous node\n node.N = null; // next node\n }\n\n RedBlackTree.prototype = {\n constructor: RedBlackTree,\n\n insert: function(after, node) {\n var parent, grandpa, uncle;\n\n if (after) {\n node.P = after;\n node.N = after.N;\n if (after.N) after.N.P = node;\n after.N = node;\n if (after.R) {\n after = after.R;\n while (after.L) after = after.L;\n after.L = node;\n } else {\n after.R = node;\n }\n parent = after;\n } else if (this._) {\n after = RedBlackFirst(this._);\n node.P = null;\n node.N = after;\n after.P = after.L = node;\n parent = after;\n } else {\n node.P = node.N = null;\n this._ = node;\n parent = null;\n }\n node.L = node.R = null;\n node.U = parent;\n node.C = true;\n\n after = node;\n while (parent && parent.C) {\n grandpa = parent.U;\n if (parent === grandpa.L) {\n uncle = grandpa.R;\n if (uncle && uncle.C) {\n parent.C = uncle.C = false;\n grandpa.C = true;\n after = grandpa;\n } else {\n if (after === parent.R) {\n RedBlackRotateLeft(this, parent);\n after = parent;\n parent = after.U;\n }\n parent.C = false;\n grandpa.C = true;\n RedBlackRotateRight(this, grandpa);\n }\n } else {\n uncle = grandpa.L;\n if (uncle && uncle.C) {\n parent.C = uncle.C = false;\n grandpa.C = true;\n after = grandpa;\n } else {\n if (after === parent.L) {\n RedBlackRotateRight(this, parent);\n after = parent;\n parent = after.U;\n }\n parent.C = false;\n grandpa.C = true;\n RedBlackRotateLeft(this, grandpa);\n }\n }\n parent = after.U;\n }\n this._.C = false;\n },\n\n remove: function(node) {\n if (node.N) node.N.P = node.P;\n if (node.P) node.P.N = node.N;\n node.N = node.P = null;\n\n var parent = node.U,\n sibling,\n left = node.L,\n right = node.R,\n next,\n red;\n\n if (!left) next = right;\n else if (!right) next = left;\n else next = RedBlackFirst(right);\n\n if (parent) {\n if (parent.L === node) parent.L = next;\n else parent.R = next;\n } else {\n this._ = next;\n }\n\n if (left && right) {\n red = next.C;\n next.C = node.C;\n next.L = left;\n left.U = next;\n if (next !== right) {\n parent = next.U;\n next.U = node.U;\n node = next.R;\n parent.L = node;\n next.R = right;\n right.U = next;\n } else {\n next.U = parent;\n parent = next;\n node = next.R;\n }\n } else {\n red = node.C;\n node = next;\n }\n\n if (node) node.U = parent;\n if (red) return;\n if (node && node.C) { node.C = false; return; }\n\n do {\n if (node === this._) break;\n if (node === parent.L) {\n sibling = parent.R;\n if (sibling.C) {\n sibling.C = false;\n parent.C = true;\n RedBlackRotateLeft(this, parent);\n sibling = parent.R;\n }\n if ((sibling.L && sibling.L.C)\n || (sibling.R && sibling.R.C)) {\n if (!sibling.R || !sibling.R.C) {\n sibling.L.C = false;\n sibling.C = true;\n RedBlackRotateRight(this, sibling);\n sibling = parent.R;\n }\n sibling.C = parent.C;\n parent.C = sibling.R.C = false;\n RedBlackRotateLeft(this, parent);\n node = this._;\n break;\n }\n } else {\n sibling = parent.L;\n if (sibling.C) {\n sibling.C = false;\n parent.C = true;\n RedBlackRotateRight(this, parent);\n sibling = parent.L;\n }\n if ((sibling.L && sibling.L.C)\n || (sibling.R && sibling.R.C)) {\n if (!sibling.L || !sibling.L.C) {\n sibling.R.C = false;\n sibling.C = true;\n RedBlackRotateLeft(this, sibling);\n sibling = parent.L;\n }\n sibling.C = parent.C;\n parent.C = sibling.L.C = false;\n RedBlackRotateRight(this, parent);\n node = this._;\n break;\n }\n }\n sibling.C = true;\n node = parent;\n parent = parent.U;\n } while (!node.C);\n\n if (node) node.C = false;\n }\n };\n\n function RedBlackRotateLeft(tree, node) {\n var p = node,\n q = node.R,\n parent = p.U;\n\n if (parent) {\n if (parent.L === p) parent.L = q;\n else parent.R = q;\n } else {\n tree._ = q;\n }\n\n q.U = parent;\n p.U = q;\n p.R = q.L;\n if (p.R) p.R.U = p;\n q.L = p;\n }\n\n function RedBlackRotateRight(tree, node) {\n var p = node,\n q = node.L,\n parent = p.U;\n\n if (parent) {\n if (parent.L === p) parent.L = q;\n else parent.R = q;\n } else {\n tree._ = q;\n }\n\n q.U = parent;\n p.U = q;\n p.L = q.R;\n if (p.L) p.L.U = p;\n q.R = p;\n }\n\n function RedBlackFirst(node) {\n while (node.L) node = node.L;\n return node;\n }\n\n function createEdge(left, right, v0, v1) {\n var edge = [null, null],\n index = edges.push(edge) - 1;\n edge.left = left;\n edge.right = right;\n if (v0) setEdgeEnd(edge, left, right, v0);\n if (v1) setEdgeEnd(edge, right, left, v1);\n cells[left.index].halfedges.push(index);\n cells[right.index].halfedges.push(index);\n return edge;\n }\n\n function createBorderEdge(left, v0, v1) {\n var edge = [v0, v1];\n edge.left = left;\n return edge;\n }\n\n function setEdgeEnd(edge, left, right, vertex) {\n if (!edge[0] && !edge[1]) {\n edge[0] = vertex;\n edge.left = left;\n edge.right = right;\n } else if (edge.left === right) {\n edge[1] = vertex;\n } else {\n edge[0] = vertex;\n }\n }\n\n // Liang–Barsky line clipping.\n function clipEdge(edge, x0, y0, x1, y1) {\n var a = edge[0],\n b = edge[1],\n ax = a[0],\n ay = a[1],\n bx = b[0],\n by = b[1],\n t0 = 0,\n t1 = 1,\n dx = bx - ax,\n dy = by - ay,\n r;\n\n r = x0 - ax;\n if (!dx && r > 0) return;\n r /= dx;\n if (dx < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dx > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = x1 - ax;\n if (!dx && r < 0) return;\n r /= dx;\n if (dx < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dx > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n r = y0 - ay;\n if (!dy && r > 0) return;\n r /= dy;\n if (dy < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dy > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = y1 - ay;\n if (!dy && r < 0) return;\n r /= dy;\n if (dy < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dy > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n if (!(t0 > 0) && !(t1 < 1)) return true; // TODO Better check?\n\n if (t0 > 0) edge[0] = [ax + t0 * dx, ay + t0 * dy];\n if (t1 < 1) edge[1] = [ax + t1 * dx, ay + t1 * dy];\n return true;\n }\n\n function connectEdge(edge, x0, y0, x1, y1) {\n var v1 = edge[1];\n if (v1) return true;\n\n var v0 = edge[0],\n left = edge.left,\n right = edge.right,\n lx = left[0],\n ly = left[1],\n rx = right[0],\n ry = right[1],\n fx = (lx + rx) / 2,\n fy = (ly + ry) / 2,\n fm,\n fb;\n\n if (ry === ly) {\n if (fx < x0 || fx >= x1) return;\n if (lx > rx) {\n if (!v0) v0 = [fx, y0];\n else if (v0[1] >= y1) return;\n v1 = [fx, y1];\n } else {\n if (!v0) v0 = [fx, y1];\n else if (v0[1] < y0) return;\n v1 = [fx, y0];\n }\n } else {\n fm = (lx - rx) / (ry - ly);\n fb = fy - fm * fx;\n if (fm < -1 || fm > 1) {\n if (lx > rx) {\n if (!v0) v0 = [(y0 - fb) / fm, y0];\n else if (v0[1] >= y1) return;\n v1 = [(y1 - fb) / fm, y1];\n } else {\n if (!v0) v0 = [(y1 - fb) / fm, y1];\n else if (v0[1] < y0) return;\n v1 = [(y0 - fb) / fm, y0];\n }\n } else {\n if (ly < ry) {\n if (!v0) v0 = [x0, fm * x0 + fb];\n else if (v0[0] >= x1) return;\n v1 = [x1, fm * x1 + fb];\n } else {\n if (!v0) v0 = [x1, fm * x1 + fb];\n else if (v0[0] < x0) return;\n v1 = [x0, fm * x0 + fb];\n }\n }\n }\n\n edge[0] = v0;\n edge[1] = v1;\n return true;\n }\n\n function clipEdges(x0, y0, x1, y1) {\n var i = edges.length,\n edge;\n\n while (i--) {\n if (!connectEdge(edge = edges[i], x0, y0, x1, y1)\n || !clipEdge(edge, x0, y0, x1, y1)\n || !(Math.abs(edge[0][0] - edge[1][0]) > epsilon$3\n || Math.abs(edge[0][1] - edge[1][1]) > epsilon$3)) {\n delete edges[i];\n }\n }\n }\n\n function createCell(site) {\n return cells[site.index] = {\n site: site,\n halfedges: []\n };\n }\n\n function cellHalfedgeAngle(cell, edge) {\n var site = cell.site,\n va = edge.left,\n vb = edge.right;\n if (site === vb) vb = va, va = site;\n if (vb) return Math.atan2(vb[1] - va[1], vb[0] - va[0]);\n if (site === va) va = edge[1], vb = edge[0];\n else va = edge[0], vb = edge[1];\n return Math.atan2(va[0] - vb[0], vb[1] - va[1]);\n }\n\n function cellHalfedgeStart(cell, edge) {\n return edge[+(edge.left !== cell.site)];\n }\n\n function cellHalfedgeEnd(cell, edge) {\n return edge[+(edge.left === cell.site)];\n }\n\n function sortCellHalfedges() {\n for (var i = 0, n = cells.length, cell, halfedges, j, m; i < n; ++i) {\n if ((cell = cells[i]) && (m = (halfedges = cell.halfedges).length)) {\n var index = new Array(m),\n array = new Array(m);\n for (j = 0; j < m; ++j) index[j] = j, array[j] = cellHalfedgeAngle(cell, edges[halfedges[j]]);\n index.sort(function(i, j) { return array[j] - array[i]; });\n for (j = 0; j < m; ++j) array[j] = halfedges[index[j]];\n for (j = 0; j < m; ++j) halfedges[j] = array[j];\n }\n }\n }\n\n function clipCells(x0, y0, x1, y1) {\n var nCells = cells.length,\n iCell,\n cell,\n site,\n iHalfedge,\n halfedges,\n nHalfedges,\n start,\n startX,\n startY,\n end,\n endX,\n endY,\n cover = true;\n\n for (iCell = 0; iCell < nCells; ++iCell) {\n if (cell = cells[iCell]) {\n site = cell.site;\n halfedges = cell.halfedges;\n iHalfedge = halfedges.length;\n\n // Remove any dangling clipped edges.\n while (iHalfedge--) {\n if (!edges[halfedges[iHalfedge]]) {\n halfedges.splice(iHalfedge, 1);\n }\n }\n\n // Insert any border edges as necessary.\n iHalfedge = 0, nHalfedges = halfedges.length;\n while (iHalfedge < nHalfedges) {\n end = cellHalfedgeEnd(cell, edges[halfedges[iHalfedge]]), endX = end[0], endY = end[1];\n start = cellHalfedgeStart(cell, edges[halfedges[++iHalfedge % nHalfedges]]), startX = start[0], startY = start[1];\n if (Math.abs(endX - startX) > epsilon$3 || Math.abs(endY - startY) > epsilon$3) {\n halfedges.splice(iHalfedge, 0, edges.push(createBorderEdge(site, end,\n Math.abs(endX - x0) < epsilon$3 && y1 - endY > epsilon$3 ? [x0, Math.abs(startX - x0) < epsilon$3 ? startY : y1]\n : Math.abs(endY - y1) < epsilon$3 && x1 - endX > epsilon$3 ? [Math.abs(startY - y1) < epsilon$3 ? startX : x1, y1]\n : Math.abs(endX - x1) < epsilon$3 && endY - y0 > epsilon$3 ? [x1, Math.abs(startX - x1) < epsilon$3 ? startY : y0]\n : Math.abs(endY - y0) < epsilon$3 && endX - x0 > epsilon$3 ? [Math.abs(startY - y0) < epsilon$3 ? startX : x0, y0]\n : null)) - 1);\n ++nHalfedges;\n }\n }\n\n if (nHalfedges) cover = false;\n }\n }\n\n // If there weren’t any edges, have the closest site cover the extent.\n // It doesn’t matter which corner of the extent we measure!\n if (cover) {\n var dx, dy, d2, dc = Infinity;\n\n for (iCell = 0, cover = null; iCell < nCells; ++iCell) {\n if (cell = cells[iCell]) {\n site = cell.site;\n dx = site[0] - x0;\n dy = site[1] - y0;\n d2 = dx * dx + dy * dy;\n if (d2 < dc) dc = d2, cover = cell;\n }\n }\n\n if (cover) {\n var v00 = [x0, y0], v01 = [x0, y1], v11 = [x1, y1], v10 = [x1, y0];\n cover.halfedges.push(\n edges.push(createBorderEdge(site = cover.site, v00, v01)) - 1,\n edges.push(createBorderEdge(site, v01, v11)) - 1,\n edges.push(createBorderEdge(site, v11, v10)) - 1,\n edges.push(createBorderEdge(site, v10, v00)) - 1\n );\n }\n }\n\n // Lastly delete any cells with no edges; these were entirely clipped.\n for (iCell = 0; iCell < nCells; ++iCell) {\n if (cell = cells[iCell]) {\n if (!cell.halfedges.length) {\n delete cells[iCell];\n }\n }\n }\n }\n\n var circlePool = [];\n\n var firstCircle;\n\n function Circle() {\n RedBlackNode(this);\n this.x =\n this.y =\n this.arc =\n this.site =\n this.cy = null;\n }\n\n function attachCircle(arc) {\n var lArc = arc.P,\n rArc = arc.N;\n\n if (!lArc || !rArc) return;\n\n var lSite = lArc.site,\n cSite = arc.site,\n rSite = rArc.site;\n\n if (lSite === rSite) return;\n\n var bx = cSite[0],\n by = cSite[1],\n ax = lSite[0] - bx,\n ay = lSite[1] - by,\n cx = rSite[0] - bx,\n cy = rSite[1] - by;\n\n var d = 2 * (ax * cy - ay * cx);\n if (d >= -epsilon2$1) return;\n\n var ha = ax * ax + ay * ay,\n hc = cx * cx + cy * cy,\n x = (cy * ha - ay * hc) / d,\n y = (ax * hc - cx * ha) / d;\n\n var circle = circlePool.pop() || new Circle;\n circle.arc = arc;\n circle.site = cSite;\n circle.x = x + bx;\n circle.y = (circle.cy = y + by) + Math.sqrt(x * x + y * y); // y bottom\n\n arc.circle = circle;\n\n var before = null,\n node = circles._;\n\n while (node) {\n if (circle.y < node.y || (circle.y === node.y && circle.x <= node.x)) {\n if (node.L) node = node.L;\n else { before = node.P; break; }\n } else {\n if (node.R) node = node.R;\n else { before = node; break; }\n }\n }\n\n circles.insert(before, circle);\n if (!before) firstCircle = circle;\n }\n\n function detachCircle(arc) {\n var circle = arc.circle;\n if (circle) {\n if (!circle.P) firstCircle = circle.N;\n circles.remove(circle);\n circlePool.push(circle);\n RedBlackNode(circle);\n arc.circle = null;\n }\n }\n\n var beachPool = [];\n\n function Beach() {\n RedBlackNode(this);\n this.edge =\n this.site =\n this.circle = null;\n }\n\n function createBeach(site) {\n var beach = beachPool.pop() || new Beach;\n beach.site = site;\n return beach;\n }\n\n function detachBeach(beach) {\n detachCircle(beach);\n beaches.remove(beach);\n beachPool.push(beach);\n RedBlackNode(beach);\n }\n\n function removeBeach(beach) {\n var circle = beach.circle,\n x = circle.x,\n y = circle.cy,\n vertex = [x, y],\n previous = beach.P,\n next = beach.N,\n disappearing = [beach];\n\n detachBeach(beach);\n\n var lArc = previous;\n while (lArc.circle\n && Math.abs(x - lArc.circle.x) < epsilon$3\n && Math.abs(y - lArc.circle.cy) < epsilon$3) {\n previous = lArc.P;\n disappearing.unshift(lArc);\n detachBeach(lArc);\n lArc = previous;\n }\n\n disappearing.unshift(lArc);\n detachCircle(lArc);\n\n var rArc = next;\n while (rArc.circle\n && Math.abs(x - rArc.circle.x) < epsilon$3\n && Math.abs(y - rArc.circle.cy) < epsilon$3) {\n next = rArc.N;\n disappearing.push(rArc);\n detachBeach(rArc);\n rArc = next;\n }\n\n disappearing.push(rArc);\n detachCircle(rArc);\n\n var nArcs = disappearing.length,\n iArc;\n for (iArc = 1; iArc < nArcs; ++iArc) {\n rArc = disappearing[iArc];\n lArc = disappearing[iArc - 1];\n setEdgeEnd(rArc.edge, lArc.site, rArc.site, vertex);\n }\n\n lArc = disappearing[0];\n rArc = disappearing[nArcs - 1];\n rArc.edge = createEdge(lArc.site, rArc.site, null, vertex);\n\n attachCircle(lArc);\n attachCircle(rArc);\n }\n\n function addBeach(site) {\n var x = site[0],\n directrix = site[1],\n lArc,\n rArc,\n dxl,\n dxr,\n node = beaches._;\n\n while (node) {\n dxl = leftBreakPoint(node, directrix) - x;\n if (dxl > epsilon$3) node = node.L; else {\n dxr = x - rightBreakPoint(node, directrix);\n if (dxr > epsilon$3) {\n if (!node.R) {\n lArc = node;\n break;\n }\n node = node.R;\n } else {\n if (dxl > -epsilon$3) {\n lArc = node.P;\n rArc = node;\n } else if (dxr > -epsilon$3) {\n lArc = node;\n rArc = node.N;\n } else {\n lArc = rArc = node;\n }\n break;\n }\n }\n }\n\n createCell(site);\n var newArc = createBeach(site);\n beaches.insert(lArc, newArc);\n\n if (!lArc && !rArc) return;\n\n if (lArc === rArc) {\n detachCircle(lArc);\n rArc = createBeach(lArc.site);\n beaches.insert(newArc, rArc);\n newArc.edge = rArc.edge = createEdge(lArc.site, newArc.site);\n attachCircle(lArc);\n attachCircle(rArc);\n return;\n }\n\n if (!rArc) { // && lArc\n newArc.edge = createEdge(lArc.site, newArc.site);\n return;\n }\n\n // else lArc !== rArc\n detachCircle(lArc);\n detachCircle(rArc);\n\n var lSite = lArc.site,\n ax = lSite[0],\n ay = lSite[1],\n bx = site[0] - ax,\n by = site[1] - ay,\n rSite = rArc.site,\n cx = rSite[0] - ax,\n cy = rSite[1] - ay,\n d = 2 * (bx * cy - by * cx),\n hb = bx * bx + by * by,\n hc = cx * cx + cy * cy,\n vertex = [(cy * hb - by * hc) / d + ax, (bx * hc - cx * hb) / d + ay];\n\n setEdgeEnd(rArc.edge, lSite, rSite, vertex);\n newArc.edge = createEdge(lSite, site, null, vertex);\n rArc.edge = createEdge(site, rSite, null, vertex);\n attachCircle(lArc);\n attachCircle(rArc);\n }\n\n function leftBreakPoint(arc, directrix) {\n var site = arc.site,\n rfocx = site[0],\n rfocy = site[1],\n pby2 = rfocy - directrix;\n\n if (!pby2) return rfocx;\n\n var lArc = arc.P;\n if (!lArc) return -Infinity;\n\n site = lArc.site;\n var lfocx = site[0],\n lfocy = site[1],\n plby2 = lfocy - directrix;\n\n if (!plby2) return lfocx;\n\n var hl = lfocx - rfocx,\n aby2 = 1 / pby2 - 1 / plby2,\n b = hl / plby2;\n\n if (aby2) return (-b + Math.sqrt(b * b - 2 * aby2 * (hl * hl / (-2 * plby2) - lfocy + plby2 / 2 + rfocy - pby2 / 2))) / aby2 + rfocx;\n\n return (rfocx + lfocx) / 2;\n }\n\n function rightBreakPoint(arc, directrix) {\n var rArc = arc.N;\n if (rArc) return leftBreakPoint(rArc, directrix);\n var site = arc.site;\n return site[1] === directrix ? site[0] : Infinity;\n }\n\n var epsilon$3 = 1e-6;\n var epsilon2$1 = 1e-12;\n var beaches;\n var cells;\n var circles;\n var edges;\n\n function triangleArea(a, b, c) {\n return (a[0] - c[0]) * (b[1] - a[1]) - (a[0] - b[0]) * (c[1] - a[1]);\n }\n\n function lexicographic(a, b) {\n return b[1] - a[1]\n || b[0] - a[0];\n }\n\n function Diagram(sites, extent) {\n var site = sites.sort(lexicographic).pop(),\n x,\n y,\n circle;\n\n edges = [];\n cells = new Array(sites.length);\n beaches = new RedBlackTree;\n circles = new RedBlackTree;\n\n while (true) {\n circle = firstCircle;\n if (site && (!circle || site[1] < circle.y || (site[1] === circle.y && site[0] < circle.x))) {\n if (site[0] !== x || site[1] !== y) {\n addBeach(site);\n x = site[0], y = site[1];\n }\n site = sites.pop();\n } else if (circle) {\n removeBeach(circle.arc);\n } else {\n break;\n }\n }\n\n sortCellHalfedges();\n\n if (extent) {\n var x0 = +extent[0][0],\n y0 = +extent[0][1],\n x1 = +extent[1][0],\n y1 = +extent[1][1];\n clipEdges(x0, y0, x1, y1);\n clipCells(x0, y0, x1, y1);\n }\n\n this.edges = edges;\n this.cells = cells;\n\n beaches =\n circles =\n edges =\n cells = null;\n }\n\n Diagram.prototype = {\n constructor: Diagram,\n\n polygons: function() {\n var edges = this.edges;\n\n return this.cells.map(function(cell) {\n var polygon = cell.halfedges.map(function(i) { return cellHalfedgeStart(cell, edges[i]); });\n polygon.data = cell.site.data;\n return polygon;\n });\n },\n\n triangles: function() {\n var triangles = [],\n edges = this.edges;\n\n this.cells.forEach(function(cell, i) {\n var site = cell.site,\n halfedges = cell.halfedges,\n j = -1,\n m = halfedges.length,\n s0,\n e1 = edges[halfedges[m - 1]],\n s1 = e1.left === site ? e1.right : e1.left;\n\n while (++j < m) {\n s0 = s1;\n e1 = edges[halfedges[j]];\n s1 = e1.left === site ? e1.right : e1.left;\n if (i < s0.index && i < s1.index && triangleArea(site, s0, s1) < 0) {\n triangles.push([site.data, s0.data, s1.data]);\n }\n }\n });\n\n return triangles;\n },\n\n links: function() {\n return this.edges.filter(function(edge) {\n return edge.right;\n }).map(function(edge) {\n return {\n source: edge.left.data,\n target: edge.right.data\n };\n });\n }\n }\n\n function voronoi() {\n var x = x$4,\n y = y$4,\n extent = null;\n\n function voronoi(data) {\n return new Diagram(data.map(function(d, i) {\n var s = [Math.round(x(d, i, data) / epsilon$3) * epsilon$3, Math.round(y(d, i, data) / epsilon$3) * epsilon$3];\n s.index = i;\n s.data = d;\n return s;\n }), extent);\n }\n\n voronoi.polygons = function(data) {\n return voronoi(data).polygons();\n };\n\n voronoi.links = function(data) {\n return voronoi(data).links();\n };\n\n voronoi.triangles = function(data) {\n return voronoi(data).triangles();\n };\n\n voronoi.x = function(_) {\n return arguments.length ? (x = typeof _ === \"function\" ? _ : constant$8(+_), voronoi) : x;\n };\n\n voronoi.y = function(_) {\n return arguments.length ? (y = typeof _ === \"function\" ? _ : constant$8(+_), voronoi) : y;\n };\n\n voronoi.extent = function(_) {\n return arguments.length ? (extent = _ == null ? null : [[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]], voronoi) : extent && [[extent[0][0], extent[0][1]], [extent[1][0], extent[1][1]]];\n };\n\n voronoi.size = function(_) {\n return arguments.length ? (extent = _ == null ? null : [[0, 0], [+_[0], +_[1]]], voronoi) : extent && [extent[1][0] - extent[0][0], extent[1][1] - extent[0][1]];\n };\n\n return voronoi;\n }\n\n function constant$9(x) {\n return function() {\n return x;\n };\n }\n\n function ZoomEvent(target, type, transform) {\n this.target = target;\n this.type = type;\n this.transform = transform;\n }\n\n function Transform(k, x, y) {\n this.k = k;\n this.x = x;\n this.y = y;\n }\n\n Transform.prototype = {\n constructor: Transform,\n scale: function(k) {\n return k === 1 ? this : new Transform(this.k * k, this.x, this.y);\n },\n translate: function(x, y) {\n return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y);\n },\n apply: function(point) {\n return [point[0] * this.k + this.x, point[1] * this.k + this.y];\n },\n applyX: function(x) {\n return x * this.k + this.x;\n },\n applyY: function(y) {\n return y * this.k + this.y;\n },\n invert: function(location) {\n return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k];\n },\n invertX: function(x) {\n return (x - this.x) / this.k;\n },\n invertY: function(y) {\n return (y - this.y) / this.k;\n },\n rescaleX: function(x) {\n return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x));\n },\n rescaleY: function(y) {\n return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y));\n },\n toString: function() {\n return \"translate(\" + this.x + \",\" + this.y + \") scale(\" + this.k + \")\";\n }\n };\n\n var identity$6 = new Transform(1, 0, 0);\n\n transform.prototype = Transform.prototype;\n\n function transform(node) {\n return node.__zoom || identity$6;\n }\n\n function nopropagation$1() {\n exports.event.stopImmediatePropagation();\n }\n\n function noevent$1() {\n exports.event.preventDefault();\n exports.event.stopImmediatePropagation();\n }\n\n // Ignore right-click, since that should open the context menu.\n function defaultFilter$1() {\n return !exports.event.button;\n }\n\n function defaultExtent() {\n var e = this, w, h;\n if (e instanceof SVGElement) {\n e = e.ownerSVGElement || e;\n w = e.width.baseVal.value;\n h = e.height.baseVal.value;\n } else {\n w = e.clientWidth;\n h = e.clientHeight;\n }\n return [[0, 0], [w, h]];\n }\n\n function defaultTransform() {\n return this.__zoom || identity$6;\n }\n\n function zoom() {\n var filter = defaultFilter$1,\n extent = defaultExtent,\n k0 = 0,\n k1 = Infinity,\n x0 = -k1,\n x1 = k1,\n y0 = x0,\n y1 = x1,\n duration = 250,\n gestures = [],\n listeners = dispatch(\"start\", \"zoom\", \"end\"),\n touchstarting,\n touchending,\n touchDelay = 500,\n wheelDelay = 150;\n\n function zoom(selection) {\n selection\n .on(\"wheel.zoom\", wheeled)\n .on(\"mousedown.zoom\", mousedowned)\n .on(\"dblclick.zoom\", dblclicked)\n .on(\"touchstart.zoom\", touchstarted)\n .on(\"touchmove.zoom\", touchmoved)\n .on(\"touchend.zoom touchcancel.zoom\", touchended)\n .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\")\n .property(\"__zoom\", defaultTransform);\n }\n\n zoom.transform = function(collection, transform) {\n var selection = collection.selection ? collection.selection() : collection;\n selection.property(\"__zoom\", defaultTransform);\n if (collection !== selection) {\n schedule(collection, transform);\n } else {\n selection.interrupt().each(function() {\n gesture(this, arguments)\n .start()\n .zoom(null, typeof transform === \"function\" ? transform.apply(this, arguments) : transform)\n .end();\n });\n }\n };\n\n zoom.scaleBy = function(selection, k) {\n zoom.scaleTo(selection, function() {\n var k0 = this.__zoom.k,\n k1 = typeof k === \"function\" ? k.apply(this, arguments) : k;\n return k0 * k1;\n });\n };\n\n zoom.scaleTo = function(selection, k) {\n zoom.transform(selection, function() {\n var e = extent.apply(this, arguments),\n t0 = this.__zoom,\n p0 = centroid(e),\n p1 = t0.invert(p0),\n k1 = typeof k === \"function\" ? k.apply(this, arguments) : k;\n return constrain(translate(scale(t0, k1), p0, p1), e);\n });\n };\n\n zoom.translateBy = function(selection, x, y) {\n zoom.transform(selection, function() {\n return constrain(this.__zoom.translate(\n typeof x === \"function\" ? x.apply(this, arguments) : x,\n typeof y === \"function\" ? y.apply(this, arguments) : y\n ), extent.apply(this, arguments));\n });\n };\n\n function scale(transform, k) {\n k = Math.max(k0, Math.min(k1, k));\n return k === transform.k ? transform : new Transform(k, transform.x, transform.y);\n }\n\n function translate(transform, p0, p1) {\n var x = p0[0] - p1[0] * transform.k, y = p0[1] - p1[1] * transform.k;\n return x === transform.x && y === transform.y ? transform : new Transform(transform.k, x, y);\n }\n\n function constrain(transform, extent) {\n var dx = Math.min(0, transform.invertX(extent[0][0]) - x0) || Math.max(0, transform.invertX(extent[1][0]) - x1),\n dy = Math.min(0, transform.invertY(extent[0][1]) - y0) || Math.max(0, transform.invertY(extent[1][1]) - y1);\n return dx || dy ? transform.translate(dx, dy) : transform;\n }\n\n function centroid(extent) {\n return [(+extent[0][0] + +extent[1][0]) / 2, (+extent[0][1] + +extent[1][1]) / 2];\n }\n\n function schedule(transition, transform, center) {\n transition\n .on(\"start.zoom\", function() { gesture(this, arguments).start(); })\n .on(\"interrupt.zoom end.zoom\", function() { gesture(this, arguments).end(); })\n .tween(\"zoom\", function() {\n var that = this,\n args = arguments,\n g = gesture(that, args),\n e = extent.apply(that, args),\n p = center || centroid(e),\n w = Math.max(e[1][0] - e[0][0], e[1][1] - e[0][1]),\n a = that.__zoom,\n b = typeof transform === \"function\" ? transform.apply(that, args) : transform,\n i = interpolateZoom(a.invert(p).concat(w / a.k), b.invert(p).concat(w / b.k));\n return function(t) {\n if (t === 1) t = b; // Avoid rounding error on end.\n else { var l = i(t), k = w / l[2]; t = new Transform(k, p[0] - l[0] * k, p[1] - l[1] * k); }\n g.zoom(null, t);\n };\n });\n }\n\n function gesture(that, args) {\n for (var i = 0, n = gestures.length, g; i < n; ++i) {\n if ((g = gestures[i]).that === that) {\n return g;\n }\n }\n return new Gesture(that, args);\n }\n\n function Gesture(that, args) {\n this.that = that;\n this.args = args;\n this.index = -1;\n this.active = 0;\n this.extent = extent.apply(that, args);\n }\n\n Gesture.prototype = {\n start: function() {\n if (++this.active === 1) {\n this.index = gestures.push(this) - 1;\n this.emit(\"start\");\n }\n return this;\n },\n zoom: function(key, transform) {\n if (this.mouse && key !== \"mouse\") this.mouse[1] = transform.invert(this.mouse[0]);\n if (this.touch0 && key !== \"touch\") this.touch0[1] = transform.invert(this.touch0[0]);\n if (this.touch1 && key !== \"touch\") this.touch1[1] = transform.invert(this.touch1[0]);\n this.that.__zoom = transform;\n this.emit(\"zoom\");\n return this;\n },\n end: function() {\n if (--this.active === 0) {\n gestures.splice(this.index, 1);\n this.index = -1;\n this.emit(\"end\");\n }\n return this;\n },\n emit: function(type) {\n customEvent(new ZoomEvent(zoom, type, this.that.__zoom), listeners.apply, listeners, [type, this.that, this.args]);\n }\n };\n\n function wheeled() {\n if (!filter.apply(this, arguments)) return;\n var g = gesture(this, arguments),\n t = this.__zoom,\n k = Math.max(k0, Math.min(k1, t.k * Math.pow(2, -exports.event.deltaY * (exports.event.deltaMode ? 120 : 1) / 500))),\n p = mouse(this);\n\n // If the mouse is in the same location as before, reuse it.\n // If there were recent wheel events, reset the wheel idle timeout.\n if (g.wheel) {\n if (g.mouse[0][0] !== p[0] || g.mouse[0][1] !== p[1]) {\n g.mouse[1] = t.invert(g.mouse[0] = p);\n }\n clearTimeout(g.wheel);\n }\n\n // If this wheel event won’t trigger a transform change, ignore it.\n else if (t.k === k) return;\n\n // Otherwise, capture the mouse point and location at the start.\n else {\n g.mouse = [p, t.invert(p)];\n interrupt(this);\n g.start();\n }\n\n noevent$1();\n g.wheel = setTimeout(wheelidled, wheelDelay);\n g.zoom(\"mouse\", constrain(translate(scale(t, k), g.mouse[0], g.mouse[1]), g.extent));\n\n function wheelidled() {\n g.wheel = null;\n g.end();\n }\n }\n\n function mousedowned() {\n if (touchending || !filter.apply(this, arguments)) return;\n var g = gesture(this, arguments),\n v = select(exports.event.view).on(\"mousemove.zoom\", mousemoved, true).on(\"mouseup.zoom\", mouseupped, true),\n p = mouse(this);\n\n dragDisable(exports.event.view);\n nopropagation$1();\n g.mouse = [p, this.__zoom.invert(p)];\n interrupt(this);\n g.start();\n\n function mousemoved() {\n noevent$1();\n g.moved = true;\n g.zoom(\"mouse\", constrain(translate(g.that.__zoom, g.mouse[0] = mouse(g.that), g.mouse[1]), g.extent));\n }\n\n function mouseupped() {\n v.on(\"mousemove.zoom mouseup.zoom\", null);\n dragEnable(exports.event.view, g.moved);\n noevent$1();\n g.end();\n }\n }\n\n function dblclicked() {\n if (!filter.apply(this, arguments)) return;\n var t0 = this.__zoom,\n p0 = mouse(this),\n p1 = t0.invert(p0),\n k1 = t0.k * (exports.event.shiftKey ? 0.5 : 2),\n t1 = constrain(translate(scale(t0, k1), p0, p1), extent.apply(this, arguments));\n\n noevent$1();\n if (duration > 0) select(this).transition().duration(duration).call(schedule, t1, p0);\n else select(this).call(zoom.transform, t1);\n }\n\n function touchstarted() {\n if (!filter.apply(this, arguments)) return;\n var g = gesture(this, arguments),\n touches = exports.event.changedTouches,\n n = touches.length, i, t, p;\n\n nopropagation$1();\n for (i = 0; i < n; ++i) {\n t = touches[i], p = touch(this, touches, t.identifier);\n p = [p, this.__zoom.invert(p), t.identifier];\n if (!g.touch0) g.touch0 = p;\n else if (!g.touch1) g.touch1 = p;\n }\n if (touchstarting) {\n touchstarting = clearTimeout(touchstarting);\n if (!g.touch1) return g.end(), dblclicked.apply(this, arguments);\n }\n if (exports.event.touches.length === n) {\n touchstarting = setTimeout(function() { touchstarting = null; }, touchDelay);\n interrupt(this);\n g.start();\n }\n }\n\n function touchmoved() {\n var g = gesture(this, arguments),\n touches = exports.event.changedTouches,\n n = touches.length, i, t, p, l;\n\n noevent$1();\n if (touchstarting) touchstarting = clearTimeout(touchstarting);\n for (i = 0; i < n; ++i) {\n t = touches[i], p = touch(this, touches, t.identifier);\n if (g.touch0 && g.touch0[2] === t.identifier) g.touch0[0] = p;\n else if (g.touch1 && g.touch1[2] === t.identifier) g.touch1[0] = p;\n }\n t = g.that.__zoom;\n if (g.touch1) {\n var p0 = g.touch0[0], l0 = g.touch0[1],\n p1 = g.touch1[0], l1 = g.touch1[1],\n dp = (dp = p1[0] - p0[0]) * dp + (dp = p1[1] - p0[1]) * dp,\n dl = (dl = l1[0] - l0[0]) * dl + (dl = l1[1] - l0[1]) * dl;\n t = scale(t, Math.sqrt(dp / dl));\n p = [(p0[0] + p1[0]) / 2, (p0[1] + p1[1]) / 2];\n l = [(l0[0] + l1[0]) / 2, (l0[1] + l1[1]) / 2];\n }\n else if (g.touch0) p = g.touch0[0], l = g.touch0[1];\n else return;\n g.zoom(\"touch\", constrain(translate(t, p, l), g.extent));\n }\n\n function touchended() {\n var g = gesture(this, arguments),\n touches = exports.event.changedTouches,\n n = touches.length, i, t;\n\n nopropagation$1();\n if (touchending) clearTimeout(touchending);\n touchending = setTimeout(function() { touchending = null; }, touchDelay);\n for (i = 0; i < n; ++i) {\n t = touches[i];\n if (g.touch0 && g.touch0[2] === t.identifier) delete g.touch0;\n else if (g.touch1 && g.touch1[2] === t.identifier) delete g.touch1;\n }\n if (g.touch1 && !g.touch0) g.touch0 = g.touch1, delete g.touch1;\n if (!g.touch0) g.end();\n }\n\n zoom.filter = function(_) {\n return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant$9(!!_), zoom) : filter;\n };\n\n zoom.extent = function(_) {\n return arguments.length ? (extent = typeof _ === \"function\" ? _ : constant$9([[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]]), zoom) : extent;\n };\n\n zoom.scaleExtent = function(_) {\n return arguments.length ? (k0 = +_[0], k1 = +_[1], zoom) : [k0, k1];\n };\n\n zoom.translateExtent = function(_) {\n return arguments.length ? (x0 = +_[0][0], x1 = +_[1][0], y0 = +_[0][1], y1 = +_[1][1], zoom) : [[x0, y0], [x1, y1]];\n };\n\n zoom.duration = function(_) {\n return arguments.length ? (duration = +_, zoom) : duration;\n };\n\n zoom.on = function() {\n var value = listeners.on.apply(listeners, arguments);\n return value === listeners ? zoom : value;\n };\n\n return zoom;\n }\n\n function constant$10(x) {\n return function() {\n return x;\n };\n }\n\n function BrushEvent(target, type, selection) {\n this.target = target;\n this.type = type;\n this.selection = selection;\n }\n\n function nopropagation$2() {\n exports.event.stopImmediatePropagation();\n }\n\n function noevent$2() {\n exports.event.preventDefault();\n exports.event.stopImmediatePropagation();\n }\n\n var MODE_DRAG = {name: \"drag\"};\n var MODE_SPACE = {name: \"space\"};\n var MODE_HANDLE = {name: \"handle\"};\n var MODE_CENTER = {name: \"center\"};\n var X = {\n name: \"x\",\n handles: [\"e\", \"w\"].map(type$1),\n input: function(x, e) { return x && [[x[0], e[0][1]], [x[1], e[1][1]]]; },\n output: function(xy) { return xy && [xy[0][0], xy[1][0]]; }\n };\n\n var Y = {\n name: \"y\",\n handles: [\"n\", \"s\"].map(type$1),\n input: function(y, e) { return y && [[e[0][0], y[0]], [e[1][0], y[1]]]; },\n output: function(xy) { return xy && [xy[0][1], xy[1][1]]; }\n };\n\n var XY = {\n name: \"xy\",\n handles: [\"n\", \"e\", \"s\", \"w\", \"nw\", \"ne\", \"se\", \"sw\"].map(type$1),\n input: function(xy) { return xy; },\n output: function(xy) { return xy; }\n };\n\n var cursors = {\n overlay: \"crosshair\",\n selection: \"move\",\n n: \"ns-resize\",\n e: \"ew-resize\",\n s: \"ns-resize\",\n w: \"ew-resize\",\n nw: \"nwse-resize\",\n ne: \"nesw-resize\",\n se: \"nwse-resize\",\n sw: \"nesw-resize\"\n };\n\n var flipX = {\n e: \"w\",\n w: \"e\",\n nw: \"ne\",\n ne: \"nw\",\n se: \"sw\",\n sw: \"se\"\n };\n\n var flipY = {\n n: \"s\",\n s: \"n\",\n nw: \"sw\",\n ne: \"se\",\n se: \"ne\",\n sw: \"nw\"\n };\n\n var signsX = {\n overlay: +1,\n selection: +1,\n n: null,\n e: +1,\n s: null,\n w: -1,\n nw: -1,\n ne: +1,\n se: +1,\n sw: -1\n };\n\n var signsY = {\n overlay: +1,\n selection: +1,\n n: -1,\n e: null,\n s: +1,\n w: null,\n nw: -1,\n ne: -1,\n se: +1,\n sw: +1\n };\n\n function type$1(t) {\n return {type: t};\n }\n\n // Ignore right-click, since that should open the context menu.\n function defaultFilter$2() {\n return !exports.event.button;\n }\n\n function defaultExtent$1() {\n var svg = this.ownerSVGElement || this;\n return [[0, 0], [svg.width.baseVal.value, svg.height.baseVal.value]];\n }\n\n // Like d3.local, but with the name “__brush†rather than auto-generated.\n function local$1(node) {\n while (!node.__brush) if (!(node = node.parentNode)) return;\n return node.__brush;\n }\n\n function empty$1(extent) {\n return extent[0][0] === extent[1][0]\n || extent[0][1] === extent[1][1];\n }\n\n function brushSelection(node) {\n var state = node.__brush;\n return state ? state.dim.output(state.selection) : null;\n }\n\n function brushX() {\n return brush$1(X);\n }\n\n function brushY() {\n return brush$1(Y);\n }\n\n function brush() {\n return brush$1(XY);\n }\n\n function brush$1(dim) {\n var extent = defaultExtent$1,\n filter = defaultFilter$2,\n listeners = dispatch(brush, \"start\", \"brush\", \"end\"),\n handleSize = 6,\n touchending;\n\n function brush(group) {\n var overlay = group\n .property(\"__brush\", initialize)\n .selectAll(\".overlay\")\n .data([type$1(\"overlay\")]);\n\n overlay.enter().append(\"rect\")\n .attr(\"class\", \"overlay\")\n .attr(\"pointer-events\", \"all\")\n .attr(\"cursor\", cursors.overlay)\n .merge(overlay)\n .each(function() {\n var extent = local$1(this).extent;\n select(this)\n .attr(\"x\", extent[0][0])\n .attr(\"y\", extent[0][1])\n .attr(\"width\", extent[1][0] - extent[0][0])\n .attr(\"height\", extent[1][1] - extent[0][1]);\n });\n\n group.selectAll(\".selection\")\n .data([type$1(\"selection\")])\n .enter().append(\"rect\")\n .attr(\"class\", \"selection\")\n .attr(\"cursor\", cursors.selection)\n .attr(\"fill\", \"#777\")\n .attr(\"fill-opacity\", 0.3)\n .attr(\"stroke\", \"#fff\")\n .attr(\"shape-rendering\", \"crispEdges\");\n\n var handle = group.selectAll(\".handle\")\n .data(dim.handles, function(d) { return d.type; });\n\n handle.exit().remove();\n\n handle.enter().append(\"rect\")\n .attr(\"class\", function(d) { return \"handle handle--\" + d.type; })\n .attr(\"cursor\", function(d) { return cursors[d.type]; });\n\n group\n .each(redraw)\n .attr(\"fill\", \"none\")\n .attr(\"pointer-events\", \"all\")\n .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\")\n .on(\"mousedown.brush touchstart.brush\", started);\n }\n\n brush.move = function(group, selection) {\n if (group.selection) {\n group\n .on(\"start.brush\", function() { emitter(this, arguments).beforestart().start(); })\n .on(\"interrupt.brush end.brush\", function() { emitter(this, arguments).end(); })\n .tween(\"brush\", function() {\n var that = this,\n state = that.__brush,\n emit = emitter(that, arguments),\n selection0 = state.selection,\n selection1 = dim.input(typeof selection === \"function\" ? selection.apply(this, arguments) : selection, state.extent),\n i = interpolate(selection0, selection1);\n\n function tween(t) {\n state.selection = t === 1 && empty$1(selection1) ? null : i(t);\n redraw.call(that);\n emit.brush();\n }\n\n return selection0 && selection1 ? tween : tween(1);\n });\n } else {\n group\n .each(function() {\n var that = this,\n args = arguments,\n state = that.__brush,\n selection1 = dim.input(typeof selection === \"function\" ? selection.apply(that, args) : selection, state.extent),\n emit = emitter(that, args).beforestart();\n\n interrupt(that);\n state.selection = selection1 == null || empty$1(selection1) ? null : selection1;\n redraw.call(that);\n emit.start().brush().end();\n });\n }\n };\n\n function redraw() {\n var group = select(this),\n selection = local$1(this).selection;\n\n if (selection) {\n group.selectAll(\".selection\")\n .style(\"display\", null)\n .attr(\"x\", selection[0][0])\n .attr(\"y\", selection[0][1])\n .attr(\"width\", selection[1][0] - selection[0][0])\n .attr(\"height\", selection[1][1] - selection[0][1]);\n\n group.selectAll(\".handle\")\n .style(\"display\", null)\n .attr(\"x\", function(d) { return d.type[d.type.length - 1] === \"e\" ? selection[1][0] - handleSize / 2 : selection[0][0] - handleSize / 2; })\n .attr(\"y\", function(d) { return d.type[0] === \"s\" ? selection[1][1] - handleSize / 2 : selection[0][1] - handleSize / 2; })\n .attr(\"width\", function(d) { return d.type === \"n\" || d.type === \"s\" ? selection[1][0] - selection[0][0] + handleSize : handleSize; })\n .attr(\"height\", function(d) { return d.type === \"e\" || d.type === \"w\" ? selection[1][1] - selection[0][1] + handleSize : handleSize; });\n }\n\n else {\n group.selectAll(\".selection,.handle\")\n .style(\"display\", \"none\")\n .attr(\"x\", null)\n .attr(\"y\", null)\n .attr(\"width\", null)\n .attr(\"height\", null);\n }\n }\n\n function emitter(that, args) {\n return that.__brush.emitter || new Emitter(that, args);\n }\n\n function Emitter(that, args) {\n this.that = that;\n this.args = args;\n this.state = that.__brush;\n this.active = 0;\n }\n\n Emitter.prototype = {\n beforestart: function() {\n if (++this.active === 1) this.state.emitter = this, this.starting = true;\n return this;\n },\n start: function() {\n if (this.starting) this.starting = false, this.emit(\"start\");\n return this;\n },\n brush: function() {\n this.emit(\"brush\");\n return this;\n },\n end: function() {\n if (--this.active === 0) delete this.state.emitter, this.emit(\"end\");\n return this;\n },\n emit: function(type) {\n customEvent(new BrushEvent(brush, type, dim.output(this.state.selection)), listeners.apply, listeners, [type, this.that, this.args]);\n }\n };\n\n function started() {\n if (exports.event.touches) { if (exports.event.changedTouches.length < exports.event.touches.length) return noevent$2(); }\n else if (touchending) return;\n if (!filter.apply(this, arguments)) return;\n\n var that = this,\n type = exports.event.target.__data__.type,\n mode = (exports.event.metaKey ? type = \"overlay\" : type) === \"selection\" ? MODE_DRAG : (exports.event.altKey ? MODE_CENTER : MODE_HANDLE),\n signX = dim === Y ? null : signsX[type],\n signY = dim === X ? null : signsY[type],\n state = local$1(that),\n extent = state.extent,\n selection = state.selection,\n W = extent[0][0], w0, w1,\n N = extent[0][1], n0, n1,\n E = extent[1][0], e0, e1,\n S = extent[1][1], s0, s1,\n dx,\n dy,\n moving,\n shifting = signX && signY && exports.event.shiftKey,\n lockX,\n lockY,\n point0 = mouse(that),\n point = point0,\n emit = emitter(that, arguments).beforestart();\n\n if (type === \"overlay\") {\n state.selection = selection = [\n [w0 = dim === Y ? W : point0[0], n0 = dim === X ? N : point0[1]],\n [e0 = dim === Y ? E : w0, s0 = dim === X ? S : n0]\n ];\n } else {\n w0 = selection[0][0];\n n0 = selection[0][1];\n e0 = selection[1][0];\n s0 = selection[1][1];\n }\n\n w1 = w0;\n n1 = n0;\n e1 = e0;\n s1 = s0;\n\n var group = select(that)\n .attr(\"pointer-events\", \"none\");\n\n var overlay = group.selectAll(\".overlay\")\n .attr(\"cursor\", cursors[type]);\n\n if (exports.event.touches) {\n group\n .on(\"touchmove.brush\", moved, true)\n .on(\"touchend.brush touchcancel.brush\", ended, true);\n } else {\n var view = select(exports.event.view)\n .on(\"keydown.brush\", keydowned, true)\n .on(\"keyup.brush\", keyupped, true)\n .on(\"mousemove.brush\", moved, true)\n .on(\"mouseup.brush\", ended, true);\n\n dragDisable(exports.event.view);\n }\n\n nopropagation$2();\n interrupt(that);\n redraw.call(that);\n emit.start();\n\n function moved() {\n var point1 = mouse(that);\n if (shifting && !lockX && !lockY) {\n if (Math.abs(point1[0] - point[0]) > Math.abs(point1[1] - point[1])) lockY = true;\n else lockX = true;\n }\n point = point1;\n moving = true;\n noevent$2();\n move();\n }\n\n function move() {\n var t;\n\n dx = point[0] - point0[0];\n dy = point[1] - point0[1];\n\n switch (mode) {\n case MODE_SPACE:\n case MODE_DRAG: {\n if (signX) dx = Math.max(W - w0, Math.min(E - e0, dx)), w1 = w0 + dx, e1 = e0 + dx;\n if (signY) dy = Math.max(N - n0, Math.min(S - s0, dy)), n1 = n0 + dy, s1 = s0 + dy;\n break;\n }\n case MODE_HANDLE: {\n if (signX < 0) dx = Math.max(W - w0, Math.min(E - w0, dx)), w1 = w0 + dx, e1 = e0;\n else if (signX > 0) dx = Math.max(W - e0, Math.min(E - e0, dx)), w1 = w0, e1 = e0 + dx;\n if (signY < 0) dy = Math.max(N - n0, Math.min(S - n0, dy)), n1 = n0 + dy, s1 = s0;\n else if (signY > 0) dy = Math.max(N - s0, Math.min(S - s0, dy)), n1 = n0, s1 = s0 + dy;\n break;\n }\n case MODE_CENTER: {\n if (signX) w1 = Math.max(W, Math.min(E, w0 - dx * signX)), e1 = Math.max(W, Math.min(E, e0 + dx * signX));\n if (signY) n1 = Math.max(N, Math.min(S, n0 - dy * signY)), s1 = Math.max(N, Math.min(S, s0 + dy * signY));\n break;\n }\n }\n\n if (e1 < w1) {\n signX *= -1;\n t = w0, w0 = e0, e0 = t;\n t = w1, w1 = e1, e1 = t;\n if (type in flipX) overlay.attr(\"cursor\", cursors[type = flipX[type]]);\n }\n\n if (s1 < n1) {\n signY *= -1;\n t = n0, n0 = s0, s0 = t;\n t = n1, n1 = s1, s1 = t;\n if (type in flipY) overlay.attr(\"cursor\", cursors[type = flipY[type]]);\n }\n\n selection = state.selection; // May be set by brush.move!\n\n if (lockX) w1 = selection[0][0], e1 = selection[1][0];\n if (lockY) n1 = selection[0][1], s1 = selection[1][1];\n\n if (selection[0][0] !== w1\n || selection[0][1] !== n1\n || selection[1][0] !== e1\n || selection[1][1] !== s1) {\n state.selection = [[w1, n1], [e1, s1]];\n redraw.call(that);\n emit.brush();\n }\n }\n\n function ended() {\n nopropagation$2();\n if (exports.event.touches) {\n if (exports.event.touches.length) return;\n if (touchending) clearTimeout(touchending);\n touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!\n group.on(\"touchmove.brush touchend.brush touchcancel.brush\", null);\n } else {\n dragEnable(exports.event.view, moving);\n view.on(\"keydown.brush keyup.brush mousemove.brush mouseup.brush\", null);\n }\n group.attr(\"pointer-events\", \"all\");\n overlay.attr(\"cursor\", cursors.overlay);\n if (empty$1(selection)) state.selection = null, redraw.call(that);\n emit.end();\n }\n\n function keydowned() {\n switch (exports.event.keyCode) {\n case 16: { // SHIFT\n shifting = signX && signY;\n break;\n }\n case 18: { // ALT\n if (mode === MODE_HANDLE) {\n if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;\n if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;\n mode = MODE_CENTER;\n move();\n }\n break;\n }\n case 32: { // SPACE; takes priority over ALT\n if (mode === MODE_HANDLE || mode === MODE_CENTER) {\n if (signX < 0) e0 = e1 - dx; else if (signX > 0) w0 = w1 - dx;\n if (signY < 0) s0 = s1 - dy; else if (signY > 0) n0 = n1 - dy;\n mode = MODE_SPACE;\n overlay.attr(\"cursor\", cursors.selection);\n move();\n }\n break;\n }\n default: return;\n }\n noevent$2();\n }\n\n function keyupped() {\n switch (exports.event.keyCode) {\n case 16: { // SHIFT\n if (shifting) {\n lockX = lockY = shifting = false;\n move();\n }\n break;\n }\n case 18: { // ALT\n if (mode === MODE_CENTER) {\n if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;\n if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;\n mode = MODE_HANDLE;\n move();\n }\n break;\n }\n case 32: { // SPACE\n if (mode === MODE_SPACE) {\n if (exports.event.altKey) {\n if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;\n if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;\n mode = MODE_CENTER;\n } else {\n if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;\n if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;\n mode = MODE_HANDLE;\n }\n overlay.attr(\"cursor\", cursors[type]);\n move();\n }\n break;\n }\n default: return;\n }\n noevent$2();\n }\n }\n\n function initialize() {\n var state = this.__brush || {selection: null};\n state.extent = extent.apply(this, arguments);\n state.dim = dim;\n return state;\n }\n\n brush.extent = function(_) {\n return arguments.length ? (extent = typeof _ === \"function\" ? _ : constant$10([[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]]), brush) : extent;\n };\n\n brush.filter = function(_) {\n return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant$10(!!_), brush) : filter;\n };\n\n brush.handleSize = function(_) {\n return arguments.length ? (handleSize = +_, brush) : handleSize;\n };\n\n brush.on = function() {\n var value = listeners.on.apply(listeners, arguments);\n return value === listeners ? brush : value;\n };\n\n return brush;\n }\n\n var cos = Math.cos;\n var sin = Math.sin;\n var pi$3 = Math.PI;\n var halfPi$2 = pi$3 / 2;\n var tau$3 = pi$3 * 2;\n var max$1 = Math.max;\n\n function compareValue(compare) {\n return function(a, b) {\n return compare(\n a.source.value + a.target.value,\n b.source.value + b.target.value\n );\n };\n }\n\n function chord() {\n var padAngle = 0,\n sortGroups = null,\n sortSubgroups = null,\n sortChords = null;\n\n function chord(matrix) {\n var n = matrix.length,\n groupSums = [],\n groupIndex = range(n),\n subgroupIndex = [],\n chords = [],\n groups = chords.groups = new Array(n),\n subgroups = new Array(n * n),\n k,\n x,\n x0,\n dx,\n i,\n j;\n\n // Compute the sum.\n k = 0, i = -1; while (++i < n) {\n x = 0, j = -1; while (++j < n) {\n x += matrix[i][j];\n }\n groupSums.push(x);\n subgroupIndex.push(range(n));\n k += x;\n }\n\n // Sort groups…\n if (sortGroups) groupIndex.sort(function(a, b) {\n return sortGroups(groupSums[a], groupSums[b]);\n });\n\n // Sort subgroups…\n if (sortSubgroups) subgroupIndex.forEach(function(d, i) {\n d.sort(function(a, b) {\n return sortSubgroups(matrix[i][a], matrix[i][b]);\n });\n });\n\n // Convert the sum to scaling factor for [0, 2pi].\n // TODO Allow start and end angle to be specified?\n // TODO Allow padding to be specified as percentage?\n k = max$1(0, tau$3 - padAngle * n) / k;\n dx = k ? padAngle : tau$3 / n;\n\n // Compute the start and end angle for each group and subgroup.\n // Note: Opera has a bug reordering object literal properties!\n x = 0, i = -1; while (++i < n) {\n x0 = x, j = -1; while (++j < n) {\n var di = groupIndex[i],\n dj = subgroupIndex[di][j],\n v = matrix[di][dj],\n a0 = x,\n a1 = x += v * k;\n subgroups[dj * n + di] = {\n index: di,\n subindex: dj,\n startAngle: a0,\n endAngle: a1,\n value: v\n };\n }\n groups[di] = {\n index: di,\n startAngle: x0,\n endAngle: x,\n value: groupSums[di]\n };\n x += dx;\n }\n\n // Generate chords for each (non-empty) subgroup-subgroup link.\n i = -1; while (++i < n) {\n j = i - 1; while (++j < n) {\n var source = subgroups[j * n + i],\n target = subgroups[i * n + j];\n if (source.value || target.value) {\n chords.push(source.value < target.value\n ? {source: target, target: source}\n : {source: source, target: target});\n }\n }\n }\n\n return sortChords ? chords.sort(sortChords) : chords;\n }\n\n chord.padAngle = function(_) {\n return arguments.length ? (padAngle = max$1(0, _), chord) : padAngle;\n };\n\n chord.sortGroups = function(_) {\n return arguments.length ? (sortGroups = _, chord) : sortGroups;\n };\n\n chord.sortSubgroups = function(_) {\n return arguments.length ? (sortSubgroups = _, chord) : sortSubgroups;\n };\n\n chord.sortChords = function(_) {\n return arguments.length ? (_ == null ? sortChords = null : (sortChords = compareValue(_))._ = _, chord) : sortChords && sortChords._;\n };\n\n return chord;\n }\n\n var slice$5 = Array.prototype.slice;\n\n function constant$11(x) {\n return function() {\n return x;\n };\n }\n\n function defaultSource(d) {\n return d.source;\n }\n\n function defaultTarget(d) {\n return d.target;\n }\n\n function defaultRadius$1(d) {\n return d.radius;\n }\n\n function defaultStartAngle(d) {\n return d.startAngle;\n }\n\n function defaultEndAngle(d) {\n return d.endAngle;\n }\n\n function ribbon() {\n var source = defaultSource,\n target = defaultTarget,\n radius = defaultRadius$1,\n startAngle = defaultStartAngle,\n endAngle = defaultEndAngle,\n context = null;\n\n function ribbon() {\n var buffer,\n argv = slice$5.call(arguments),\n s = source.apply(this, argv),\n t = target.apply(this, argv),\n sr = +radius.apply(this, (argv[0] = s, argv)),\n sa0 = startAngle.apply(this, argv) - halfPi$2,\n sa1 = endAngle.apply(this, argv) - halfPi$2,\n sx0 = sr * cos(sa0),\n sy0 = sr * sin(sa0),\n tr = +radius.apply(this, (argv[0] = t, argv)),\n ta0 = startAngle.apply(this, argv) - halfPi$2,\n ta1 = endAngle.apply(this, argv) - halfPi$2;\n\n if (!context) context = buffer = path();\n\n context.moveTo(sx0, sy0);\n context.arc(0, 0, sr, sa0, sa1);\n if (sa0 !== ta0 || sa1 !== ta1) { // TODO sr !== tr?\n context.quadraticCurveTo(0, 0, tr * cos(ta0), tr * sin(ta0));\n context.arc(0, 0, tr, ta0, ta1);\n }\n context.quadraticCurveTo(0, 0, sx0, sy0);\n context.closePath();\n\n if (buffer) return context = null, buffer + \"\" || null;\n }\n\n ribbon.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant$11(+_), ribbon) : radius;\n };\n\n ribbon.startAngle = function(_) {\n return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant$11(+_), ribbon) : startAngle;\n };\n\n ribbon.endAngle = function(_) {\n return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant$11(+_), ribbon) : endAngle;\n };\n\n ribbon.source = function(_) {\n return arguments.length ? (source = _, ribbon) : source;\n };\n\n ribbon.target = function(_) {\n return arguments.length ? (target = _, ribbon) : target;\n };\n\n ribbon.context = function(_) {\n return arguments.length ? ((context = _ == null ? null : _), ribbon) : context;\n };\n\n return ribbon;\n }\n\n // Adds floating point numbers with twice the normal precision.\n // Reference: J. R. Shewchuk, Adaptive Precision Floating-Point Arithmetic and\n // Fast Robust Geometric Predicates, Discrete & Computational Geometry 18(3)\n // 305–363 (1997).\n // Code adapted from GeographicLib by Charles F. F. Karney,\n // http://geographiclib.sourceforge.net/\n\n function adder() {\n return new Adder;\n }\n\n function Adder() {\n this.reset();\n }\n\n Adder.prototype = {\n constructor: Adder,\n reset: function() {\n this.s = // rounded value\n this.t = 0; // exact error\n },\n add: function(y) {\n add$1(temp, y, this.t);\n add$1(this, temp.s, this.s);\n if (this.s) this.t += temp.t;\n else this.s = temp.t;\n },\n valueOf: function() {\n return this.s;\n }\n };\n\n var temp = new Adder;\n\n function add$1(adder, a, b) {\n var x = adder.s = a + b,\n bv = x - a,\n av = x - bv;\n adder.t = (a - av) + (b - bv);\n }\n\n var epsilon$4 = 1e-6;\n var epsilon2$2 = 1e-12;\n var pi$4 = Math.PI;\n var halfPi$3 = pi$4 / 2;\n var quarterPi = pi$4 / 4;\n var tau$4 = pi$4 * 2;\n\n var degrees$1 = 180 / pi$4;\n var radians = pi$4 / 180;\n\n var abs = Math.abs;\n var atan = Math.atan;\n var atan2 = Math.atan2;\n var cos$1 = Math.cos;\n var ceil = Math.ceil;\n var exp = Math.exp;\n var log$1 = Math.log;\n var pow$1 = Math.pow;\n var sin$1 = Math.sin;\n var sign$1 = Math.sign || function(x) { return x > 0 ? 1 : x < 0 ? -1 : 0; };\n var sqrt$1 = Math.sqrt;\n var tan = Math.tan;\n\n function acos(x) {\n return x > 1 ? 0 : x < -1 ? pi$4 : Math.acos(x);\n }\n\n function asin$1(x) {\n return x > 1 ? halfPi$3 : x < -1 ? -halfPi$3 : Math.asin(x);\n }\n\n function haversin(x) {\n return (x = sin$1(x / 2)) * x;\n }\n\n function noop$2() {}\n\n function streamGeometry(geometry, stream) {\n if (geometry && streamGeometryType.hasOwnProperty(geometry.type)) {\n streamGeometryType[geometry.type](geometry, stream);\n }\n }\n\n var streamObjectType = {\n Feature: function(feature, stream) {\n streamGeometry(feature.geometry, stream);\n },\n FeatureCollection: function(object, stream) {\n var features = object.features, i = -1, n = features.length;\n while (++i < n) streamGeometry(features[i].geometry, stream);\n }\n };\n\n var streamGeometryType = {\n Sphere: function(object, stream) {\n stream.sphere();\n },\n Point: function(object, stream) {\n object = object.coordinates;\n stream.point(object[0], object[1], object[2]);\n },\n MultiPoint: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) object = coordinates[i], stream.point(object[0], object[1], object[2]);\n },\n LineString: function(object, stream) {\n streamLine(object.coordinates, stream, 0);\n },\n MultiLineString: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) streamLine(coordinates[i], stream, 0);\n },\n Polygon: function(object, stream) {\n streamPolygon(object.coordinates, stream);\n },\n MultiPolygon: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) streamPolygon(coordinates[i], stream);\n },\n GeometryCollection: function(object, stream) {\n var geometries = object.geometries, i = -1, n = geometries.length;\n while (++i < n) streamGeometry(geometries[i], stream);\n }\n };\n\n function streamLine(coordinates, stream, closed) {\n var i = -1, n = coordinates.length - closed, coordinate;\n stream.lineStart();\n while (++i < n) coordinate = coordinates[i], stream.point(coordinate[0], coordinate[1], coordinate[2]);\n stream.lineEnd();\n }\n\n function streamPolygon(coordinates, stream) {\n var i = -1, n = coordinates.length;\n stream.polygonStart();\n while (++i < n) streamLine(coordinates[i], stream, 1);\n stream.polygonEnd();\n }\n\n function stream(object, stream) {\n if (object && streamObjectType.hasOwnProperty(object.type)) {\n streamObjectType[object.type](object, stream);\n } else {\n streamGeometry(object, stream);\n }\n }\n\n var areaRingSum;\n\n var areaSum;\n var lambda00;\n var phi00;\n var lambda0;\n var cosPhi0;\n var sinPhi0;\n var areaStream = {\n point: noop$2,\n lineStart: noop$2,\n lineEnd: noop$2,\n polygonStart: function() {\n areaRingSum.reset();\n areaStream.lineStart = areaRingStart;\n areaStream.lineEnd = areaRingEnd;\n },\n polygonEnd: function() {\n var areaRing = +areaRingSum;\n areaSum.add(areaRing < 0 ? tau$4 + areaRing : areaRing);\n this.lineStart = this.lineEnd = this.point = noop$2;\n },\n sphere: function() {\n areaSum.add(tau$4);\n }\n };\n\n function areaRingStart() {\n areaStream.point = areaPointFirst;\n }\n\n function areaRingEnd() {\n areaPoint(lambda00, phi00);\n }\n\n function areaPointFirst(lambda, phi) {\n areaStream.point = areaPoint;\n lambda00 = lambda, phi00 = phi;\n lambda *= radians, phi *= radians;\n lambda0 = lambda, cosPhi0 = cos$1(phi = phi / 2 + quarterPi), sinPhi0 = sin$1(phi);\n }\n\n function areaPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n phi = phi / 2 + quarterPi; // half the angular distance from south pole\n\n // Spherical excess E for a spherical triangle with vertices: south pole,\n // previous point, current point. Uses a formula derived from Cagnoli’s\n // theorem. See Todhunter, Spherical Trig. (1871), Sec. 103, Eq. (2).\n var dLambda = lambda - lambda0,\n sdLambda = dLambda >= 0 ? 1 : -1,\n adLambda = sdLambda * dLambda,\n cosPhi = cos$1(phi),\n sinPhi = sin$1(phi),\n k = sinPhi0 * sinPhi,\n u = cosPhi0 * cosPhi + k * cos$1(adLambda),\n v = k * sdLambda * sin$1(adLambda);\n areaRingSum.add(atan2(v, u));\n\n // Advance the previous points.\n lambda0 = lambda, cosPhi0 = cosPhi, sinPhi0 = sinPhi;\n }\n\n function area$2(object) {\n if (areaSum) areaSum.reset();\n else areaSum = adder(), areaRingSum = adder();\n stream(object, areaStream);\n return areaSum * 2;\n }\n\n function spherical(cartesian) {\n return [atan2(cartesian[1], cartesian[0]), asin$1(cartesian[2])];\n }\n\n function cartesian(spherical) {\n var lambda = spherical[0], phi = spherical[1], cosPhi = cos$1(phi);\n return [cosPhi * cos$1(lambda), cosPhi * sin$1(lambda), sin$1(phi)];\n }\n\n function cartesianDot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n }\n\n function cartesianCross(a, b) {\n return [a[1] * b[2] - a[2] * b[1], a[2] * b[0] - a[0] * b[2], a[0] * b[1] - a[1] * b[0]];\n }\n\n // TODO return a\n function cartesianAddInPlace(a, b) {\n a[0] += b[0], a[1] += b[1], a[2] += b[2];\n }\n\n function cartesianScale(vector, k) {\n return [vector[0] * k, vector[1] * k, vector[2] * k];\n }\n\n // TODO return d\n function cartesianNormalizeInPlace(d) {\n var l = sqrt$1(d[0] * d[0] + d[1] * d[1] + d[2] * d[2]);\n d[0] /= l, d[1] /= l, d[2] /= l;\n }\n\nvar lambda0$1;\n var phi0;\n var lambda1;\n var phi1;\n var lambda2;\nvar lambda00$1;\nvar phi00$1;\n var p0;\n var deltaSum;\n var ranges;\nvar range$1;\n var boundsStream = {\n point: boundsPoint,\n lineStart: boundsLineStart,\n lineEnd: boundsLineEnd,\n polygonStart: function() {\n boundsStream.point = boundsRingPoint;\n boundsStream.lineStart = boundsRingStart;\n boundsStream.lineEnd = boundsRingEnd;\n deltaSum.reset();\n areaStream.polygonStart();\n },\n polygonEnd: function() {\n areaStream.polygonEnd();\n boundsStream.point = boundsPoint;\n boundsStream.lineStart = boundsLineStart;\n boundsStream.lineEnd = boundsLineEnd;\n if (areaRingSum < 0) lambda0$1 = -(lambda1 = 180), phi0 = -(phi1 = 90);\n else if (deltaSum > epsilon$4) phi1 = 90;\n else if (deltaSum < -epsilon$4) phi0 = -90;\n range$1[0] = lambda0$1, range$1[1] = lambda1;\n }\n };\n\n function boundsPoint(lambda, phi) {\n ranges.push(range$1 = [lambda0$1 = lambda, lambda1 = lambda]);\n if (phi < phi0) phi0 = phi;\n if (phi > phi1) phi1 = phi;\n }\n\n function linePoint(lambda, phi) {\n var p = cartesian([lambda * radians, phi * radians]);\n if (p0) {\n var normal = cartesianCross(p0, p),\n equatorial = [normal[1], -normal[0], 0],\n inflection = cartesianCross(equatorial, normal);\n cartesianNormalizeInPlace(inflection);\n inflection = spherical(inflection);\n var delta = lambda - lambda2,\n sign = delta > 0 ? 1 : -1,\n lambdai = inflection[0] * degrees$1 * sign,\n phii,\n antimeridian = abs(delta) > 180;\n if (antimeridian ^ (sign * lambda2 < lambdai && lambdai < sign * lambda)) {\n phii = inflection[1] * degrees$1;\n if (phii > phi1) phi1 = phii;\n } else if (lambdai = (lambdai + 360) % 360 - 180, antimeridian ^ (sign * lambda2 < lambdai && lambdai < sign * lambda)) {\n phii = -inflection[1] * degrees$1;\n if (phii < phi0) phi0 = phii;\n } else {\n if (phi < phi0) phi0 = phi;\n if (phi > phi1) phi1 = phi;\n }\n if (antimeridian) {\n if (lambda < lambda2) {\n if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;\n } else {\n if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;\n }\n } else {\n if (lambda1 >= lambda0$1) {\n if (lambda < lambda0$1) lambda0$1 = lambda;\n if (lambda > lambda1) lambda1 = lambda;\n } else {\n if (lambda > lambda2) {\n if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;\n } else {\n if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;\n }\n }\n }\n } else {\n boundsPoint(lambda, phi);\n }\n p0 = p, lambda2 = lambda;\n }\n\n function boundsLineStart() {\n boundsStream.point = linePoint;\n }\n\n function boundsLineEnd() {\n range$1[0] = lambda0$1, range$1[1] = lambda1;\n boundsStream.point = boundsPoint;\n p0 = null;\n }\n\n function boundsRingPoint(lambda, phi) {\n if (p0) {\n var delta = lambda - lambda2;\n deltaSum.add(abs(delta) > 180 ? delta + (delta > 0 ? 360 : -360) : delta);\n } else {\n lambda00$1 = lambda, phi00$1 = phi;\n }\n areaStream.point(lambda, phi);\n linePoint(lambda, phi);\n }\n\n function boundsRingStart() {\n areaStream.lineStart();\n }\n\n function boundsRingEnd() {\n boundsRingPoint(lambda00$1, phi00$1);\n areaStream.lineEnd();\n if (abs(deltaSum) > epsilon$4) lambda0$1 = -(lambda1 = 180);\n range$1[0] = lambda0$1, range$1[1] = lambda1;\n p0 = null;\n }\n\n // Finds the left-right distance between two longitudes.\n // This is almost the same as (lambda1 - lambda0 + 360°) % 360°, except that we want\n // the distance between ±180° to be 360°.\n function angle(lambda0, lambda1) {\n return (lambda1 -= lambda0) < 0 ? lambda1 + 360 : lambda1;\n }\n\n function rangeCompare(a, b) {\n return a[0] - b[0];\n }\n\n function rangeContains(range, x) {\n return range[0] <= range[1] ? range[0] <= x && x <= range[1] : x < range[0] || range[1] < x;\n }\n\n function bounds(feature) {\n var i, n, a, b, merged, deltaMax, delta;\n\n if (deltaSum) deltaSum.reset();\n else deltaSum = adder();\n phi1 = lambda1 = -(lambda0$1 = phi0 = Infinity);\n ranges = [];\n stream(feature, boundsStream);\n\n // First, sort ranges by their minimum longitudes.\n if (n = ranges.length) {\n ranges.sort(rangeCompare);\n\n // Then, merge any ranges that overlap.\n for (i = 1, a = ranges[0], merged = [a]; i < n; ++i) {\n b = ranges[i];\n if (rangeContains(a, b[0]) || rangeContains(a, b[1])) {\n if (angle(a[0], b[1]) > angle(a[0], a[1])) a[1] = b[1];\n if (angle(b[0], a[1]) > angle(a[0], a[1])) a[0] = b[0];\n } else {\n merged.push(a = b);\n }\n }\n\n // Finally, find the largest gap between the merged ranges.\n // The final bounding box will be the inverse of this gap.\n for (deltaMax = -Infinity, n = merged.length - 1, i = 0, a = merged[n]; i <= n; a = b, ++i) {\n b = merged[i];\n if ((delta = angle(a[1], b[0])) > deltaMax) deltaMax = delta, lambda0$1 = b[0], lambda1 = a[1];\n }\n }\n\n ranges = range$1 = null;\n\n return lambda0$1 === Infinity || phi0 === Infinity\n ? [[NaN, NaN], [NaN, NaN]]\n : [[lambda0$1, phi0], [lambda1, phi1]];\n }\n\n var W0;\n var W1;\n var X0;\n var Y0;\n var Z0;\n var X1;\n var Y1;\n var Z1;\n var X2;\n var Y2;\n var Z2;\nvar lambda00$2;\nvar phi00$2;\n var x0;\n var y0;\n var z0;\n // previous point\n\n var centroidStream = {\n sphere: noop$2,\n point: centroidPoint,\n lineStart: centroidLineStart,\n lineEnd: centroidLineEnd,\n polygonStart: function() {\n centroidStream.lineStart = centroidRingStart;\n centroidStream.lineEnd = centroidRingEnd;\n },\n polygonEnd: function() {\n centroidStream.lineStart = centroidLineStart;\n centroidStream.lineEnd = centroidLineEnd;\n }\n };\n\n // Arithmetic mean of Cartesian vectors.\n function centroidPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos$1(phi);\n centroidPointCartesian(cosPhi * cos$1(lambda), cosPhi * sin$1(lambda), sin$1(phi));\n }\n\n function centroidPointCartesian(x, y, z) {\n ++W0;\n X0 += (x - X0) / W0;\n Y0 += (y - Y0) / W0;\n Z0 += (z - Z0) / W0;\n }\n\n function centroidLineStart() {\n centroidStream.point = centroidLinePointFirst;\n }\n\n function centroidLinePointFirst(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos$1(phi);\n x0 = cosPhi * cos$1(lambda);\n y0 = cosPhi * sin$1(lambda);\n z0 = sin$1(phi);\n centroidStream.point = centroidLinePoint;\n centroidPointCartesian(x0, y0, z0);\n }\n\n function centroidLinePoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos$1(phi),\n x = cosPhi * cos$1(lambda),\n y = cosPhi * sin$1(lambda),\n z = sin$1(phi),\n w = atan2(sqrt$1((w = y0 * z - z0 * y) * w + (w = z0 * x - x0 * z) * w + (w = x0 * y - y0 * x) * w), x0 * x + y0 * y + z0 * z);\n W1 += w;\n X1 += w * (x0 + (x0 = x));\n Y1 += w * (y0 + (y0 = y));\n Z1 += w * (z0 + (z0 = z));\n centroidPointCartesian(x0, y0, z0);\n }\n\n function centroidLineEnd() {\n centroidStream.point = centroidPoint;\n }\n\n // See J. E. Brock, The Inertia Tensor for a Spherical Triangle,\n // J. Applied Mechanics 42, 239 (1975).\n function centroidRingStart() {\n centroidStream.point = centroidRingPointFirst;\n }\n\n function centroidRingEnd() {\n centroidRingPoint(lambda00$2, phi00$2);\n centroidStream.point = centroidPoint;\n }\n\n function centroidRingPointFirst(lambda, phi) {\n lambda00$2 = lambda, phi00$2 = phi;\n lambda *= radians, phi *= radians;\n centroidStream.point = centroidRingPoint;\n var cosPhi = cos$1(phi);\n x0 = cosPhi * cos$1(lambda);\n y0 = cosPhi * sin$1(lambda);\n z0 = sin$1(phi);\n centroidPointCartesian(x0, y0, z0);\n }\n\n function centroidRingPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos$1(phi),\n x = cosPhi * cos$1(lambda),\n y = cosPhi * sin$1(lambda),\n z = sin$1(phi),\n cx = y0 * z - z0 * y,\n cy = z0 * x - x0 * z,\n cz = x0 * y - y0 * x,\n m = sqrt$1(cx * cx + cy * cy + cz * cz),\n u = x0 * x + y0 * y + z0 * z,\n v = m && -acos(u) / m, // area weight\n w = atan2(m, u); // line weight\n X2 += v * cx;\n Y2 += v * cy;\n Z2 += v * cz;\n W1 += w;\n X1 += w * (x0 + (x0 = x));\n Y1 += w * (y0 + (y0 = y));\n Z1 += w * (z0 + (z0 = z));\n centroidPointCartesian(x0, y0, z0);\n }\n\n function centroid$1(object) {\n W0 = W1 =\n X0 = Y0 = Z0 =\n X1 = Y1 = Z1 =\n X2 = Y2 = Z2 = 0;\n stream(object, centroidStream);\n\n var x = X2,\n y = Y2,\n z = Z2,\n m = x * x + y * y + z * z;\n\n // If the area-weighted ccentroid is undefined, fall back to length-weighted ccentroid.\n if (m < epsilon2$2) {\n x = X1, y = Y1, z = Z1;\n // If the feature has zero length, fall back to arithmetic mean of point vectors.\n if (W1 < epsilon$4) x = X0, y = Y0, z = Z0;\n m = x * x + y * y + z * z;\n // If the feature still has an undefined ccentroid, then return.\n if (m < epsilon2$2) return [NaN, NaN];\n }\n\n return [atan2(y, x) * degrees$1, asin$1(z / sqrt$1(m)) * degrees$1];\n }\n\n function constant$12(x) {\n return function() {\n return x;\n };\n }\n\n function compose(a, b) {\n\n function compose(x, y) {\n return x = a(x, y), b(x[0], x[1]);\n }\n\n if (a.invert && b.invert) compose.invert = function(x, y) {\n return x = b.invert(x, y), x && a.invert(x[0], x[1]);\n };\n\n return compose;\n }\n\n function rotationIdentity(lambda, phi) {\n return [lambda > pi$4 ? lambda - tau$4 : lambda < -pi$4 ? lambda + tau$4 : lambda, phi];\n }\n\n rotationIdentity.invert = rotationIdentity;\n\n function rotateRadians(deltaLambda, deltaPhi, deltaGamma) {\n return (deltaLambda %= tau$4) ? (deltaPhi || deltaGamma ? compose(rotationLambda(deltaLambda), rotationPhiGamma(deltaPhi, deltaGamma))\n : rotationLambda(deltaLambda))\n : (deltaPhi || deltaGamma ? rotationPhiGamma(deltaPhi, deltaGamma)\n : rotationIdentity);\n }\n\n function forwardRotationLambda(deltaLambda) {\n return function(lambda, phi) {\n return lambda += deltaLambda, [lambda > pi$4 ? lambda - tau$4 : lambda < -pi$4 ? lambda + tau$4 : lambda, phi];\n };\n }\n\n function rotationLambda(deltaLambda) {\n var rotation = forwardRotationLambda(deltaLambda);\n rotation.invert = forwardRotationLambda(-deltaLambda);\n return rotation;\n }\n\n function rotationPhiGamma(deltaPhi, deltaGamma) {\n var cosDeltaPhi = cos$1(deltaPhi),\n sinDeltaPhi = sin$1(deltaPhi),\n cosDeltaGamma = cos$1(deltaGamma),\n sinDeltaGamma = sin$1(deltaGamma);\n\n function rotation(lambda, phi) {\n var cosPhi = cos$1(phi),\n x = cos$1(lambda) * cosPhi,\n y = sin$1(lambda) * cosPhi,\n z = sin$1(phi),\n k = z * cosDeltaPhi + x * sinDeltaPhi;\n return [\n atan2(y * cosDeltaGamma - k * sinDeltaGamma, x * cosDeltaPhi - z * sinDeltaPhi),\n asin$1(k * cosDeltaGamma + y * sinDeltaGamma)\n ];\n }\n\n rotation.invert = function(lambda, phi) {\n var cosPhi = cos$1(phi),\n x = cos$1(lambda) * cosPhi,\n y = sin$1(lambda) * cosPhi,\n z = sin$1(phi),\n k = z * cosDeltaGamma - y * sinDeltaGamma;\n return [\n atan2(y * cosDeltaGamma + z * sinDeltaGamma, x * cosDeltaPhi + k * sinDeltaPhi),\n asin$1(k * cosDeltaPhi - x * sinDeltaPhi)\n ];\n };\n\n return rotation;\n }\n\n function rotation(rotate) {\n rotate = rotateRadians(rotate[0] * radians, rotate[1] * radians, rotate.length > 2 ? rotate[2] * radians : 0);\n\n function forward(coordinates) {\n coordinates = rotate(coordinates[0] * radians, coordinates[1] * radians);\n return coordinates[0] *= degrees$1, coordinates[1] *= degrees$1, coordinates;\n }\n\n forward.invert = function(coordinates) {\n coordinates = rotate.invert(coordinates[0] * radians, coordinates[1] * radians);\n return coordinates[0] *= degrees$1, coordinates[1] *= degrees$1, coordinates;\n };\n\n return forward;\n }\n\n // Generates a circle centered at [0°, 0°], with a given radius and precision.\n function circleStream(stream, radius, delta, direction, t0, t1) {\n if (!delta) return;\n var cosRadius = cos$1(radius),\n sinRadius = sin$1(radius),\n step = direction * delta;\n if (t0 == null) {\n t0 = radius + direction * tau$4;\n t1 = radius - step / 2;\n } else {\n t0 = circleRadius(cosRadius, t0);\n t1 = circleRadius(cosRadius, t1);\n if (direction > 0 ? t0 < t1 : t0 > t1) t0 += direction * tau$4;\n }\n for (var point, t = t0; direction > 0 ? t > t1 : t < t1; t -= step) {\n point = spherical([cosRadius, -sinRadius * cos$1(t), -sinRadius * sin$1(t)]);\n stream.point(point[0], point[1]);\n }\n }\n\n // Returns the signed angle of a cartesian point relative to [cosRadius, 0, 0].\n function circleRadius(cosRadius, point) {\n point = cartesian(point), point[0] -= cosRadius;\n cartesianNormalizeInPlace(point);\n var radius = acos(-point[1]);\n return ((-point[2] < 0 ? -radius : radius) + tau$4 - epsilon$4) % tau$4;\n }\n\n function circle$1() {\n var center = constant$12([0, 0]),\n radius = constant$12(90),\n precision = constant$12(6),\n ring,\n rotate,\n stream = {point: point};\n\n function point(x, y) {\n ring.push(x = rotate(x, y));\n x[0] *= degrees$1, x[1] *= degrees$1;\n }\n\n function circle() {\n var c = center.apply(this, arguments),\n r = radius.apply(this, arguments) * radians,\n p = precision.apply(this, arguments) * radians;\n ring = [];\n rotate = rotateRadians(-c[0] * radians, -c[1] * radians, 0).invert;\n circleStream(stream, r, p, 1);\n c = {type: \"Polygon\", coordinates: [ring]};\n ring = rotate = null;\n return c;\n }\n\n circle.center = function(_) {\n return arguments.length ? (center = typeof _ === \"function\" ? _ : constant$12([+_[0], +_[1]]), circle) : center;\n };\n\n circle.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant$12(+_), circle) : radius;\n };\n\n circle.precision = function(_) {\n return arguments.length ? (precision = typeof _ === \"function\" ? _ : constant$12(+_), circle) : precision;\n };\n\n return circle;\n }\n\n function clipBuffer() {\n var lines = [],\n line;\n return {\n point: function(x, y) {\n line.push([x, y]);\n },\n lineStart: function() {\n lines.push(line = []);\n },\n lineEnd: noop$2,\n rejoin: function() {\n if (lines.length > 1) lines.push(lines.pop().concat(lines.shift()));\n },\n result: function() {\n var result = lines;\n lines = [];\n line = null;\n return result;\n }\n };\n }\n\n function clipLine(a, b, x0, y0, x1, y1) {\n var ax = a[0],\n ay = a[1],\n bx = b[0],\n by = b[1],\n t0 = 0,\n t1 = 1,\n dx = bx - ax,\n dy = by - ay,\n r;\n\n r = x0 - ax;\n if (!dx && r > 0) return;\n r /= dx;\n if (dx < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dx > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = x1 - ax;\n if (!dx && r < 0) return;\n r /= dx;\n if (dx < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dx > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n r = y0 - ay;\n if (!dy && r > 0) return;\n r /= dy;\n if (dy < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dy > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = y1 - ay;\n if (!dy && r < 0) return;\n r /= dy;\n if (dy < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dy > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n if (t0 > 0) a[0] = ax + t0 * dx, a[1] = ay + t0 * dy;\n if (t1 < 1) b[0] = ax + t1 * dx, b[1] = ay + t1 * dy;\n return true;\n }\n\n function pointEqual(a, b) {\n return abs(a[0] - b[0]) < epsilon$4 && abs(a[1] - b[1]) < epsilon$4;\n }\n\n function Intersection(point, points, other, entry) {\n this.x = point;\n this.z = points;\n this.o = other; // another intersection\n this.e = entry; // is an entry?\n this.v = false; // visited\n this.n = this.p = null; // next & previous\n }\n\n // A generalized polygon clipping algorithm: given a polygon that has been cut\n // into its visible line segments, and rejoins the segments by interpolating\n // along the clip edge.\n function clipPolygon(segments, compareIntersection, startInside, interpolate, stream) {\n var subject = [],\n clip = [],\n i,\n n;\n\n segments.forEach(function(segment) {\n if ((n = segment.length - 1) <= 0) return;\n var n, p0 = segment[0], p1 = segment[n], x;\n\n // If the first and last points of a segment are coincident, then treat as a\n // closed ring. TODO if all rings are closed, then the winding order of the\n // exterior ring should be checked.\n if (pointEqual(p0, p1)) {\n stream.lineStart();\n for (i = 0; i < n; ++i) stream.point((p0 = segment[i])[0], p0[1]);\n stream.lineEnd();\n return;\n }\n\n subject.push(x = new Intersection(p0, segment, null, true));\n clip.push(x.o = new Intersection(p0, null, x, false));\n subject.push(x = new Intersection(p1, segment, null, false));\n clip.push(x.o = new Intersection(p1, null, x, true));\n });\n\n if (!subject.length) return;\n\n clip.sort(compareIntersection);\n link$1(subject);\n link$1(clip);\n\n for (i = 0, n = clip.length; i < n; ++i) {\n clip[i].e = startInside = !startInside;\n }\n\n var start = subject[0],\n points,\n point;\n\n while (1) {\n // Find first unvisited intersection.\n var current = start,\n isSubject = true;\n while (current.v) if ((current = current.n) === start) return;\n points = current.z;\n stream.lineStart();\n do {\n current.v = current.o.v = true;\n if (current.e) {\n if (isSubject) {\n for (i = 0, n = points.length; i < n; ++i) stream.point((point = points[i])[0], point[1]);\n } else {\n interpolate(current.x, current.n.x, 1, stream);\n }\n current = current.n;\n } else {\n if (isSubject) {\n points = current.p.z;\n for (i = points.length - 1; i >= 0; --i) stream.point((point = points[i])[0], point[1]);\n } else {\n interpolate(current.x, current.p.x, -1, stream);\n }\n current = current.p;\n }\n current = current.o;\n points = current.z;\n isSubject = !isSubject;\n } while (!current.v);\n stream.lineEnd();\n }\n }\n\n function link$1(array) {\n if (!(n = array.length)) return;\n var n,\n i = 0,\n a = array[0],\n b;\n while (++i < n) {\n a.n = b = array[i];\n b.p = a;\n a = b;\n }\n a.n = b = array[0];\n b.p = a;\n }\n\n var clipMax = 1e9;\n var clipMin = -clipMax;\n // TODO Use d3-polygon’s polygonContains here for the ring check?\n // TODO Eliminate duplicate buffering in clipBuffer and polygon.push?\n\n function clipExtent(x0, y0, x1, y1) {\n\n function visible(x, y) {\n return x0 <= x && x <= x1 && y0 <= y && y <= y1;\n }\n\n function interpolate(from, to, direction, stream) {\n var a = 0, a1 = 0;\n if (from == null\n || (a = corner(from, direction)) !== (a1 = corner(to, direction))\n || comparePoint(from, to) < 0 ^ direction > 0) {\n do stream.point(a === 0 || a === 3 ? x0 : x1, a > 1 ? y1 : y0);\n while ((a = (a + direction + 4) % 4) !== a1);\n } else {\n stream.point(to[0], to[1]);\n }\n }\n\n function corner(p, direction) {\n return abs(p[0] - x0) < epsilon$4 ? direction > 0 ? 0 : 3\n : abs(p[0] - x1) < epsilon$4 ? direction > 0 ? 2 : 1\n : abs(p[1] - y0) < epsilon$4 ? direction > 0 ? 1 : 0\n : direction > 0 ? 3 : 2; // abs(p[1] - y1) < epsilon\n }\n\n function compareIntersection(a, b) {\n return comparePoint(a.x, b.x);\n }\n\n function comparePoint(a, b) {\n var ca = corner(a, 1),\n cb = corner(b, 1);\n return ca !== cb ? ca - cb\n : ca === 0 ? b[1] - a[1]\n : ca === 1 ? a[0] - b[0]\n : ca === 2 ? a[1] - b[1]\n : b[0] - a[0];\n }\n\n return function(stream) {\n var activeStream = stream,\n bufferStream = clipBuffer(),\n segments,\n polygon,\n ring,\n x__, y__, v__, // first point\n x_, y_, v_, // previous point\n first,\n clean;\n\n var clipStream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: polygonStart,\n polygonEnd: polygonEnd\n };\n\n function point(x, y) {\n if (visible(x, y)) activeStream.point(x, y);\n }\n\n function polygonInside() {\n var winding = 0;\n\n for (var i = 0, n = polygon.length; i < n; ++i) {\n for (var ring = polygon[i], j = 1, m = ring.length, point = ring[0], a0, a1, b0 = point[0], b1 = point[1]; j < m; ++j) {\n a0 = b0, a1 = b1, point = ring[j], b0 = point[0], b1 = point[1];\n if (a1 <= y1) { if (b1 > y1 && (b0 - a0) * (y1 - a1) > (b1 - a1) * (x0 - a0)) ++winding; }\n else { if (b1 <= y1 && (b0 - a0) * (y1 - a1) < (b1 - a1) * (x0 - a0)) --winding; }\n }\n }\n\n return winding;\n }\n\n // Buffer geometry within a polygon and then clip it en masse.\n function polygonStart() {\n activeStream = bufferStream, segments = [], polygon = [], clean = true;\n }\n\n function polygonEnd() {\n var startInside = polygonInside(),\n cleanInside = clean && startInside,\n visible = (segments = merge(segments)).length;\n if (cleanInside || visible) {\n stream.polygonStart();\n if (cleanInside) {\n stream.lineStart();\n interpolate(null, null, 1, stream);\n stream.lineEnd();\n }\n if (visible) {\n clipPolygon(segments, compareIntersection, startInside, interpolate, stream);\n }\n stream.polygonEnd();\n }\n activeStream = stream, segments = polygon = ring = null;\n }\n\n function lineStart() {\n clipStream.point = linePoint;\n if (polygon) polygon.push(ring = []);\n first = true;\n v_ = false;\n x_ = y_ = NaN;\n }\n\n // TODO rather than special-case polygons, simply handle them separately.\n // Ideally, coincident intersection points should be jittered to avoid\n // clipping issues.\n function lineEnd() {\n if (segments) {\n linePoint(x__, y__);\n if (v__ && v_) bufferStream.rejoin();\n segments.push(bufferStream.result());\n }\n clipStream.point = point;\n if (v_) activeStream.lineEnd();\n }\n\n function linePoint(x, y) {\n var v = visible(x, y);\n if (polygon) ring.push([x, y]);\n if (first) {\n x__ = x, y__ = y, v__ = v;\n first = false;\n if (v) {\n activeStream.lineStart();\n activeStream.point(x, y);\n }\n } else {\n if (v && v_) activeStream.point(x, y);\n else {\n var a = [x_ = Math.max(clipMin, Math.min(clipMax, x_)), y_ = Math.max(clipMin, Math.min(clipMax, y_))],\n b = [x = Math.max(clipMin, Math.min(clipMax, x)), y = Math.max(clipMin, Math.min(clipMax, y))];\n if (clipLine(a, b, x0, y0, x1, y1)) {\n if (!v_) {\n activeStream.lineStart();\n activeStream.point(a[0], a[1]);\n }\n activeStream.point(b[0], b[1]);\n if (!v) activeStream.lineEnd();\n clean = false;\n } else if (v) {\n activeStream.lineStart();\n activeStream.point(x, y);\n clean = false;\n }\n }\n }\n x_ = x, y_ = y, v_ = v;\n }\n\n return clipStream;\n };\n }\n\n function extent$1() {\n var x0 = 0,\n y0 = 0,\n x1 = 960,\n y1 = 500,\n cache,\n cacheStream,\n clip;\n\n return clip = {\n stream: function(stream) {\n return cache && cacheStream === stream ? cache : cache = clipExtent(x0, y0, x1, y1)(cacheStream = stream);\n },\n extent: function(_) {\n return arguments.length ? (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1], cache = cacheStream = null, clip) : [[x0, y0], [x1, y1]];\n }\n };\n }\n\n var lengthSum;\nvar lambda0$2;\nvar sinPhi0$1;\nvar cosPhi0$1;\n var lengthStream = {\n sphere: noop$2,\n point: noop$2,\n lineStart: lengthLineStart,\n lineEnd: noop$2,\n polygonStart: noop$2,\n polygonEnd: noop$2\n };\n\n function lengthLineStart() {\n lengthStream.point = lengthPointFirst;\n lengthStream.lineEnd = lengthLineEnd;\n }\n\n function lengthLineEnd() {\n lengthStream.point = lengthStream.lineEnd = noop$2;\n }\n\n function lengthPointFirst(lambda, phi) {\n lambda *= radians, phi *= radians;\n lambda0$2 = lambda, sinPhi0$1 = sin$1(phi), cosPhi0$1 = cos$1(phi);\n lengthStream.point = lengthPoint;\n }\n\n function lengthPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var sinPhi = sin$1(phi),\n cosPhi = cos$1(phi),\n delta = abs(lambda - lambda0$2),\n cosDelta = cos$1(delta),\n sinDelta = sin$1(delta),\n x = cosPhi * sinDelta,\n y = cosPhi0$1 * sinPhi - sinPhi0$1 * cosPhi * cosDelta,\n z = sinPhi0$1 * sinPhi + cosPhi0$1 * cosPhi * cosDelta;\n lengthSum.add(atan2(sqrt$1(x * x + y * y), z));\n lambda0$2 = lambda, sinPhi0$1 = sinPhi, cosPhi0$1 = cosPhi;\n }\n\n function length$2(object) {\n if (lengthSum) lengthSum.reset();\n else lengthSum = adder();\n stream(object, lengthStream);\n return +lengthSum;\n }\n\n var coordinates = [null, null];\nvar object$1 = {type: \"LineString\", coordinates: coordinates};\n function distance(a, b) {\n coordinates[0] = a;\n coordinates[1] = b;\n return length$2(object$1);\n }\n\n function graticuleX(y0, y1, dy) {\n var y = range(y0, y1 - epsilon$4, dy).concat(y1);\n return function(x) { return y.map(function(y) { return [x, y]; }); };\n }\n\n function graticuleY(x0, x1, dx) {\n var x = range(x0, x1 - epsilon$4, dx).concat(x1);\n return function(y) { return x.map(function(x) { return [x, y]; }); };\n }\n\n function graticule() {\n var x1, x0, X1, X0,\n y1, y0, Y1, Y0,\n dx = 10, dy = dx, DX = 90, DY = 360,\n x, y, X, Y,\n precision = 2.5;\n\n function graticule() {\n return {type: \"MultiLineString\", coordinates: lines()};\n }\n\n function lines() {\n return range(ceil(X0 / DX) * DX, X1, DX).map(X)\n .concat(range(ceil(Y0 / DY) * DY, Y1, DY).map(Y))\n .concat(range(ceil(x0 / dx) * dx, x1, dx).filter(function(x) { return abs(x % DX) > epsilon$4; }).map(x))\n .concat(range(ceil(y0 / dy) * dy, y1, dy).filter(function(y) { return abs(y % DY) > epsilon$4; }).map(y));\n }\n\n graticule.lines = function() {\n return lines().map(function(coordinates) { return {type: \"LineString\", coordinates: coordinates}; });\n };\n\n graticule.outline = function() {\n return {\n type: \"Polygon\",\n coordinates: [\n X(X0).concat(\n Y(Y1).slice(1),\n X(X1).reverse().slice(1),\n Y(Y0).reverse().slice(1))\n ]\n };\n };\n\n graticule.extent = function(_) {\n if (!arguments.length) return graticule.extentMinor();\n return graticule.extentMajor(_).extentMinor(_);\n };\n\n graticule.extentMajor = function(_) {\n if (!arguments.length) return [[X0, Y0], [X1, Y1]];\n X0 = +_[0][0], X1 = +_[1][0];\n Y0 = +_[0][1], Y1 = +_[1][1];\n if (X0 > X1) _ = X0, X0 = X1, X1 = _;\n if (Y0 > Y1) _ = Y0, Y0 = Y1, Y1 = _;\n return graticule.precision(precision);\n };\n\n graticule.extentMinor = function(_) {\n if (!arguments.length) return [[x0, y0], [x1, y1]];\n x0 = +_[0][0], x1 = +_[1][0];\n y0 = +_[0][1], y1 = +_[1][1];\n if (x0 > x1) _ = x0, x0 = x1, x1 = _;\n if (y0 > y1) _ = y0, y0 = y1, y1 = _;\n return graticule.precision(precision);\n };\n\n graticule.step = function(_) {\n if (!arguments.length) return graticule.stepMinor();\n return graticule.stepMajor(_).stepMinor(_);\n };\n\n graticule.stepMajor = function(_) {\n if (!arguments.length) return [DX, DY];\n DX = +_[0], DY = +_[1];\n return graticule;\n };\n\n graticule.stepMinor = function(_) {\n if (!arguments.length) return [dx, dy];\n dx = +_[0], dy = +_[1];\n return graticule;\n };\n\n graticule.precision = function(_) {\n if (!arguments.length) return precision;\n precision = +_;\n x = graticuleX(y0, y1, 90);\n y = graticuleY(x0, x1, precision);\n X = graticuleX(Y0, Y1, 90);\n Y = graticuleY(X0, X1, precision);\n return graticule;\n };\n\n return graticule\n .extentMajor([[-180, -90 + epsilon$4], [180, 90 - epsilon$4]])\n .extentMinor([[-180, -80 - epsilon$4], [180, 80 + epsilon$4]]);\n }\n\n function interpolate$2(a, b) {\n var x0 = a[0] * radians,\n y0 = a[1] * radians,\n x1 = b[0] * radians,\n y1 = b[1] * radians,\n cy0 = cos$1(y0),\n sy0 = sin$1(y0),\n cy1 = cos$1(y1),\n sy1 = sin$1(y1),\n kx0 = cy0 * cos$1(x0),\n ky0 = cy0 * sin$1(x0),\n kx1 = cy1 * cos$1(x1),\n ky1 = cy1 * sin$1(x1),\n d = 2 * asin$1(sqrt$1(haversin(y1 - y0) + cy0 * cy1 * haversin(x1 - x0))),\n k = sin$1(d);\n\n var interpolate = d ? function(t) {\n var B = sin$1(t *= d) / k,\n A = sin$1(d - t) / k,\n x = A * kx0 + B * kx1,\n y = A * ky0 + B * ky1,\n z = A * sy0 + B * sy1;\n return [\n atan2(y, x) * degrees$1,\n atan2(z, sqrt$1(x * x + y * y)) * degrees$1\n ];\n } : function() {\n return [x0 * degrees$1, y0 * degrees$1];\n };\n\n interpolate.distance = d;\n\n return interpolate;\n }\n\n function identity$7(x) {\n return x;\n }\n\nvar areaSum$1 = adder();\nvar areaRingSum$1 = adder();\n var x00;\n var y00;\nvar x0$1;\nvar y0$1;\n var areaStream$1 = {\n point: noop$2,\n lineStart: noop$2,\n lineEnd: noop$2,\n polygonStart: function() {\n areaStream$1.lineStart = areaRingStart$1;\n areaStream$1.lineEnd = areaRingEnd$1;\n },\n polygonEnd: function() {\n areaStream$1.lineStart = areaStream$1.lineEnd = areaStream$1.point = noop$2;\n areaSum$1.add(abs(areaRingSum$1));\n areaRingSum$1.reset();\n },\n result: function() {\n var area = areaSum$1 / 2;\n areaSum$1.reset();\n return area;\n }\n };\n\n function areaRingStart$1() {\n areaStream$1.point = areaPointFirst$1;\n }\n\n function areaPointFirst$1(x, y) {\n areaStream$1.point = areaPoint$1;\n x00 = x0$1 = x, y00 = y0$1 = y;\n }\n\n function areaPoint$1(x, y) {\n areaRingSum$1.add(y0$1 * x - x0$1 * y);\n x0$1 = x, y0$1 = y;\n }\n\n function areaRingEnd$1() {\n areaPoint$1(x00, y00);\n }\n\nvar x0$2 = Infinity;\nvar y0$2 = x0$2;\n var x1 = -x0$2;\n var y1 = x1;\n var boundsStream$1 = {\n point: boundsPoint$1,\n lineStart: noop$2,\n lineEnd: noop$2,\n polygonStart: noop$2,\n polygonEnd: noop$2,\n result: function() {\n var bounds = [[x0$2, y0$2], [x1, y1]];\n x1 = y1 = -(y0$2 = x0$2 = Infinity);\n return bounds;\n }\n };\n\n function boundsPoint$1(x, y) {\n if (x < x0$2) x0$2 = x;\n if (x > x1) x1 = x;\n if (y < y0$2) y0$2 = y;\n if (y > y1) y1 = y;\n }\n\nvar X0$1 = 0;\nvar Y0$1 = 0;\nvar Z0$1 = 0;\nvar X1$1 = 0;\nvar Y1$1 = 0;\nvar Z1$1 = 0;\nvar X2$1 = 0;\nvar Y2$1 = 0;\nvar Z2$1 = 0;\nvar x00$1;\nvar y00$1;\nvar x0$3;\nvar y0$3;\n var centroidStream$1 = {\n point: centroidPoint$1,\n lineStart: centroidLineStart$1,\n lineEnd: centroidLineEnd$1,\n polygonStart: function() {\n centroidStream$1.lineStart = centroidRingStart$1;\n centroidStream$1.lineEnd = centroidRingEnd$1;\n },\n polygonEnd: function() {\n centroidStream$1.point = centroidPoint$1;\n centroidStream$1.lineStart = centroidLineStart$1;\n centroidStream$1.lineEnd = centroidLineEnd$1;\n },\n result: function() {\n var centroid = Z2$1 ? [X2$1 / Z2$1, Y2$1 / Z2$1]\n : Z1$1 ? [X1$1 / Z1$1, Y1$1 / Z1$1]\n : Z0$1 ? [X0$1 / Z0$1, Y0$1 / Z0$1]\n : [NaN, NaN];\n X0$1 = Y0$1 = Z0$1 =\n X1$1 = Y1$1 = Z1$1 =\n X2$1 = Y2$1 = Z2$1 = 0;\n return centroid;\n }\n };\n\n function centroidPoint$1(x, y) {\n X0$1 += x;\n Y0$1 += y;\n ++Z0$1;\n }\n\n function centroidLineStart$1() {\n centroidStream$1.point = centroidPointFirstLine;\n }\n\n function centroidPointFirstLine(x, y) {\n centroidStream$1.point = centroidPointLine;\n centroidPoint$1(x0$3 = x, y0$3 = y);\n }\n\n function centroidPointLine(x, y) {\n var dx = x - x0$3, dy = y - y0$3, z = sqrt$1(dx * dx + dy * dy);\n X1$1 += z * (x0$3 + x) / 2;\n Y1$1 += z * (y0$3 + y) / 2;\n Z1$1 += z;\n centroidPoint$1(x0$3 = x, y0$3 = y);\n }\n\n function centroidLineEnd$1() {\n centroidStream$1.point = centroidPoint$1;\n }\n\n function centroidRingStart$1() {\n centroidStream$1.point = centroidPointFirstRing;\n }\n\n function centroidRingEnd$1() {\n centroidPointRing(x00$1, y00$1);\n }\n\n function centroidPointFirstRing(x, y) {\n centroidStream$1.point = centroidPointRing;\n centroidPoint$1(x00$1 = x0$3 = x, y00$1 = y0$3 = y);\n }\n\n function centroidPointRing(x, y) {\n var dx = x - x0$3,\n dy = y - y0$3,\n z = sqrt$1(dx * dx + dy * dy);\n\n X1$1 += z * (x0$3 + x) / 2;\n Y1$1 += z * (y0$3 + y) / 2;\n Z1$1 += z;\n\n z = y0$3 * x - x0$3 * y;\n X2$1 += z * (x0$3 + x);\n Y2$1 += z * (y0$3 + y);\n Z2$1 += z * 3;\n centroidPoint$1(x0$3 = x, y0$3 = y);\n }\n\n function PathContext(context) {\n var pointRadius = 4.5;\n\n var stream = {\n point: point,\n\n // While inside a line, override point to moveTo then lineTo.\n lineStart: function() { stream.point = pointLineStart; },\n lineEnd: lineEnd,\n\n // While inside a polygon, override lineEnd to closePath.\n polygonStart: function() { stream.lineEnd = lineEndPolygon; },\n polygonEnd: function() { stream.lineEnd = lineEnd; stream.point = point; },\n\n pointRadius: function(_) {\n pointRadius = _;\n return stream;\n },\n\n result: noop$2\n };\n\n function point(x, y) {\n context.moveTo(x + pointRadius, y);\n context.arc(x, y, pointRadius, 0, tau$4);\n }\n\n function pointLineStart(x, y) {\n context.moveTo(x, y);\n stream.point = pointLine;\n }\n\n function pointLine(x, y) {\n context.lineTo(x, y);\n }\n\n function lineEnd() {\n stream.point = point;\n }\n\n function lineEndPolygon() {\n context.closePath();\n }\n\n return stream;\n }\n\n function PathString() {\n var pointCircle = circle$2(4.5),\n string = [];\n\n var stream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() {\n stream.lineEnd = lineEndPolygon;\n },\n polygonEnd: function() {\n stream.lineEnd = lineEnd;\n stream.point = point;\n },\n pointRadius: function(_) {\n pointCircle = circle$2(_);\n return stream;\n },\n result: function() {\n if (string.length) {\n var result = string.join(\"\");\n string = [];\n return result;\n }\n }\n };\n\n function point(x, y) {\n string.push(\"M\", x, \",\", y, pointCircle);\n }\n\n function pointLineStart(x, y) {\n string.push(\"M\", x, \",\", y);\n stream.point = pointLine;\n }\n\n function pointLine(x, y) {\n string.push(\"L\", x, \",\", y);\n }\n\n function lineStart() {\n stream.point = pointLineStart;\n }\n\n function lineEnd() {\n stream.point = point;\n }\n\n function lineEndPolygon() {\n string.push(\"Z\");\n }\n\n return stream;\n }\n\n function circle$2(radius) {\n return \"m0,\" + radius\n + \"a\" + radius + \",\" + radius + \" 0 1,1 0,\" + -2 * radius\n + \"a\" + radius + \",\" + radius + \" 0 1,1 0,\" + 2 * radius\n + \"z\";\n }\n\n function index$3() {\n var pointRadius = 4.5,\n projection,\n projectionStream,\n context,\n contextStream;\n\n function path(object) {\n if (object) {\n if (typeof pointRadius === \"function\") contextStream.pointRadius(+pointRadius.apply(this, arguments));\n stream(object, projectionStream(contextStream));\n }\n return contextStream.result();\n }\n\n path.area = function(object) {\n stream(object, projectionStream(areaStream$1));\n return areaStream$1.result();\n };\n\n path.bounds = function(object) {\n stream(object, projectionStream(boundsStream$1));\n return boundsStream$1.result();\n };\n\n path.centroid = function(object) {\n stream(object, projectionStream(centroidStream$1));\n return centroidStream$1.result();\n };\n\n path.projection = function(_) {\n return arguments.length ? (projectionStream = (projection = _) == null ? identity$7 : _.stream, path) : projection;\n };\n\n path.context = function(_) {\n if (!arguments.length) return context;\n contextStream = (context = _) == null ? new PathString : new PathContext(_);\n if (typeof pointRadius !== \"function\") contextStream.pointRadius(pointRadius);\n return path;\n };\n\n path.pointRadius = function(_) {\n if (!arguments.length) return pointRadius;\n pointRadius = typeof _ === \"function\" ? _ : (contextStream.pointRadius(+_), +_);\n return path;\n };\n\n return path.projection(null).context(null);\n }\n\n var sum$2 = adder();\n\n function polygonContains(polygon, point) {\n var lambda = point[0],\n phi = point[1],\n normal = [sin$1(lambda), -cos$1(lambda), 0],\n angle = 0,\n winding = 0;\n\n for (var i = 0, n = polygon.length; i < n; ++i) {\n if (!(m = (ring = polygon[i]).length)) continue;\n var ring,\n m,\n point0 = ring[m - 1],\n lambda0 = point0[0],\n phi0 = point0[1] / 2 + quarterPi,\n sinPhi0 = sin$1(phi0),\n cosPhi0 = cos$1(phi0);\n\n for (var j = 0; j < m; ++j, lambda0 = lambda1, sinPhi0 = sinPhi1, cosPhi0 = cosPhi1, point0 = point1) {\n var point1 = ring[j],\n lambda1 = point1[0],\n phi1 = point1[1] / 2 + quarterPi,\n sinPhi1 = sin$1(phi1),\n cosPhi1 = cos$1(phi1),\n delta = lambda1 - lambda0,\n sign = delta >= 0 ? 1 : -1,\n absDelta = sign * delta,\n antimeridian = absDelta > pi$4,\n k = sinPhi0 * sinPhi1;\n\n sum$2.add(atan2(k * sign * sin$1(absDelta), cosPhi0 * cosPhi1 + k * cos$1(absDelta)));\n angle += antimeridian ? delta + sign * tau$4 : delta;\n\n // Are the longitudes either side of the point’s meridian (lambda),\n // and are the latitudes smaller than the parallel (phi)?\n if (antimeridian ^ lambda0 >= lambda ^ lambda1 >= lambda) {\n var arc = cartesianCross(cartesian(point0), cartesian(point1));\n cartesianNormalizeInPlace(arc);\n var intersection = cartesianCross(normal, arc);\n cartesianNormalizeInPlace(intersection);\n var phiArc = (antimeridian ^ delta >= 0 ? -1 : 1) * asin$1(intersection[2]);\n if (phi > phiArc || phi === phiArc && (arc[0] || arc[1])) {\n winding += antimeridian ^ delta >= 0 ? 1 : -1;\n }\n }\n }\n }\n\n // First, determine whether the South pole is inside or outside:\n //\n // It is inside if:\n // * the polygon winds around it in a clockwise direction.\n // * the polygon does not (cumulatively) wind around it, but has a negative\n // (counter-clockwise) area.\n //\n // Second, count the (signed) number of times a segment crosses a lambda\n // from the point to the South pole. If it is zero, then the point is the\n // same side as the South pole.\n\n var contains = (angle < -epsilon$4 || angle < epsilon$4 && sum$2 < -epsilon$4) ^ (winding & 1);\n sum$2.reset();\n return contains;\n }\n\n function clip(pointVisible, clipLine, interpolate, start) {\n return function(rotate, sink) {\n var line = clipLine(sink),\n rotatedStart = rotate.invert(start[0], start[1]),\n ringBuffer = clipBuffer(),\n ringSink = clipLine(ringBuffer),\n polygonStarted = false,\n polygon,\n segments,\n ring;\n\n var clip = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() {\n clip.point = pointRing;\n clip.lineStart = ringStart;\n clip.lineEnd = ringEnd;\n segments = [];\n polygon = [];\n },\n polygonEnd: function() {\n clip.point = point;\n clip.lineStart = lineStart;\n clip.lineEnd = lineEnd;\n segments = merge(segments);\n var startInside = polygonContains(polygon, rotatedStart);\n if (segments.length) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n clipPolygon(segments, compareIntersection, startInside, interpolate, sink);\n } else if (startInside) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n sink.lineStart();\n interpolate(null, null, 1, sink);\n sink.lineEnd();\n }\n if (polygonStarted) sink.polygonEnd(), polygonStarted = false;\n segments = polygon = null;\n },\n sphere: function() {\n sink.polygonStart();\n sink.lineStart();\n interpolate(null, null, 1, sink);\n sink.lineEnd();\n sink.polygonEnd();\n }\n };\n\n function point(lambda, phi) {\n var point = rotate(lambda, phi);\n if (pointVisible(lambda = point[0], phi = point[1])) sink.point(lambda, phi);\n }\n\n function pointLine(lambda, phi) {\n var point = rotate(lambda, phi);\n line.point(point[0], point[1]);\n }\n\n function lineStart() {\n clip.point = pointLine;\n line.lineStart();\n }\n\n function lineEnd() {\n clip.point = point;\n line.lineEnd();\n }\n\n function pointRing(lambda, phi) {\n ring.push([lambda, phi]);\n var point = rotate(lambda, phi);\n ringSink.point(point[0], point[1]);\n }\n\n function ringStart() {\n ringSink.lineStart();\n ring = [];\n }\n\n function ringEnd() {\n pointRing(ring[0][0], ring[0][1]);\n ringSink.lineEnd();\n\n var clean = ringSink.clean(),\n ringSegments = ringBuffer.result(),\n i, n = ringSegments.length, m,\n segment,\n point;\n\n ring.pop();\n polygon.push(ring);\n ring = null;\n\n if (!n) return;\n\n // No intersections.\n if (clean & 1) {\n segment = ringSegments[0];\n if ((m = segment.length - 1) > 0) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n sink.lineStart();\n for (i = 0; i < m; ++i) sink.point((point = segment[i])[0], point[1]);\n sink.lineEnd();\n }\n return;\n }\n\n // Rejoin connected segments.\n // TODO reuse ringBuffer.rejoin()?\n if (n > 1 && clean & 2) ringSegments.push(ringSegments.pop().concat(ringSegments.shift()));\n\n segments.push(ringSegments.filter(validSegment));\n }\n\n return clip;\n };\n }\n\n function validSegment(segment) {\n return segment.length > 1;\n }\n\n // Intersections are sorted along the clip edge. For both antimeridian cutting\n // and circle clipping, the same comparison is used.\n function compareIntersection(a, b) {\n return ((a = a.x)[0] < 0 ? a[1] - halfPi$3 - epsilon$4 : halfPi$3 - a[1])\n - ((b = b.x)[0] < 0 ? b[1] - halfPi$3 - epsilon$4 : halfPi$3 - b[1]);\n }\n\n var clipAntimeridian = clip(\n function() { return true; },\n clipAntimeridianLine,\n clipAntimeridianInterpolate,\n [-pi$4, -halfPi$3]\n );\n\n // Takes a line and cuts into visible segments. Return values: 0 - there were\n // intersections or the line was empty; 1 - no intersections; 2 - there were\n // intersections, and the first and last segments should be rejoined.\n function clipAntimeridianLine(stream) {\n var lambda0 = NaN,\n phi0 = NaN,\n sign0 = NaN,\n clean; // no intersections\n\n return {\n lineStart: function() {\n stream.lineStart();\n clean = 1;\n },\n point: function(lambda1, phi1) {\n var sign1 = lambda1 > 0 ? pi$4 : -pi$4,\n delta = abs(lambda1 - lambda0);\n if (abs(delta - pi$4) < epsilon$4) { // line crosses a pole\n stream.point(lambda0, phi0 = (phi0 + phi1) / 2 > 0 ? halfPi$3 : -halfPi$3);\n stream.point(sign0, phi0);\n stream.lineEnd();\n stream.lineStart();\n stream.point(sign1, phi0);\n stream.point(lambda1, phi0);\n clean = 0;\n } else if (sign0 !== sign1 && delta >= pi$4) { // line crosses antimeridian\n if (abs(lambda0 - sign0) < epsilon$4) lambda0 -= sign0 * epsilon$4; // handle degeneracies\n if (abs(lambda1 - sign1) < epsilon$4) lambda1 -= sign1 * epsilon$4;\n phi0 = clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1);\n stream.point(sign0, phi0);\n stream.lineEnd();\n stream.lineStart();\n stream.point(sign1, phi0);\n clean = 0;\n }\n stream.point(lambda0 = lambda1, phi0 = phi1);\n sign0 = sign1;\n },\n lineEnd: function() {\n stream.lineEnd();\n lambda0 = phi0 = NaN;\n },\n clean: function() {\n return 2 - clean; // if intersections, rejoin first and last segments\n }\n };\n }\n\n function clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1) {\n var cosPhi0,\n cosPhi1,\n sinLambda0Lambda1 = sin$1(lambda0 - lambda1);\n return abs(sinLambda0Lambda1) > epsilon$4\n ? atan((sin$1(phi0) * (cosPhi1 = cos$1(phi1)) * sin$1(lambda1)\n - sin$1(phi1) * (cosPhi0 = cos$1(phi0)) * sin$1(lambda0))\n / (cosPhi0 * cosPhi1 * sinLambda0Lambda1))\n : (phi0 + phi1) / 2;\n }\n\n function clipAntimeridianInterpolate(from, to, direction, stream) {\n var phi;\n if (from == null) {\n phi = direction * halfPi$3;\n stream.point(-pi$4, phi);\n stream.point(0, phi);\n stream.point(pi$4, phi);\n stream.point(pi$4, 0);\n stream.point(pi$4, -phi);\n stream.point(0, -phi);\n stream.point(-pi$4, -phi);\n stream.point(-pi$4, 0);\n stream.point(-pi$4, phi);\n } else if (abs(from[0] - to[0]) > epsilon$4) {\n var lambda = from[0] < to[0] ? pi$4 : -pi$4;\n phi = direction * lambda / 2;\n stream.point(-lambda, phi);\n stream.point(0, phi);\n stream.point(lambda, phi);\n } else {\n stream.point(to[0], to[1]);\n }\n }\n\n function clipCircle(radius, delta) {\n var cr = cos$1(radius),\n smallRadius = cr > 0,\n notHemisphere = abs(cr) > epsilon$4; // TODO optimise for this common case\n\n function interpolate(from, to, direction, stream) {\n circleStream(stream, radius, delta, direction, from, to);\n }\n\n function visible(lambda, phi) {\n return cos$1(lambda) * cos$1(phi) > cr;\n }\n\n // Takes a line and cuts into visible segments. Return values used for polygon\n // clipping: 0 - there were intersections or the line was empty; 1 - no\n // intersections 2 - there were intersections, and the first and last segments\n // should be rejoined.\n function clipLine(stream) {\n var point0, // previous point\n c0, // code for previous point\n v0, // visibility of previous point\n v00, // visibility of first point\n clean; // no intersections\n return {\n lineStart: function() {\n v00 = v0 = false;\n clean = 1;\n },\n point: function(lambda, phi) {\n var point1 = [lambda, phi],\n point2,\n v = visible(lambda, phi),\n c = smallRadius\n ? v ? 0 : code(lambda, phi)\n : v ? code(lambda + (lambda < 0 ? pi$4 : -pi$4), phi) : 0;\n if (!point0 && (v00 = v0 = v)) stream.lineStart();\n // Handle degeneracies.\n // TODO ignore if not clipping polygons.\n if (v !== v0) {\n point2 = intersect(point0, point1);\n if (pointEqual(point0, point2) || pointEqual(point1, point2)) {\n point1[0] += epsilon$4;\n point1[1] += epsilon$4;\n v = visible(point1[0], point1[1]);\n }\n }\n if (v !== v0) {\n clean = 0;\n if (v) {\n // outside going in\n stream.lineStart();\n point2 = intersect(point1, point0);\n stream.point(point2[0], point2[1]);\n } else {\n // inside going out\n point2 = intersect(point0, point1);\n stream.point(point2[0], point2[1]);\n stream.lineEnd();\n }\n point0 = point2;\n } else if (notHemisphere && point0 && smallRadius ^ v) {\n var t;\n // If the codes for two points are different, or are both zero,\n // and there this segment intersects with the small circle.\n if (!(c & c0) && (t = intersect(point1, point0, true))) {\n clean = 0;\n if (smallRadius) {\n stream.lineStart();\n stream.point(t[0][0], t[0][1]);\n stream.point(t[1][0], t[1][1]);\n stream.lineEnd();\n } else {\n stream.point(t[1][0], t[1][1]);\n stream.lineEnd();\n stream.lineStart();\n stream.point(t[0][0], t[0][1]);\n }\n }\n }\n if (v && (!point0 || !pointEqual(point0, point1))) {\n stream.point(point1[0], point1[1]);\n }\n point0 = point1, v0 = v, c0 = c;\n },\n lineEnd: function() {\n if (v0) stream.lineEnd();\n point0 = null;\n },\n // Rejoin first and last segments if there were intersections and the first\n // and last points were visible.\n clean: function() {\n return clean | ((v00 && v0) << 1);\n }\n };\n }\n\n // Intersects the great circle between a and b with the clip circle.\n function intersect(a, b, two) {\n var pa = cartesian(a),\n pb = cartesian(b);\n\n // We have two planes, n1.p = d1 and n2.p = d2.\n // Find intersection line p(t) = c1 n1 + c2 n2 + t (n1 ⨯ n2).\n var n1 = [1, 0, 0], // normal\n n2 = cartesianCross(pa, pb),\n n2n2 = cartesianDot(n2, n2),\n n1n2 = n2[0], // cartesianDot(n1, n2),\n determinant = n2n2 - n1n2 * n1n2;\n\n // Two polar points.\n if (!determinant) return !two && a;\n\n var c1 = cr * n2n2 / determinant,\n c2 = -cr * n1n2 / determinant,\n n1xn2 = cartesianCross(n1, n2),\n A = cartesianScale(n1, c1),\n B = cartesianScale(n2, c2);\n cartesianAddInPlace(A, B);\n\n // Solve |p(t)|^2 = 1.\n var u = n1xn2,\n w = cartesianDot(A, u),\n uu = cartesianDot(u, u),\n t2 = w * w - uu * (cartesianDot(A, A) - 1);\n\n if (t2 < 0) return;\n\n var t = sqrt$1(t2),\n q = cartesianScale(u, (-w - t) / uu);\n cartesianAddInPlace(q, A);\n q = spherical(q);\n\n if (!two) return q;\n\n // Two intersection points.\n var lambda0 = a[0],\n lambda1 = b[0],\n phi0 = a[1],\n phi1 = b[1],\n z;\n\n if (lambda1 < lambda0) z = lambda0, lambda0 = lambda1, lambda1 = z;\n\n var delta = lambda1 - lambda0,\n polar = abs(delta - pi$4) < epsilon$4,\n meridian = polar || delta < epsilon$4;\n\n if (!polar && phi1 < phi0) z = phi0, phi0 = phi1, phi1 = z;\n\n // Check that the first point is between a and b.\n if (meridian\n ? polar\n ? phi0 + phi1 > 0 ^ q[1] < (abs(q[0] - lambda0) < epsilon$4 ? phi0 : phi1)\n : phi0 <= q[1] && q[1] <= phi1\n : delta > pi$4 ^ (lambda0 <= q[0] && q[0] <= lambda1)) {\n var q1 = cartesianScale(u, (-w + t) / uu);\n cartesianAddInPlace(q1, A);\n return [q, spherical(q1)];\n }\n }\n\n // Generates a 4-bit vector representing the location of a point relative to\n // the small circle's bounding box.\n function code(lambda, phi) {\n var r = smallRadius ? radius : pi$4 - radius,\n code = 0;\n if (lambda < -r) code |= 1; // left\n else if (lambda > r) code |= 2; // right\n if (phi < -r) code |= 4; // below\n else if (phi > r) code |= 8; // above\n return code;\n }\n\n return clip(visible, clipLine, interpolate, smallRadius ? [0, -radius] : [-pi$4, radius - pi$4]);\n }\n\n function transform$1(prototype) {\n return {\n stream: transform$2(prototype)\n };\n }\n\n function transform$2(prototype) {\n function T() {}\n var p = T.prototype = Object.create(Transform$1.prototype);\n for (var k in prototype) p[k] = prototype[k];\n return function(stream) {\n var t = new T;\n t.stream = stream;\n return t;\n };\n }\n\n function Transform$1() {}\n\n Transform$1.prototype = {\n point: function(x, y) { this.stream.point(x, y); },\n sphere: function() { this.stream.sphere(); },\n lineStart: function() { this.stream.lineStart(); },\n lineEnd: function() { this.stream.lineEnd(); },\n polygonStart: function() { this.stream.polygonStart(); },\n polygonEnd: function() { this.stream.polygonEnd(); }\n };\n\n var maxDepth = 16;\n var cosMinDistance = cos$1(30 * radians);\n // cos(minimum angular distance)\n\n function resample(project, delta2) {\n return +delta2 ? resample$1(project, delta2) : resampleNone(project);\n }\n\n function resampleNone(project) {\n return transform$2({\n point: function(x, y) {\n x = project(x, y);\n this.stream.point(x[0], x[1]);\n }\n });\n }\n\n function resample$1(project, delta2) {\n\n function resampleLineTo(x0, y0, lambda0, a0, b0, c0, x1, y1, lambda1, a1, b1, c1, depth, stream) {\n var dx = x1 - x0,\n dy = y1 - y0,\n d2 = dx * dx + dy * dy;\n if (d2 > 4 * delta2 && depth--) {\n var a = a0 + a1,\n b = b0 + b1,\n c = c0 + c1,\n m = sqrt$1(a * a + b * b + c * c),\n phi2 = asin$1(c /= m),\n lambda2 = abs(abs(c) - 1) < epsilon$4 || abs(lambda0 - lambda1) < epsilon$4 ? (lambda0 + lambda1) / 2 : atan2(b, a),\n p = project(lambda2, phi2),\n x2 = p[0],\n y2 = p[1],\n dx2 = x2 - x0,\n dy2 = y2 - y0,\n dz = dy * dx2 - dx * dy2;\n if (dz * dz / d2 > delta2 // perpendicular projected distance\n || abs((dx * dx2 + dy * dy2) / d2 - 0.5) > 0.3 // midpoint close to an end\n || a0 * a1 + b0 * b1 + c0 * c1 < cosMinDistance) { // angular distance\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x2, y2, lambda2, a /= m, b /= m, c, depth, stream);\n stream.point(x2, y2);\n resampleLineTo(x2, y2, lambda2, a, b, c, x1, y1, lambda1, a1, b1, c1, depth, stream);\n }\n }\n }\n return function(stream) {\n var lambda00, x00, y00, a00, b00, c00, // first point\n lambda0, x0, y0, a0, b0, c0; // previous point\n\n var resampleStream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() { stream.polygonStart(); resampleStream.lineStart = ringStart; },\n polygonEnd: function() { stream.polygonEnd(); resampleStream.lineStart = lineStart; }\n };\n\n function point(x, y) {\n x = project(x, y);\n stream.point(x[0], x[1]);\n }\n\n function lineStart() {\n x0 = NaN;\n resampleStream.point = linePoint;\n stream.lineStart();\n }\n\n function linePoint(lambda, phi) {\n var c = cartesian([lambda, phi]), p = project(lambda, phi);\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x0 = p[0], y0 = p[1], lambda0 = lambda, a0 = c[0], b0 = c[1], c0 = c[2], maxDepth, stream);\n stream.point(x0, y0);\n }\n\n function lineEnd() {\n resampleStream.point = point;\n stream.lineEnd();\n }\n\n function ringStart() {\n lineStart();\n resampleStream.point = ringPoint;\n resampleStream.lineEnd = ringEnd;\n }\n\n function ringPoint(lambda, phi) {\n linePoint(lambda00 = lambda, phi), x00 = x0, y00 = y0, a00 = a0, b00 = b0, c00 = c0;\n resampleStream.point = linePoint;\n }\n\n function ringEnd() {\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x00, y00, lambda00, a00, b00, c00, maxDepth, stream);\n resampleStream.lineEnd = lineEnd;\n lineEnd();\n }\n\n return resampleStream;\n };\n }\n\n var transformRadians = transform$2({\n point: function(x, y) {\n this.stream.point(x * radians, y * radians);\n }\n });\n\n function projection(project) {\n return projectionMutator(function() { return project; })();\n }\n\n function projectionMutator(projectAt) {\n var project,\n k = 150, // scale\n x = 480, y = 250, // translate\n dx, dy, lambda = 0, phi = 0, // center\n deltaLambda = 0, deltaPhi = 0, deltaGamma = 0, rotate, projectRotate, // rotate\n theta = null, preclip = clipAntimeridian, // clip angle\n x0 = null, y0, x1, y1, postclip = identity$7, // clip extent\n delta2 = 0.5, projectResample = resample(projectTransform, delta2), // precision\n cache,\n cacheStream;\n\n function projection(point) {\n point = projectRotate(point[0] * radians, point[1] * radians);\n return [point[0] * k + dx, dy - point[1] * k];\n }\n\n function invert(point) {\n point = projectRotate.invert((point[0] - dx) / k, (dy - point[1]) / k);\n return point && [point[0] * degrees$1, point[1] * degrees$1];\n }\n\n function projectTransform(x, y) {\n return x = project(x, y), [x[0] * k + dx, dy - x[1] * k];\n }\n\n projection.stream = function(stream) {\n return cache && cacheStream === stream ? cache : cache = transformRadians(preclip(rotate, projectResample(postclip(cacheStream = stream))));\n };\n\n projection.clipAngle = function(_) {\n return arguments.length ? (preclip = +_ ? clipCircle(theta = _ * radians, 6 * radians) : (theta = null, clipAntimeridian), reset()) : theta * degrees$1;\n };\n\n projection.clipExtent = function(_) {\n return arguments.length ? (postclip = _ == null ? (x0 = y0 = x1 = y1 = null, identity$7) : clipExtent(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n };\n\n projection.scale = function(_) {\n return arguments.length ? (k = +_, recenter()) : k;\n };\n\n projection.translate = function(_) {\n return arguments.length ? (x = +_[0], y = +_[1], recenter()) : [x, y];\n };\n\n projection.center = function(_) {\n return arguments.length ? (lambda = _[0] % 360 * radians, phi = _[1] % 360 * radians, recenter()) : [lambda * degrees$1, phi * degrees$1];\n };\n\n projection.rotate = function(_) {\n return arguments.length ? (deltaLambda = _[0] % 360 * radians, deltaPhi = _[1] % 360 * radians, deltaGamma = _.length > 2 ? _[2] % 360 * radians : 0, recenter()) : [deltaLambda * degrees$1, deltaPhi * degrees$1, deltaGamma * degrees$1];\n };\n\n projection.precision = function(_) {\n return arguments.length ? (projectResample = resample(projectTransform, delta2 = _ * _), reset()) : sqrt$1(delta2);\n };\n\n function recenter() {\n projectRotate = compose(rotate = rotateRadians(deltaLambda, deltaPhi, deltaGamma), project);\n var center = project(lambda, phi);\n dx = x - center[0] * k;\n dy = y + center[1] * k;\n return reset();\n }\n\n function reset() {\n cache = cacheStream = null;\n return projection;\n }\n\n return function() {\n project = projectAt.apply(this, arguments);\n projection.invert = project.invert && invert;\n return recenter();\n };\n }\n\n function conicProjection(projectAt) {\n var phi0 = 0,\n phi1 = pi$4 / 3,\n m = projectionMutator(projectAt),\n p = m(phi0, phi1);\n\n p.parallels = function(_) {\n return arguments.length ? m(phi0 = _[0] * radians, phi1 = _[1] * radians) : [phi0 * degrees$1, phi1 * degrees$1];\n };\n\n return p;\n }\n\n function conicEqualAreaRaw(y0, y1) {\n var sy0 = sin$1(y0),\n n = (sy0 + sin$1(y1)) / 2,\n c = 1 + sy0 * (2 * n - sy0),\n r0 = sqrt$1(c) / n;\n\n function project(x, y) {\n var r = sqrt$1(c - 2 * n * sin$1(y)) / n;\n return [r * sin$1(x *= n), r0 - r * cos$1(x)];\n }\n\n project.invert = function(x, y) {\n var r0y = r0 - y;\n return [atan2(x, r0y) / n, asin$1((c - (x * x + r0y * r0y) * n * n) / (2 * n))];\n };\n\n return project;\n }\n\n function conicEqualArea() {\n return conicProjection(conicEqualAreaRaw)\n .scale(155.424)\n .center([0, 33.6442]);\n }\n\n function albers() {\n return conicEqualArea()\n .parallels([29.5, 45.5])\n .scale(1070)\n .translate([480, 250])\n .rotate([96, 0])\n .center([-0.6, 38.7]);\n }\n\n // The projections must have mutually exclusive clip regions on the sphere,\n // as this will avoid emitting interleaving lines and polygons.\n function multiplex(streams) {\n var n = streams.length;\n return {\n point: function(x, y) { var i = -1; while (++i < n) streams[i].point(x, y); },\n sphere: function() { var i = -1; while (++i < n) streams[i].sphere(); },\n lineStart: function() { var i = -1; while (++i < n) streams[i].lineStart(); },\n lineEnd: function() { var i = -1; while (++i < n) streams[i].lineEnd(); },\n polygonStart: function() { var i = -1; while (++i < n) streams[i].polygonStart(); },\n polygonEnd: function() { var i = -1; while (++i < n) streams[i].polygonEnd(); }\n };\n }\n\n // A composite projection for the United States, configured by default for\n // 960×500. The projection also works quite well at 960×600 if you change the\n // scale to 1285 and adjust the translate accordingly. The set of standard\n // parallels for each region comes from USGS, which is published here:\n // http://egsc.usgs.gov/isb/pubs/MapProjections/projections.html#albers\n function albersUsa() {\n var cache,\n cacheStream,\n lower48 = albers(), lower48Point,\n alaska = conicEqualArea().rotate([154, 0]).center([-2, 58.5]).parallels([55, 65]), alaskaPoint, // EPSG:3338\n hawaii = conicEqualArea().rotate([157, 0]).center([-3, 19.9]).parallels([8, 18]), hawaiiPoint, // ESRI:102007\n point, pointStream = {point: function(x, y) { point = [x, y]; }};\n\n function albersUsa(coordinates) {\n var x = coordinates[0], y = coordinates[1];\n return point = null,\n (lower48Point.point(x, y), point)\n || (alaskaPoint.point(x, y), point)\n || (hawaiiPoint.point(x, y), point);\n }\n\n albersUsa.invert = function(coordinates) {\n var k = lower48.scale(),\n t = lower48.translate(),\n x = (coordinates[0] - t[0]) / k,\n y = (coordinates[1] - t[1]) / k;\n return (y >= 0.120 && y < 0.234 && x >= -0.425 && x < -0.214 ? alaska\n : y >= 0.166 && y < 0.234 && x >= -0.214 && x < -0.115 ? hawaii\n : lower48).invert(coordinates);\n };\n\n albersUsa.stream = function(stream) {\n return cache && cacheStream === stream ? cache : cache = multiplex([lower48.stream(cacheStream = stream), alaska.stream(stream), hawaii.stream(stream)]);\n };\n\n albersUsa.precision = function(_) {\n if (!arguments.length) return lower48.precision();\n lower48.precision(_), alaska.precision(_), hawaii.precision(_);\n return albersUsa;\n };\n\n albersUsa.scale = function(_) {\n if (!arguments.length) return lower48.scale();\n lower48.scale(_), alaska.scale(_ * 0.35), hawaii.scale(_);\n return albersUsa.translate(lower48.translate());\n };\n\n albersUsa.translate = function(_) {\n if (!arguments.length) return lower48.translate();\n var k = lower48.scale(), x = +_[0], y = +_[1];\n\n lower48Point = lower48\n .translate(_)\n .clipExtent([[x - 0.455 * k, y - 0.238 * k], [x + 0.455 * k, y + 0.238 * k]])\n .stream(pointStream);\n\n alaskaPoint = alaska\n .translate([x - 0.307 * k, y + 0.201 * k])\n .clipExtent([[x - 0.425 * k + epsilon$4, y + 0.120 * k + epsilon$4], [x - 0.214 * k - epsilon$4, y + 0.234 * k - epsilon$4]])\n .stream(pointStream);\n\n hawaiiPoint = hawaii\n .translate([x - 0.205 * k, y + 0.212 * k])\n .clipExtent([[x - 0.214 * k + epsilon$4, y + 0.166 * k + epsilon$4], [x - 0.115 * k - epsilon$4, y + 0.234 * k - epsilon$4]])\n .stream(pointStream);\n\n return albersUsa;\n };\n\n return albersUsa.scale(1070);\n }\n\n function azimuthalRaw(scale) {\n return function(x, y) {\n var cx = cos$1(x),\n cy = cos$1(y),\n k = scale(cx * cy);\n return [\n k * cy * sin$1(x),\n k * sin$1(y)\n ];\n }\n }\n\n function azimuthalInvert(angle) {\n return function(x, y) {\n var z = sqrt$1(x * x + y * y),\n c = angle(z),\n sc = sin$1(c),\n cc = cos$1(c);\n return [\n atan2(x * sc, z * cc),\n asin$1(z && y * sc / z)\n ];\n }\n }\n\n var azimuthalEqualAreaRaw = azimuthalRaw(function(cxcy) {\n return sqrt$1(2 / (1 + cxcy));\n });\n\n azimuthalEqualAreaRaw.invert = azimuthalInvert(function(z) {\n return 2 * asin$1(z / 2);\n });\n\n function azimuthalEqualArea() {\n return projection(azimuthalEqualAreaRaw)\n .scale(124.75)\n .clipAngle(180 - 1e-3);\n }\n\n var azimuthalEquidistantRaw = azimuthalRaw(function(c) {\n return (c = acos(c)) && c / sin$1(c);\n });\n\n azimuthalEquidistantRaw.invert = azimuthalInvert(function(z) {\n return z;\n });\n\n function azimuthalEquidistant() {\n return projection(azimuthalEquidistantRaw)\n .scale(79.4188)\n .clipAngle(180 - 1e-3);\n }\n\n function mercatorRaw(lambda, phi) {\n return [lambda, log$1(tan((halfPi$3 + phi) / 2))];\n }\n\n mercatorRaw.invert = function(x, y) {\n return [x, 2 * atan(exp(y)) - halfPi$3];\n };\n\n function mercator() {\n return mercatorProjection(mercatorRaw)\n .scale(961 / tau$4);\n }\n\n function mercatorProjection(project) {\n var m = projection(project),\n scale = m.scale,\n translate = m.translate,\n clipExtent = m.clipExtent,\n clipAuto;\n\n m.scale = function(_) {\n return arguments.length ? (scale(_), clipAuto && m.clipExtent(null), m) : scale();\n };\n\n m.translate = function(_) {\n return arguments.length ? (translate(_), clipAuto && m.clipExtent(null), m) : translate();\n };\n\n m.clipExtent = function(_) {\n if (!arguments.length) return clipAuto ? null : clipExtent();\n if (clipAuto = _ == null) {\n var k = pi$4 * scale(),\n t = translate();\n _ = [[t[0] - k, t[1] - k], [t[0] + k, t[1] + k]];\n }\n clipExtent(_);\n return m;\n };\n\n return m.clipExtent(null);\n }\n\n function tany(y) {\n return tan((halfPi$3 + y) / 2);\n }\n\n function conicConformalRaw(y0, y1) {\n var cy0 = cos$1(y0),\n n = y0 === y1 ? sin$1(y0) : log$1(cy0 / cos$1(y1)) / log$1(tany(y1) / tany(y0)),\n f = cy0 * pow$1(tany(y0), n) / n;\n\n if (!n) return mercatorRaw;\n\n function project(x, y) {\n if (f > 0) { if (y < -halfPi$3 + epsilon$4) y = -halfPi$3 + epsilon$4; }\n else { if (y > halfPi$3 - epsilon$4) y = halfPi$3 - epsilon$4; }\n var r = f / pow$1(tany(y), n);\n return [r * sin$1(n * x), f - r * cos$1(n * x)];\n }\n\n project.invert = function(x, y) {\n var fy = f - y, r = sign$1(n) * sqrt$1(x * x + fy * fy);\n return [atan2(x, fy) / n, 2 * atan(pow$1(f / r, 1 / n)) - halfPi$3];\n };\n\n return project;\n }\n\n function conicConformal() {\n return conicProjection(conicConformalRaw)\n .scale(109.5)\n .parallels([30, 30]);\n }\n\n function equirectangularRaw(lambda, phi) {\n return [lambda, phi];\n }\n\n equirectangularRaw.invert = equirectangularRaw;\n\n function equirectangular() {\n return projection(equirectangularRaw)\n .scale(152.63);\n }\n\n function conicEquidistantRaw(y0, y1) {\n var cy0 = cos$1(y0),\n n = y0 === y1 ? sin$1(y0) : (cy0 - cos$1(y1)) / (y1 - y0),\n g = cy0 / n + y0;\n\n if (abs(n) < epsilon$4) return equirectangularRaw;\n\n function project(x, y) {\n var gy = g - y, nx = n * x;\n return [gy * sin$1(nx), g - gy * cos$1(nx)];\n }\n\n project.invert = function(x, y) {\n var gy = g - y;\n return [atan2(x, gy) / n, g - sign$1(n) * sqrt$1(x * x + gy * gy)];\n };\n\n return project;\n }\n\n function conicEquidistant() {\n return conicProjection(conicEquidistantRaw)\n .scale(131.154)\n .center([0, 13.9389]);\n }\n\n function gnomonicRaw(x, y) {\n var cy = cos$1(y), k = cos$1(x) * cy;\n return [cy * sin$1(x) / k, sin$1(y) / k];\n }\n\n gnomonicRaw.invert = azimuthalInvert(atan);\n\n function gnomonic() {\n return projection(gnomonicRaw)\n .scale(144.049)\n .clipAngle(60);\n }\n\n function orthographicRaw(x, y) {\n return [cos$1(y) * sin$1(x), sin$1(y)];\n }\n\n orthographicRaw.invert = azimuthalInvert(asin$1);\n\n function orthographic() {\n return projection(orthographicRaw)\n .scale(249.5)\n .clipAngle(90 + epsilon$4);\n }\n\n function stereographicRaw(x, y) {\n var cy = cos$1(y), k = 1 + cos$1(x) * cy;\n return [cy * sin$1(x) / k, sin$1(y) / k];\n }\n\n stereographicRaw.invert = azimuthalInvert(function(z) {\n return 2 + atan(z);\n });\n\n function stereographic() {\n return projection(stereographicRaw)\n .scale(250)\n .clipAngle(142);\n }\n\n function transverseMercatorRaw(lambda, phi) {\n return [log$1(tan((halfPi$3 + phi) / 2)), -lambda];\n }\n\n transverseMercatorRaw.invert = function(x, y) {\n return [-y, 2 * atan(exp(x)) - halfPi$3];\n };\n\n function transverseMercator() {\n var m = mercatorProjection(transverseMercatorRaw),\n center = m.center,\n rotate = m.rotate;\n\n m.center = function(_) {\n return arguments.length ? center([-_[1], _[0]]) : (_ = center(), [_[1], -_[0]]);\n };\n\n m.rotate = function(_) {\n return arguments.length ? rotate([_[0], _[1], _.length > 2 ? _[2] + 90 : 90]) : (_ = rotate(), [_[0], _[1], _[2] - 90]);\n };\n\n return rotate([0, 0, 90])\n .scale(159.155);\n }\n\n exports.version = version;\n exports.bisect = bisectRight;\n exports.bisectRight = bisectRight;\n exports.bisectLeft = bisectLeft;\n exports.ascending = ascending;\n exports.bisector = bisector;\n exports.descending = descending;\n exports.deviation = deviation;\n exports.extent = extent;\n exports.histogram = histogram;\n exports.thresholdFreedmanDiaconis = freedmanDiaconis;\n exports.thresholdScott = scott;\n exports.thresholdSturges = sturges;\n exports.max = max;\n exports.mean = mean;\n exports.median = median;\n exports.merge = merge;\n exports.min = min;\n exports.pairs = pairs;\n exports.permute = permute;\n exports.quantile = threshold;\n exports.range = range;\n exports.scan = scan;\n exports.shuffle = shuffle;\n exports.sum = sum;\n exports.ticks = ticks;\n exports.tickStep = tickStep;\n exports.transpose = transpose;\n exports.variance = variance;\n exports.zip = zip;\n exports.entries = entries;\n exports.keys = keys;\n exports.values = values;\n exports.map = map$1;\n exports.set = set;\n exports.nest = nest;\n exports.randomUniform = uniform;\n exports.randomNormal = normal;\n exports.randomLogNormal = logNormal;\n exports.randomBates = bates;\n exports.randomIrwinHall = irwinHall;\n exports.randomExponential = exponential;\n exports.easeLinear = linear;\n exports.easeQuad = quadInOut;\n exports.easeQuadIn = quadIn;\n exports.easeQuadOut = quadOut;\n exports.easeQuadInOut = quadInOut;\n exports.easeCubic = easeCubicInOut;\n exports.easeCubicIn = cubicIn;\n exports.easeCubicOut = cubicOut;\n exports.easeCubicInOut = easeCubicInOut;\n exports.easePoly = polyInOut;\n exports.easePolyIn = polyIn;\n exports.easePolyOut = polyOut;\n exports.easePolyInOut = polyInOut;\n exports.easeSin = sinInOut;\n exports.easeSinIn = sinIn;\n exports.easeSinOut = sinOut;\n exports.easeSinInOut = sinInOut;\n exports.easeExp = expInOut;\n exports.easeExpIn = expIn;\n exports.easeExpOut = expOut;\n exports.easeExpInOut = expInOut;\n exports.easeCircle = circleInOut;\n exports.easeCircleIn = circleIn;\n exports.easeCircleOut = circleOut;\n exports.easeCircleInOut = circleInOut;\n exports.easeBounce = bounceOut;\n exports.easeBounceIn = bounceIn;\n exports.easeBounceOut = bounceOut;\n exports.easeBounceInOut = bounceInOut;\n exports.easeBack = backInOut;\n exports.easeBackIn = backIn;\n exports.easeBackOut = backOut;\n exports.easeBackInOut = backInOut;\n exports.easeElastic = elasticOut;\n exports.easeElasticIn = elasticIn;\n exports.easeElasticOut = elasticOut;\n exports.easeElasticInOut = elasticInOut;\n exports.polygonArea = area;\n exports.polygonCentroid = centroid;\n exports.polygonHull = hull;\n exports.polygonContains = contains;\n exports.polygonLength = length$1;\n exports.path = path;\n exports.quadtree = quadtree;\n exports.queue = queue;\n exports.arc = arc;\n exports.area = area$1;\n exports.line = line;\n exports.pie = pie;\n exports.radialArea = radialArea;\n exports.radialLine = radialLine$1;\n exports.symbol = symbol;\n exports.symbols = symbols;\n exports.symbolCircle = circle;\n exports.symbolCross = cross$1;\n exports.symbolDiamond = diamond;\n exports.symbolSquare = square;\n exports.symbolStar = star;\n exports.symbolTriangle = triangle;\n exports.symbolWye = wye;\n exports.curveBasisClosed = basisClosed;\n exports.curveBasisOpen = basisOpen;\n exports.curveBasis = basis;\n exports.curveBundle = bundle;\n exports.curveCardinalClosed = cardinalClosed;\n exports.curveCardinalOpen = cardinalOpen;\n exports.curveCardinal = cardinal;\n exports.curveCatmullRomClosed = catmullRomClosed;\n exports.curveCatmullRomOpen = catmullRomOpen;\n exports.curveCatmullRom = catmullRom;\n exports.curveLinearClosed = linearClosed;\n exports.curveLinear = curveLinear;\n exports.curveMonotoneX = monotoneX;\n exports.curveMonotoneY = monotoneY;\n exports.curveNatural = natural;\n exports.curveStep = step;\n exports.curveStepAfter = stepAfter;\n exports.curveStepBefore = stepBefore;\n exports.stack = stack;\n exports.stackOffsetExpand = expand;\n exports.stackOffsetNone = none;\n exports.stackOffsetSilhouette = silhouette;\n exports.stackOffsetWiggle = wiggle;\n exports.stackOrderAscending = ascending$1;\n exports.stackOrderDescending = descending$2;\n exports.stackOrderInsideOut = insideOut;\n exports.stackOrderNone = none$1;\n exports.stackOrderReverse = reverse;\n exports.color = color;\n exports.rgb = colorRgb;\n exports.hsl = colorHsl;\n exports.lab = lab;\n exports.hcl = colorHcl;\n exports.cubehelix = cubehelix;\n exports.interpolate = interpolate;\n exports.interpolateArray = array$1;\n exports.interpolateDate = date;\n exports.interpolateNumber = interpolateNumber;\n exports.interpolateObject = object;\n exports.interpolateRound = interpolateRound;\n exports.interpolateString = interpolateString;\n exports.interpolateTransformCss = interpolateTransform$1;\n exports.interpolateTransformSvg = interpolateTransform$2;\n exports.interpolateZoom = interpolateZoom;\n exports.interpolateRgb = interpolateRgb;\n exports.interpolateRgbBasis = rgbBasis;\n exports.interpolateRgbBasisClosed = rgbBasisClosed;\n exports.interpolateHsl = hsl$1;\n exports.interpolateHslLong = hslLong;\n exports.interpolateLab = lab$1;\n exports.interpolateHcl = hcl$1;\n exports.interpolateHclLong = hclLong;\n exports.interpolateCubehelix = cubehelix$2;\n exports.interpolateCubehelixLong = interpolateCubehelixLong;\n exports.interpolateBasis = basis$2;\n exports.interpolateBasisClosed = basisClosed$1;\n exports.quantize = quantize;\n exports.dispatch = dispatch;\n exports.dsvFormat = dsv;\n exports.csvParse = csvParse;\n exports.csvParseRows = csvParseRows;\n exports.csvFormat = csvFormat;\n exports.csvFormatRows = csvFormatRows;\n exports.tsvParse = tsvParse;\n exports.tsvParseRows = tsvParseRows;\n exports.tsvFormat = tsvFormat;\n exports.tsvFormatRows = tsvFormatRows;\n exports.request = request;\n exports.html = html;\n exports.json = json;\n exports.text = text;\n exports.xml = xml;\n exports.csv = csv$1;\n exports.tsv = tsv$1;\n exports.now = now;\n exports.timer = timer;\n exports.timerFlush = timerFlush;\n exports.timeout = timeout$1;\n exports.interval = interval$1;\n exports.timeInterval = newInterval;\n exports.timeMillisecond = millisecond;\n exports.timeMilliseconds = milliseconds;\n exports.timeSecond = second;\n exports.timeSeconds = seconds;\n exports.timeMinute = minute;\n exports.timeMinutes = minutes;\n exports.timeHour = hour;\n exports.timeHours = hours;\n exports.timeDay = day;\n exports.timeDays = days;\n exports.timeWeek = timeWeek;\n exports.timeWeeks = sundays;\n exports.timeSunday = timeWeek;\n exports.timeSundays = sundays;\n exports.timeMonday = timeMonday;\n exports.timeMondays = mondays;\n exports.timeTuesday = tuesday;\n exports.timeTuesdays = tuesdays;\n exports.timeWednesday = wednesday;\n exports.timeWednesdays = wednesdays;\n exports.timeThursday = thursday;\n exports.timeThursdays = thursdays;\n exports.timeFriday = friday;\n exports.timeFridays = fridays;\n exports.timeSaturday = saturday;\n exports.timeSaturdays = saturdays;\n exports.timeMonth = month;\n exports.timeMonths = months;\n exports.timeYear = year;\n exports.timeYears = years;\n exports.utcMillisecond = millisecond;\n exports.utcMilliseconds = milliseconds;\n exports.utcSecond = second;\n exports.utcSeconds = seconds;\n exports.utcMinute = utcMinute;\n exports.utcMinutes = utcMinutes;\n exports.utcHour = utcHour;\n exports.utcHours = utcHours;\n exports.utcDay = utcDay;\n exports.utcDays = utcDays;\n exports.utcWeek = utcWeek;\n exports.utcWeeks = utcSundays;\n exports.utcSunday = utcWeek;\n exports.utcSundays = utcSundays;\n exports.utcMonday = utcMonday;\n exports.utcMondays = utcMondays;\n exports.utcTuesday = utcTuesday;\n exports.utcTuesdays = utcTuesdays;\n exports.utcWednesday = utcWednesday;\n exports.utcWednesdays = utcWednesdays;\n exports.utcThursday = utcThursday;\n exports.utcThursdays = utcThursdays;\n exports.utcFriday = utcFriday;\n exports.utcFridays = utcFridays;\n exports.utcSaturday = utcSaturday;\n exports.utcSaturdays = utcSaturdays;\n exports.utcMonth = utcMonth;\n exports.utcMonths = utcMonths;\n exports.utcYear = utcYear;\n exports.utcYears = utcYears;\n exports.formatLocale = formatLocale;\n exports.formatDefaultLocale = defaultLocale;\n exports.formatSpecifier = formatSpecifier;\n exports.precisionFixed = precisionFixed;\n exports.precisionPrefix = precisionPrefix;\n exports.precisionRound = precisionRound;\n exports.isoFormat = formatIso;\n exports.isoParse = parseIso;\n exports.timeFormatLocale = formatLocale$1;\n exports.timeFormatDefaultLocale = defaultLocale$1;\n exports.scaleBand = band;\n exports.scalePoint = point$4;\n exports.scaleIdentity = identity$4;\n exports.scaleLinear = linear$2;\n exports.scaleLog = log;\n exports.scaleOrdinal = ordinal;\n exports.scaleImplicit = implicit;\n exports.scalePow = pow;\n exports.scaleSqrt = sqrt;\n exports.scaleQuantile = quantile;\n exports.scaleQuantize = quantize$1;\n exports.scaleThreshold = threshold$1;\n exports.scaleTime = time;\n exports.scaleUtc = utcTime;\n exports.schemeCategory10 = category10;\n exports.schemeCategory20b = category20b;\n exports.schemeCategory20c = category20c;\n exports.schemeCategory20 = category20;\n exports.scaleSequential = sequential;\n exports.interpolateCubehelixDefault = cubehelix$3;\n exports.interpolateRainbow = rainbow$1;\n exports.interpolateWarm = warm;\n exports.interpolateCool = cool;\n exports.interpolateViridis = viridis;\n exports.interpolateMagma = magma;\n exports.interpolateInferno = inferno;\n exports.interpolatePlasma = plasma;\n exports.creator = creator;\n exports.customEvent = customEvent;\n exports.local = local;\n exports.matcher = matcher$1;\n exports.mouse = mouse;\n exports.namespace = namespace;\n exports.namespaces = namespaces;\n exports.select = select;\n exports.selectAll = selectAll;\n exports.selection = selection;\n exports.selector = selector;\n exports.selectorAll = selectorAll;\n exports.touch = touch;\n exports.touches = touches;\n exports.window = window;\n exports.active = active;\n exports.interrupt = interrupt;\n exports.transition = transition;\n exports.axisTop = axisTop;\n exports.axisRight = axisRight;\n exports.axisBottom = axisBottom;\n exports.axisLeft = axisLeft;\n exports.cluster = cluster;\n exports.hierarchy = hierarchy;\n exports.pack = index;\n exports.packSiblings = siblings;\n exports.packEnclose = enclose;\n exports.partition = partition;\n exports.stratify = stratify;\n exports.tree = tree;\n exports.treemap = index$1;\n exports.treemapBinary = binary;\n exports.treemapDice = treemapDice;\n exports.treemapSlice = treemapSlice;\n exports.treemapSliceDice = sliceDice;\n exports.treemapSquarify = squarify;\n exports.treemapResquarify = resquarify;\n exports.forceCenter = center$1;\n exports.forceCollide = collide;\n exports.forceLink = link;\n exports.forceManyBody = manyBody;\n exports.forceSimulation = simulation;\n exports.forceX = x$3;\n exports.forceY = y$3;\n exports.drag = drag;\n exports.dragDisable = dragDisable;\n exports.dragEnable = dragEnable;\n exports.voronoi = voronoi;\n exports.zoom = zoom;\n exports.zoomIdentity = identity$6;\n exports.zoomTransform = transform;\n exports.brush = brush;\n exports.brushX = brushX;\n exports.brushY = brushY;\n exports.brushSelection = brushSelection;\n exports.chord = chord;\n exports.ribbon = ribbon;\n exports.geoAlbers = albers;\n exports.geoAlbersUsa = albersUsa;\n exports.geoArea = area$2;\n exports.geoAzimuthalEqualArea = azimuthalEqualArea;\n exports.geoAzimuthalEqualAreaRaw = azimuthalEqualAreaRaw;\n exports.geoAzimuthalEquidistant = azimuthalEquidistant;\n exports.geoAzimuthalEquidistantRaw = azimuthalEquidistantRaw;\n exports.geoBounds = bounds;\n exports.geoCentroid = centroid$1;\n exports.geoCircle = circle$1;\n exports.geoClipExtent = extent$1;\n exports.geoConicConformal = conicConformal;\n exports.geoConicConformalRaw = conicConformalRaw;\n exports.geoConicEqualArea = conicEqualArea;\n exports.geoConicEqualAreaRaw = conicEqualAreaRaw;\n exports.geoConicEquidistant = conicEquidistant;\n exports.geoConicEquidistantRaw = conicEquidistantRaw;\n exports.geoDistance = distance;\n exports.geoEquirectangular = equirectangular;\n exports.geoEquirectangularRaw = equirectangularRaw;\n exports.geoGnomonic = gnomonic;\n exports.geoGnomonicRaw = gnomonicRaw;\n exports.geoGraticule = graticule;\n exports.geoInterpolate = interpolate$2;\n exports.geoLength = length$2;\n exports.geoMercator = mercator;\n exports.geoMercatorRaw = mercatorRaw;\n exports.geoOrthographic = orthographic;\n exports.geoOrthographicRaw = orthographicRaw;\n exports.geoPath = index$3;\n exports.geoProjection = projection;\n exports.geoProjectionMutator = projectionMutator;\n exports.geoRotation = rotation;\n exports.geoStereographic = stereographic;\n exports.geoStereographicRaw = stereographicRaw;\n exports.geoStream = stream;\n exports.geoTransform = transform$1;\n exports.geoTransverseMercator = transverseMercator;\n exports.geoTransverseMercatorRaw = transverseMercatorRaw;\n\n Object.defineProperty(exports, '__esModule', { value: true });\n\n}));","/*! DataTables 1.10.12\n * ©2008-2015 SpryMedia Ltd - datatables.net/license\n */\n\n/**\n * @summary DataTables\n * @description Paginate, search and order HTML tables\n * @version 1.10.12\n * @file jquery.dataTables.js\n * @author SpryMedia Ltd (www.sprymedia.co.uk)\n * @contact www.sprymedia.co.uk/contact\n * @copyright Copyright 2008-2015 SpryMedia Ltd.\n *\n * This source file is free software, available under the following license:\n * MIT license - http://datatables.net/license\n *\n * This source file is distributed in the hope that it will be useful, but\n * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY\n * or FITNESS FOR A PARTICULAR PURPOSE. See the license files for details.\n *\n * For details please refer to: http://www.datatables.net\n */\n\n/*jslint evil: true, undef: true, browser: true */\n/*globals $,require,jQuery,define,_selector_run,_selector_opts,_selector_first,_selector_row_indexes,_ext,_Api,_api_register,_api_registerPlural,_re_new_lines,_re_html,_re_formatted_numeric,_re_escape_regex,_empty,_intVal,_numToDecimal,_isNumber,_isHtml,_htmlNumeric,_pluck,_pluck_order,_range,_stripHtml,_unique,_fnBuildAjax,_fnAjaxUpdate,_fnAjaxParameters,_fnAjaxUpdateDraw,_fnAjaxDataSrc,_fnAddColumn,_fnColumnOptions,_fnAdjustColumnSizing,_fnVisibleToColumnIndex,_fnColumnIndexToVisible,_fnVisbleColumns,_fnGetColumns,_fnColumnTypes,_fnApplyColumnDefs,_fnHungarianMap,_fnCamelToHungarian,_fnLanguageCompat,_fnBrowserDetect,_fnAddData,_fnAddTr,_fnNodeToDataIndex,_fnNodeToColumnIndex,_fnGetCellData,_fnSetCellData,_fnSplitObjNotation,_fnGetObjectDataFn,_fnSetObjectDataFn,_fnGetDataMaster,_fnClearTable,_fnDeleteIndex,_fnInvalidate,_fnGetRowElements,_fnCreateTr,_fnBuildHead,_fnDrawHead,_fnDraw,_fnReDraw,_fnAddOptionsHtml,_fnDetectHeader,_fnGetUniqueThs,_fnFeatureHtmlFilter,_fnFilterComplete,_fnFilterCustom,_fnFilterColumn,_fnFilter,_fnFilterCreateSearch,_fnEscapeRegex,_fnFilterData,_fnFeatureHtmlInfo,_fnUpdateInfo,_fnInfoMacros,_fnInitialise,_fnInitComplete,_fnLengthChange,_fnFeatureHtmlLength,_fnFeatureHtmlPaginate,_fnPageChange,_fnFeatureHtmlProcessing,_fnProcessingDisplay,_fnFeatureHtmlTable,_fnScrollDraw,_fnApplyToChildren,_fnCalculateColumnWidths,_fnThrottle,_fnConvertToWidth,_fnGetWidestNode,_fnGetMaxLenString,_fnStringToCss,_fnSortFlatten,_fnSort,_fnSortAria,_fnSortListener,_fnSortAttachListener,_fnSortingClasses,_fnSortData,_fnSaveState,_fnLoadState,_fnSettingsFromNode,_fnLog,_fnMap,_fnBindAction,_fnCallbackReg,_fnCallbackFire,_fnLengthOverflow,_fnRenderer,_fnDataSource,_fnRowAttributes*/\n\n(function( factory ) {\n\t\"use strict\";\n\n\tif ( typeof define === 'function' && define.amd ) {\n\t\t// AMD\n\t\tdefine( ['jquery'], function ( $ ) {\n\t\t\treturn factory( $, window, document );\n\t\t} );\n\t}\n\telse if ( typeof exports === 'object' ) {\n\t\t// CommonJS\n\t\tmodule.exports = function (root, $) {\n\t\t\tif ( ! root ) {\n\t\t\t\t// CommonJS environments without a window global must pass a\n\t\t\t\t// root. This will give an error otherwise\n\t\t\t\troot = window;\n\t\t\t}\n\n\t\t\tif ( ! $ ) {\n\t\t\t\t$ = typeof window !== 'undefined' ? // jQuery's factory checks for a global window\n\t\t\t\t\trequire('jquery') :\n\t\t\t\t\trequire('jquery')( root );\n\t\t\t}\n\n\t\t\treturn factory( $, root, root.document );\n\t\t};\n\t}\n\telse {\n\t\t// Browser\n\t\tfactory( jQuery, window, document );\n\t}\n}\n(function( $, window, document, undefined ) {\n\t\"use strict\";\n\n\t/**\n\t * DataTables is a plug-in for the jQuery Javascript library. It is a highly\n\t * flexible tool, based upon the foundations of progressive enhancement,\n\t * which will add advanced interaction controls to any HTML table. For a\n\t * full list of features please refer to\n\t * [DataTables.net](href=\"http://datatables.net).\n\t *\n\t * Note that the `DataTable` object is not a global variable but is aliased\n\t * to `jQuery.fn.DataTable` and `jQuery.fn.dataTable` through which it may\n\t * be accessed.\n\t *\n\t * @class\n\t * @param {object} [init={}] Configuration object for DataTables. Options\n\t * are defined by {@link DataTable.defaults}\n\t * @requires jQuery 1.7+\n\t *\n\t * @example\n\t * // Basic initialisation\n\t * $(document).ready( function {\n\t * $('#example').dataTable();\n\t * } );\n\t *\n\t * @example\n\t * // Initialisation with configuration options - in this case, disable\n\t * // pagination and sorting.\n\t * $(document).ready( function {\n\t * $('#example').dataTable( {\n\t * \"paginate\": false,\n\t * \"sort\": false\n\t * } );\n\t * } );\n\t */\n\tvar DataTable = function ( options )\n\t{\n\t\t/**\n\t\t * Perform a jQuery selector action on the table's TR elements (from the tbody) and\n\t\t * return the resulting jQuery object.\n\t\t * @param {string|node|jQuery} sSelector jQuery selector or node collection to act on\n\t\t * @param {object} [oOpts] Optional parameters for modifying the rows to be included\n\t\t * @param {string} [oOpts.filter=none] Select TR elements that meet the current filter\n\t\t * criterion (\"applied\") or all TR elements (i.e. no filter).\n\t\t * @param {string} [oOpts.order=current] Order of the TR elements in the processed array.\n\t\t * Can be either 'current', whereby the current sorting of the table is used, or\n\t\t * 'original' whereby the original order the data was read into the table is used.\n\t\t * @param {string} [oOpts.page=all] Limit the selection to the currently displayed page\n\t\t * (\"current\") or not (\"all\"). If 'current' is given, then order is assumed to be\n\t\t * 'current' and filter is 'applied', regardless of what they might be given as.\n\t\t * @returns {object} jQuery object, filtered by the given selector.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Highlight every second row\n\t\t * oTable.$('tr:odd').css('backgroundColor', 'blue');\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Filter to rows with 'Webkit' in them, add a background colour and then\n\t\t * // remove the filter, thus highlighting the 'Webkit' rows only.\n\t\t * oTable.fnFilter('Webkit');\n\t\t * oTable.$('tr', {\"search\": \"applied\"}).css('backgroundColor', 'blue');\n\t\t * oTable.fnFilter('');\n\t\t * } );\n\t\t */\n\t\tthis.$ = function ( sSelector, oOpts )\n\t\t{\n\t\t\treturn this.api(true).$( sSelector, oOpts );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Almost identical to $ in operation, but in this case returns the data for the matched\n\t\t * rows - as such, the jQuery selector used should match TR row nodes or TD/TH cell nodes\n\t\t * rather than any descendants, so the data can be obtained for the row/cell. If matching\n\t\t * rows are found, the data returned is the original data array/object that was used to\n\t\t * create the row (or a generated array if from a DOM source).\n\t\t *\n\t\t * This method is often useful in-combination with $ where both functions are given the\n\t\t * same parameters and the array indexes will match identically.\n\t\t * @param {string|node|jQuery} sSelector jQuery selector or node collection to act on\n\t\t * @param {object} [oOpts] Optional parameters for modifying the rows to be included\n\t\t * @param {string} [oOpts.filter=none] Select elements that meet the current filter\n\t\t * criterion (\"applied\") or all elements (i.e. no filter).\n\t\t * @param {string} [oOpts.order=current] Order of the data in the processed array.\n\t\t * Can be either 'current', whereby the current sorting of the table is used, or\n\t\t * 'original' whereby the original order the data was read into the table is used.\n\t\t * @param {string} [oOpts.page=all] Limit the selection to the currently displayed page\n\t\t * (\"current\") or not (\"all\"). If 'current' is given, then order is assumed to be\n\t\t * 'current' and filter is 'applied', regardless of what they might be given as.\n\t\t * @returns {array} Data for the matched elements. If any elements, as a result of the\n\t\t * selector, were not TR, TD or TH elements in the DataTable, they will have a null\n\t\t * entry in the array.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Get the data from the first row in the table\n\t\t * var data = oTable._('tr:first');\n\t\t *\n\t\t * // Do something useful with the data\n\t\t * alert( \"First cell is: \"+data[0] );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Filter to 'Webkit' and get all data for\n\t\t * oTable.fnFilter('Webkit');\n\t\t * var data = oTable._('tr', {\"search\": \"applied\"});\n\t\t *\n\t\t * // Do something with the data\n\t\t * alert( data.length+\" rows matched the search\" );\n\t\t * } );\n\t\t */\n\t\tthis._ = function ( sSelector, oOpts )\n\t\t{\n\t\t\treturn this.api(true).rows( sSelector, oOpts ).data();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Create a DataTables Api instance, with the currently selected tables for\n\t\t * the Api's context.\n\t\t * @param {boolean} [traditional=false] Set the API instance's context to be\n\t\t * only the table referred to by the `DataTable.ext.iApiIndex` option, as was\n\t\t * used in the API presented by DataTables 1.9- (i.e. the traditional mode),\n\t\t * or if all tables captured in the jQuery object should be used.\n\t\t * @return {DataTables.Api}\n\t\t */\n\t\tthis.api = function ( traditional )\n\t\t{\n\t\t\treturn traditional ?\n\t\t\t\tnew _Api(\n\t\t\t\t\t_fnSettingsFromNode( this[ _ext.iApiIndex ] )\n\t\t\t\t) :\n\t\t\t\tnew _Api( this );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Add a single new row or multiple rows of data to the table. Please note\n\t\t * that this is suitable for client-side processing only - if you are using\n\t\t * server-side processing (i.e. \"bServerSide\": true), then to add data, you\n\t\t * must add it to the data source, i.e. the server-side, through an Ajax call.\n\t\t * @param {array|object} data The data to be added to the table. This can be:\n\t\t * <ul>\n\t\t * <li>1D array of data - add a single row with the data provided</li>\n\t\t * <li>2D array of arrays - add multiple rows in a single call</li>\n\t\t * <li>object - data object when using <i>mData</i></li>\n\t\t * <li>array of objects - multiple data objects when using <i>mData</i></li>\n\t\t * </ul>\n\t\t * @param {bool} [redraw=true] redraw the table or not\n\t\t * @returns {array} An array of integers, representing the list of indexes in\n\t\t * <i>aoData</i> ({@link DataTable.models.oSettings}) that have been added to\n\t\t * the table.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * // Global var for counter\n\t\t * var giCount = 2;\n\t\t *\n\t\t * $(document).ready(function() {\n\t\t * $('#example').dataTable();\n\t\t * } );\n\t\t *\n\t\t * function fnClickAddRow() {\n\t\t * $('#example').dataTable().fnAddData( [\n\t\t * giCount+\".1\",\n\t\t * giCount+\".2\",\n\t\t * giCount+\".3\",\n\t\t * giCount+\".4\" ]\n\t\t * );\n\t\t *\n\t\t * giCount++;\n\t\t * }\n\t\t */\n\t\tthis.fnAddData = function( data, redraw )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\n\t\t\t/* Check if we want to add multiple rows or not */\n\t\t\tvar rows = $.isArray(data) && ( $.isArray(data[0]) || $.isPlainObject(data[0]) ) ?\n\t\t\t\tapi.rows.add( data ) :\n\t\t\t\tapi.row.add( data );\n\t\t\n\t\t\tif ( redraw === undefined || redraw ) {\n\t\t\t\tapi.draw();\n\t\t\t}\n\t\t\n\t\t\treturn rows.flatten().toArray();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * This function will make DataTables recalculate the column sizes, based on the data\n\t\t * contained in the table and the sizes applied to the columns (in the DOM, CSS or\n\t\t * through the sWidth parameter). This can be useful when the width of the table's\n\t\t * parent element changes (for example a window resize).\n\t\t * @param {boolean} [bRedraw=true] Redraw the table or not, you will typically want to\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable( {\n\t\t * \"sScrollY\": \"200px\",\n\t\t * \"bPaginate\": false\n\t\t * } );\n\t\t *\n\t\t * $(window).bind('resize', function () {\n\t\t * oTable.fnAdjustColumnSizing();\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\tthis.fnAdjustColumnSizing = function ( bRedraw )\n\t\t{\n\t\t\tvar api = this.api( true ).columns.adjust();\n\t\t\tvar settings = api.settings()[0];\n\t\t\tvar scroll = settings.oScroll;\n\t\t\n\t\t\tif ( bRedraw === undefined || bRedraw ) {\n\t\t\t\tapi.draw( false );\n\t\t\t}\n\t\t\telse if ( scroll.sX !== \"\" || scroll.sY !== \"\" ) {\n\t\t\t\t/* If not redrawing, but scrolling, we want to apply the new column sizes anyway */\n\t\t\t\t_fnScrollDraw( settings );\n\t\t\t}\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Quickly and simply clear a table\n\t\t * @param {bool} [bRedraw=true] redraw the table or not\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Immediately 'nuke' the current rows (perhaps waiting for an Ajax callback...)\n\t\t * oTable.fnClearTable();\n\t\t * } );\n\t\t */\n\t\tthis.fnClearTable = function( bRedraw )\n\t\t{\n\t\t\tvar api = this.api( true ).clear();\n\t\t\n\t\t\tif ( bRedraw === undefined || bRedraw ) {\n\t\t\t\tapi.draw();\n\t\t\t}\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * The exact opposite of 'opening' a row, this function will close any rows which\n\t\t * are currently 'open'.\n\t\t * @param {node} nTr the table row to 'close'\n\t\t * @returns {int} 0 on success, or 1 if failed (can't find the row)\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable;\n\t\t *\n\t\t * // 'open' an information row when a row is clicked on\n\t\t * $('#example tbody tr').click( function () {\n\t\t * if ( oTable.fnIsOpen(this) ) {\n\t\t * oTable.fnClose( this );\n\t\t * } else {\n\t\t * oTable.fnOpen( this, \"Temporary row opened\", \"info_row\" );\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * oTable = $('#example').dataTable();\n\t\t * } );\n\t\t */\n\t\tthis.fnClose = function( nTr )\n\t\t{\n\t\t\tthis.api( true ).row( nTr ).child.hide();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Remove a row for the table\n\t\t * @param {mixed} target The index of the row from aoData to be deleted, or\n\t\t * the TR element you want to delete\n\t\t * @param {function|null} [callBack] Callback function\n\t\t * @param {bool} [redraw=true] Redraw the table or not\n\t\t * @returns {array} The row that was deleted\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Immediately remove the first row\n\t\t * oTable.fnDeleteRow( 0 );\n\t\t * } );\n\t\t */\n\t\tthis.fnDeleteRow = function( target, callback, redraw )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\tvar rows = api.rows( target );\n\t\t\tvar settings = rows.settings()[0];\n\t\t\tvar data = settings.aoData[ rows[0][0] ];\n\t\t\n\t\t\trows.remove();\n\t\t\n\t\t\tif ( callback ) {\n\t\t\t\tcallback.call( this, settings, data );\n\t\t\t}\n\t\t\n\t\t\tif ( redraw === undefined || redraw ) {\n\t\t\t\tapi.draw();\n\t\t\t}\n\t\t\n\t\t\treturn data;\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Restore the table to it's original state in the DOM by removing all of DataTables\n\t\t * enhancements, alterations to the DOM structure of the table and event listeners.\n\t\t * @param {boolean} [remove=false] Completely remove the table from the DOM\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * // This example is fairly pointless in reality, but shows how fnDestroy can be used\n\t\t * var oTable = $('#example').dataTable();\n\t\t * oTable.fnDestroy();\n\t\t * } );\n\t\t */\n\t\tthis.fnDestroy = function ( remove )\n\t\t{\n\t\t\tthis.api( true ).destroy( remove );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Redraw the table\n\t\t * @param {bool} [complete=true] Re-filter and resort (if enabled) the table before the draw.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Re-draw the table - you wouldn't want to do it here, but it's an example :-)\n\t\t * oTable.fnDraw();\n\t\t * } );\n\t\t */\n\t\tthis.fnDraw = function( complete )\n\t\t{\n\t\t\t// Note that this isn't an exact match to the old call to _fnDraw - it takes\n\t\t\t// into account the new data, but can hold position.\n\t\t\tthis.api( true ).draw( complete );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Filter the input based on data\n\t\t * @param {string} sInput String to filter the table on\n\t\t * @param {int|null} [iColumn] Column to limit filtering to\n\t\t * @param {bool} [bRegex=false] Treat as regular expression or not\n\t\t * @param {bool} [bSmart=true] Perform smart filtering or not\n\t\t * @param {bool} [bShowGlobal=true] Show the input global filter in it's input box(es)\n\t\t * @param {bool} [bCaseInsensitive=true] Do case-insensitive matching (true) or not (false)\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Sometime later - filter...\n\t\t * oTable.fnFilter( 'test string' );\n\t\t * } );\n\t\t */\n\t\tthis.fnFilter = function( sInput, iColumn, bRegex, bSmart, bShowGlobal, bCaseInsensitive )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\n\t\t\tif ( iColumn === null || iColumn === undefined ) {\n\t\t\t\tapi.search( sInput, bRegex, bSmart, bCaseInsensitive );\n\t\t\t}\n\t\t\telse {\n\t\t\t\tapi.column( iColumn ).search( sInput, bRegex, bSmart, bCaseInsensitive );\n\t\t\t}\n\t\t\n\t\t\tapi.draw();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Get the data for the whole table, an individual row or an individual cell based on the\n\t\t * provided parameters.\n\t\t * @param {int|node} [src] A TR row node, TD/TH cell node or an integer. If given as\n\t\t * a TR node then the data source for the whole row will be returned. If given as a\n\t\t * TD/TH cell node then iCol will be automatically calculated and the data for the\n\t\t * cell returned. If given as an integer, then this is treated as the aoData internal\n\t\t * data index for the row (see fnGetPosition) and the data for that row used.\n\t\t * @param {int} [col] Optional column index that you want the data of.\n\t\t * @returns {array|object|string} If mRow is undefined, then the data for all rows is\n\t\t * returned. If mRow is defined, just data for that row, and is iCol is\n\t\t * defined, only data for the designated cell is returned.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * // Row data\n\t\t * $(document).ready(function() {\n\t\t * oTable = $('#example').dataTable();\n\t\t *\n\t\t * oTable.$('tr').click( function () {\n\t\t * var data = oTable.fnGetData( this );\n\t\t * // ... do something with the array / object of data for the row\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Individual cell data\n\t\t * $(document).ready(function() {\n\t\t * oTable = $('#example').dataTable();\n\t\t *\n\t\t * oTable.$('td').click( function () {\n\t\t * var sData = oTable.fnGetData( this );\n\t\t * alert( 'The cell clicked on had the value of '+sData );\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\tthis.fnGetData = function( src, col )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\n\t\t\tif ( src !== undefined ) {\n\t\t\t\tvar type = src.nodeName ? src.nodeName.toLowerCase() : '';\n\t\t\n\t\t\t\treturn col !== undefined || type == 'td' || type == 'th' ?\n\t\t\t\t\tapi.cell( src, col ).data() :\n\t\t\t\t\tapi.row( src ).data() || null;\n\t\t\t}\n\t\t\n\t\t\treturn api.data().toArray();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Get an array of the TR nodes that are used in the table's body. Note that you will\n\t\t * typically want to use the '$' API method in preference to this as it is more\n\t\t * flexible.\n\t\t * @param {int} [iRow] Optional row index for the TR element you want\n\t\t * @returns {array|node} If iRow is undefined, returns an array of all TR elements\n\t\t * in the table's body, or iRow is defined, just the TR element requested.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Get the nodes from the table\n\t\t * var nNodes = oTable.fnGetNodes( );\n\t\t * } );\n\t\t */\n\t\tthis.fnGetNodes = function( iRow )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\n\t\t\treturn iRow !== undefined ?\n\t\t\t\tapi.row( iRow ).node() :\n\t\t\t\tapi.rows().nodes().flatten().toArray();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Get the array indexes of a particular cell from it's DOM element\n\t\t * and column index including hidden columns\n\t\t * @param {node} node this can either be a TR, TD or TH in the table's body\n\t\t * @returns {int} If nNode is given as a TR, then a single index is returned, or\n\t\t * if given as a cell, an array of [row index, column index (visible),\n\t\t * column index (all)] is given.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * $('#example tbody td').click( function () {\n\t\t * // Get the position of the current data from the node\n\t\t * var aPos = oTable.fnGetPosition( this );\n\t\t *\n\t\t * // Get the data array for this row\n\t\t * var aData = oTable.fnGetData( aPos[0] );\n\t\t *\n\t\t * // Update the data array and return the value\n\t\t * aData[ aPos[1] ] = 'clicked';\n\t\t * this.innerHTML = 'clicked';\n\t\t * } );\n\t\t *\n\t\t * // Init DataTables\n\t\t * oTable = $('#example').dataTable();\n\t\t * } );\n\t\t */\n\t\tthis.fnGetPosition = function( node )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\tvar nodeName = node.nodeName.toUpperCase();\n\t\t\n\t\t\tif ( nodeName == 'TR' ) {\n\t\t\t\treturn api.row( node ).index();\n\t\t\t}\n\t\t\telse if ( nodeName == 'TD' || nodeName == 'TH' ) {\n\t\t\t\tvar cell = api.cell( node ).index();\n\t\t\n\t\t\t\treturn [\n\t\t\t\t\tcell.row,\n\t\t\t\t\tcell.columnVisible,\n\t\t\t\t\tcell.column\n\t\t\t\t];\n\t\t\t}\n\t\t\treturn null;\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Check to see if a row is 'open' or not.\n\t\t * @param {node} nTr the table row to check\n\t\t * @returns {boolean} true if the row is currently open, false otherwise\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable;\n\t\t *\n\t\t * // 'open' an information row when a row is clicked on\n\t\t * $('#example tbody tr').click( function () {\n\t\t * if ( oTable.fnIsOpen(this) ) {\n\t\t * oTable.fnClose( this );\n\t\t * } else {\n\t\t * oTable.fnOpen( this, \"Temporary row opened\", \"info_row\" );\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * oTable = $('#example').dataTable();\n\t\t * } );\n\t\t */\n\t\tthis.fnIsOpen = function( nTr )\n\t\t{\n\t\t\treturn this.api( true ).row( nTr ).child.isShown();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * This function will place a new row directly after a row which is currently\n\t\t * on display on the page, with the HTML contents that is passed into the\n\t\t * function. This can be used, for example, to ask for confirmation that a\n\t\t * particular record should be deleted.\n\t\t * @param {node} nTr The table row to 'open'\n\t\t * @param {string|node|jQuery} mHtml The HTML to put into the row\n\t\t * @param {string} sClass Class to give the new TD cell\n\t\t * @returns {node} The row opened. Note that if the table row passed in as the\n\t\t * first parameter, is not found in the table, this method will silently\n\t\t * return.\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable;\n\t\t *\n\t\t * // 'open' an information row when a row is clicked on\n\t\t * $('#example tbody tr').click( function () {\n\t\t * if ( oTable.fnIsOpen(this) ) {\n\t\t * oTable.fnClose( this );\n\t\t * } else {\n\t\t * oTable.fnOpen( this, \"Temporary row opened\", \"info_row\" );\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * oTable = $('#example').dataTable();\n\t\t * } );\n\t\t */\n\t\tthis.fnOpen = function( nTr, mHtml, sClass )\n\t\t{\n\t\t\treturn this.api( true )\n\t\t\t\t.row( nTr )\n\t\t\t\t.child( mHtml, sClass )\n\t\t\t\t.show()\n\t\t\t\t.child()[0];\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Change the pagination - provides the internal logic for pagination in a simple API\n\t\t * function. With this function you can have a DataTables table go to the next,\n\t\t * previous, first or last pages.\n\t\t * @param {string|int} mAction Paging action to take: \"first\", \"previous\", \"next\" or \"last\"\n\t\t * or page number to jump to (integer), note that page 0 is the first page.\n\t\t * @param {bool} [bRedraw=true] Redraw the table or not\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t * oTable.fnPageChange( 'next' );\n\t\t * } );\n\t\t */\n\t\tthis.fnPageChange = function ( mAction, bRedraw )\n\t\t{\n\t\t\tvar api = this.api( true ).page( mAction );\n\t\t\n\t\t\tif ( bRedraw === undefined || bRedraw ) {\n\t\t\t\tapi.draw(false);\n\t\t\t}\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Show a particular column\n\t\t * @param {int} iCol The column whose display should be changed\n\t\t * @param {bool} bShow Show (true) or hide (false) the column\n\t\t * @param {bool} [bRedraw=true] Redraw the table or not\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Hide the second column after initialisation\n\t\t * oTable.fnSetColumnVis( 1, false );\n\t\t * } );\n\t\t */\n\t\tthis.fnSetColumnVis = function ( iCol, bShow, bRedraw )\n\t\t{\n\t\t\tvar api = this.api( true ).column( iCol ).visible( bShow );\n\t\t\n\t\t\tif ( bRedraw === undefined || bRedraw ) {\n\t\t\t\tapi.columns.adjust().draw();\n\t\t\t}\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Get the settings for a particular table for external manipulation\n\t\t * @returns {object} DataTables settings object. See\n\t\t * {@link DataTable.models.oSettings}\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t * var oSettings = oTable.fnSettings();\n\t\t *\n\t\t * // Show an example parameter from the settings\n\t\t * alert( oSettings._iDisplayStart );\n\t\t * } );\n\t\t */\n\t\tthis.fnSettings = function()\n\t\t{\n\t\t\treturn _fnSettingsFromNode( this[_ext.iApiIndex] );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Sort the table by a particular column\n\t\t * @param {int} iCol the data index to sort on. Note that this will not match the\n\t\t * 'display index' if you have hidden data entries\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Sort immediately with columns 0 and 1\n\t\t * oTable.fnSort( [ [0,'asc'], [1,'asc'] ] );\n\t\t * } );\n\t\t */\n\t\tthis.fnSort = function( aaSort )\n\t\t{\n\t\t\tthis.api( true ).order( aaSort ).draw();\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Attach a sort listener to an element for a given column\n\t\t * @param {node} nNode the element to attach the sort listener to\n\t\t * @param {int} iColumn the column that a click on this node will sort on\n\t\t * @param {function} [fnCallback] callback function when sort is run\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t *\n\t\t * // Sort on column 1, when 'sorter' is clicked on\n\t\t * oTable.fnSortListener( document.getElementById('sorter'), 1 );\n\t\t * } );\n\t\t */\n\t\tthis.fnSortListener = function( nNode, iColumn, fnCallback )\n\t\t{\n\t\t\tthis.api( true ).order.listener( nNode, iColumn, fnCallback );\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Update a table cell or row - this method will accept either a single value to\n\t\t * update the cell with, an array of values with one element for each column or\n\t\t * an object in the same format as the original data source. The function is\n\t\t * self-referencing in order to make the multi column updates easier.\n\t\t * @param {object|array|string} mData Data to update the cell/row with\n\t\t * @param {node|int} mRow TR element you want to update or the aoData index\n\t\t * @param {int} [iColumn] The column to update, give as null or undefined to\n\t\t * update a whole row.\n\t\t * @param {bool} [bRedraw=true] Redraw the table or not\n\t\t * @param {bool} [bAction=true] Perform pre-draw actions or not\n\t\t * @returns {int} 0 on success, 1 on error\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t * oTable.fnUpdate( 'Example update', 0, 0 ); // Single cell\n\t\t * oTable.fnUpdate( ['a', 'b', 'c', 'd', 'e'], $('tbody tr')[0] ); // Row\n\t\t * } );\n\t\t */\n\t\tthis.fnUpdate = function( mData, mRow, iColumn, bRedraw, bAction )\n\t\t{\n\t\t\tvar api = this.api( true );\n\t\t\n\t\t\tif ( iColumn === undefined || iColumn === null ) {\n\t\t\t\tapi.row( mRow ).data( mData );\n\t\t\t}\n\t\t\telse {\n\t\t\t\tapi.cell( mRow, iColumn ).data( mData );\n\t\t\t}\n\t\t\n\t\t\tif ( bAction === undefined || bAction ) {\n\t\t\t\tapi.columns.adjust();\n\t\t\t}\n\t\t\n\t\t\tif ( bRedraw === undefined || bRedraw ) {\n\t\t\t\tapi.draw();\n\t\t\t}\n\t\t\treturn 0;\n\t\t};\n\t\t\n\t\t\n\t\t/**\n\t\t * Provide a common method for plug-ins to check the version of DataTables being used, in order\n\t\t * to ensure compatibility.\n\t\t * @param {string} sVersion Version string to check for, in the format \"X.Y.Z\". Note that the\n\t\t * formats \"X\" and \"X.Y\" are also acceptable.\n\t\t * @returns {boolean} true if this version of DataTables is greater or equal to the required\n\t\t * version, or false if this version of DataTales is not suitable\n\t\t * @method\n\t\t * @dtopt API\n\t\t * @deprecated Since v1.10\n\t\t *\n\t\t * @example\n\t\t * $(document).ready(function() {\n\t\t * var oTable = $('#example').dataTable();\n\t\t * alert( oTable.fnVersionCheck( '1.9.0' ) );\n\t\t * } );\n\t\t */\n\t\tthis.fnVersionCheck = _ext.fnVersionCheck;\n\t\t\n\n\t\tvar _that = this;\n\t\tvar emptyInit = options === undefined;\n\t\tvar len = this.length;\n\n\t\tif ( emptyInit ) {\n\t\t\toptions = {};\n\t\t}\n\n\t\tthis.oApi = this.internal = _ext.internal;\n\n\t\t// Extend with old style plug-in API methods\n\t\tfor ( var fn in DataTable.ext.internal ) {\n\t\t\tif ( fn ) {\n\t\t\t\tthis[fn] = _fnExternApiFunc(fn);\n\t\t\t}\n\t\t}\n\n\t\tthis.each(function() {\n\t\t\t// For each initialisation we want to give it a clean initialisation\n\t\t\t// object that can be bashed around\n\t\t\tvar o = {};\n\t\t\tvar oInit = len > 1 ? // optimisation for single table case\n\t\t\t\t_fnExtend( o, options, true ) :\n\t\t\t\toptions;\n\n\t\t\t/*global oInit,_that,emptyInit*/\n\t\t\tvar i=0, iLen, j, jLen, k, kLen;\n\t\t\tvar sId = this.getAttribute( 'id' );\n\t\t\tvar bInitHandedOff = false;\n\t\t\tvar defaults = DataTable.defaults;\n\t\t\tvar $this = $(this);\n\t\t\t\n\t\t\t\n\t\t\t/* Sanity check */\n\t\t\tif ( this.nodeName.toLowerCase() != 'table' )\n\t\t\t{\n\t\t\t\t_fnLog( null, 0, 'Non-table node initialisation ('+this.nodeName+')', 2 );\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t\n\t\t\t/* Backwards compatibility for the defaults */\n\t\t\t_fnCompatOpts( defaults );\n\t\t\t_fnCompatCols( defaults.column );\n\t\t\t\n\t\t\t/* Convert the camel-case defaults to Hungarian */\n\t\t\t_fnCamelToHungarian( defaults, defaults, true );\n\t\t\t_fnCamelToHungarian( defaults.column, defaults.column, true );\n\t\t\t\n\t\t\t/* Setting up the initialisation object */\n\t\t\t_fnCamelToHungarian( defaults, $.extend( oInit, $this.data() ) );\n\t\t\t\n\t\t\t\n\t\t\t\n\t\t\t/* Check to see if we are re-initialising a table */\n\t\t\tvar allSettings = DataTable.settings;\n\t\t\tfor ( i=0, iLen=allSettings.length ; i<iLen ; i++ )\n\t\t\t{\n\t\t\t\tvar s = allSettings[i];\n\t\t\t\n\t\t\t\t/* Base check on table node */\n\t\t\t\tif ( s.nTable == this || s.nTHead.parentNode == this || (s.nTFoot && s.nTFoot.parentNode == this) )\n\t\t\t\t{\n\t\t\t\t\tvar bRetrieve = oInit.bRetrieve !== undefined ? oInit.bRetrieve : defaults.bRetrieve;\n\t\t\t\t\tvar bDestroy = oInit.bDestroy !== undefined ? oInit.bDestroy : defaults.bDestroy;\n\t\t\t\n\t\t\t\t\tif ( emptyInit || bRetrieve )\n\t\t\t\t\t{\n\t\t\t\t\t\treturn s.oInstance;\n\t\t\t\t\t}\n\t\t\t\t\telse if ( bDestroy )\n\t\t\t\t\t{\n\t\t\t\t\t\ts.oInstance.fnDestroy();\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\t_fnLog( s, 0, 'Cannot reinitialise DataTable', 3 );\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\n\t\t\t\t/* If the element we are initialising has the same ID as a table which was previously\n\t\t\t\t * initialised, but the table nodes don't match (from before) then we destroy the old\n\t\t\t\t * instance by simply deleting it. This is under the assumption that the table has been\n\t\t\t\t * destroyed by other methods. Anyone using non-id selectors will need to do this manually\n\t\t\t\t */\n\t\t\t\tif ( s.sTableId == this.id )\n\t\t\t\t{\n\t\t\t\t\tallSettings.splice( i, 1 );\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\t/* Ensure the table has an ID - required for accessibility */\n\t\t\tif ( sId === null || sId === \"\" )\n\t\t\t{\n\t\t\t\tsId = \"DataTables_Table_\"+(DataTable.ext._unique++);\n\t\t\t\tthis.id = sId;\n\t\t\t}\n\t\t\t\n\t\t\t/* Create the settings object for this table and set some of the default parameters */\n\t\t\tvar oSettings = $.extend( true, {}, DataTable.models.oSettings, {\n\t\t\t\t\"sDestroyWidth\": $this[0].style.width,\n\t\t\t\t\"sInstance\": sId,\n\t\t\t\t\"sTableId\": sId\n\t\t\t} );\n\t\t\toSettings.nTable = this;\n\t\t\toSettings.oApi = _that.internal;\n\t\t\toSettings.oInit = oInit;\n\t\t\t\n\t\t\tallSettings.push( oSettings );\n\t\t\t\n\t\t\t// Need to add the instance after the instance after the settings object has been added\n\t\t\t// to the settings array, so we can self reference the table instance if more than one\n\t\t\toSettings.oInstance = (_that.length===1) ? _that : $this.dataTable();\n\t\t\t\n\t\t\t// Backwards compatibility, before we apply all the defaults\n\t\t\t_fnCompatOpts( oInit );\n\t\t\t\n\t\t\tif ( oInit.oLanguage )\n\t\t\t{\n\t\t\t\t_fnLanguageCompat( oInit.oLanguage );\n\t\t\t}\n\t\t\t\n\t\t\t// If the length menu is given, but the init display length is not, use the length menu\n\t\t\tif ( oInit.aLengthMenu && ! oInit.iDisplayLength )\n\t\t\t{\n\t\t\t\toInit.iDisplayLength = $.isArray( oInit.aLengthMenu[0] ) ?\n\t\t\t\t\toInit.aLengthMenu[0][0] : oInit.aLengthMenu[0];\n\t\t\t}\n\t\t\t\n\t\t\t// Apply the defaults and init options to make a single init object will all\n\t\t\t// options defined from defaults and instance options.\n\t\t\toInit = _fnExtend( $.extend( true, {}, defaults ), oInit );\n\t\t\t\n\t\t\t\n\t\t\t// Map the initialisation options onto the settings object\n\t\t\t_fnMap( oSettings.oFeatures, oInit, [\n\t\t\t\t\"bPaginate\",\n\t\t\t\t\"bLengthChange\",\n\t\t\t\t\"bFilter\",\n\t\t\t\t\"bSort\",\n\t\t\t\t\"bSortMulti\",\n\t\t\t\t\"bInfo\",\n\t\t\t\t\"bProcessing\",\n\t\t\t\t\"bAutoWidth\",\n\t\t\t\t\"bSortClasses\",\n\t\t\t\t\"bServerSide\",\n\t\t\t\t\"bDeferRender\"\n\t\t\t] );\n\t\t\t_fnMap( oSettings, oInit, [\n\t\t\t\t\"asStripeClasses\",\n\t\t\t\t\"ajax\",\n\t\t\t\t\"fnServerData\",\n\t\t\t\t\"fnFormatNumber\",\n\t\t\t\t\"sServerMethod\",\n\t\t\t\t\"aaSorting\",\n\t\t\t\t\"aaSortingFixed\",\n\t\t\t\t\"aLengthMenu\",\n\t\t\t\t\"sPaginationType\",\n\t\t\t\t\"sAjaxSource\",\n\t\t\t\t\"sAjaxDataProp\",\n\t\t\t\t\"iStateDuration\",\n\t\t\t\t\"sDom\",\n\t\t\t\t\"bSortCellsTop\",\n\t\t\t\t\"iTabIndex\",\n\t\t\t\t\"fnStateLoadCallback\",\n\t\t\t\t\"fnStateSaveCallback\",\n\t\t\t\t\"renderer\",\n\t\t\t\t\"searchDelay\",\n\t\t\t\t\"rowId\",\n\t\t\t\t[ \"iCookieDuration\", \"iStateDuration\" ], // backwards compat\n\t\t\t\t[ \"oSearch\", \"oPreviousSearch\" ],\n\t\t\t\t[ \"aoSearchCols\", \"aoPreSearchCols\" ],\n\t\t\t\t[ \"iDisplayLength\", \"_iDisplayLength\" ],\n\t\t\t\t[ \"bJQueryUI\", \"bJUI\" ]\n\t\t\t] );\n\t\t\t_fnMap( oSettings.oScroll, oInit, [\n\t\t\t\t[ \"sScrollX\", \"sX\" ],\n\t\t\t\t[ \"sScrollXInner\", \"sXInner\" ],\n\t\t\t\t[ \"sScrollY\", \"sY\" ],\n\t\t\t\t[ \"bScrollCollapse\", \"bCollapse\" ]\n\t\t\t] );\n\t\t\t_fnMap( oSettings.oLanguage, oInit, \"fnInfoCallback\" );\n\t\t\t\n\t\t\t/* Callback functions which are array driven */\n\t\t\t_fnCallbackReg( oSettings, 'aoDrawCallback', oInit.fnDrawCallback, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoServerParams', oInit.fnServerParams, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoStateSaveParams', oInit.fnStateSaveParams, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoStateLoadParams', oInit.fnStateLoadParams, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoStateLoaded', oInit.fnStateLoaded, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoRowCallback', oInit.fnRowCallback, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoRowCreatedCallback', oInit.fnCreatedRow, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoHeaderCallback', oInit.fnHeaderCallback, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoFooterCallback', oInit.fnFooterCallback, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoInitComplete', oInit.fnInitComplete, 'user' );\n\t\t\t_fnCallbackReg( oSettings, 'aoPreDrawCallback', oInit.fnPreDrawCallback, 'user' );\n\t\t\t\n\t\t\toSettings.rowIdFn = _fnGetObjectDataFn( oInit.rowId );\n\t\t\t\n\t\t\t/* Browser support detection */\n\t\t\t_fnBrowserDetect( oSettings );\n\t\t\t\n\t\t\tvar oClasses = oSettings.oClasses;\n\t\t\t\n\t\t\t// @todo Remove in 1.11\n\t\t\tif ( oInit.bJQueryUI )\n\t\t\t{\n\t\t\t\t/* Use the JUI classes object for display. You could clone the oStdClasses object if\n\t\t\t\t * you want to have multiple tables with multiple independent classes\n\t\t\t\t */\n\t\t\t\t$.extend( oClasses, DataTable.ext.oJUIClasses, oInit.oClasses );\n\t\t\t\n\t\t\t\tif ( oInit.sDom === defaults.sDom && defaults.sDom === \"lfrtip\" )\n\t\t\t\t{\n\t\t\t\t\t/* Set the DOM to use a layout suitable for jQuery UI's theming */\n\t\t\t\t\toSettings.sDom = '<\"H\"lfr>t<\"F\"ip>';\n\t\t\t\t}\n\t\t\t\n\t\t\t\tif ( ! oSettings.renderer ) {\n\t\t\t\t\toSettings.renderer = 'jqueryui';\n\t\t\t\t}\n\t\t\t\telse if ( $.isPlainObject( oSettings.renderer ) && ! oSettings.renderer.header ) {\n\t\t\t\t\toSettings.renderer.header = 'jqueryui';\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t$.extend( oClasses, DataTable.ext.classes, oInit.oClasses );\n\t\t\t}\n\t\t\t$this.addClass( oClasses.sTable );\n\t\t\t\n\t\t\t\n\t\t\tif ( oSettings.iInitDisplayStart === undefined )\n\t\t\t{\n\t\t\t\t/* Display start point, taking into account the save saving */\n\t\t\t\toSettings.iInitDisplayStart = oInit.iDisplayStart;\n\t\t\t\toSettings._iDisplayStart = oInit.iDisplayStart;\n\t\t\t}\n\t\t\t\n\t\t\tif ( oInit.iDeferLoading !== null )\n\t\t\t{\n\t\t\t\toSettings.bDeferLoading = true;\n\t\t\t\tvar tmp = $.isArray( oInit.iDeferLoading );\n\t\t\t\toSettings._iRecordsDisplay = tmp ? oInit.iDeferLoading[0] : oInit.iDeferLoading;\n\t\t\t\toSettings._iRecordsTotal = tmp ? oInit.iDeferLoading[1] : oInit.iDeferLoading;\n\t\t\t}\n\t\t\t\n\t\t\t/* Language definitions */\n\t\t\tvar oLanguage = oSettings.oLanguage;\n\t\t\t$.extend( true, oLanguage, oInit.oLanguage );\n\t\t\t\n\t\t\tif ( oLanguage.sUrl !== \"\" )\n\t\t\t{\n\t\t\t\t/* Get the language definitions from a file - because this Ajax call makes the language\n\t\t\t\t * get async to the remainder of this function we use bInitHandedOff to indicate that\n\t\t\t\t * _fnInitialise will be fired by the returned Ajax handler, rather than the constructor\n\t\t\t\t */\n\t\t\t\t$.ajax( {\n\t\t\t\t\tdataType: 'json',\n\t\t\t\t\turl: oLanguage.sUrl,\n\t\t\t\t\tsuccess: function ( json ) {\n\t\t\t\t\t\t_fnLanguageCompat( json );\n\t\t\t\t\t\t_fnCamelToHungarian( defaults.oLanguage, json );\n\t\t\t\t\t\t$.extend( true, oLanguage, json );\n\t\t\t\t\t\t_fnInitialise( oSettings );\n\t\t\t\t\t},\n\t\t\t\t\terror: function () {\n\t\t\t\t\t\t// Error occurred loading language file, continue on as best we can\n\t\t\t\t\t\t_fnInitialise( oSettings );\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t\tbInitHandedOff = true;\n\t\t\t}\n\t\t\t\n\t\t\t/*\n\t\t\t * Stripes\n\t\t\t */\n\t\t\tif ( oInit.asStripeClasses === null )\n\t\t\t{\n\t\t\t\toSettings.asStripeClasses =[\n\t\t\t\t\toClasses.sStripeOdd,\n\t\t\t\t\toClasses.sStripeEven\n\t\t\t\t];\n\t\t\t}\n\t\t\t\n\t\t\t/* Remove row stripe classes if they are already on the table row */\n\t\t\tvar stripeClasses = oSettings.asStripeClasses;\n\t\t\tvar rowOne = $this.children('tbody').find('tr').eq(0);\n\t\t\tif ( $.inArray( true, $.map( stripeClasses, function(el, i) {\n\t\t\t\treturn rowOne.hasClass(el);\n\t\t\t} ) ) !== -1 ) {\n\t\t\t\t$('tbody tr', this).removeClass( stripeClasses.join(' ') );\n\t\t\t\toSettings.asDestroyStripes = stripeClasses.slice();\n\t\t\t}\n\t\t\t\n\t\t\t/*\n\t\t\t * Columns\n\t\t\t * See if we should load columns automatically or use defined ones\n\t\t\t */\n\t\t\tvar anThs = [];\n\t\t\tvar aoColumnsInit;\n\t\t\tvar nThead = this.getElementsByTagName('thead');\n\t\t\tif ( nThead.length !== 0 )\n\t\t\t{\n\t\t\t\t_fnDetectHeader( oSettings.aoHeader, nThead[0] );\n\t\t\t\tanThs = _fnGetUniqueThs( oSettings );\n\t\t\t}\n\t\t\t\n\t\t\t/* If not given a column array, generate one with nulls */\n\t\t\tif ( oInit.aoColumns === null )\n\t\t\t{\n\t\t\t\taoColumnsInit = [];\n\t\t\t\tfor ( i=0, iLen=anThs.length ; i<iLen ; i++ )\n\t\t\t\t{\n\t\t\t\t\taoColumnsInit.push( null );\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\taoColumnsInit = oInit.aoColumns;\n\t\t\t}\n\t\t\t\n\t\t\t/* Add the columns */\n\t\t\tfor ( i=0, iLen=aoColumnsInit.length ; i<iLen ; i++ )\n\t\t\t{\n\t\t\t\t_fnAddColumn( oSettings, anThs ? anThs[i] : null );\n\t\t\t}\n\t\t\t\n\t\t\t/* Apply the column definitions */\n\t\t\t_fnApplyColumnDefs( oSettings, oInit.aoColumnDefs, aoColumnsInit, function (iCol, oDef) {\n\t\t\t\t_fnColumnOptions( oSettings, iCol, oDef );\n\t\t\t} );\n\t\t\t\n\t\t\t/* HTML5 attribute detection - build an mData object automatically if the\n\t\t\t * attributes are found\n\t\t\t */\n\t\t\tif ( rowOne.length ) {\n\t\t\t\tvar a = function ( cell, name ) {\n\t\t\t\t\treturn cell.getAttribute( 'data-'+name ) !== null ? name : null;\n\t\t\t\t};\n\t\t\t\n\t\t\t\t$( rowOne[0] ).children('th, td').each( function (i, cell) {\n\t\t\t\t\tvar col = oSettings.aoColumns[i];\n\t\t\t\n\t\t\t\t\tif ( col.mData === i ) {\n\t\t\t\t\t\tvar sort = a( cell, 'sort' ) || a( cell, 'order' );\n\t\t\t\t\t\tvar filter = a( cell, 'filter' ) || a( cell, 'search' );\n\t\t\t\n\t\t\t\t\t\tif ( sort !== null || filter !== null ) {\n\t\t\t\t\t\t\tcol.mData = {\n\t\t\t\t\t\t\t\t_: i+'.display',\n\t\t\t\t\t\t\t\tsort: sort !== null ? i+'.@data-'+sort : undefined,\n\t\t\t\t\t\t\t\ttype: sort !== null ? i+'.@data-'+sort : undefined,\n\t\t\t\t\t\t\t\tfilter: filter !== null ? i+'.@data-'+filter : undefined\n\t\t\t\t\t\t\t};\n\t\t\t\n\t\t\t\t\t\t\t_fnColumnOptions( oSettings, i );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t}\n\t\t\t\n\t\t\tvar features = oSettings.oFeatures;\n\t\t\t\n\t\t\t/* Must be done after everything which can be overridden by the state saving! */\n\t\t\tif ( oInit.bStateSave )\n\t\t\t{\n\t\t\t\tfeatures.bStateSave = true;\n\t\t\t\t_fnLoadState( oSettings, oInit );\n\t\t\t\t_fnCallbackReg( oSettings, 'aoDrawCallback', _fnSaveState, 'state_save' );\n\t\t\t}\n\t\t\t\n\t\t\t\n\t\t\t/*\n\t\t\t * Sorting\n\t\t\t * @todo For modularisation (1.11) this needs to do into a sort start up handler\n\t\t\t */\n\t\t\t\n\t\t\t// If aaSorting is not defined, then we use the first indicator in asSorting\n\t\t\t// in case that has been altered, so the default sort reflects that option\n\t\t\tif ( oInit.aaSorting === undefined )\n\t\t\t{\n\t\t\t\tvar sorting = oSettings.aaSorting;\n\t\t\t\tfor ( i=0, iLen=sorting.length ; i<iLen ; i++ )\n\t\t\t\t{\n\t\t\t\t\tsorting[i][1] = oSettings.aoColumns[ i ].asSorting[0];\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\t/* Do a first pass on the sorting classes (allows any size changes to be taken into\n\t\t\t * account, and also will apply sorting disabled classes if disabled\n\t\t\t */\n\t\t\t_fnSortingClasses( oSettings );\n\t\t\t\n\t\t\tif ( features.bSort )\n\t\t\t{\n\t\t\t\t_fnCallbackReg( oSettings, 'aoDrawCallback', function () {\n\t\t\t\t\tif ( oSettings.bSorted ) {\n\t\t\t\t\t\tvar aSort = _fnSortFlatten( oSettings );\n\t\t\t\t\t\tvar sortedColumns = {};\n\t\t\t\n\t\t\t\t\t\t$.each( aSort, function (i, val) {\n\t\t\t\t\t\t\tsortedColumns[ val.src ] = val.dir;\n\t\t\t\t\t\t} );\n\t\t\t\n\t\t\t\t\t\t_fnCallbackFire( oSettings, null, 'order', [oSettings, aSort, sortedColumns] );\n\t\t\t\t\t\t_fnSortAria( oSettings );\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t}\n\t\t\t\n\t\t\t_fnCallbackReg( oSettings, 'aoDrawCallback', function () {\n\t\t\t\tif ( oSettings.bSorted || _fnDataSource( oSettings ) === 'ssp' || features.bDeferRender ) {\n\t\t\t\t\t_fnSortingClasses( oSettings );\n\t\t\t\t}\n\t\t\t}, 'sc' );\n\t\t\t\n\t\t\t\n\t\t\t/*\n\t\t\t * Final init\n\t\t\t * Cache the header, body and footer as required, creating them if needed\n\t\t\t */\n\t\t\t\n\t\t\t// Work around for Webkit bug 83867 - store the caption-side before removing from doc\n\t\t\tvar captions = $this.children('caption').each( function () {\n\t\t\t\tthis._captionSide = $this.css('caption-side');\n\t\t\t} );\n\t\t\t\n\t\t\tvar thead = $this.children('thead');\n\t\t\tif ( thead.length === 0 )\n\t\t\t{\n\t\t\t\tthead = $('<thead/>').appendTo(this);\n\t\t\t}\n\t\t\toSettings.nTHead = thead[0];\n\t\t\t\n\t\t\tvar tbody = $this.children('tbody');\n\t\t\tif ( tbody.length === 0 )\n\t\t\t{\n\t\t\t\ttbody = $('<tbody/>').appendTo(this);\n\t\t\t}\n\t\t\toSettings.nTBody = tbody[0];\n\t\t\t\n\t\t\tvar tfoot = $this.children('tfoot');\n\t\t\tif ( tfoot.length === 0 && captions.length > 0 && (oSettings.oScroll.sX !== \"\" || oSettings.oScroll.sY !== \"\") )\n\t\t\t{\n\t\t\t\t// If we are a scrolling table, and no footer has been given, then we need to create\n\t\t\t\t// a tfoot element for the caption element to be appended to\n\t\t\t\ttfoot = $('<tfoot/>').appendTo(this);\n\t\t\t}\n\t\t\t\n\t\t\tif ( tfoot.length === 0 || tfoot.children().length === 0 ) {\n\t\t\t\t$this.addClass( oClasses.sNoFooter );\n\t\t\t}\n\t\t\telse if ( tfoot.length > 0 ) {\n\t\t\t\toSettings.nTFoot = tfoot[0];\n\t\t\t\t_fnDetectHeader( oSettings.aoFooter, oSettings.nTFoot );\n\t\t\t}\n\t\t\t\n\t\t\t/* Check if there is data passing into the constructor */\n\t\t\tif ( oInit.aaData )\n\t\t\t{\n\t\t\t\tfor ( i=0 ; i<oInit.aaData.length ; i++ )\n\t\t\t\t{\n\t\t\t\t\t_fnAddData( oSettings, oInit.aaData[ i ] );\n\t\t\t\t}\n\t\t\t}\n\t\t\telse if ( oSettings.bDeferLoading || _fnDataSource( oSettings ) == 'dom' )\n\t\t\t{\n\t\t\t\t/* Grab the data from the page - only do this when deferred loading or no Ajax\n\t\t\t\t * source since there is no point in reading the DOM data if we are then going\n\t\t\t\t * to replace it with Ajax data\n\t\t\t\t */\n\t\t\t\t_fnAddTr( oSettings, $(oSettings.nTBody).children('tr') );\n\t\t\t}\n\t\t\t\n\t\t\t/* Copy the data index array */\n\t\t\toSettings.aiDisplay = oSettings.aiDisplayMaster.slice();\n\t\t\t\n\t\t\t/* Initialisation complete - table can be drawn */\n\t\t\toSettings.bInitialised = true;\n\t\t\t\n\t\t\t/* Check if we need to initialise the table (it might not have been handed off to the\n\t\t\t * language processor)\n\t\t\t */\n\t\t\tif ( bInitHandedOff === false )\n\t\t\t{\n\t\t\t\t_fnInitialise( oSettings );\n\t\t\t}\n\t\t} );\n\t\t_that = null;\n\t\treturn this;\n\t};\n\n\t\n\t/*\n\t * It is useful to have variables which are scoped locally so only the\n\t * DataTables functions can access them and they don't leak into global space.\n\t * At the same time these functions are often useful over multiple files in the\n\t * core and API, so we list, or at least document, all variables which are used\n\t * by DataTables as private variables here. This also ensures that there is no\n\t * clashing of variable names and that they can easily referenced for reuse.\n\t */\n\t\n\t\n\t// Defined else where\n\t// _selector_run\n\t// _selector_opts\n\t// _selector_first\n\t// _selector_row_indexes\n\t\n\tvar _ext; // DataTable.ext\n\tvar _Api; // DataTable.Api\n\tvar _api_register; // DataTable.Api.register\n\tvar _api_registerPlural; // DataTable.Api.registerPlural\n\t\n\tvar _re_dic = {};\n\tvar _re_new_lines = /[\\r\\n]/g;\n\tvar _re_html = /<.*?>/g;\n\tvar _re_date_start = /^[\\w\\+\\-]/;\n\tvar _re_date_end = /[\\w\\+\\-]$/;\n\t\n\t// Escape regular expression special characters\n\tvar _re_escape_regex = new RegExp( '(\\\\' + [ '/', '.', '*', '+', '?', '|', '(', ')', '[', ']', '{', '}', '\\\\', '$', '^', '-' ].join('|\\\\') + ')', 'g' );\n\t\n\t// http://en.wikipedia.org/wiki/Foreign_exchange_market\n\t// - \\u20BD - Russian ruble.\n\t// - \\u20a9 - South Korean Won\n\t// - \\u20BA - Turkish Lira\n\t// - \\u20B9 - Indian Rupee\n\t// - R - Brazil (R$) and South Africa\n\t// - fr - Swiss Franc\n\t// - kr - Swedish krona, Norwegian krone and Danish krone\n\t// - \\u2009 is thin space and \\u202F is narrow no-break space, both used in many\n\t// standards as thousands separators.\n\tvar _re_formatted_numeric = /[',$£€¥%\\u2009\\u202F\\u20BD\\u20a9\\u20BArfk]/gi;\n\t\n\t\n\tvar _empty = function ( d ) {\n\t\treturn !d || d === true || d === '-' ? true : false;\n\t};\n\t\n\t\n\tvar _intVal = function ( s ) {\n\t\tvar integer = parseInt( s, 10 );\n\t\treturn !isNaN(integer) && isFinite(s) ? integer : null;\n\t};\n\t\n\t// Convert from a formatted number with characters other than `.` as the\n\t// decimal place, to a Javascript number\n\tvar _numToDecimal = function ( num, decimalPoint ) {\n\t\t// Cache created regular expressions for speed as this function is called often\n\t\tif ( ! _re_dic[ decimalPoint ] ) {\n\t\t\t_re_dic[ decimalPoint ] = new RegExp( _fnEscapeRegex( decimalPoint ), 'g' );\n\t\t}\n\t\treturn typeof num === 'string' && decimalPoint !== '.' ?\n\t\t\tnum.replace( /\\./g, '' ).replace( _re_dic[ decimalPoint ], '.' ) :\n\t\t\tnum;\n\t};\n\t\n\t\n\tvar _isNumber = function ( d, decimalPoint, formatted ) {\n\t\tvar strType = typeof d === 'string';\n\t\n\t\t// If empty return immediately so there must be a number if it is a\n\t\t// formatted string (this stops the string \"k\", or \"kr\", etc being detected\n\t\t// as a formatted number for currency\n\t\tif ( _empty( d ) ) {\n\t\t\treturn true;\n\t\t}\n\t\n\t\tif ( decimalPoint && strType ) {\n\t\t\td = _numToDecimal( d, decimalPoint );\n\t\t}\n\t\n\t\tif ( formatted && strType ) {\n\t\t\td = d.replace( _re_formatted_numeric, '' );\n\t\t}\n\t\n\t\treturn !isNaN( parseFloat(d) ) && isFinite( d );\n\t};\n\t\n\t\n\t// A string without HTML in it can be considered to be HTML still\n\tvar _isHtml = function ( d ) {\n\t\treturn _empty( d ) || typeof d === 'string';\n\t};\n\t\n\t\n\tvar _htmlNumeric = function ( d, decimalPoint, formatted ) {\n\t\tif ( _empty( d ) ) {\n\t\t\treturn true;\n\t\t}\n\t\n\t\tvar html = _isHtml( d );\n\t\treturn ! html ?\n\t\t\tnull :\n\t\t\t_isNumber( _stripHtml( d ), decimalPoint, formatted ) ?\n\t\t\t\ttrue :\n\t\t\t\tnull;\n\t};\n\t\n\t\n\tvar _pluck = function ( a, prop, prop2 ) {\n\t\tvar out = [];\n\t\tvar i=0, ien=a.length;\n\t\n\t\t// Could have the test in the loop for slightly smaller code, but speed\n\t\t// is essential here\n\t\tif ( prop2 !== undefined ) {\n\t\t\tfor ( ; i<ien ; i++ ) {\n\t\t\t\tif ( a[i] && a[i][ prop ] ) {\n\t\t\t\t\tout.push( a[i][ prop ][ prop2 ] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tfor ( ; i<ien ; i++ ) {\n\t\t\t\tif ( a[i] ) {\n\t\t\t\t\tout.push( a[i][ prop ] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\treturn out;\n\t};\n\t\n\t\n\t// Basically the same as _pluck, but rather than looping over `a` we use `order`\n\t// as the indexes to pick from `a`\n\tvar _pluck_order = function ( a, order, prop, prop2 )\n\t{\n\t\tvar out = [];\n\t\tvar i=0, ien=order.length;\n\t\n\t\t// Could have the test in the loop for slightly smaller code, but speed\n\t\t// is essential here\n\t\tif ( prop2 !== undefined ) {\n\t\t\tfor ( ; i<ien ; i++ ) {\n\t\t\t\tif ( a[ order[i] ][ prop ] ) {\n\t\t\t\t\tout.push( a[ order[i] ][ prop ][ prop2 ] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tfor ( ; i<ien ; i++ ) {\n\t\t\t\tout.push( a[ order[i] ][ prop ] );\n\t\t\t}\n\t\t}\n\t\n\t\treturn out;\n\t};\n\t\n\t\n\tvar _range = function ( len, start )\n\t{\n\t\tvar out = [];\n\t\tvar end;\n\t\n\t\tif ( start === undefined ) {\n\t\t\tstart = 0;\n\t\t\tend = len;\n\t\t}\n\t\telse {\n\t\t\tend = start;\n\t\t\tstart = len;\n\t\t}\n\t\n\t\tfor ( var i=start ; i<end ; i++ ) {\n\t\t\tout.push( i );\n\t\t}\n\t\n\t\treturn out;\n\t};\n\t\n\t\n\tvar _removeEmpty = function ( a )\n\t{\n\t\tvar out = [];\n\t\n\t\tfor ( var i=0, ien=a.length ; i<ien ; i++ ) {\n\t\t\tif ( a[i] ) { // careful - will remove all falsy values!\n\t\t\t\tout.push( a[i] );\n\t\t\t}\n\t\t}\n\t\n\t\treturn out;\n\t};\n\t\n\t\n\tvar _stripHtml = function ( d ) {\n\t\treturn d.replace( _re_html, '' );\n\t};\n\t\n\t\n\t/**\n\t * Find the unique elements in a source array.\n\t *\n\t * @param {array} src Source array\n\t * @return {array} Array of unique items\n\t * @ignore\n\t */\n\tvar _unique = function ( src )\n\t{\n\t\t// A faster unique method is to use object keys to identify used values,\n\t\t// but this doesn't work with arrays or objects, which we must also\n\t\t// consider. See jsperf.com/compare-array-unique-versions/4 for more\n\t\t// information.\n\t\tvar\n\t\t\tout = [],\n\t\t\tval,\n\t\t\ti, ien=src.length,\n\t\t\tj, k=0;\n\t\n\t\tagain: for ( i=0 ; i<ien ; i++ ) {\n\t\t\tval = src[i];\n\t\n\t\t\tfor ( j=0 ; j<k ; j++ ) {\n\t\t\t\tif ( out[j] === val ) {\n\t\t\t\t\tcontinue again;\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\tout.push( val );\n\t\t\tk++;\n\t\t}\n\t\n\t\treturn out;\n\t};\n\t\n\t\n\t/**\n\t * DataTables utility methods\n\t * \n\t * This namespace provides helper methods that DataTables uses internally to\n\t * create a DataTable, but which are not exclusively used only for DataTables.\n\t * These methods can be used by extension authors to save the duplication of\n\t * code.\n\t *\n\t * @namespace\n\t */\n\tDataTable.util = {\n\t\t/**\n\t\t * Throttle the calls to a function. Arguments and context are maintained\n\t\t * for the throttled function.\n\t\t *\n\t\t * @param {function} fn Function to be called\n\t\t * @param {integer} freq Call frequency in mS\n\t\t * @return {function} Wrapped function\n\t\t */\n\t\tthrottle: function ( fn, freq ) {\n\t\t\tvar\n\t\t\t\tfrequency = freq !== undefined ? freq : 200,\n\t\t\t\tlast,\n\t\t\t\ttimer;\n\t\n\t\t\treturn function () {\n\t\t\t\tvar\n\t\t\t\t\tthat = this,\n\t\t\t\t\tnow = +new Date(),\n\t\t\t\t\targs = arguments;\n\t\n\t\t\t\tif ( last && now < last + frequency ) {\n\t\t\t\t\tclearTimeout( timer );\n\t\n\t\t\t\t\ttimer = setTimeout( function () {\n\t\t\t\t\t\tlast = undefined;\n\t\t\t\t\t\tfn.apply( that, args );\n\t\t\t\t\t}, frequency );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tlast = now;\n\t\t\t\t\tfn.apply( that, args );\n\t\t\t\t}\n\t\t\t};\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Escape a string such that it can be used in a regular expression\n\t\t *\n\t\t * @param {string} val string to escape\n\t\t * @returns {string} escaped string\n\t\t */\n\t\tescapeRegex: function ( val ) {\n\t\t\treturn val.replace( _re_escape_regex, '\\\\$1' );\n\t\t}\n\t};\n\t\n\t\n\t\n\t/**\n\t * Create a mapping object that allows camel case parameters to be looked up\n\t * for their Hungarian counterparts. The mapping is stored in a private\n\t * parameter called `_hungarianMap` which can be accessed on the source object.\n\t * @param {object} o\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnHungarianMap ( o )\n\t{\n\t\tvar\n\t\t\thungarian = 'a aa ai ao as b fn i m o s ',\n\t\t\tmatch,\n\t\t\tnewKey,\n\t\t\tmap = {};\n\t\n\t\t$.each( o, function (key, val) {\n\t\t\tmatch = key.match(/^([^A-Z]+?)([A-Z])/);\n\t\n\t\t\tif ( match && hungarian.indexOf(match[1]+' ') !== -1 )\n\t\t\t{\n\t\t\t\tnewKey = key.replace( match[0], match[2].toLowerCase() );\n\t\t\t\tmap[ newKey ] = key;\n\t\n\t\t\t\tif ( match[1] === 'o' )\n\t\t\t\t{\n\t\t\t\t\t_fnHungarianMap( o[key] );\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t\n\t\to._hungarianMap = map;\n\t}\n\t\n\t\n\t/**\n\t * Convert from camel case parameters to Hungarian, based on a Hungarian map\n\t * created by _fnHungarianMap.\n\t * @param {object} src The model object which holds all parameters that can be\n\t * mapped.\n\t * @param {object} user The object to convert from camel case to Hungarian.\n\t * @param {boolean} force When set to `true`, properties which already have a\n\t * Hungarian value in the `user` object will be overwritten. Otherwise they\n\t * won't be.\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnCamelToHungarian ( src, user, force )\n\t{\n\t\tif ( ! src._hungarianMap ) {\n\t\t\t_fnHungarianMap( src );\n\t\t}\n\t\n\t\tvar hungarianKey;\n\t\n\t\t$.each( user, function (key, val) {\n\t\t\thungarianKey = src._hungarianMap[ key ];\n\t\n\t\t\tif ( hungarianKey !== undefined && (force || user[hungarianKey] === undefined) )\n\t\t\t{\n\t\t\t\t// For objects, we need to buzz down into the object to copy parameters\n\t\t\t\tif ( hungarianKey.charAt(0) === 'o' )\n\t\t\t\t{\n\t\t\t\t\t// Copy the camelCase options over to the hungarian\n\t\t\t\t\tif ( ! user[ hungarianKey ] ) {\n\t\t\t\t\t\tuser[ hungarianKey ] = {};\n\t\t\t\t\t}\n\t\t\t\t\t$.extend( true, user[hungarianKey], user[key] );\n\t\n\t\t\t\t\t_fnCamelToHungarian( src[hungarianKey], user[hungarianKey], force );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tuser[hungarianKey] = user[ key ];\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t}\n\t\n\t\n\t/**\n\t * Language compatibility - when certain options are given, and others aren't, we\n\t * need to duplicate the values over, in order to provide backwards compatibility\n\t * with older language files.\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnLanguageCompat( lang )\n\t{\n\t\tvar defaults = DataTable.defaults.oLanguage;\n\t\tvar zeroRecords = lang.sZeroRecords;\n\t\n\t\t/* Backwards compatibility - if there is no sEmptyTable given, then use the same as\n\t\t * sZeroRecords - assuming that is given.\n\t\t */\n\t\tif ( ! lang.sEmptyTable && zeroRecords &&\n\t\t\tdefaults.sEmptyTable === \"No data available in table\" )\n\t\t{\n\t\t\t_fnMap( lang, lang, 'sZeroRecords', 'sEmptyTable' );\n\t\t}\n\t\n\t\t/* Likewise with loading records */\n\t\tif ( ! lang.sLoadingRecords && zeroRecords &&\n\t\t\tdefaults.sLoadingRecords === \"Loading...\" )\n\t\t{\n\t\t\t_fnMap( lang, lang, 'sZeroRecords', 'sLoadingRecords' );\n\t\t}\n\t\n\t\t// Old parameter name of the thousands separator mapped onto the new\n\t\tif ( lang.sInfoThousands ) {\n\t\t\tlang.sThousands = lang.sInfoThousands;\n\t\t}\n\t\n\t\tvar decimal = lang.sDecimal;\n\t\tif ( decimal ) {\n\t\t\t_addNumericSort( decimal );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Map one parameter onto another\n\t * @param {object} o Object to map\n\t * @param {*} knew The new parameter name\n\t * @param {*} old The old parameter name\n\t */\n\tvar _fnCompatMap = function ( o, knew, old ) {\n\t\tif ( o[ knew ] !== undefined ) {\n\t\t\to[ old ] = o[ knew ];\n\t\t}\n\t};\n\t\n\t\n\t/**\n\t * Provide backwards compatibility for the main DT options. Note that the new\n\t * options are mapped onto the old parameters, so this is an external interface\n\t * change only.\n\t * @param {object} init Object to map\n\t */\n\tfunction _fnCompatOpts ( init )\n\t{\n\t\t_fnCompatMap( init, 'ordering', 'bSort' );\n\t\t_fnCompatMap( init, 'orderMulti', 'bSortMulti' );\n\t\t_fnCompatMap( init, 'orderClasses', 'bSortClasses' );\n\t\t_fnCompatMap( init, 'orderCellsTop', 'bSortCellsTop' );\n\t\t_fnCompatMap( init, 'order', 'aaSorting' );\n\t\t_fnCompatMap( init, 'orderFixed', 'aaSortingFixed' );\n\t\t_fnCompatMap( init, 'paging', 'bPaginate' );\n\t\t_fnCompatMap( init, 'pagingType', 'sPaginationType' );\n\t\t_fnCompatMap( init, 'pageLength', 'iDisplayLength' );\n\t\t_fnCompatMap( init, 'searching', 'bFilter' );\n\t\n\t\t// Boolean initialisation of x-scrolling\n\t\tif ( typeof init.sScrollX === 'boolean' ) {\n\t\t\tinit.sScrollX = init.sScrollX ? '100%' : '';\n\t\t}\n\t\tif ( typeof init.scrollX === 'boolean' ) {\n\t\t\tinit.scrollX = init.scrollX ? '100%' : '';\n\t\t}\n\t\n\t\t// Column search objects are in an array, so it needs to be converted\n\t\t// element by element\n\t\tvar searchCols = init.aoSearchCols;\n\t\n\t\tif ( searchCols ) {\n\t\t\tfor ( var i=0, ien=searchCols.length ; i<ien ; i++ ) {\n\t\t\t\tif ( searchCols[i] ) {\n\t\t\t\t\t_fnCamelToHungarian( DataTable.models.oSearch, searchCols[i] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Provide backwards compatibility for column options. Note that the new options\n\t * are mapped onto the old parameters, so this is an external interface change\n\t * only.\n\t * @param {object} init Object to map\n\t */\n\tfunction _fnCompatCols ( init )\n\t{\n\t\t_fnCompatMap( init, 'orderable', 'bSortable' );\n\t\t_fnCompatMap( init, 'orderData', 'aDataSort' );\n\t\t_fnCompatMap( init, 'orderSequence', 'asSorting' );\n\t\t_fnCompatMap( init, 'orderDataType', 'sortDataType' );\n\t\n\t\t// orderData can be given as an integer\n\t\tvar dataSort = init.aDataSort;\n\t\tif ( dataSort && ! $.isArray( dataSort ) ) {\n\t\t\tinit.aDataSort = [ dataSort ];\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Browser feature detection for capabilities, quirks\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnBrowserDetect( settings )\n\t{\n\t\t// We don't need to do this every time DataTables is constructed, the values\n\t\t// calculated are specific to the browser and OS configuration which we\n\t\t// don't expect to change between initialisations\n\t\tif ( ! DataTable.__browser ) {\n\t\t\tvar browser = {};\n\t\t\tDataTable.__browser = browser;\n\t\n\t\t\t// Scrolling feature / quirks detection\n\t\t\tvar n = $('<div/>')\n\t\t\t\t.css( {\n\t\t\t\t\tposition: 'fixed',\n\t\t\t\t\ttop: 0,\n\t\t\t\t\tleft: 0,\n\t\t\t\t\theight: 1,\n\t\t\t\t\twidth: 1,\n\t\t\t\t\toverflow: 'hidden'\n\t\t\t\t} )\n\t\t\t\t.append(\n\t\t\t\t\t$('<div/>')\n\t\t\t\t\t\t.css( {\n\t\t\t\t\t\t\tposition: 'absolute',\n\t\t\t\t\t\t\ttop: 1,\n\t\t\t\t\t\t\tleft: 1,\n\t\t\t\t\t\t\twidth: 100,\n\t\t\t\t\t\t\toverflow: 'scroll'\n\t\t\t\t\t\t} )\n\t\t\t\t\t\t.append(\n\t\t\t\t\t\t\t$('<div/>')\n\t\t\t\t\t\t\t\t.css( {\n\t\t\t\t\t\t\t\t\twidth: '100%',\n\t\t\t\t\t\t\t\t\theight: 10\n\t\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t)\n\t\t\t\t)\n\t\t\t\t.appendTo( 'body' );\n\t\n\t\t\tvar outer = n.children();\n\t\t\tvar inner = outer.children();\n\t\n\t\t\t// Numbers below, in order, are:\n\t\t\t// inner.offsetWidth, inner.clientWidth, outer.offsetWidth, outer.clientWidth\n\t\t\t//\n\t\t\t// IE6 XP: 100 100 100 83\n\t\t\t// IE7 Vista: 100 100 100 83\n\t\t\t// IE 8+ Windows: 83 83 100 83\n\t\t\t// Evergreen Windows: 83 83 100 83\n\t\t\t// Evergreen Mac with scrollbars: 85 85 100 85\n\t\t\t// Evergreen Mac without scrollbars: 100 100 100 100\n\t\n\t\t\t// Get scrollbar width\n\t\t\tbrowser.barWidth = outer[0].offsetWidth - outer[0].clientWidth;\n\t\n\t\t\t// IE6/7 will oversize a width 100% element inside a scrolling element, to\n\t\t\t// include the width of the scrollbar, while other browsers ensure the inner\n\t\t\t// element is contained without forcing scrolling\n\t\t\tbrowser.bScrollOversize = inner[0].offsetWidth === 100 && outer[0].clientWidth !== 100;\n\t\n\t\t\t// In rtl text layout, some browsers (most, but not all) will place the\n\t\t\t// scrollbar on the left, rather than the right.\n\t\t\tbrowser.bScrollbarLeft = Math.round( inner.offset().left ) !== 1;\n\t\n\t\t\t// IE8- don't provide height and width for getBoundingClientRect\n\t\t\tbrowser.bBounding = n[0].getBoundingClientRect().width ? true : false;\n\t\n\t\t\tn.remove();\n\t\t}\n\t\n\t\t$.extend( settings.oBrowser, DataTable.__browser );\n\t\tsettings.oScroll.iBarWidth = DataTable.__browser.barWidth;\n\t}\n\t\n\t\n\t/**\n\t * Array.prototype reduce[Right] method, used for browsers which don't support\n\t * JS 1.6. Done this way to reduce code size, since we iterate either way\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnReduce ( that, fn, init, start, end, inc )\n\t{\n\t\tvar\n\t\t\ti = start,\n\t\t\tvalue,\n\t\t\tisSet = false;\n\t\n\t\tif ( init !== undefined ) {\n\t\t\tvalue = init;\n\t\t\tisSet = true;\n\t\t}\n\t\n\t\twhile ( i !== end ) {\n\t\t\tif ( ! that.hasOwnProperty(i) ) {\n\t\t\t\tcontinue;\n\t\t\t}\n\t\n\t\t\tvalue = isSet ?\n\t\t\t\tfn( value, that[i], i, that ) :\n\t\t\t\tthat[i];\n\t\n\t\t\tisSet = true;\n\t\t\ti += inc;\n\t\t}\n\t\n\t\treturn value;\n\t}\n\t\n\t/**\n\t * Add a column to the list used for the table with default values\n\t * @param {object} oSettings dataTables settings object\n\t * @param {node} nTh The th element for this column\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAddColumn( oSettings, nTh )\n\t{\n\t\t// Add column to aoColumns array\n\t\tvar oDefaults = DataTable.defaults.column;\n\t\tvar iCol = oSettings.aoColumns.length;\n\t\tvar oCol = $.extend( {}, DataTable.models.oColumn, oDefaults, {\n\t\t\t\"nTh\": nTh ? nTh : document.createElement('th'),\n\t\t\t\"sTitle\": oDefaults.sTitle ? oDefaults.sTitle : nTh ? nTh.innerHTML : '',\n\t\t\t\"aDataSort\": oDefaults.aDataSort ? oDefaults.aDataSort : [iCol],\n\t\t\t\"mData\": oDefaults.mData ? oDefaults.mData : iCol,\n\t\t\tidx: iCol\n\t\t} );\n\t\toSettings.aoColumns.push( oCol );\n\t\n\t\t// Add search object for column specific search. Note that the `searchCols[ iCol ]`\n\t\t// passed into extend can be undefined. This allows the user to give a default\n\t\t// with only some of the parameters defined, and also not give a default\n\t\tvar searchCols = oSettings.aoPreSearchCols;\n\t\tsearchCols[ iCol ] = $.extend( {}, DataTable.models.oSearch, searchCols[ iCol ] );\n\t\n\t\t// Use the default column options function to initialise classes etc\n\t\t_fnColumnOptions( oSettings, iCol, $(nTh).data() );\n\t}\n\t\n\t\n\t/**\n\t * Apply options for a column\n\t * @param {object} oSettings dataTables settings object\n\t * @param {int} iCol column index to consider\n\t * @param {object} oOptions object with sType, bVisible and bSearchable etc\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnColumnOptions( oSettings, iCol, oOptions )\n\t{\n\t\tvar oCol = oSettings.aoColumns[ iCol ];\n\t\tvar oClasses = oSettings.oClasses;\n\t\tvar th = $(oCol.nTh);\n\t\n\t\t// Try to get width information from the DOM. We can't get it from CSS\n\t\t// as we'd need to parse the CSS stylesheet. `width` option can override\n\t\tif ( ! oCol.sWidthOrig ) {\n\t\t\t// Width attribute\n\t\t\toCol.sWidthOrig = th.attr('width') || null;\n\t\n\t\t\t// Style attribute\n\t\t\tvar t = (th.attr('style') || '').match(/width:\\s*(\\d+[pxem%]+)/);\n\t\t\tif ( t ) {\n\t\t\t\toCol.sWidthOrig = t[1];\n\t\t\t}\n\t\t}\n\t\n\t\t/* User specified column options */\n\t\tif ( oOptions !== undefined && oOptions !== null )\n\t\t{\n\t\t\t// Backwards compatibility\n\t\t\t_fnCompatCols( oOptions );\n\t\n\t\t\t// Map camel case parameters to their Hungarian counterparts\n\t\t\t_fnCamelToHungarian( DataTable.defaults.column, oOptions );\n\t\n\t\t\t/* Backwards compatibility for mDataProp */\n\t\t\tif ( oOptions.mDataProp !== undefined && !oOptions.mData )\n\t\t\t{\n\t\t\t\toOptions.mData = oOptions.mDataProp;\n\t\t\t}\n\t\n\t\t\tif ( oOptions.sType )\n\t\t\t{\n\t\t\t\toCol._sManualType = oOptions.sType;\n\t\t\t}\n\t\n\t\t\t// `class` is a reserved word in Javascript, so we need to provide\n\t\t\t// the ability to use a valid name for the camel case input\n\t\t\tif ( oOptions.className && ! oOptions.sClass )\n\t\t\t{\n\t\t\t\toOptions.sClass = oOptions.className;\n\t\t\t}\n\t\n\t\t\t$.extend( oCol, oOptions );\n\t\t\t_fnMap( oCol, oOptions, \"sWidth\", \"sWidthOrig\" );\n\t\n\t\t\t/* iDataSort to be applied (backwards compatibility), but aDataSort will take\n\t\t\t * priority if defined\n\t\t\t */\n\t\t\tif ( oOptions.iDataSort !== undefined )\n\t\t\t{\n\t\t\t\toCol.aDataSort = [ oOptions.iDataSort ];\n\t\t\t}\n\t\t\t_fnMap( oCol, oOptions, \"aDataSort\" );\n\t\t}\n\t\n\t\t/* Cache the data get and set functions for speed */\n\t\tvar mDataSrc = oCol.mData;\n\t\tvar mData = _fnGetObjectDataFn( mDataSrc );\n\t\tvar mRender = oCol.mRender ? _fnGetObjectDataFn( oCol.mRender ) : null;\n\t\n\t\tvar attrTest = function( src ) {\n\t\t\treturn typeof src === 'string' && src.indexOf('@') !== -1;\n\t\t};\n\t\toCol._bAttrSrc = $.isPlainObject( mDataSrc ) && (\n\t\t\tattrTest(mDataSrc.sort) || attrTest(mDataSrc.type) || attrTest(mDataSrc.filter)\n\t\t);\n\t\toCol._setter = null;\n\t\n\t\toCol.fnGetData = function (rowData, type, meta) {\n\t\t\tvar innerData = mData( rowData, type, undefined, meta );\n\t\n\t\t\treturn mRender && type ?\n\t\t\t\tmRender( innerData, type, rowData, meta ) :\n\t\t\t\tinnerData;\n\t\t};\n\t\toCol.fnSetData = function ( rowData, val, meta ) {\n\t\t\treturn _fnSetObjectDataFn( mDataSrc )( rowData, val, meta );\n\t\t};\n\t\n\t\t// Indicate if DataTables should read DOM data as an object or array\n\t\t// Used in _fnGetRowElements\n\t\tif ( typeof mDataSrc !== 'number' ) {\n\t\t\toSettings._rowReadObject = true;\n\t\t}\n\t\n\t\t/* Feature sorting overrides column specific when off */\n\t\tif ( !oSettings.oFeatures.bSort )\n\t\t{\n\t\t\toCol.bSortable = false;\n\t\t\tth.addClass( oClasses.sSortableNone ); // Have to add class here as order event isn't called\n\t\t}\n\t\n\t\t/* Check that the class assignment is correct for sorting */\n\t\tvar bAsc = $.inArray('asc', oCol.asSorting) !== -1;\n\t\tvar bDesc = $.inArray('desc', oCol.asSorting) !== -1;\n\t\tif ( !oCol.bSortable || (!bAsc && !bDesc) )\n\t\t{\n\t\t\toCol.sSortingClass = oClasses.sSortableNone;\n\t\t\toCol.sSortingClassJUI = \"\";\n\t\t}\n\t\telse if ( bAsc && !bDesc )\n\t\t{\n\t\t\toCol.sSortingClass = oClasses.sSortableAsc;\n\t\t\toCol.sSortingClassJUI = oClasses.sSortJUIAscAllowed;\n\t\t}\n\t\telse if ( !bAsc && bDesc )\n\t\t{\n\t\t\toCol.sSortingClass = oClasses.sSortableDesc;\n\t\t\toCol.sSortingClassJUI = oClasses.sSortJUIDescAllowed;\n\t\t}\n\t\telse\n\t\t{\n\t\t\toCol.sSortingClass = oClasses.sSortable;\n\t\t\toCol.sSortingClassJUI = oClasses.sSortJUI;\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Adjust the table column widths for new data. Note: you would probably want to\n\t * do a redraw after calling this function!\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAdjustColumnSizing ( settings )\n\t{\n\t\t/* Not interested in doing column width calculation if auto-width is disabled */\n\t\tif ( settings.oFeatures.bAutoWidth !== false )\n\t\t{\n\t\t\tvar columns = settings.aoColumns;\n\t\n\t\t\t_fnCalculateColumnWidths( settings );\n\t\t\tfor ( var i=0 , iLen=columns.length ; i<iLen ; i++ )\n\t\t\t{\n\t\t\t\tcolumns[i].nTh.style.width = columns[i].sWidth;\n\t\t\t}\n\t\t}\n\t\n\t\tvar scroll = settings.oScroll;\n\t\tif ( scroll.sY !== '' || scroll.sX !== '')\n\t\t{\n\t\t\t_fnScrollDraw( settings );\n\t\t}\n\t\n\t\t_fnCallbackFire( settings, null, 'column-sizing', [settings] );\n\t}\n\t\n\t\n\t/**\n\t * Covert the index of a visible column to the index in the data array (take account\n\t * of hidden columns)\n\t * @param {object} oSettings dataTables settings object\n\t * @param {int} iMatch Visible column index to lookup\n\t * @returns {int} i the data index\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnVisibleToColumnIndex( oSettings, iMatch )\n\t{\n\t\tvar aiVis = _fnGetColumns( oSettings, 'bVisible' );\n\t\n\t\treturn typeof aiVis[iMatch] === 'number' ?\n\t\t\taiVis[iMatch] :\n\t\t\tnull;\n\t}\n\t\n\t\n\t/**\n\t * Covert the index of an index in the data array and convert it to the visible\n\t * column index (take account of hidden columns)\n\t * @param {int} iMatch Column index to lookup\n\t * @param {object} oSettings dataTables settings object\n\t * @returns {int} i the data index\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnColumnIndexToVisible( oSettings, iMatch )\n\t{\n\t\tvar aiVis = _fnGetColumns( oSettings, 'bVisible' );\n\t\tvar iPos = $.inArray( iMatch, aiVis );\n\t\n\t\treturn iPos !== -1 ? iPos : null;\n\t}\n\t\n\t\n\t/**\n\t * Get the number of visible columns\n\t * @param {object} oSettings dataTables settings object\n\t * @returns {int} i the number of visible columns\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnVisbleColumns( oSettings )\n\t{\n\t\tvar vis = 0;\n\t\n\t\t// No reduce in IE8, use a loop for now\n\t\t$.each( oSettings.aoColumns, function ( i, col ) {\n\t\t\tif ( col.bVisible && $(col.nTh).css('display') !== 'none' ) {\n\t\t\t\tvis++;\n\t\t\t}\n\t\t} );\n\t\n\t\treturn vis;\n\t}\n\t\n\t\n\t/**\n\t * Get an array of column indexes that match a given property\n\t * @param {object} oSettings dataTables settings object\n\t * @param {string} sParam Parameter in aoColumns to look for - typically\n\t * bVisible or bSearchable\n\t * @returns {array} Array of indexes with matched properties\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetColumns( oSettings, sParam )\n\t{\n\t\tvar a = [];\n\t\n\t\t$.map( oSettings.aoColumns, function(val, i) {\n\t\t\tif ( val[sParam] ) {\n\t\t\t\ta.push( i );\n\t\t\t}\n\t\t} );\n\t\n\t\treturn a;\n\t}\n\t\n\t\n\t/**\n\t * Calculate the 'type' of a column\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnColumnTypes ( settings )\n\t{\n\t\tvar columns = settings.aoColumns;\n\t\tvar data = settings.aoData;\n\t\tvar types = DataTable.ext.type.detect;\n\t\tvar i, ien, j, jen, k, ken;\n\t\tvar col, cell, detectedType, cache;\n\t\n\t\t// For each column, spin over the \n\t\tfor ( i=0, ien=columns.length ; i<ien ; i++ ) {\n\t\t\tcol = columns[i];\n\t\t\tcache = [];\n\t\n\t\t\tif ( ! col.sType && col._sManualType ) {\n\t\t\t\tcol.sType = col._sManualType;\n\t\t\t}\n\t\t\telse if ( ! col.sType ) {\n\t\t\t\tfor ( j=0, jen=types.length ; j<jen ; j++ ) {\n\t\t\t\t\tfor ( k=0, ken=data.length ; k<ken ; k++ ) {\n\t\t\t\t\t\t// Use a cache array so we only need to get the type data\n\t\t\t\t\t\t// from the formatter once (when using multiple detectors)\n\t\t\t\t\t\tif ( cache[k] === undefined ) {\n\t\t\t\t\t\t\tcache[k] = _fnGetCellData( settings, k, i, 'type' );\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\tdetectedType = types[j]( cache[k], settings );\n\t\n\t\t\t\t\t\t// If null, then this type can't apply to this column, so\n\t\t\t\t\t\t// rather than testing all cells, break out. There is an\n\t\t\t\t\t\t// exception for the last type which is `html`. We need to\n\t\t\t\t\t\t// scan all rows since it is possible to mix string and HTML\n\t\t\t\t\t\t// types\n\t\t\t\t\t\tif ( ! detectedType && j !== types.length-1 ) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t// Only a single match is needed for html type since it is\n\t\t\t\t\t\t// bottom of the pile and very similar to string\n\t\t\t\t\t\tif ( detectedType === 'html' ) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\n\t\t\t\t\t// Type is valid for all data points in the column - use this\n\t\t\t\t\t// type\n\t\t\t\t\tif ( detectedType ) {\n\t\t\t\t\t\tcol.sType = detectedType;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\t// Fall back - if no type was detected, always use string\n\t\t\t\tif ( ! col.sType ) {\n\t\t\t\t\tcol.sType = 'string';\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Take the column definitions and static columns arrays and calculate how\n\t * they relate to column indexes. The callback function will then apply the\n\t * definition found for a column to a suitable configuration object.\n\t * @param {object} oSettings dataTables settings object\n\t * @param {array} aoColDefs The aoColumnDefs array that is to be applied\n\t * @param {array} aoCols The aoColumns array that defines columns individually\n\t * @param {function} fn Callback function - takes two parameters, the calculated\n\t * column index and the definition for that column.\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnApplyColumnDefs( oSettings, aoColDefs, aoCols, fn )\n\t{\n\t\tvar i, iLen, j, jLen, k, kLen, def;\n\t\tvar columns = oSettings.aoColumns;\n\t\n\t\t// Column definitions with aTargets\n\t\tif ( aoColDefs )\n\t\t{\n\t\t\t/* Loop over the definitions array - loop in reverse so first instance has priority */\n\t\t\tfor ( i=aoColDefs.length-1 ; i>=0 ; i-- )\n\t\t\t{\n\t\t\t\tdef = aoColDefs[i];\n\t\n\t\t\t\t/* Each definition can target multiple columns, as it is an array */\n\t\t\t\tvar aTargets = def.targets !== undefined ?\n\t\t\t\t\tdef.targets :\n\t\t\t\t\tdef.aTargets;\n\t\n\t\t\t\tif ( ! $.isArray( aTargets ) )\n\t\t\t\t{\n\t\t\t\t\taTargets = [ aTargets ];\n\t\t\t\t}\n\t\n\t\t\t\tfor ( j=0, jLen=aTargets.length ; j<jLen ; j++ )\n\t\t\t\t{\n\t\t\t\t\tif ( typeof aTargets[j] === 'number' && aTargets[j] >= 0 )\n\t\t\t\t\t{\n\t\t\t\t\t\t/* Add columns that we don't yet know about */\n\t\t\t\t\t\twhile( columns.length <= aTargets[j] )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t_fnAddColumn( oSettings );\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t/* Integer, basic index */\n\t\t\t\t\t\tfn( aTargets[j], def );\n\t\t\t\t\t}\n\t\t\t\t\telse if ( typeof aTargets[j] === 'number' && aTargets[j] < 0 )\n\t\t\t\t\t{\n\t\t\t\t\t\t/* Negative integer, right to left column counting */\n\t\t\t\t\t\tfn( columns.length+aTargets[j], def );\n\t\t\t\t\t}\n\t\t\t\t\telse if ( typeof aTargets[j] === 'string' )\n\t\t\t\t\t{\n\t\t\t\t\t\t/* Class name matching on TH element */\n\t\t\t\t\t\tfor ( k=0, kLen=columns.length ; k<kLen ; k++ )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif ( aTargets[j] == \"_all\" ||\n\t\t\t\t\t\t\t $(columns[k].nTh).hasClass( aTargets[j] ) )\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfn( k, def );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\t// Statically defined columns array\n\t\tif ( aoCols )\n\t\t{\n\t\t\tfor ( i=0, iLen=aoCols.length ; i<iLen ; i++ )\n\t\t\t{\n\t\t\t\tfn( i, aoCols[i] );\n\t\t\t}\n\t\t}\n\t}\n\t\n\t/**\n\t * Add a data array to the table, creating DOM node etc. This is the parallel to\n\t * _fnGatherData, but for adding rows from a Javascript source, rather than a\n\t * DOM source.\n\t * @param {object} oSettings dataTables settings object\n\t * @param {array} aData data array to be added\n\t * @param {node} [nTr] TR element to add to the table - optional. If not given,\n\t * DataTables will create a row automatically\n\t * @param {array} [anTds] Array of TD|TH elements for the row - must be given\n\t * if nTr is.\n\t * @returns {int} >=0 if successful (index of new aoData entry), -1 if failed\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAddData ( oSettings, aDataIn, nTr, anTds )\n\t{\n\t\t/* Create the object for storing information about this new row */\n\t\tvar iRow = oSettings.aoData.length;\n\t\tvar oData = $.extend( true, {}, DataTable.models.oRow, {\n\t\t\tsrc: nTr ? 'dom' : 'data',\n\t\t\tidx: iRow\n\t\t} );\n\t\n\t\toData._aData = aDataIn;\n\t\toSettings.aoData.push( oData );\n\t\n\t\t/* Create the cells */\n\t\tvar nTd, sThisType;\n\t\tvar columns = oSettings.aoColumns;\n\t\n\t\t// Invalidate the column types as the new data needs to be revalidated\n\t\tfor ( var i=0, iLen=columns.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tcolumns[i].sType = null;\n\t\t}\n\t\n\t\t/* Add to the display array */\n\t\toSettings.aiDisplayMaster.push( iRow );\n\t\n\t\tvar id = oSettings.rowIdFn( aDataIn );\n\t\tif ( id !== undefined ) {\n\t\t\toSettings.aIds[ id ] = oData;\n\t\t}\n\t\n\t\t/* Create the DOM information, or register it if already present */\n\t\tif ( nTr || ! oSettings.oFeatures.bDeferRender )\n\t\t{\n\t\t\t_fnCreateTr( oSettings, iRow, nTr, anTds );\n\t\t}\n\t\n\t\treturn iRow;\n\t}\n\t\n\t\n\t/**\n\t * Add one or more TR elements to the table. Generally we'd expect to\n\t * use this for reading data from a DOM sourced table, but it could be\n\t * used for an TR element. Note that if a TR is given, it is used (i.e.\n\t * it is not cloned).\n\t * @param {object} settings dataTables settings object\n\t * @param {array|node|jQuery} trs The TR element(s) to add to the table\n\t * @returns {array} Array of indexes for the added rows\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAddTr( settings, trs )\n\t{\n\t\tvar row;\n\t\n\t\t// Allow an individual node to be passed in\n\t\tif ( ! (trs instanceof $) ) {\n\t\t\ttrs = $(trs);\n\t\t}\n\t\n\t\treturn trs.map( function (i, el) {\n\t\t\trow = _fnGetRowElements( settings, el );\n\t\t\treturn _fnAddData( settings, row.data, el, row.cells );\n\t\t} );\n\t}\n\t\n\t\n\t/**\n\t * Take a TR element and convert it to an index in aoData\n\t * @param {object} oSettings dataTables settings object\n\t * @param {node} n the TR element to find\n\t * @returns {int} index if the node is found, null if not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnNodeToDataIndex( oSettings, n )\n\t{\n\t\treturn (n._DT_RowIndex!==undefined) ? n._DT_RowIndex : null;\n\t}\n\t\n\t\n\t/**\n\t * Take a TD element and convert it into a column data index (not the visible index)\n\t * @param {object} oSettings dataTables settings object\n\t * @param {int} iRow The row number the TD/TH can be found in\n\t * @param {node} n The TD/TH element to find\n\t * @returns {int} index if the node is found, -1 if not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnNodeToColumnIndex( oSettings, iRow, n )\n\t{\n\t\treturn $.inArray( n, oSettings.aoData[ iRow ].anCells );\n\t}\n\t\n\t\n\t/**\n\t * Get the data for a given cell from the internal cache, taking into account data mapping\n\t * @param {object} settings dataTables settings object\n\t * @param {int} rowIdx aoData row id\n\t * @param {int} colIdx Column index\n\t * @param {string} type data get type ('display', 'type' 'filter' 'sort')\n\t * @returns {*} Cell data\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetCellData( settings, rowIdx, colIdx, type )\n\t{\n\t\tvar draw = settings.iDraw;\n\t\tvar col = settings.aoColumns[colIdx];\n\t\tvar rowData = settings.aoData[rowIdx]._aData;\n\t\tvar defaultContent = col.sDefaultContent;\n\t\tvar cellData = col.fnGetData( rowData, type, {\n\t\t\tsettings: settings,\n\t\t\trow: rowIdx,\n\t\t\tcol: colIdx\n\t\t} );\n\t\n\t\tif ( cellData === undefined ) {\n\t\t\tif ( settings.iDrawError != draw && defaultContent === null ) {\n\t\t\t\t_fnLog( settings, 0, \"Requested unknown parameter \"+\n\t\t\t\t\t(typeof col.mData=='function' ? '{function}' : \"'\"+col.mData+\"'\")+\n\t\t\t\t\t\" for row \"+rowIdx+\", column \"+colIdx, 4 );\n\t\t\t\tsettings.iDrawError = draw;\n\t\t\t}\n\t\t\treturn defaultContent;\n\t\t}\n\t\n\t\t// When the data source is null and a specific data type is requested (i.e.\n\t\t// not the original data), we can use default column data\n\t\tif ( (cellData === rowData || cellData === null) && defaultContent !== null && type !== undefined ) {\n\t\t\tcellData = defaultContent;\n\t\t}\n\t\telse if ( typeof cellData === 'function' ) {\n\t\t\t// If the data source is a function, then we run it and use the return,\n\t\t\t// executing in the scope of the data object (for instances)\n\t\t\treturn cellData.call( rowData );\n\t\t}\n\t\n\t\tif ( cellData === null && type == 'display' ) {\n\t\t\treturn '';\n\t\t}\n\t\treturn cellData;\n\t}\n\t\n\t\n\t/**\n\t * Set the value for a specific cell, into the internal data cache\n\t * @param {object} settings dataTables settings object\n\t * @param {int} rowIdx aoData row id\n\t * @param {int} colIdx Column index\n\t * @param {*} val Value to set\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSetCellData( settings, rowIdx, colIdx, val )\n\t{\n\t\tvar col = settings.aoColumns[colIdx];\n\t\tvar rowData = settings.aoData[rowIdx]._aData;\n\t\n\t\tcol.fnSetData( rowData, val, {\n\t\t\tsettings: settings,\n\t\t\trow: rowIdx,\n\t\t\tcol: colIdx\n\t\t} );\n\t}\n\t\n\t\n\t// Private variable that is used to match action syntax in the data property object\n\tvar __reArray = /\\[.*?\\]$/;\n\tvar __reFn = /\\(\\)$/;\n\t\n\t/**\n\t * Split string on periods, taking into account escaped periods\n\t * @param {string} str String to split\n\t * @return {array} Split string\n\t */\n\tfunction _fnSplitObjNotation( str )\n\t{\n\t\treturn $.map( str.match(/(\\\\.|[^\\.])+/g) || [''], function ( s ) {\n\t\t\treturn s.replace(/\\\\./g, '.');\n\t\t} );\n\t}\n\t\n\t\n\t/**\n\t * Return a function that can be used to get data from a source object, taking\n\t * into account the ability to use nested objects as a source\n\t * @param {string|int|function} mSource The data source for the object\n\t * @returns {function} Data get function\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetObjectDataFn( mSource )\n\t{\n\t\tif ( $.isPlainObject( mSource ) )\n\t\t{\n\t\t\t/* Build an object of get functions, and wrap them in a single call */\n\t\t\tvar o = {};\n\t\t\t$.each( mSource, function (key, val) {\n\t\t\t\tif ( val ) {\n\t\t\t\t\to[key] = _fnGetObjectDataFn( val );\n\t\t\t\t}\n\t\t\t} );\n\t\n\t\t\treturn function (data, type, row, meta) {\n\t\t\t\tvar t = o[type] || o._;\n\t\t\t\treturn t !== undefined ?\n\t\t\t\t\tt(data, type, row, meta) :\n\t\t\t\t\tdata;\n\t\t\t};\n\t\t}\n\t\telse if ( mSource === null )\n\t\t{\n\t\t\t/* Give an empty string for rendering / sorting etc */\n\t\t\treturn function (data) { // type, row and meta also passed, but not used\n\t\t\t\treturn data;\n\t\t\t};\n\t\t}\n\t\telse if ( typeof mSource === 'function' )\n\t\t{\n\t\t\treturn function (data, type, row, meta) {\n\t\t\t\treturn mSource( data, type, row, meta );\n\t\t\t};\n\t\t}\n\t\telse if ( typeof mSource === 'string' && (mSource.indexOf('.') !== -1 ||\n\t\t\t mSource.indexOf('[') !== -1 || mSource.indexOf('(') !== -1) )\n\t\t{\n\t\t\t/* If there is a . in the source string then the data source is in a\n\t\t\t * nested object so we loop over the data for each level to get the next\n\t\t\t * level down. On each loop we test for undefined, and if found immediately\n\t\t\t * return. This allows entire objects to be missing and sDefaultContent to\n\t\t\t * be used if defined, rather than throwing an error\n\t\t\t */\n\t\t\tvar fetchData = function (data, type, src) {\n\t\t\t\tvar arrayNotation, funcNotation, out, innerSrc;\n\t\n\t\t\t\tif ( src !== \"\" )\n\t\t\t\t{\n\t\t\t\t\tvar a = _fnSplitObjNotation( src );\n\t\n\t\t\t\t\tfor ( var i=0, iLen=a.length ; i<iLen ; i++ )\n\t\t\t\t\t{\n\t\t\t\t\t\t// Check if we are dealing with special notation\n\t\t\t\t\t\tarrayNotation = a[i].match(__reArray);\n\t\t\t\t\t\tfuncNotation = a[i].match(__reFn);\n\t\n\t\t\t\t\t\tif ( arrayNotation )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// Array notation\n\t\t\t\t\t\t\ta[i] = a[i].replace(__reArray, '');\n\t\n\t\t\t\t\t\t\t// Condition allows simply [] to be passed in\n\t\t\t\t\t\t\tif ( a[i] !== \"\" ) {\n\t\t\t\t\t\t\t\tdata = data[ a[i] ];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tout = [];\n\t\n\t\t\t\t\t\t\t// Get the remainder of the nested object to get\n\t\t\t\t\t\t\ta.splice( 0, i+1 );\n\t\t\t\t\t\t\tinnerSrc = a.join('.');\n\t\n\t\t\t\t\t\t\t// Traverse each entry in the array getting the properties requested\n\t\t\t\t\t\t\tif ( $.isArray( data ) ) {\n\t\t\t\t\t\t\t\tfor ( var j=0, jLen=data.length ; j<jLen ; j++ ) {\n\t\t\t\t\t\t\t\t\tout.push( fetchData( data[j], type, innerSrc ) );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t\t// If a string is given in between the array notation indicators, that\n\t\t\t\t\t\t\t// is used to join the strings together, otherwise an array is returned\n\t\t\t\t\t\t\tvar join = arrayNotation[0].substring(1, arrayNotation[0].length-1);\n\t\t\t\t\t\t\tdata = (join===\"\") ? out : out.join(join);\n\t\n\t\t\t\t\t\t\t// The inner call to fetchData has already traversed through the remainder\n\t\t\t\t\t\t\t// of the source requested, so we exit from the loop\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse if ( funcNotation )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// Function call\n\t\t\t\t\t\t\ta[i] = a[i].replace(__reFn, '');\n\t\t\t\t\t\t\tdata = data[ a[i] ]();\n\t\t\t\t\t\t\tcontinue;\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\tif ( data === null || data[ a[i] ] === undefined )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\treturn undefined;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tdata = data[ a[i] ];\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\treturn data;\n\t\t\t};\n\t\n\t\t\treturn function (data, type) { // row and meta also passed, but not used\n\t\t\t\treturn fetchData( data, type, mSource );\n\t\t\t};\n\t\t}\n\t\telse\n\t\t{\n\t\t\t/* Array or flat object mapping */\n\t\t\treturn function (data, type) { // row and meta also passed, but not used\n\t\t\t\treturn data[mSource];\n\t\t\t};\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Return a function that can be used to set data from a source object, taking\n\t * into account the ability to use nested objects as a source\n\t * @param {string|int|function} mSource The data source for the object\n\t * @returns {function} Data set function\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSetObjectDataFn( mSource )\n\t{\n\t\tif ( $.isPlainObject( mSource ) )\n\t\t{\n\t\t\t/* Unlike get, only the underscore (global) option is used for for\n\t\t\t * setting data since we don't know the type here. This is why an object\n\t\t\t * option is not documented for `mData` (which is read/write), but it is\n\t\t\t * for `mRender` which is read only.\n\t\t\t */\n\t\t\treturn _fnSetObjectDataFn( mSource._ );\n\t\t}\n\t\telse if ( mSource === null )\n\t\t{\n\t\t\t/* Nothing to do when the data source is null */\n\t\t\treturn function () {};\n\t\t}\n\t\telse if ( typeof mSource === 'function' )\n\t\t{\n\t\t\treturn function (data, val, meta) {\n\t\t\t\tmSource( data, 'set', val, meta );\n\t\t\t};\n\t\t}\n\t\telse if ( typeof mSource === 'string' && (mSource.indexOf('.') !== -1 ||\n\t\t\t mSource.indexOf('[') !== -1 || mSource.indexOf('(') !== -1) )\n\t\t{\n\t\t\t/* Like the get, we need to get data from a nested object */\n\t\t\tvar setData = function (data, val, src) {\n\t\t\t\tvar a = _fnSplitObjNotation( src ), b;\n\t\t\t\tvar aLast = a[a.length-1];\n\t\t\t\tvar arrayNotation, funcNotation, o, innerSrc;\n\t\n\t\t\t\tfor ( var i=0, iLen=a.length-1 ; i<iLen ; i++ )\n\t\t\t\t{\n\t\t\t\t\t// Check if we are dealing with an array notation request\n\t\t\t\t\tarrayNotation = a[i].match(__reArray);\n\t\t\t\t\tfuncNotation = a[i].match(__reFn);\n\t\n\t\t\t\t\tif ( arrayNotation )\n\t\t\t\t\t{\n\t\t\t\t\t\ta[i] = a[i].replace(__reArray, '');\n\t\t\t\t\t\tdata[ a[i] ] = [];\n\t\n\t\t\t\t\t\t// Get the remainder of the nested object to set so we can recurse\n\t\t\t\t\t\tb = a.slice();\n\t\t\t\t\t\tb.splice( 0, i+1 );\n\t\t\t\t\t\tinnerSrc = b.join('.');\n\t\n\t\t\t\t\t\t// Traverse each entry in the array setting the properties requested\n\t\t\t\t\t\tif ( $.isArray( val ) )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tfor ( var j=0, jLen=val.length ; j<jLen ; j++ )\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\to = {};\n\t\t\t\t\t\t\t\tsetData( o, val[j], innerSrc );\n\t\t\t\t\t\t\t\tdata[ a[i] ].push( o );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// We've been asked to save data to an array, but it\n\t\t\t\t\t\t\t// isn't array data to be saved. Best that can be done\n\t\t\t\t\t\t\t// is to just save the value.\n\t\t\t\t\t\t\tdata[ a[i] ] = val;\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t// The inner call to setData has already traversed through the remainder\n\t\t\t\t\t\t// of the source and has set the data, thus we can exit here\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t\telse if ( funcNotation )\n\t\t\t\t\t{\n\t\t\t\t\t\t// Function call\n\t\t\t\t\t\ta[i] = a[i].replace(__reFn, '');\n\t\t\t\t\t\tdata = data[ a[i] ]( val );\n\t\t\t\t\t}\n\t\n\t\t\t\t\t// If the nested object doesn't currently exist - since we are\n\t\t\t\t\t// trying to set the value - create it\n\t\t\t\t\tif ( data[ a[i] ] === null || data[ a[i] ] === undefined )\n\t\t\t\t\t{\n\t\t\t\t\t\tdata[ a[i] ] = {};\n\t\t\t\t\t}\n\t\t\t\t\tdata = data[ a[i] ];\n\t\t\t\t}\n\t\n\t\t\t\t// Last item in the input - i.e, the actual set\n\t\t\t\tif ( aLast.match(__reFn ) )\n\t\t\t\t{\n\t\t\t\t\t// Function call\n\t\t\t\t\tdata = data[ aLast.replace(__reFn, '') ]( val );\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t// If array notation is used, we just want to strip it and use the property name\n\t\t\t\t\t// and assign the value. If it isn't used, then we get the result we want anyway\n\t\t\t\t\tdata[ aLast.replace(__reArray, '') ] = val;\n\t\t\t\t}\n\t\t\t};\n\t\n\t\t\treturn function (data, val) { // meta is also passed in, but not used\n\t\t\t\treturn setData( data, val, mSource );\n\t\t\t};\n\t\t}\n\t\telse\n\t\t{\n\t\t\t/* Array or flat object mapping */\n\t\t\treturn function (data, val) { // meta is also passed in, but not used\n\t\t\t\tdata[mSource] = val;\n\t\t\t};\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Return an array with the full table data\n\t * @param {object} oSettings dataTables settings object\n\t * @returns array {array} aData Master data array\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetDataMaster ( settings )\n\t{\n\t\treturn _pluck( settings.aoData, '_aData' );\n\t}\n\t\n\t\n\t/**\n\t * Nuke the table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnClearTable( settings )\n\t{\n\t\tsettings.aoData.length = 0;\n\t\tsettings.aiDisplayMaster.length = 0;\n\t\tsettings.aiDisplay.length = 0;\n\t\tsettings.aIds = {};\n\t}\n\t\n\t\n\t /**\n\t * Take an array of integers (index array) and remove a target integer (value - not\n\t * the key!)\n\t * @param {array} a Index array to target\n\t * @param {int} iTarget value to find\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnDeleteIndex( a, iTarget, splice )\n\t{\n\t\tvar iTargetIndex = -1;\n\t\n\t\tfor ( var i=0, iLen=a.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tif ( a[i] == iTarget )\n\t\t\t{\n\t\t\t\tiTargetIndex = i;\n\t\t\t}\n\t\t\telse if ( a[i] > iTarget )\n\t\t\t{\n\t\t\t\ta[i]--;\n\t\t\t}\n\t\t}\n\t\n\t\tif ( iTargetIndex != -1 && splice === undefined )\n\t\t{\n\t\t\ta.splice( iTargetIndex, 1 );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Mark cached data as invalid such that a re-read of the data will occur when\n\t * the cached data is next requested. Also update from the data source object.\n\t *\n\t * @param {object} settings DataTables settings object\n\t * @param {int} rowIdx Row index to invalidate\n\t * @param {string} [src] Source to invalidate from: undefined, 'auto', 'dom'\n\t * or 'data'\n\t * @param {int} [colIdx] Column index to invalidate. If undefined the whole\n\t * row will be invalidated\n\t * @memberof DataTable#oApi\n\t *\n\t * @todo For the modularisation of v1.11 this will need to become a callback, so\n\t * the sort and filter methods can subscribe to it. That will required\n\t * initialisation options for sorting, which is why it is not already baked in\n\t */\n\tfunction _fnInvalidate( settings, rowIdx, src, colIdx )\n\t{\n\t\tvar row = settings.aoData[ rowIdx ];\n\t\tvar i, ien;\n\t\tvar cellWrite = function ( cell, col ) {\n\t\t\t// This is very frustrating, but in IE if you just write directly\n\t\t\t// to innerHTML, and elements that are overwritten are GC'ed,\n\t\t\t// even if there is a reference to them elsewhere\n\t\t\twhile ( cell.childNodes.length ) {\n\t\t\t\tcell.removeChild( cell.firstChild );\n\t\t\t}\n\t\n\t\t\tcell.innerHTML = _fnGetCellData( settings, rowIdx, col, 'display' );\n\t\t};\n\t\n\t\t// Are we reading last data from DOM or the data object?\n\t\tif ( src === 'dom' || ((! src || src === 'auto') && row.src === 'dom') ) {\n\t\t\t// Read the data from the DOM\n\t\t\trow._aData = _fnGetRowElements(\n\t\t\t\t\tsettings, row, colIdx, colIdx === undefined ? undefined : row._aData\n\t\t\t\t)\n\t\t\t\t.data;\n\t\t}\n\t\telse {\n\t\t\t// Reading from data object, update the DOM\n\t\t\tvar cells = row.anCells;\n\t\n\t\t\tif ( cells ) {\n\t\t\t\tif ( colIdx !== undefined ) {\n\t\t\t\t\tcellWrite( cells[colIdx], colIdx );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tfor ( i=0, ien=cells.length ; i<ien ; i++ ) {\n\t\t\t\t\t\tcellWrite( cells[i], i );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\t// For both row and cell invalidation, the cached data for sorting and\n\t\t// filtering is nulled out\n\t\trow._aSortData = null;\n\t\trow._aFilterData = null;\n\t\n\t\t// Invalidate the type for a specific column (if given) or all columns since\n\t\t// the data might have changed\n\t\tvar cols = settings.aoColumns;\n\t\tif ( colIdx !== undefined ) {\n\t\t\tcols[ colIdx ].sType = null;\n\t\t}\n\t\telse {\n\t\t\tfor ( i=0, ien=cols.length ; i<ien ; i++ ) {\n\t\t\t\tcols[i].sType = null;\n\t\t\t}\n\t\n\t\t\t// Update DataTables special `DT_*` attributes for the row\n\t\t\t_fnRowAttributes( settings, row );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Build a data source object from an HTML row, reading the contents of the\n\t * cells that are in the row.\n\t *\n\t * @param {object} settings DataTables settings object\n\t * @param {node|object} TR element from which to read data or existing row\n\t * object from which to re-read the data from the cells\n\t * @param {int} [colIdx] Optional column index\n\t * @param {array|object} [d] Data source object. If `colIdx` is given then this\n\t * parameter should also be given and will be used to write the data into.\n\t * Only the column in question will be written\n\t * @returns {object} Object with two parameters: `data` the data read, in\n\t * document order, and `cells` and array of nodes (they can be useful to the\n\t * caller, so rather than needing a second traversal to get them, just return\n\t * them from here).\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetRowElements( settings, row, colIdx, d )\n\t{\n\t\tvar\n\t\t\ttds = [],\n\t\t\ttd = row.firstChild,\n\t\t\tname, col, o, i=0, contents,\n\t\t\tcolumns = settings.aoColumns,\n\t\t\tobjectRead = settings._rowReadObject;\n\t\n\t\t// Allow the data object to be passed in, or construct\n\t\td = d !== undefined ?\n\t\t\td :\n\t\t\tobjectRead ?\n\t\t\t\t{} :\n\t\t\t\t[];\n\t\n\t\tvar attr = function ( str, td ) {\n\t\t\tif ( typeof str === 'string' ) {\n\t\t\t\tvar idx = str.indexOf('@');\n\t\n\t\t\t\tif ( idx !== -1 ) {\n\t\t\t\t\tvar attr = str.substring( idx+1 );\n\t\t\t\t\tvar setter = _fnSetObjectDataFn( str );\n\t\t\t\t\tsetter( d, td.getAttribute( attr ) );\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\n\t\t// Read data from a cell and store into the data object\n\t\tvar cellProcess = function ( cell ) {\n\t\t\tif ( colIdx === undefined || colIdx === i ) {\n\t\t\t\tcol = columns[i];\n\t\t\t\tcontents = $.trim(cell.innerHTML);\n\t\n\t\t\t\tif ( col && col._bAttrSrc ) {\n\t\t\t\t\tvar setter = _fnSetObjectDataFn( col.mData._ );\n\t\t\t\t\tsetter( d, contents );\n\t\n\t\t\t\t\tattr( col.mData.sort, cell );\n\t\t\t\t\tattr( col.mData.type, cell );\n\t\t\t\t\tattr( col.mData.filter, cell );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\t// Depending on the `data` option for the columns the data can\n\t\t\t\t\t// be read to either an object or an array.\n\t\t\t\t\tif ( objectRead ) {\n\t\t\t\t\t\tif ( ! col._setter ) {\n\t\t\t\t\t\t\t// Cache the setter function\n\t\t\t\t\t\t\tcol._setter = _fnSetObjectDataFn( col.mData );\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcol._setter( d, contents );\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\td[i] = contents;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\ti++;\n\t\t};\n\t\n\t\tif ( td ) {\n\t\t\t// `tr` element was passed in\n\t\t\twhile ( td ) {\n\t\t\t\tname = td.nodeName.toUpperCase();\n\t\n\t\t\t\tif ( name == \"TD\" || name == \"TH\" ) {\n\t\t\t\t\tcellProcess( td );\n\t\t\t\t\ttds.push( td );\n\t\t\t\t}\n\t\n\t\t\t\ttd = td.nextSibling;\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\t// Existing row object passed in\n\t\t\ttds = row.anCells;\n\t\n\t\t\tfor ( var j=0, jen=tds.length ; j<jen ; j++ ) {\n\t\t\t\tcellProcess( tds[j] );\n\t\t\t}\n\t\t}\n\t\n\t\t// Read the ID from the DOM if present\n\t\tvar rowNode = row.firstChild ? row : row.nTr;\n\t\n\t\tif ( rowNode ) {\n\t\t\tvar id = rowNode.getAttribute( 'id' );\n\t\n\t\t\tif ( id ) {\n\t\t\t\t_fnSetObjectDataFn( settings.rowId )( d, id );\n\t\t\t}\n\t\t}\n\t\n\t\treturn {\n\t\t\tdata: d,\n\t\t\tcells: tds\n\t\t};\n\t}\n\t/**\n\t * Create a new TR element (and it's TD children) for a row\n\t * @param {object} oSettings dataTables settings object\n\t * @param {int} iRow Row to consider\n\t * @param {node} [nTrIn] TR element to add to the table - optional. If not given,\n\t * DataTables will create a row automatically\n\t * @param {array} [anTds] Array of TD|TH elements for the row - must be given\n\t * if nTr is.\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnCreateTr ( oSettings, iRow, nTrIn, anTds )\n\t{\n\t\tvar\n\t\t\trow = oSettings.aoData[iRow],\n\t\t\trowData = row._aData,\n\t\t\tcells = [],\n\t\t\tnTr, nTd, oCol,\n\t\t\ti, iLen;\n\t\n\t\tif ( row.nTr === null )\n\t\t{\n\t\t\tnTr = nTrIn || document.createElement('tr');\n\t\n\t\t\trow.nTr = nTr;\n\t\t\trow.anCells = cells;\n\t\n\t\t\t/* Use a private property on the node to allow reserve mapping from the node\n\t\t\t * to the aoData array for fast look up\n\t\t\t */\n\t\t\tnTr._DT_RowIndex = iRow;\n\t\n\t\t\t/* Special parameters can be given by the data source to be used on the row */\n\t\t\t_fnRowAttributes( oSettings, row );\n\t\n\t\t\t/* Process each column */\n\t\t\tfor ( i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )\n\t\t\t{\n\t\t\t\toCol = oSettings.aoColumns[i];\n\t\n\t\t\t\tnTd = nTrIn ? anTds[i] : document.createElement( oCol.sCellType );\n\t\t\t\tnTd._DT_CellIndex = {\n\t\t\t\t\trow: iRow,\n\t\t\t\t\tcolumn: i\n\t\t\t\t};\n\t\t\t\t\n\t\t\t\tcells.push( nTd );\n\t\n\t\t\t\t// Need to create the HTML if new, or if a rendering function is defined\n\t\t\t\tif ( (!nTrIn || oCol.mRender || oCol.mData !== i) &&\n\t\t\t\t\t (!$.isPlainObject(oCol.mData) || oCol.mData._ !== i+'.display')\n\t\t\t\t) {\n\t\t\t\t\tnTd.innerHTML = _fnGetCellData( oSettings, iRow, i, 'display' );\n\t\t\t\t}\n\t\n\t\t\t\t/* Add user defined class */\n\t\t\t\tif ( oCol.sClass )\n\t\t\t\t{\n\t\t\t\t\tnTd.className += ' '+oCol.sClass;\n\t\t\t\t}\n\t\n\t\t\t\t// Visibility - add or remove as required\n\t\t\t\tif ( oCol.bVisible && ! nTrIn )\n\t\t\t\t{\n\t\t\t\t\tnTr.appendChild( nTd );\n\t\t\t\t}\n\t\t\t\telse if ( ! oCol.bVisible && nTrIn )\n\t\t\t\t{\n\t\t\t\t\tnTd.parentNode.removeChild( nTd );\n\t\t\t\t}\n\t\n\t\t\t\tif ( oCol.fnCreatedCell )\n\t\t\t\t{\n\t\t\t\t\toCol.fnCreatedCell.call( oSettings.oInstance,\n\t\t\t\t\t\tnTd, _fnGetCellData( oSettings, iRow, i ), rowData, iRow, i\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t_fnCallbackFire( oSettings, 'aoRowCreatedCallback', null, [nTr, rowData, iRow] );\n\t\t}\n\t\n\t\t// Remove once webkit bug 131819 and Chromium bug 365619 have been resolved\n\t\t// and deployed\n\t\trow.nTr.setAttribute( 'role', 'row' );\n\t}\n\t\n\t\n\t/**\n\t * Add attributes to a row based on the special `DT_*` parameters in a data\n\t * source object.\n\t * @param {object} settings DataTables settings object\n\t * @param {object} DataTables row object for the row to be modified\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnRowAttributes( settings, row )\n\t{\n\t\tvar tr = row.nTr;\n\t\tvar data = row._aData;\n\t\n\t\tif ( tr ) {\n\t\t\tvar id = settings.rowIdFn( data );\n\t\n\t\t\tif ( id ) {\n\t\t\t\ttr.id = id;\n\t\t\t}\n\t\n\t\t\tif ( data.DT_RowClass ) {\n\t\t\t\t// Remove any classes added by DT_RowClass before\n\t\t\t\tvar a = data.DT_RowClass.split(' ');\n\t\t\t\trow.__rowc = row.__rowc ?\n\t\t\t\t\t_unique( row.__rowc.concat( a ) ) :\n\t\t\t\t\ta;\n\t\n\t\t\t\t$(tr)\n\t\t\t\t\t.removeClass( row.__rowc.join(' ') )\n\t\t\t\t\t.addClass( data.DT_RowClass );\n\t\t\t}\n\t\n\t\t\tif ( data.DT_RowAttr ) {\n\t\t\t\t$(tr).attr( data.DT_RowAttr );\n\t\t\t}\n\t\n\t\t\tif ( data.DT_RowData ) {\n\t\t\t\t$(tr).data( data.DT_RowData );\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Create the HTML header for the table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnBuildHead( oSettings )\n\t{\n\t\tvar i, ien, cell, row, column;\n\t\tvar thead = oSettings.nTHead;\n\t\tvar tfoot = oSettings.nTFoot;\n\t\tvar createHeader = $('th, td', thead).length === 0;\n\t\tvar classes = oSettings.oClasses;\n\t\tvar columns = oSettings.aoColumns;\n\t\n\t\tif ( createHeader ) {\n\t\t\trow = $('<tr/>').appendTo( thead );\n\t\t}\n\t\n\t\tfor ( i=0, ien=columns.length ; i<ien ; i++ ) {\n\t\t\tcolumn = columns[i];\n\t\t\tcell = $( column.nTh ).addClass( column.sClass );\n\t\n\t\t\tif ( createHeader ) {\n\t\t\t\tcell.appendTo( row );\n\t\t\t}\n\t\n\t\t\t// 1.11 move into sorting\n\t\t\tif ( oSettings.oFeatures.bSort ) {\n\t\t\t\tcell.addClass( column.sSortingClass );\n\t\n\t\t\t\tif ( column.bSortable !== false ) {\n\t\t\t\t\tcell\n\t\t\t\t\t\t.attr( 'tabindex', oSettings.iTabIndex )\n\t\t\t\t\t\t.attr( 'aria-controls', oSettings.sTableId );\n\t\n\t\t\t\t\t_fnSortAttachListener( oSettings, column.nTh, i );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\tif ( column.sTitle != cell[0].innerHTML ) {\n\t\t\t\tcell.html( column.sTitle );\n\t\t\t}\n\t\n\t\t\t_fnRenderer( oSettings, 'header' )(\n\t\t\t\toSettings, cell, column, classes\n\t\t\t);\n\t\t}\n\t\n\t\tif ( createHeader ) {\n\t\t\t_fnDetectHeader( oSettings.aoHeader, thead );\n\t\t}\n\t\t\n\t\t/* ARIA role for the rows */\n\t \t$(thead).find('>tr').attr('role', 'row');\n\t\n\t\t/* Deal with the footer - add classes if required */\n\t\t$(thead).find('>tr>th, >tr>td').addClass( classes.sHeaderTH );\n\t\t$(tfoot).find('>tr>th, >tr>td').addClass( classes.sFooterTH );\n\t\n\t\t// Cache the footer cells. Note that we only take the cells from the first\n\t\t// row in the footer. If there is more than one row the user wants to\n\t\t// interact with, they need to use the table().foot() method. Note also this\n\t\t// allows cells to be used for multiple columns using colspan\n\t\tif ( tfoot !== null ) {\n\t\t\tvar cells = oSettings.aoFooter[0];\n\t\n\t\t\tfor ( i=0, ien=cells.length ; i<ien ; i++ ) {\n\t\t\t\tcolumn = columns[i];\n\t\t\t\tcolumn.nTf = cells[i].cell;\n\t\n\t\t\t\tif ( column.sClass ) {\n\t\t\t\t\t$(column.nTf).addClass( column.sClass );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Draw the header (or footer) element based on the column visibility states. The\n\t * methodology here is to use the layout array from _fnDetectHeader, modified for\n\t * the instantaneous column visibility, to construct the new layout. The grid is\n\t * traversed over cell at a time in a rows x columns grid fashion, although each\n\t * cell insert can cover multiple elements in the grid - which is tracks using the\n\t * aApplied array. Cell inserts in the grid will only occur where there isn't\n\t * already a cell in that position.\n\t * @param {object} oSettings dataTables settings object\n\t * @param array {objects} aoSource Layout array from _fnDetectHeader\n\t * @param {boolean} [bIncludeHidden=false] If true then include the hidden columns in the calc,\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnDrawHead( oSettings, aoSource, bIncludeHidden )\n\t{\n\t\tvar i, iLen, j, jLen, k, kLen, n, nLocalTr;\n\t\tvar aoLocal = [];\n\t\tvar aApplied = [];\n\t\tvar iColumns = oSettings.aoColumns.length;\n\t\tvar iRowspan, iColspan;\n\t\n\t\tif ( ! aoSource )\n\t\t{\n\t\t\treturn;\n\t\t}\n\t\n\t\tif ( bIncludeHidden === undefined )\n\t\t{\n\t\t\tbIncludeHidden = false;\n\t\t}\n\t\n\t\t/* Make a copy of the master layout array, but without the visible columns in it */\n\t\tfor ( i=0, iLen=aoSource.length ; i<iLen ; i++ )\n\t\t{\n\t\t\taoLocal[i] = aoSource[i].slice();\n\t\t\taoLocal[i].nTr = aoSource[i].nTr;\n\t\n\t\t\t/* Remove any columns which are currently hidden */\n\t\t\tfor ( j=iColumns-1 ; j>=0 ; j-- )\n\t\t\t{\n\t\t\t\tif ( !oSettings.aoColumns[j].bVisible && !bIncludeHidden )\n\t\t\t\t{\n\t\t\t\t\taoLocal[i].splice( j, 1 );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t/* Prep the applied array - it needs an element for each row */\n\t\t\taApplied.push( [] );\n\t\t}\n\t\n\t\tfor ( i=0, iLen=aoLocal.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tnLocalTr = aoLocal[i].nTr;\n\t\n\t\t\t/* All cells are going to be replaced, so empty out the row */\n\t\t\tif ( nLocalTr )\n\t\t\t{\n\t\t\t\twhile( (n = nLocalTr.firstChild) )\n\t\t\t\t{\n\t\t\t\t\tnLocalTr.removeChild( n );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\tfor ( j=0, jLen=aoLocal[i].length ; j<jLen ; j++ )\n\t\t\t{\n\t\t\t\tiRowspan = 1;\n\t\t\t\tiColspan = 1;\n\t\n\t\t\t\t/* Check to see if there is already a cell (row/colspan) covering our target\n\t\t\t\t * insert point. If there is, then there is nothing to do.\n\t\t\t\t */\n\t\t\t\tif ( aApplied[i][j] === undefined )\n\t\t\t\t{\n\t\t\t\t\tnLocalTr.appendChild( aoLocal[i][j].cell );\n\t\t\t\t\taApplied[i][j] = 1;\n\t\n\t\t\t\t\t/* Expand the cell to cover as many rows as needed */\n\t\t\t\t\twhile ( aoLocal[i+iRowspan] !== undefined &&\n\t\t\t\t\t aoLocal[i][j].cell == aoLocal[i+iRowspan][j].cell )\n\t\t\t\t\t{\n\t\t\t\t\t\taApplied[i+iRowspan][j] = 1;\n\t\t\t\t\t\tiRowspan++;\n\t\t\t\t\t}\n\t\n\t\t\t\t\t/* Expand the cell to cover as many columns as needed */\n\t\t\t\t\twhile ( aoLocal[i][j+iColspan] !== undefined &&\n\t\t\t\t\t aoLocal[i][j].cell == aoLocal[i][j+iColspan].cell )\n\t\t\t\t\t{\n\t\t\t\t\t\t/* Must update the applied array over the rows for the columns */\n\t\t\t\t\t\tfor ( k=0 ; k<iRowspan ; k++ )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\taApplied[i+k][j+iColspan] = 1;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tiColspan++;\n\t\t\t\t\t}\n\t\n\t\t\t\t\t/* Do the actual expansion in the DOM */\n\t\t\t\t\t$(aoLocal[i][j].cell)\n\t\t\t\t\t\t.attr('rowspan', iRowspan)\n\t\t\t\t\t\t.attr('colspan', iColspan);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Insert the required TR nodes into the table for display\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnDraw( oSettings )\n\t{\n\t\t/* Provide a pre-callback function which can be used to cancel the draw is false is returned */\n\t\tvar aPreDraw = _fnCallbackFire( oSettings, 'aoPreDrawCallback', 'preDraw', [oSettings] );\n\t\tif ( $.inArray( false, aPreDraw ) !== -1 )\n\t\t{\n\t\t\t_fnProcessingDisplay( oSettings, false );\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar i, iLen, n;\n\t\tvar anRows = [];\n\t\tvar iRowCount = 0;\n\t\tvar asStripeClasses = oSettings.asStripeClasses;\n\t\tvar iStripes = asStripeClasses.length;\n\t\tvar iOpenRows = oSettings.aoOpenRows.length;\n\t\tvar oLang = oSettings.oLanguage;\n\t\tvar iInitDisplayStart = oSettings.iInitDisplayStart;\n\t\tvar bServerSide = _fnDataSource( oSettings ) == 'ssp';\n\t\tvar aiDisplay = oSettings.aiDisplay;\n\t\n\t\toSettings.bDrawing = true;\n\t\n\t\t/* Check and see if we have an initial draw position from state saving */\n\t\tif ( iInitDisplayStart !== undefined && iInitDisplayStart !== -1 )\n\t\t{\n\t\t\toSettings._iDisplayStart = bServerSide ?\n\t\t\t\tiInitDisplayStart :\n\t\t\t\tiInitDisplayStart >= oSettings.fnRecordsDisplay() ?\n\t\t\t\t\t0 :\n\t\t\t\t\tiInitDisplayStart;\n\t\n\t\t\toSettings.iInitDisplayStart = -1;\n\t\t}\n\t\n\t\tvar iDisplayStart = oSettings._iDisplayStart;\n\t\tvar iDisplayEnd = oSettings.fnDisplayEnd();\n\t\n\t\t/* Server-side processing draw intercept */\n\t\tif ( oSettings.bDeferLoading )\n\t\t{\n\t\t\toSettings.bDeferLoading = false;\n\t\t\toSettings.iDraw++;\n\t\t\t_fnProcessingDisplay( oSettings, false );\n\t\t}\n\t\telse if ( !bServerSide )\n\t\t{\n\t\t\toSettings.iDraw++;\n\t\t}\n\t\telse if ( !oSettings.bDestroying && !_fnAjaxUpdate( oSettings ) )\n\t\t{\n\t\t\treturn;\n\t\t}\n\t\n\t\tif ( aiDisplay.length !== 0 )\n\t\t{\n\t\t\tvar iStart = bServerSide ? 0 : iDisplayStart;\n\t\t\tvar iEnd = bServerSide ? oSettings.aoData.length : iDisplayEnd;\n\t\n\t\t\tfor ( var j=iStart ; j<iEnd ; j++ )\n\t\t\t{\n\t\t\t\tvar iDataIndex = aiDisplay[j];\n\t\t\t\tvar aoData = oSettings.aoData[ iDataIndex ];\n\t\t\t\tif ( aoData.nTr === null )\n\t\t\t\t{\n\t\t\t\t\t_fnCreateTr( oSettings, iDataIndex );\n\t\t\t\t}\n\t\n\t\t\t\tvar nRow = aoData.nTr;\n\t\n\t\t\t\t/* Remove the old striping classes and then add the new one */\n\t\t\t\tif ( iStripes !== 0 )\n\t\t\t\t{\n\t\t\t\t\tvar sStripe = asStripeClasses[ iRowCount % iStripes ];\n\t\t\t\t\tif ( aoData._sRowStripe != sStripe )\n\t\t\t\t\t{\n\t\t\t\t\t\t$(nRow).removeClass( aoData._sRowStripe ).addClass( sStripe );\n\t\t\t\t\t\taoData._sRowStripe = sStripe;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\t// Row callback functions - might want to manipulate the row\n\t\t\t\t// iRowCount and j are not currently documented. Are they at all\n\t\t\t\t// useful?\n\t\t\t\t_fnCallbackFire( oSettings, 'aoRowCallback', null,\n\t\t\t\t\t[nRow, aoData._aData, iRowCount, j] );\n\t\n\t\t\t\tanRows.push( nRow );\n\t\t\t\tiRowCount++;\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\t/* Table is empty - create a row with an empty message in it */\n\t\t\tvar sZero = oLang.sZeroRecords;\n\t\t\tif ( oSettings.iDraw == 1 && _fnDataSource( oSettings ) == 'ajax' )\n\t\t\t{\n\t\t\t\tsZero = oLang.sLoadingRecords;\n\t\t\t}\n\t\t\telse if ( oLang.sEmptyTable && oSettings.fnRecordsTotal() === 0 )\n\t\t\t{\n\t\t\t\tsZero = oLang.sEmptyTable;\n\t\t\t}\n\t\n\t\t\tanRows[ 0 ] = $( '<tr/>', { 'class': iStripes ? asStripeClasses[0] : '' } )\n\t\t\t\t.append( $('<td />', {\n\t\t\t\t\t'valign': 'top',\n\t\t\t\t\t'colSpan': _fnVisbleColumns( oSettings ),\n\t\t\t\t\t'class': oSettings.oClasses.sRowEmpty\n\t\t\t\t} ).html( sZero ) )[0];\n\t\t}\n\t\n\t\t/* Header and footer callbacks */\n\t\t_fnCallbackFire( oSettings, 'aoHeaderCallback', 'header', [ $(oSettings.nTHead).children('tr')[0],\n\t\t\t_fnGetDataMaster( oSettings ), iDisplayStart, iDisplayEnd, aiDisplay ] );\n\t\n\t\t_fnCallbackFire( oSettings, 'aoFooterCallback', 'footer', [ $(oSettings.nTFoot).children('tr')[0],\n\t\t\t_fnGetDataMaster( oSettings ), iDisplayStart, iDisplayEnd, aiDisplay ] );\n\t\n\t\tvar body = $(oSettings.nTBody);\n\t\n\t\tbody.children().detach();\n\t\tbody.append( $(anRows) );\n\t\n\t\t/* Call all required callback functions for the end of a draw */\n\t\t_fnCallbackFire( oSettings, 'aoDrawCallback', 'draw', [oSettings] );\n\t\n\t\t/* Draw is complete, sorting and filtering must be as well */\n\t\toSettings.bSorted = false;\n\t\toSettings.bFiltered = false;\n\t\toSettings.bDrawing = false;\n\t}\n\t\n\t\n\t/**\n\t * Redraw the table - taking account of the various features which are enabled\n\t * @param {object} oSettings dataTables settings object\n\t * @param {boolean} [holdPosition] Keep the current paging position. By default\n\t * the paging is reset to the first page\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnReDraw( settings, holdPosition )\n\t{\n\t\tvar\n\t\t\tfeatures = settings.oFeatures,\n\t\t\tsort = features.bSort,\n\t\t\tfilter = features.bFilter;\n\t\n\t\tif ( sort ) {\n\t\t\t_fnSort( settings );\n\t\t}\n\t\n\t\tif ( filter ) {\n\t\t\t_fnFilterComplete( settings, settings.oPreviousSearch );\n\t\t}\n\t\telse {\n\t\t\t// No filtering, so we want to just use the display master\n\t\t\tsettings.aiDisplay = settings.aiDisplayMaster.slice();\n\t\t}\n\t\n\t\tif ( holdPosition !== true ) {\n\t\t\tsettings._iDisplayStart = 0;\n\t\t}\n\t\n\t\t// Let any modules know about the draw hold position state (used by\n\t\t// scrolling internally)\n\t\tsettings._drawHold = holdPosition;\n\t\n\t\t_fnDraw( settings );\n\t\n\t\tsettings._drawHold = false;\n\t}\n\t\n\t\n\t/**\n\t * Add the options to the page HTML for the table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAddOptionsHtml ( oSettings )\n\t{\n\t\tvar classes = oSettings.oClasses;\n\t\tvar table = $(oSettings.nTable);\n\t\tvar holding = $('<div/>').insertBefore( table ); // Holding element for speed\n\t\tvar features = oSettings.oFeatures;\n\t\n\t\t// All DataTables are wrapped in a div\n\t\tvar insert = $('<div/>', {\n\t\t\tid: oSettings.sTableId+'_wrapper',\n\t\t\t'class': classes.sWrapper + (oSettings.nTFoot ? '' : ' '+classes.sNoFooter)\n\t\t} );\n\t\n\t\toSettings.nHolding = holding[0];\n\t\toSettings.nTableWrapper = insert[0];\n\t\toSettings.nTableReinsertBefore = oSettings.nTable.nextSibling;\n\t\n\t\t/* Loop over the user set positioning and place the elements as needed */\n\t\tvar aDom = oSettings.sDom.split('');\n\t\tvar featureNode, cOption, nNewNode, cNext, sAttr, j;\n\t\tfor ( var i=0 ; i<aDom.length ; i++ )\n\t\t{\n\t\t\tfeatureNode = null;\n\t\t\tcOption = aDom[i];\n\t\n\t\t\tif ( cOption == '<' )\n\t\t\t{\n\t\t\t\t/* New container div */\n\t\t\t\tnNewNode = $('<div/>')[0];\n\t\n\t\t\t\t/* Check to see if we should append an id and/or a class name to the container */\n\t\t\t\tcNext = aDom[i+1];\n\t\t\t\tif ( cNext == \"'\" || cNext == '\"' )\n\t\t\t\t{\n\t\t\t\t\tsAttr = \"\";\n\t\t\t\t\tj = 2;\n\t\t\t\t\twhile ( aDom[i+j] != cNext )\n\t\t\t\t\t{\n\t\t\t\t\t\tsAttr += aDom[i+j];\n\t\t\t\t\t\tj++;\n\t\t\t\t\t}\n\t\n\t\t\t\t\t/* Replace jQuery UI constants @todo depreciated */\n\t\t\t\t\tif ( sAttr == \"H\" )\n\t\t\t\t\t{\n\t\t\t\t\t\tsAttr = classes.sJUIHeader;\n\t\t\t\t\t}\n\t\t\t\t\telse if ( sAttr == \"F\" )\n\t\t\t\t\t{\n\t\t\t\t\t\tsAttr = classes.sJUIFooter;\n\t\t\t\t\t}\n\t\n\t\t\t\t\t/* The attribute can be in the format of \"#id.class\", \"#id\" or \"class\" This logic\n\t\t\t\t\t * breaks the string into parts and applies them as needed\n\t\t\t\t\t */\n\t\t\t\t\tif ( sAttr.indexOf('.') != -1 )\n\t\t\t\t\t{\n\t\t\t\t\t\tvar aSplit = sAttr.split('.');\n\t\t\t\t\t\tnNewNode.id = aSplit[0].substr(1, aSplit[0].length-1);\n\t\t\t\t\t\tnNewNode.className = aSplit[1];\n\t\t\t\t\t}\n\t\t\t\t\telse if ( sAttr.charAt(0) == \"#\" )\n\t\t\t\t\t{\n\t\t\t\t\t\tnNewNode.id = sAttr.substr(1, sAttr.length-1);\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\tnNewNode.className = sAttr;\n\t\t\t\t\t}\n\t\n\t\t\t\t\ti += j; /* Move along the position array */\n\t\t\t\t}\n\t\n\t\t\t\tinsert.append( nNewNode );\n\t\t\t\tinsert = $(nNewNode);\n\t\t\t}\n\t\t\telse if ( cOption == '>' )\n\t\t\t{\n\t\t\t\t/* End container div */\n\t\t\t\tinsert = insert.parent();\n\t\t\t}\n\t\t\t// @todo Move options into their own plugins?\n\t\t\telse if ( cOption == 'l' && features.bPaginate && features.bLengthChange )\n\t\t\t{\n\t\t\t\t/* Length */\n\t\t\t\tfeatureNode = _fnFeatureHtmlLength( oSettings );\n\t\t\t}\n\t\t\telse if ( cOption == 'f' && features.bFilter )\n\t\t\t{\n\t\t\t\t/* Filter */\n\t\t\t\tfeatureNode = _fnFeatureHtmlFilter( oSettings );\n\t\t\t}\n\t\t\telse if ( cOption == 'r' && features.bProcessing )\n\t\t\t{\n\t\t\t\t/* pRocessing */\n\t\t\t\tfeatureNode = _fnFeatureHtmlProcessing( oSettings );\n\t\t\t}\n\t\t\telse if ( cOption == 't' )\n\t\t\t{\n\t\t\t\t/* Table */\n\t\t\t\tfeatureNode = _fnFeatureHtmlTable( oSettings );\n\t\t\t}\n\t\t\telse if ( cOption == 'i' && features.bInfo )\n\t\t\t{\n\t\t\t\t/* Info */\n\t\t\t\tfeatureNode = _fnFeatureHtmlInfo( oSettings );\n\t\t\t}\n\t\t\telse if ( cOption == 'p' && features.bPaginate )\n\t\t\t{\n\t\t\t\t/* Pagination */\n\t\t\t\tfeatureNode = _fnFeatureHtmlPaginate( oSettings );\n\t\t\t}\n\t\t\telse if ( DataTable.ext.feature.length !== 0 )\n\t\t\t{\n\t\t\t\t/* Plug-in features */\n\t\t\t\tvar aoFeatures = DataTable.ext.feature;\n\t\t\t\tfor ( var k=0, kLen=aoFeatures.length ; k<kLen ; k++ )\n\t\t\t\t{\n\t\t\t\t\tif ( cOption == aoFeatures[k].cFeature )\n\t\t\t\t\t{\n\t\t\t\t\t\tfeatureNode = aoFeatures[k].fnInit( oSettings );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t/* Add to the 2D features array */\n\t\t\tif ( featureNode )\n\t\t\t{\n\t\t\t\tvar aanFeatures = oSettings.aanFeatures;\n\t\n\t\t\t\tif ( ! aanFeatures[cOption] )\n\t\t\t\t{\n\t\t\t\t\taanFeatures[cOption] = [];\n\t\t\t\t}\n\t\n\t\t\t\taanFeatures[cOption].push( featureNode );\n\t\t\t\tinsert.append( featureNode );\n\t\t\t}\n\t\t}\n\t\n\t\t/* Built our DOM structure - replace the holding div with what we want */\n\t\tholding.replaceWith( insert );\n\t\toSettings.nHolding = null;\n\t}\n\t\n\t\n\t/**\n\t * Use the DOM source to create up an array of header cells. The idea here is to\n\t * create a layout grid (array) of rows x columns, which contains a reference\n\t * to the cell that that point in the grid (regardless of col/rowspan), such that\n\t * any column / row could be removed and the new grid constructed\n\t * @param array {object} aLayout Array to store the calculated layout in\n\t * @param {node} nThead The header/footer element for the table\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnDetectHeader ( aLayout, nThead )\n\t{\n\t\tvar nTrs = $(nThead).children('tr');\n\t\tvar nTr, nCell;\n\t\tvar i, k, l, iLen, jLen, iColShifted, iColumn, iColspan, iRowspan;\n\t\tvar bUnique;\n\t\tvar fnShiftCol = function ( a, i, j ) {\n\t\t\tvar k = a[i];\n\t while ( k[j] ) {\n\t\t\t\tj++;\n\t\t\t}\n\t\t\treturn j;\n\t\t};\n\t\n\t\taLayout.splice( 0, aLayout.length );\n\t\n\t\t/* We know how many rows there are in the layout - so prep it */\n\t\tfor ( i=0, iLen=nTrs.length ; i<iLen ; i++ )\n\t\t{\n\t\t\taLayout.push( [] );\n\t\t}\n\t\n\t\t/* Calculate a layout array */\n\t\tfor ( i=0, iLen=nTrs.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tnTr = nTrs[i];\n\t\t\tiColumn = 0;\n\t\n\t\t\t/* For every cell in the row... */\n\t\t\tnCell = nTr.firstChild;\n\t\t\twhile ( nCell ) {\n\t\t\t\tif ( nCell.nodeName.toUpperCase() == \"TD\" ||\n\t\t\t\t nCell.nodeName.toUpperCase() == \"TH\" )\n\t\t\t\t{\n\t\t\t\t\t/* Get the col and rowspan attributes from the DOM and sanitise them */\n\t\t\t\t\tiColspan = nCell.getAttribute('colspan') * 1;\n\t\t\t\t\tiRowspan = nCell.getAttribute('rowspan') * 1;\n\t\t\t\t\tiColspan = (!iColspan || iColspan===0 || iColspan===1) ? 1 : iColspan;\n\t\t\t\t\tiRowspan = (!iRowspan || iRowspan===0 || iRowspan===1) ? 1 : iRowspan;\n\t\n\t\t\t\t\t/* There might be colspan cells already in this row, so shift our target\n\t\t\t\t\t * accordingly\n\t\t\t\t\t */\n\t\t\t\t\tiColShifted = fnShiftCol( aLayout, i, iColumn );\n\t\n\t\t\t\t\t/* Cache calculation for unique columns */\n\t\t\t\t\tbUnique = iColspan === 1 ? true : false;\n\t\n\t\t\t\t\t/* If there is col / rowspan, copy the information into the layout grid */\n\t\t\t\t\tfor ( l=0 ; l<iColspan ; l++ )\n\t\t\t\t\t{\n\t\t\t\t\t\tfor ( k=0 ; k<iRowspan ; k++ )\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\taLayout[i+k][iColShifted+l] = {\n\t\t\t\t\t\t\t\t\"cell\": nCell,\n\t\t\t\t\t\t\t\t\"unique\": bUnique\n\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\taLayout[i+k].nTr = nTr;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tnCell = nCell.nextSibling;\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Get an array of unique th elements, one for each column\n\t * @param {object} oSettings dataTables settings object\n\t * @param {node} nHeader automatically detect the layout from this node - optional\n\t * @param {array} aLayout thead/tfoot layout from _fnDetectHeader - optional\n\t * @returns array {node} aReturn list of unique th's\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetUniqueThs ( oSettings, nHeader, aLayout )\n\t{\n\t\tvar aReturn = [];\n\t\tif ( !aLayout )\n\t\t{\n\t\t\taLayout = oSettings.aoHeader;\n\t\t\tif ( nHeader )\n\t\t\t{\n\t\t\t\taLayout = [];\n\t\t\t\t_fnDetectHeader( aLayout, nHeader );\n\t\t\t}\n\t\t}\n\t\n\t\tfor ( var i=0, iLen=aLayout.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tfor ( var j=0, jLen=aLayout[i].length ; j<jLen ; j++ )\n\t\t\t{\n\t\t\t\tif ( aLayout[i][j].unique &&\n\t\t\t\t\t (!aReturn[j] || !oSettings.bSortCellsTop) )\n\t\t\t\t{\n\t\t\t\t\taReturn[j] = aLayout[i][j].cell;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\treturn aReturn;\n\t}\n\t\n\t/**\n\t * Create an Ajax call based on the table's settings, taking into account that\n\t * parameters can have multiple forms, and backwards compatibility.\n\t *\n\t * @param {object} oSettings dataTables settings object\n\t * @param {array} data Data to send to the server, required by\n\t * DataTables - may be augmented by developer callbacks\n\t * @param {function} fn Callback function to run when data is obtained\n\t */\n\tfunction _fnBuildAjax( oSettings, data, fn )\n\t{\n\t\t// Compatibility with 1.9-, allow fnServerData and event to manipulate\n\t\t_fnCallbackFire( oSettings, 'aoServerParams', 'serverParams', [data] );\n\t\n\t\t// Convert to object based for 1.10+ if using the old array scheme which can\n\t\t// come from server-side processing or serverParams\n\t\tif ( data && $.isArray(data) ) {\n\t\t\tvar tmp = {};\n\t\t\tvar rbracket = /(.*?)\\[\\]$/;\n\t\n\t\t\t$.each( data, function (key, val) {\n\t\t\t\tvar match = val.name.match(rbracket);\n\t\n\t\t\t\tif ( match ) {\n\t\t\t\t\t// Support for arrays\n\t\t\t\t\tvar name = match[0];\n\t\n\t\t\t\t\tif ( ! tmp[ name ] ) {\n\t\t\t\t\t\ttmp[ name ] = [];\n\t\t\t\t\t}\n\t\t\t\t\ttmp[ name ].push( val.value );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\ttmp[val.name] = val.value;\n\t\t\t\t}\n\t\t\t} );\n\t\t\tdata = tmp;\n\t\t}\n\t\n\t\tvar ajaxData;\n\t\tvar ajax = oSettings.ajax;\n\t\tvar instance = oSettings.oInstance;\n\t\tvar callback = function ( json ) {\n\t\t\t_fnCallbackFire( oSettings, null, 'xhr', [oSettings, json, oSettings.jqXHR] );\n\t\t\tfn( json );\n\t\t};\n\t\n\t\tif ( $.isPlainObject( ajax ) && ajax.data )\n\t\t{\n\t\t\tajaxData = ajax.data;\n\t\n\t\t\tvar newData = $.isFunction( ajaxData ) ?\n\t\t\t\tajaxData( data, oSettings ) : // fn can manipulate data or return\n\t\t\t\tajaxData; // an object object or array to merge\n\t\n\t\t\t// If the function returned something, use that alone\n\t\t\tdata = $.isFunction( ajaxData ) && newData ?\n\t\t\t\tnewData :\n\t\t\t\t$.extend( true, data, newData );\n\t\n\t\t\t// Remove the data property as we've resolved it already and don't want\n\t\t\t// jQuery to do it again (it is restored at the end of the function)\n\t\t\tdelete ajax.data;\n\t\t}\n\t\n\t\tvar baseAjax = {\n\t\t\t\"data\": data,\n\t\t\t\"success\": function (json) {\n\t\t\t\tvar error = json.error || json.sError;\n\t\t\t\tif ( error ) {\n\t\t\t\t\t_fnLog( oSettings, 0, error );\n\t\t\t\t}\n\t\n\t\t\t\toSettings.json = json;\n\t\t\t\tcallback( json );\n\t\t\t},\n\t\t\t\"dataType\": \"json\",\n\t\t\t\"cache\": false,\n\t\t\t\"type\": oSettings.sServerMethod,\n\t\t\t\"error\": function (xhr, error, thrown) {\n\t\t\t\tvar ret = _fnCallbackFire( oSettings, null, 'xhr', [oSettings, null, oSettings.jqXHR] );\n\t\n\t\t\t\tif ( $.inArray( true, ret ) === -1 ) {\n\t\t\t\t\tif ( error == \"parsererror\" ) {\n\t\t\t\t\t\t_fnLog( oSettings, 0, 'Invalid JSON response', 1 );\n\t\t\t\t\t}\n\t\t\t\t\telse if ( xhr.readyState === 4 ) {\n\t\t\t\t\t\t_fnLog( oSettings, 0, 'Ajax error', 7 );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\t_fnProcessingDisplay( oSettings, false );\n\t\t\t}\n\t\t};\n\t\n\t\t// Store the data submitted for the API\n\t\toSettings.oAjaxData = data;\n\t\n\t\t// Allow plug-ins and external processes to modify the data\n\t\t_fnCallbackFire( oSettings, null, 'preXhr', [oSettings, data] );\n\t\n\t\tif ( oSettings.fnServerData )\n\t\t{\n\t\t\t// DataTables 1.9- compatibility\n\t\t\toSettings.fnServerData.call( instance,\n\t\t\t\toSettings.sAjaxSource,\n\t\t\t\t$.map( data, function (val, key) { // Need to convert back to 1.9 trad format\n\t\t\t\t\treturn { name: key, value: val };\n\t\t\t\t} ),\n\t\t\t\tcallback,\n\t\t\t\toSettings\n\t\t\t);\n\t\t}\n\t\telse if ( oSettings.sAjaxSource || typeof ajax === 'string' )\n\t\t{\n\t\t\t// DataTables 1.9- compatibility\n\t\t\toSettings.jqXHR = $.ajax( $.extend( baseAjax, {\n\t\t\t\turl: ajax || oSettings.sAjaxSource\n\t\t\t} ) );\n\t\t}\n\t\telse if ( $.isFunction( ajax ) )\n\t\t{\n\t\t\t// Is a function - let the caller define what needs to be done\n\t\t\toSettings.jqXHR = ajax.call( instance, data, callback, oSettings );\n\t\t}\n\t\telse\n\t\t{\n\t\t\t// Object to extend the base settings\n\t\t\toSettings.jqXHR = $.ajax( $.extend( baseAjax, ajax ) );\n\t\n\t\t\t// Restore for next time around\n\t\t\tajax.data = ajaxData;\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Update the table using an Ajax call\n\t * @param {object} settings dataTables settings object\n\t * @returns {boolean} Block the table drawing or not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAjaxUpdate( settings )\n\t{\n\t\tif ( settings.bAjaxDataGet ) {\n\t\t\tsettings.iDraw++;\n\t\t\t_fnProcessingDisplay( settings, true );\n\t\n\t\t\t_fnBuildAjax(\n\t\t\t\tsettings,\n\t\t\t\t_fnAjaxParameters( settings ),\n\t\t\t\tfunction(json) {\n\t\t\t\t\t_fnAjaxUpdateDraw( settings, json );\n\t\t\t\t}\n\t\t\t);\n\t\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t}\n\t\n\t\n\t/**\n\t * Build up the parameters in an object needed for a server-side processing\n\t * request. Note that this is basically done twice, is different ways - a modern\n\t * method which is used by default in DataTables 1.10 which uses objects and\n\t * arrays, or the 1.9- method with is name / value pairs. 1.9 method is used if\n\t * the sAjaxSource option is used in the initialisation, or the legacyAjax\n\t * option is set.\n\t * @param {object} oSettings dataTables settings object\n\t * @returns {bool} block the table drawing or not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAjaxParameters( settings )\n\t{\n\t\tvar\n\t\t\tcolumns = settings.aoColumns,\n\t\t\tcolumnCount = columns.length,\n\t\t\tfeatures = settings.oFeatures,\n\t\t\tpreSearch = settings.oPreviousSearch,\n\t\t\tpreColSearch = settings.aoPreSearchCols,\n\t\t\ti, data = [], dataProp, column, columnSearch,\n\t\t\tsort = _fnSortFlatten( settings ),\n\t\t\tdisplayStart = settings._iDisplayStart,\n\t\t\tdisplayLength = features.bPaginate !== false ?\n\t\t\t\tsettings._iDisplayLength :\n\t\t\t\t-1;\n\t\n\t\tvar param = function ( name, value ) {\n\t\t\tdata.push( { 'name': name, 'value': value } );\n\t\t};\n\t\n\t\t// DataTables 1.9- compatible method\n\t\tparam( 'sEcho', settings.iDraw );\n\t\tparam( 'iColumns', columnCount );\n\t\tparam( 'sColumns', _pluck( columns, 'sName' ).join(',') );\n\t\tparam( 'iDisplayStart', displayStart );\n\t\tparam( 'iDisplayLength', displayLength );\n\t\n\t\t// DataTables 1.10+ method\n\t\tvar d = {\n\t\t\tdraw: settings.iDraw,\n\t\t\tcolumns: [],\n\t\t\torder: [],\n\t\t\tstart: displayStart,\n\t\t\tlength: displayLength,\n\t\t\tsearch: {\n\t\t\t\tvalue: preSearch.sSearch,\n\t\t\t\tregex: preSearch.bRegex\n\t\t\t}\n\t\t};\n\t\n\t\tfor ( i=0 ; i<columnCount ; i++ ) {\n\t\t\tcolumn = columns[i];\n\t\t\tcolumnSearch = preColSearch[i];\n\t\t\tdataProp = typeof column.mData==\"function\" ? 'function' : column.mData ;\n\t\n\t\t\td.columns.push( {\n\t\t\t\tdata: dataProp,\n\t\t\t\tname: column.sName,\n\t\t\t\tsearchable: column.bSearchable,\n\t\t\t\torderable: column.bSortable,\n\t\t\t\tsearch: {\n\t\t\t\t\tvalue: columnSearch.sSearch,\n\t\t\t\t\tregex: columnSearch.bRegex\n\t\t\t\t}\n\t\t\t} );\n\t\n\t\t\tparam( \"mDataProp_\"+i, dataProp );\n\t\n\t\t\tif ( features.bFilter ) {\n\t\t\t\tparam( 'sSearch_'+i, columnSearch.sSearch );\n\t\t\t\tparam( 'bRegex_'+i, columnSearch.bRegex );\n\t\t\t\tparam( 'bSearchable_'+i, column.bSearchable );\n\t\t\t}\n\t\n\t\t\tif ( features.bSort ) {\n\t\t\t\tparam( 'bSortable_'+i, column.bSortable );\n\t\t\t}\n\t\t}\n\t\n\t\tif ( features.bFilter ) {\n\t\t\tparam( 'sSearch', preSearch.sSearch );\n\t\t\tparam( 'bRegex', preSearch.bRegex );\n\t\t}\n\t\n\t\tif ( features.bSort ) {\n\t\t\t$.each( sort, function ( i, val ) {\n\t\t\t\td.order.push( { column: val.col, dir: val.dir } );\n\t\n\t\t\t\tparam( 'iSortCol_'+i, val.col );\n\t\t\t\tparam( 'sSortDir_'+i, val.dir );\n\t\t\t} );\n\t\n\t\t\tparam( 'iSortingCols', sort.length );\n\t\t}\n\t\n\t\t// If the legacy.ajax parameter is null, then we automatically decide which\n\t\t// form to use, based on sAjaxSource\n\t\tvar legacy = DataTable.ext.legacy.ajax;\n\t\tif ( legacy === null ) {\n\t\t\treturn settings.sAjaxSource ? data : d;\n\t\t}\n\t\n\t\t// Otherwise, if legacy has been specified then we use that to decide on the\n\t\t// form\n\t\treturn legacy ? data : d;\n\t}\n\t\n\t\n\t/**\n\t * Data the data from the server (nuking the old) and redraw the table\n\t * @param {object} oSettings dataTables settings object\n\t * @param {object} json json data return from the server.\n\t * @param {string} json.sEcho Tracking flag for DataTables to match requests\n\t * @param {int} json.iTotalRecords Number of records in the data set, not accounting for filtering\n\t * @param {int} json.iTotalDisplayRecords Number of records in the data set, accounting for filtering\n\t * @param {array} json.aaData The data to display on this page\n\t * @param {string} [json.sColumns] Column ordering (sName, comma separated)\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnAjaxUpdateDraw ( settings, json )\n\t{\n\t\t// v1.10 uses camelCase variables, while 1.9 uses Hungarian notation.\n\t\t// Support both\n\t\tvar compat = function ( old, modern ) {\n\t\t\treturn json[old] !== undefined ? json[old] : json[modern];\n\t\t};\n\t\n\t\tvar data = _fnAjaxDataSrc( settings, json );\n\t\tvar draw = compat( 'sEcho', 'draw' );\n\t\tvar recordsTotal = compat( 'iTotalRecords', 'recordsTotal' );\n\t\tvar recordsFiltered = compat( 'iTotalDisplayRecords', 'recordsFiltered' );\n\t\n\t\tif ( draw ) {\n\t\t\t// Protect against out of sequence returns\n\t\t\tif ( draw*1 < settings.iDraw ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tsettings.iDraw = draw * 1;\n\t\t}\n\t\n\t\t_fnClearTable( settings );\n\t\tsettings._iRecordsTotal = parseInt(recordsTotal, 10);\n\t\tsettings._iRecordsDisplay = parseInt(recordsFiltered, 10);\n\t\n\t\tfor ( var i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t_fnAddData( settings, data[i] );\n\t\t}\n\t\tsettings.aiDisplay = settings.aiDisplayMaster.slice();\n\t\n\t\tsettings.bAjaxDataGet = false;\n\t\t_fnDraw( settings );\n\t\n\t\tif ( ! settings._bInitComplete ) {\n\t\t\t_fnInitComplete( settings, json );\n\t\t}\n\t\n\t\tsettings.bAjaxDataGet = true;\n\t\t_fnProcessingDisplay( settings, false );\n\t}\n\t\n\t\n\t/**\n\t * Get the data from the JSON data source to use for drawing a table. Using\n\t * `_fnGetObjectDataFn` allows the data to be sourced from a property of the\n\t * source object, or from a processing function.\n\t * @param {object} oSettings dataTables settings object\n\t * @param {object} json Data source object / array from the server\n\t * @return {array} Array of data to use\n\t */\n\tfunction _fnAjaxDataSrc ( oSettings, json )\n\t{\n\t\tvar dataSrc = $.isPlainObject( oSettings.ajax ) && oSettings.ajax.dataSrc !== undefined ?\n\t\t\toSettings.ajax.dataSrc :\n\t\t\toSettings.sAjaxDataProp; // Compatibility with 1.9-.\n\t\n\t\t// Compatibility with 1.9-. In order to read from aaData, check if the\n\t\t// default has been changed, if not, check for aaData\n\t\tif ( dataSrc === 'data' ) {\n\t\t\treturn json.aaData || json[dataSrc];\n\t\t}\n\t\n\t\treturn dataSrc !== \"\" ?\n\t\t\t_fnGetObjectDataFn( dataSrc )( json ) :\n\t\t\tjson;\n\t}\n\t\n\t/**\n\t * Generate the node required for filtering text\n\t * @returns {node} Filter control element\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlFilter ( settings )\n\t{\n\t\tvar classes = settings.oClasses;\n\t\tvar tableId = settings.sTableId;\n\t\tvar language = settings.oLanguage;\n\t\tvar previousSearch = settings.oPreviousSearch;\n\t\tvar features = settings.aanFeatures;\n\t\tvar input = '<input type=\"search\" class=\"'+classes.sFilterInput+'\"/>';\n\t\n\t\tvar str = language.sSearch;\n\t\tstr = str.match(/_INPUT_/) ?\n\t\t\tstr.replace('_INPUT_', input) :\n\t\t\tstr+input;\n\t\n\t\tvar filter = $('<div/>', {\n\t\t\t\t'id': ! features.f ? tableId+'_filter' : null,\n\t\t\t\t'class': classes.sFilter\n\t\t\t} )\n\t\t\t.append( $('<label/>' ).append( str ) );\n\t\n\t\tvar searchFn = function() {\n\t\t\t/* Update all other filter input elements for the new display */\n\t\t\tvar n = features.f;\n\t\t\tvar val = !this.value ? \"\" : this.value; // mental IE8 fix :-(\n\t\n\t\t\t/* Now do the filter */\n\t\t\tif ( val != previousSearch.sSearch ) {\n\t\t\t\t_fnFilterComplete( settings, {\n\t\t\t\t\t\"sSearch\": val,\n\t\t\t\t\t\"bRegex\": previousSearch.bRegex,\n\t\t\t\t\t\"bSmart\": previousSearch.bSmart ,\n\t\t\t\t\t\"bCaseInsensitive\": previousSearch.bCaseInsensitive\n\t\t\t\t} );\n\t\n\t\t\t\t// Need to redraw, without resorting\n\t\t\t\tsettings._iDisplayStart = 0;\n\t\t\t\t_fnDraw( settings );\n\t\t\t}\n\t\t};\n\t\n\t\tvar searchDelay = settings.searchDelay !== null ?\n\t\t\tsettings.searchDelay :\n\t\t\t_fnDataSource( settings ) === 'ssp' ?\n\t\t\t\t400 :\n\t\t\t\t0;\n\t\n\t\tvar jqFilter = $('input', filter)\n\t\t\t.val( previousSearch.sSearch )\n\t\t\t.attr( 'placeholder', language.sSearchPlaceholder )\n\t\t\t.bind(\n\t\t\t\t'keyup.DT search.DT input.DT paste.DT cut.DT',\n\t\t\t\tsearchDelay ?\n\t\t\t\t\t_fnThrottle( searchFn, searchDelay ) :\n\t\t\t\t\tsearchFn\n\t\t\t)\n\t\t\t.bind( 'keypress.DT', function(e) {\n\t\t\t\t/* Prevent form submission */\n\t\t\t\tif ( e.keyCode == 13 ) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t} )\n\t\t\t.attr('aria-controls', tableId);\n\t\n\t\t// Update the input elements whenever the table is filtered\n\t\t$(settings.nTable).on( 'search.dt.DT', function ( ev, s ) {\n\t\t\tif ( settings === s ) {\n\t\t\t\t// IE9 throws an 'unknown error' if document.activeElement is used\n\t\t\t\t// inside an iframe or frame...\n\t\t\t\ttry {\n\t\t\t\t\tif ( jqFilter[0] !== document.activeElement ) {\n\t\t\t\t\t\tjqFilter.val( previousSearch.sSearch );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tcatch ( e ) {}\n\t\t\t}\n\t\t} );\n\t\n\t\treturn filter[0];\n\t}\n\t\n\t\n\t/**\n\t * Filter the table using both the global filter and column based filtering\n\t * @param {object} oSettings dataTables settings object\n\t * @param {object} oSearch search information\n\t * @param {int} [iForce] force a research of the master array (1) or not (undefined or 0)\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFilterComplete ( oSettings, oInput, iForce )\n\t{\n\t\tvar oPrevSearch = oSettings.oPreviousSearch;\n\t\tvar aoPrevSearch = oSettings.aoPreSearchCols;\n\t\tvar fnSaveFilter = function ( oFilter ) {\n\t\t\t/* Save the filtering values */\n\t\t\toPrevSearch.sSearch = oFilter.sSearch;\n\t\t\toPrevSearch.bRegex = oFilter.bRegex;\n\t\t\toPrevSearch.bSmart = oFilter.bSmart;\n\t\t\toPrevSearch.bCaseInsensitive = oFilter.bCaseInsensitive;\n\t\t};\n\t\tvar fnRegex = function ( o ) {\n\t\t\t// Backwards compatibility with the bEscapeRegex option\n\t\t\treturn o.bEscapeRegex !== undefined ? !o.bEscapeRegex : o.bRegex;\n\t\t};\n\t\n\t\t// Resolve any column types that are unknown due to addition or invalidation\n\t\t// @todo As per sort - can this be moved into an event handler?\n\t\t_fnColumnTypes( oSettings );\n\t\n\t\t/* In server-side processing all filtering is done by the server, so no point hanging around here */\n\t\tif ( _fnDataSource( oSettings ) != 'ssp' )\n\t\t{\n\t\t\t/* Global filter */\n\t\t\t_fnFilter( oSettings, oInput.sSearch, iForce, fnRegex(oInput), oInput.bSmart, oInput.bCaseInsensitive );\n\t\t\tfnSaveFilter( oInput );\n\t\n\t\t\t/* Now do the individual column filter */\n\t\t\tfor ( var i=0 ; i<aoPrevSearch.length ; i++ )\n\t\t\t{\n\t\t\t\t_fnFilterColumn( oSettings, aoPrevSearch[i].sSearch, i, fnRegex(aoPrevSearch[i]),\n\t\t\t\t\taoPrevSearch[i].bSmart, aoPrevSearch[i].bCaseInsensitive );\n\t\t\t}\n\t\n\t\t\t/* Custom filtering */\n\t\t\t_fnFilterCustom( oSettings );\n\t\t}\n\t\telse\n\t\t{\n\t\t\tfnSaveFilter( oInput );\n\t\t}\n\t\n\t\t/* Tell the draw function we have been filtering */\n\t\toSettings.bFiltered = true;\n\t\t_fnCallbackFire( oSettings, null, 'search', [oSettings] );\n\t}\n\t\n\t\n\t/**\n\t * Apply custom filtering functions\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFilterCustom( settings )\n\t{\n\t\tvar filters = DataTable.ext.search;\n\t\tvar displayRows = settings.aiDisplay;\n\t\tvar row, rowIdx;\n\t\n\t\tfor ( var i=0, ien=filters.length ; i<ien ; i++ ) {\n\t\t\tvar rows = [];\n\t\n\t\t\t// Loop over each row and see if it should be included\n\t\t\tfor ( var j=0, jen=displayRows.length ; j<jen ; j++ ) {\n\t\t\t\trowIdx = displayRows[ j ];\n\t\t\t\trow = settings.aoData[ rowIdx ];\n\t\n\t\t\t\tif ( filters[i]( settings, row._aFilterData, rowIdx, row._aData, j ) ) {\n\t\t\t\t\trows.push( rowIdx );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// So the array reference doesn't break set the results into the\n\t\t\t// existing array\n\t\t\tdisplayRows.length = 0;\n\t\t\t$.merge( displayRows, rows );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Filter the table on a per-column basis\n\t * @param {object} oSettings dataTables settings object\n\t * @param {string} sInput string to filter on\n\t * @param {int} iColumn column to filter\n\t * @param {bool} bRegex treat search string as a regular expression or not\n\t * @param {bool} bSmart use smart filtering or not\n\t * @param {bool} bCaseInsensitive Do case insenstive matching or not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFilterColumn ( settings, searchStr, colIdx, regex, smart, caseInsensitive )\n\t{\n\t\tif ( searchStr === '' ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar data;\n\t\tvar display = settings.aiDisplay;\n\t\tvar rpSearch = _fnFilterCreateSearch( searchStr, regex, smart, caseInsensitive );\n\t\n\t\tfor ( var i=display.length-1 ; i>=0 ; i-- ) {\n\t\t\tdata = settings.aoData[ display[i] ]._aFilterData[ colIdx ];\n\t\n\t\t\tif ( ! rpSearch.test( data ) ) {\n\t\t\t\tdisplay.splice( i, 1 );\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Filter the data table based on user input and draw the table\n\t * @param {object} settings dataTables settings object\n\t * @param {string} input string to filter on\n\t * @param {int} force optional - force a research of the master array (1) or not (undefined or 0)\n\t * @param {bool} regex treat as a regular expression or not\n\t * @param {bool} smart perform smart filtering or not\n\t * @param {bool} caseInsensitive Do case insenstive matching or not\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFilter( settings, input, force, regex, smart, caseInsensitive )\n\t{\n\t\tvar rpSearch = _fnFilterCreateSearch( input, regex, smart, caseInsensitive );\n\t\tvar prevSearch = settings.oPreviousSearch.sSearch;\n\t\tvar displayMaster = settings.aiDisplayMaster;\n\t\tvar display, invalidated, i;\n\t\n\t\t// Need to take account of custom filtering functions - always filter\n\t\tif ( DataTable.ext.search.length !== 0 ) {\n\t\t\tforce = true;\n\t\t}\n\t\n\t\t// Check if any of the rows were invalidated\n\t\tinvalidated = _fnFilterData( settings );\n\t\n\t\t// If the input is blank - we just want the full data set\n\t\tif ( input.length <= 0 ) {\n\t\t\tsettings.aiDisplay = displayMaster.slice();\n\t\t}\n\t\telse {\n\t\t\t// New search - start from the master array\n\t\t\tif ( invalidated ||\n\t\t\t\t force ||\n\t\t\t\t prevSearch.length > input.length ||\n\t\t\t\t input.indexOf(prevSearch) !== 0 ||\n\t\t\t\t settings.bSorted // On resort, the display master needs to be\n\t\t\t\t // re-filtered since indexes will have changed\n\t\t\t) {\n\t\t\t\tsettings.aiDisplay = displayMaster.slice();\n\t\t\t}\n\t\n\t\t\t// Search the display array\n\t\t\tdisplay = settings.aiDisplay;\n\t\n\t\t\tfor ( i=display.length-1 ; i>=0 ; i-- ) {\n\t\t\t\tif ( ! rpSearch.test( settings.aoData[ display[i] ]._sFilterRow ) ) {\n\t\t\t\t\tdisplay.splice( i, 1 );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Build a regular expression object suitable for searching a table\n\t * @param {string} sSearch string to search for\n\t * @param {bool} bRegex treat as a regular expression or not\n\t * @param {bool} bSmart perform smart filtering or not\n\t * @param {bool} bCaseInsensitive Do case insensitive matching or not\n\t * @returns {RegExp} constructed object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFilterCreateSearch( search, regex, smart, caseInsensitive )\n\t{\n\t\tsearch = regex ?\n\t\t\tsearch :\n\t\t\t_fnEscapeRegex( search );\n\t\t\n\t\tif ( smart ) {\n\t\t\t/* For smart filtering we want to allow the search to work regardless of\n\t\t\t * word order. We also want double quoted text to be preserved, so word\n\t\t\t * order is important - a la google. So this is what we want to\n\t\t\t * generate:\n\t\t\t * \n\t\t\t * ^(?=.*?\\bone\\b)(?=.*?\\btwo three\\b)(?=.*?\\bfour\\b).*$\n\t\t\t */\n\t\t\tvar a = $.map( search.match( /\"[^\"]+\"|[^ ]+/g ) || [''], function ( word ) {\n\t\t\t\tif ( word.charAt(0) === '\"' ) {\n\t\t\t\t\tvar m = word.match( /^\"(.*)\"$/ );\n\t\t\t\t\tword = m ? m[1] : word;\n\t\t\t\t}\n\t\n\t\t\t\treturn word.replace('\"', '');\n\t\t\t} );\n\t\n\t\t\tsearch = '^(?=.*?'+a.join( ')(?=.*?' )+').*$';\n\t\t}\n\t\n\t\treturn new RegExp( search, caseInsensitive ? 'i' : '' );\n\t}\n\t\n\t\n\t/**\n\t * Escape a string such that it can be used in a regular expression\n\t * @param {string} sVal string to escape\n\t * @returns {string} escaped string\n\t * @memberof DataTable#oApi\n\t */\n\tvar _fnEscapeRegex = DataTable.util.escapeRegex;\n\t\n\tvar __filter_div = $('<div>')[0];\n\tvar __filter_div_textContent = __filter_div.textContent !== undefined;\n\t\n\t// Update the filtering data for each row if needed (by invalidation or first run)\n\tfunction _fnFilterData ( settings )\n\t{\n\t\tvar columns = settings.aoColumns;\n\t\tvar column;\n\t\tvar i, j, ien, jen, filterData, cellData, row;\n\t\tvar fomatters = DataTable.ext.type.search;\n\t\tvar wasInvalidated = false;\n\t\n\t\tfor ( i=0, ien=settings.aoData.length ; i<ien ; i++ ) {\n\t\t\trow = settings.aoData[i];\n\t\n\t\t\tif ( ! row._aFilterData ) {\n\t\t\t\tfilterData = [];\n\t\n\t\t\t\tfor ( j=0, jen=columns.length ; j<jen ; j++ ) {\n\t\t\t\t\tcolumn = columns[j];\n\t\n\t\t\t\t\tif ( column.bSearchable ) {\n\t\t\t\t\t\tcellData = _fnGetCellData( settings, i, j, 'filter' );\n\t\n\t\t\t\t\t\tif ( fomatters[ column.sType ] ) {\n\t\t\t\t\t\t\tcellData = fomatters[ column.sType ]( cellData );\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t// Search in DataTables 1.10 is string based. In 1.11 this\n\t\t\t\t\t\t// should be altered to also allow strict type checking.\n\t\t\t\t\t\tif ( cellData === null ) {\n\t\t\t\t\t\t\tcellData = '';\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\tif ( typeof cellData !== 'string' && cellData.toString ) {\n\t\t\t\t\t\t\tcellData = cellData.toString();\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tcellData = '';\n\t\t\t\t\t}\n\t\n\t\t\t\t\t// If it looks like there is an HTML entity in the string,\n\t\t\t\t\t// attempt to decode it so sorting works as expected. Note that\n\t\t\t\t\t// we could use a single line of jQuery to do this, but the DOM\n\t\t\t\t\t// method used here is much faster http://jsperf.com/html-decode\n\t\t\t\t\tif ( cellData.indexOf && cellData.indexOf('&') !== -1 ) {\n\t\t\t\t\t\t__filter_div.innerHTML = cellData;\n\t\t\t\t\t\tcellData = __filter_div_textContent ?\n\t\t\t\t\t\t\t__filter_div.textContent :\n\t\t\t\t\t\t\t__filter_div.innerText;\n\t\t\t\t\t}\n\t\n\t\t\t\t\tif ( cellData.replace ) {\n\t\t\t\t\t\tcellData = cellData.replace(/[\\r\\n]/g, '');\n\t\t\t\t\t}\n\t\n\t\t\t\t\tfilterData.push( cellData );\n\t\t\t\t}\n\t\n\t\t\t\trow._aFilterData = filterData;\n\t\t\t\trow._sFilterRow = filterData.join(' ');\n\t\t\t\twasInvalidated = true;\n\t\t\t}\n\t\t}\n\t\n\t\treturn wasInvalidated;\n\t}\n\t\n\t\n\t/**\n\t * Convert from the internal Hungarian notation to camelCase for external\n\t * interaction\n\t * @param {object} obj Object to convert\n\t * @returns {object} Inverted object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSearchToCamel ( obj )\n\t{\n\t\treturn {\n\t\t\tsearch: obj.sSearch,\n\t\t\tsmart: obj.bSmart,\n\t\t\tregex: obj.bRegex,\n\t\t\tcaseInsensitive: obj.bCaseInsensitive\n\t\t};\n\t}\n\t\n\t\n\t\n\t/**\n\t * Convert from camelCase notation to the internal Hungarian. We could use the\n\t * Hungarian convert function here, but this is cleaner\n\t * @param {object} obj Object to convert\n\t * @returns {object} Inverted object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSearchToHung ( obj )\n\t{\n\t\treturn {\n\t\t\tsSearch: obj.search,\n\t\t\tbSmart: obj.smart,\n\t\t\tbRegex: obj.regex,\n\t\t\tbCaseInsensitive: obj.caseInsensitive\n\t\t};\n\t}\n\t\n\t/**\n\t * Generate the node required for the info display\n\t * @param {object} oSettings dataTables settings object\n\t * @returns {node} Information element\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlInfo ( settings )\n\t{\n\t\tvar\n\t\t\ttid = settings.sTableId,\n\t\t\tnodes = settings.aanFeatures.i,\n\t\t\tn = $('<div/>', {\n\t\t\t\t'class': settings.oClasses.sInfo,\n\t\t\t\t'id': ! nodes ? tid+'_info' : null\n\t\t\t} );\n\t\n\t\tif ( ! nodes ) {\n\t\t\t// Update display on each draw\n\t\t\tsettings.aoDrawCallback.push( {\n\t\t\t\t\"fn\": _fnUpdateInfo,\n\t\t\t\t\"sName\": \"information\"\n\t\t\t} );\n\t\n\t\t\tn\n\t\t\t\t.attr( 'role', 'status' )\n\t\t\t\t.attr( 'aria-live', 'polite' );\n\t\n\t\t\t// Table is described by our info div\n\t\t\t$(settings.nTable).attr( 'aria-describedby', tid+'_info' );\n\t\t}\n\t\n\t\treturn n[0];\n\t}\n\t\n\t\n\t/**\n\t * Update the information elements in the display\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnUpdateInfo ( settings )\n\t{\n\t\t/* Show information about the table */\n\t\tvar nodes = settings.aanFeatures.i;\n\t\tif ( nodes.length === 0 ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar\n\t\t\tlang = settings.oLanguage,\n\t\t\tstart = settings._iDisplayStart+1,\n\t\t\tend = settings.fnDisplayEnd(),\n\t\t\tmax = settings.fnRecordsTotal(),\n\t\t\ttotal = settings.fnRecordsDisplay(),\n\t\t\tout = total ?\n\t\t\t\tlang.sInfo :\n\t\t\t\tlang.sInfoEmpty;\n\t\n\t\tif ( total !== max ) {\n\t\t\t/* Record set after filtering */\n\t\t\tout += ' ' + lang.sInfoFiltered;\n\t\t}\n\t\n\t\t// Convert the macros\n\t\tout += lang.sInfoPostFix;\n\t\tout = _fnInfoMacros( settings, out );\n\t\n\t\tvar callback = lang.fnInfoCallback;\n\t\tif ( callback !== null ) {\n\t\t\tout = callback.call( settings.oInstance,\n\t\t\t\tsettings, start, end, max, total, out\n\t\t\t);\n\t\t}\n\t\n\t\t$(nodes).html( out );\n\t}\n\t\n\t\n\tfunction _fnInfoMacros ( settings, str )\n\t{\n\t\t// When infinite scrolling, we are always starting at 1. _iDisplayStart is used only\n\t\t// internally\n\t\tvar\n\t\t\tformatter = settings.fnFormatNumber,\n\t\t\tstart = settings._iDisplayStart+1,\n\t\t\tlen = settings._iDisplayLength,\n\t\t\tvis = settings.fnRecordsDisplay(),\n\t\t\tall = len === -1;\n\t\n\t\treturn str.\n\t\t\treplace(/_START_/g, formatter.call( settings, start ) ).\n\t\t\treplace(/_END_/g, formatter.call( settings, settings.fnDisplayEnd() ) ).\n\t\t\treplace(/_MAX_/g, formatter.call( settings, settings.fnRecordsTotal() ) ).\n\t\t\treplace(/_TOTAL_/g, formatter.call( settings, vis ) ).\n\t\t\treplace(/_PAGE_/g, formatter.call( settings, all ? 1 : Math.ceil( start / len ) ) ).\n\t\t\treplace(/_PAGES_/g, formatter.call( settings, all ? 1 : Math.ceil( vis / len ) ) );\n\t}\n\t\n\t\n\t\n\t/**\n\t * Draw the table for the first time, adding all required features\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnInitialise ( settings )\n\t{\n\t\tvar i, iLen, iAjaxStart=settings.iInitDisplayStart;\n\t\tvar columns = settings.aoColumns, column;\n\t\tvar features = settings.oFeatures;\n\t\tvar deferLoading = settings.bDeferLoading; // value modified by the draw\n\t\n\t\t/* Ensure that the table data is fully initialised */\n\t\tif ( ! settings.bInitialised ) {\n\t\t\tsetTimeout( function(){ _fnInitialise( settings ); }, 200 );\n\t\t\treturn;\n\t\t}\n\t\n\t\t/* Show the display HTML options */\n\t\t_fnAddOptionsHtml( settings );\n\t\n\t\t/* Build and draw the header / footer for the table */\n\t\t_fnBuildHead( settings );\n\t\t_fnDrawHead( settings, settings.aoHeader );\n\t\t_fnDrawHead( settings, settings.aoFooter );\n\t\n\t\t/* Okay to show that something is going on now */\n\t\t_fnProcessingDisplay( settings, true );\n\t\n\t\t/* Calculate sizes for columns */\n\t\tif ( features.bAutoWidth ) {\n\t\t\t_fnCalculateColumnWidths( settings );\n\t\t}\n\t\n\t\tfor ( i=0, iLen=columns.length ; i<iLen ; i++ ) {\n\t\t\tcolumn = columns[i];\n\t\n\t\t\tif ( column.sWidth ) {\n\t\t\t\tcolumn.nTh.style.width = _fnStringToCss( column.sWidth );\n\t\t\t}\n\t\t}\n\t\n\t\t_fnCallbackFire( settings, null, 'preInit', [settings] );\n\t\n\t\t// If there is default sorting required - let's do it. The sort function\n\t\t// will do the drawing for us. Otherwise we draw the table regardless of the\n\t\t// Ajax source - this allows the table to look initialised for Ajax sourcing\n\t\t// data (show 'loading' message possibly)\n\t\t_fnReDraw( settings );\n\t\n\t\t// Server-side processing init complete is done by _fnAjaxUpdateDraw\n\t\tvar dataSrc = _fnDataSource( settings );\n\t\tif ( dataSrc != 'ssp' || deferLoading ) {\n\t\t\t// if there is an ajax source load the data\n\t\t\tif ( dataSrc == 'ajax' ) {\n\t\t\t\t_fnBuildAjax( settings, [], function(json) {\n\t\t\t\t\tvar aData = _fnAjaxDataSrc( settings, json );\n\t\n\t\t\t\t\t// Got the data - add it to the table\n\t\t\t\t\tfor ( i=0 ; i<aData.length ; i++ ) {\n\t\t\t\t\t\t_fnAddData( settings, aData[i] );\n\t\t\t\t\t}\n\t\n\t\t\t\t\t// Reset the init display for cookie saving. We've already done\n\t\t\t\t\t// a filter, and therefore cleared it before. So we need to make\n\t\t\t\t\t// it appear 'fresh'\n\t\t\t\t\tsettings.iInitDisplayStart = iAjaxStart;\n\t\n\t\t\t\t\t_fnReDraw( settings );\n\t\n\t\t\t\t\t_fnProcessingDisplay( settings, false );\n\t\t\t\t\t_fnInitComplete( settings, json );\n\t\t\t\t}, settings );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t_fnProcessingDisplay( settings, false );\n\t\t\t\t_fnInitComplete( settings );\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Draw the table for the first time, adding all required features\n\t * @param {object} oSettings dataTables settings object\n\t * @param {object} [json] JSON from the server that completed the table, if using Ajax source\n\t * with client-side processing (optional)\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnInitComplete ( settings, json )\n\t{\n\t\tsettings._bInitComplete = true;\n\t\n\t\t// When data was added after the initialisation (data or Ajax) we need to\n\t\t// calculate the column sizing\n\t\tif ( json || settings.oInit.aaData ) {\n\t\t\t_fnAdjustColumnSizing( settings );\n\t\t}\n\t\n\t\t_fnCallbackFire( settings, null, 'plugin-init', [settings, json] );\n\t\t_fnCallbackFire( settings, 'aoInitComplete', 'init', [settings, json] );\n\t}\n\t\n\t\n\tfunction _fnLengthChange ( settings, val )\n\t{\n\t\tvar len = parseInt( val, 10 );\n\t\tsettings._iDisplayLength = len;\n\t\n\t\t_fnLengthOverflow( settings );\n\t\n\t\t// Fire length change event\n\t\t_fnCallbackFire( settings, null, 'length', [settings, len] );\n\t}\n\t\n\t\n\t/**\n\t * Generate the node required for user display length changing\n\t * @param {object} settings dataTables settings object\n\t * @returns {node} Display length feature node\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlLength ( settings )\n\t{\n\t\tvar\n\t\t\tclasses = settings.oClasses,\n\t\t\ttableId = settings.sTableId,\n\t\t\tmenu = settings.aLengthMenu,\n\t\t\td2 = $.isArray( menu[0] ),\n\t\t\tlengths = d2 ? menu[0] : menu,\n\t\t\tlanguage = d2 ? menu[1] : menu;\n\t\n\t\tvar select = $('<select/>', {\n\t\t\t'name': tableId+'_length',\n\t\t\t'aria-controls': tableId,\n\t\t\t'class': classes.sLengthSelect\n\t\t} );\n\t\n\t\tfor ( var i=0, ien=lengths.length ; i<ien ; i++ ) {\n\t\t\tselect[0][ i ] = new Option( language[i], lengths[i] );\n\t\t}\n\t\n\t\tvar div = $('<div><label/></div>').addClass( classes.sLength );\n\t\tif ( ! settings.aanFeatures.l ) {\n\t\t\tdiv[0].id = tableId+'_length';\n\t\t}\n\t\n\t\tdiv.children().append(\n\t\t\tsettings.oLanguage.sLengthMenu.replace( '_MENU_', select[0].outerHTML )\n\t\t);\n\t\n\t\t// Can't use `select` variable as user might provide their own and the\n\t\t// reference is broken by the use of outerHTML\n\t\t$('select', div)\n\t\t\t.val( settings._iDisplayLength )\n\t\t\t.bind( 'change.DT', function(e) {\n\t\t\t\t_fnLengthChange( settings, $(this).val() );\n\t\t\t\t_fnDraw( settings );\n\t\t\t} );\n\t\n\t\t// Update node value whenever anything changes the table's length\n\t\t$(settings.nTable).bind( 'length.dt.DT', function (e, s, len) {\n\t\t\tif ( settings === s ) {\n\t\t\t\t$('select', div).val( len );\n\t\t\t}\n\t\t} );\n\t\n\t\treturn div[0];\n\t}\n\t\n\t\n\t\n\t/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *\n\t * Note that most of the paging logic is done in\n\t * DataTable.ext.pager\n\t */\n\t\n\t/**\n\t * Generate the node required for default pagination\n\t * @param {object} oSettings dataTables settings object\n\t * @returns {node} Pagination feature node\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlPaginate ( settings )\n\t{\n\t\tvar\n\t\t\ttype = settings.sPaginationType,\n\t\t\tplugin = DataTable.ext.pager[ type ],\n\t\t\tmodern = typeof plugin === 'function',\n\t\t\tredraw = function( settings ) {\n\t\t\t\t_fnDraw( settings );\n\t\t\t},\n\t\t\tnode = $('<div/>').addClass( settings.oClasses.sPaging + type )[0],\n\t\t\tfeatures = settings.aanFeatures;\n\t\n\t\tif ( ! modern ) {\n\t\t\tplugin.fnInit( settings, node, redraw );\n\t\t}\n\t\n\t\t/* Add a draw callback for the pagination on first instance, to update the paging display */\n\t\tif ( ! features.p )\n\t\t{\n\t\t\tnode.id = settings.sTableId+'_paginate';\n\t\n\t\t\tsettings.aoDrawCallback.push( {\n\t\t\t\t\"fn\": function( settings ) {\n\t\t\t\t\tif ( modern ) {\n\t\t\t\t\t\tvar\n\t\t\t\t\t\t\tstart = settings._iDisplayStart,\n\t\t\t\t\t\t\tlen = settings._iDisplayLength,\n\t\t\t\t\t\t\tvisRecords = settings.fnRecordsDisplay(),\n\t\t\t\t\t\t\tall = len === -1,\n\t\t\t\t\t\t\tpage = all ? 0 : Math.ceil( start / len ),\n\t\t\t\t\t\t\tpages = all ? 1 : Math.ceil( visRecords / len ),\n\t\t\t\t\t\t\tbuttons = plugin(page, pages),\n\t\t\t\t\t\t\ti, ien;\n\t\n\t\t\t\t\t\tfor ( i=0, ien=features.p.length ; i<ien ; i++ ) {\n\t\t\t\t\t\t\t_fnRenderer( settings, 'pageButton' )(\n\t\t\t\t\t\t\t\tsettings, features.p[i], i, buttons, page, pages\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tplugin.fnUpdate( settings, redraw );\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\t\"sName\": \"pagination\"\n\t\t\t} );\n\t\t}\n\t\n\t\treturn node;\n\t}\n\t\n\t\n\t/**\n\t * Alter the display settings to change the page\n\t * @param {object} settings DataTables settings object\n\t * @param {string|int} action Paging action to take: \"first\", \"previous\",\n\t * \"next\" or \"last\" or page number to jump to (integer)\n\t * @param [bool] redraw Automatically draw the update or not\n\t * @returns {bool} true page has changed, false - no change\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnPageChange ( settings, action, redraw )\n\t{\n\t\tvar\n\t\t\tstart = settings._iDisplayStart,\n\t\t\tlen = settings._iDisplayLength,\n\t\t\trecords = settings.fnRecordsDisplay();\n\t\n\t\tif ( records === 0 || len === -1 )\n\t\t{\n\t\t\tstart = 0;\n\t\t}\n\t\telse if ( typeof action === \"number\" )\n\t\t{\n\t\t\tstart = action * len;\n\t\n\t\t\tif ( start > records )\n\t\t\t{\n\t\t\t\tstart = 0;\n\t\t\t}\n\t\t}\n\t\telse if ( action == \"first\" )\n\t\t{\n\t\t\tstart = 0;\n\t\t}\n\t\telse if ( action == \"previous\" )\n\t\t{\n\t\t\tstart = len >= 0 ?\n\t\t\t\tstart - len :\n\t\t\t\t0;\n\t\n\t\t\tif ( start < 0 )\n\t\t\t{\n\t\t\t start = 0;\n\t\t\t}\n\t\t}\n\t\telse if ( action == \"next\" )\n\t\t{\n\t\t\tif ( start + len < records )\n\t\t\t{\n\t\t\t\tstart += len;\n\t\t\t}\n\t\t}\n\t\telse if ( action == \"last\" )\n\t\t{\n\t\t\tstart = Math.floor( (records-1) / len) * len;\n\t\t}\n\t\telse\n\t\t{\n\t\t\t_fnLog( settings, 0, \"Unknown paging action: \"+action, 5 );\n\t\t}\n\t\n\t\tvar changed = settings._iDisplayStart !== start;\n\t\tsettings._iDisplayStart = start;\n\t\n\t\tif ( changed ) {\n\t\t\t_fnCallbackFire( settings, null, 'page', [settings] );\n\t\n\t\t\tif ( redraw ) {\n\t\t\t\t_fnDraw( settings );\n\t\t\t}\n\t\t}\n\t\n\t\treturn changed;\n\t}\n\t\n\t\n\t\n\t/**\n\t * Generate the node required for the processing node\n\t * @param {object} settings dataTables settings object\n\t * @returns {node} Processing element\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlProcessing ( settings )\n\t{\n\t\treturn $('<div/>', {\n\t\t\t\t'id': ! settings.aanFeatures.r ? settings.sTableId+'_processing' : null,\n\t\t\t\t'class': settings.oClasses.sProcessing\n\t\t\t} )\n\t\t\t.html( settings.oLanguage.sProcessing )\n\t\t\t.insertBefore( settings.nTable )[0];\n\t}\n\t\n\t\n\t/**\n\t * Display or hide the processing indicator\n\t * @param {object} settings dataTables settings object\n\t * @param {bool} show Show the processing indicator (true) or not (false)\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnProcessingDisplay ( settings, show )\n\t{\n\t\tif ( settings.oFeatures.bProcessing ) {\n\t\t\t$(settings.aanFeatures.r).css( 'display', show ? 'block' : 'none' );\n\t\t}\n\t\n\t\t_fnCallbackFire( settings, null, 'processing', [settings, show] );\n\t}\n\t\n\t/**\n\t * Add any control elements for the table - specifically scrolling\n\t * @param {object} settings dataTables settings object\n\t * @returns {node} Node to add to the DOM\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnFeatureHtmlTable ( settings )\n\t{\n\t\tvar table = $(settings.nTable);\n\t\n\t\t// Add the ARIA grid role to the table\n\t\ttable.attr( 'role', 'grid' );\n\t\n\t\t// Scrolling from here on in\n\t\tvar scroll = settings.oScroll;\n\t\n\t\tif ( scroll.sX === '' && scroll.sY === '' ) {\n\t\t\treturn settings.nTable;\n\t\t}\n\t\n\t\tvar scrollX = scroll.sX;\n\t\tvar scrollY = scroll.sY;\n\t\tvar classes = settings.oClasses;\n\t\tvar caption = table.children('caption');\n\t\tvar captionSide = caption.length ? caption[0]._captionSide : null;\n\t\tvar headerClone = $( table[0].cloneNode(false) );\n\t\tvar footerClone = $( table[0].cloneNode(false) );\n\t\tvar footer = table.children('tfoot');\n\t\tvar _div = '<div/>';\n\t\tvar size = function ( s ) {\n\t\t\treturn !s ? null : _fnStringToCss( s );\n\t\t};\n\t\n\t\tif ( ! footer.length ) {\n\t\t\tfooter = null;\n\t\t}\n\t\n\t\t/*\n\t\t * The HTML structure that we want to generate in this function is:\n\t\t * div - scroller\n\t\t * div - scroll head\n\t\t * div - scroll head inner\n\t\t * table - scroll head table\n\t\t * thead - thead\n\t\t * div - scroll body\n\t\t * table - table (master table)\n\t\t * thead - thead clone for sizing\n\t\t * tbody - tbody\n\t\t * div - scroll foot\n\t\t * div - scroll foot inner\n\t\t * table - scroll foot table\n\t\t * tfoot - tfoot\n\t\t */\n\t\tvar scroller = $( _div, { 'class': classes.sScrollWrapper } )\n\t\t\t.append(\n\t\t\t\t$(_div, { 'class': classes.sScrollHead } )\n\t\t\t\t\t.css( {\n\t\t\t\t\t\toverflow: 'hidden',\n\t\t\t\t\t\tposition: 'relative',\n\t\t\t\t\t\tborder: 0,\n\t\t\t\t\t\twidth: scrollX ? size(scrollX) : '100%'\n\t\t\t\t\t} )\n\t\t\t\t\t.append(\n\t\t\t\t\t\t$(_div, { 'class': classes.sScrollHeadInner } )\n\t\t\t\t\t\t\t.css( {\n\t\t\t\t\t\t\t\t'box-sizing': 'content-box',\n\t\t\t\t\t\t\t\twidth: scroll.sXInner || '100%'\n\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t\t.append(\n\t\t\t\t\t\t\t\theaderClone\n\t\t\t\t\t\t\t\t\t.removeAttr('id')\n\t\t\t\t\t\t\t\t\t.css( 'margin-left', 0 )\n\t\t\t\t\t\t\t\t\t.append( captionSide === 'top' ? caption : null )\n\t\t\t\t\t\t\t\t\t.append(\n\t\t\t\t\t\t\t\t\t\ttable.children('thead')\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t)\n\t\t\t\t\t)\n\t\t\t)\n\t\t\t.append(\n\t\t\t\t$(_div, { 'class': classes.sScrollBody } )\n\t\t\t\t\t.css( {\n\t\t\t\t\t\tposition: 'relative',\n\t\t\t\t\t\toverflow: 'auto',\n\t\t\t\t\t\twidth: size( scrollX )\n\t\t\t\t\t} )\n\t\t\t\t\t.append( table )\n\t\t\t);\n\t\n\t\tif ( footer ) {\n\t\t\tscroller.append(\n\t\t\t\t$(_div, { 'class': classes.sScrollFoot } )\n\t\t\t\t\t.css( {\n\t\t\t\t\t\toverflow: 'hidden',\n\t\t\t\t\t\tborder: 0,\n\t\t\t\t\t\twidth: scrollX ? size(scrollX) : '100%'\n\t\t\t\t\t} )\n\t\t\t\t\t.append(\n\t\t\t\t\t\t$(_div, { 'class': classes.sScrollFootInner } )\n\t\t\t\t\t\t\t.append(\n\t\t\t\t\t\t\t\tfooterClone\n\t\t\t\t\t\t\t\t\t.removeAttr('id')\n\t\t\t\t\t\t\t\t\t.css( 'margin-left', 0 )\n\t\t\t\t\t\t\t\t\t.append( captionSide === 'bottom' ? caption : null )\n\t\t\t\t\t\t\t\t\t.append(\n\t\t\t\t\t\t\t\t\t\ttable.children('tfoot')\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t)\n\t\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\n\t\tvar children = scroller.children();\n\t\tvar scrollHead = children[0];\n\t\tvar scrollBody = children[1];\n\t\tvar scrollFoot = footer ? children[2] : null;\n\t\n\t\t// When the body is scrolled, then we also want to scroll the headers\n\t\tif ( scrollX ) {\n\t\t\t$(scrollBody).on( 'scroll.DT', function (e) {\n\t\t\t\tvar scrollLeft = this.scrollLeft;\n\t\n\t\t\t\tscrollHead.scrollLeft = scrollLeft;\n\t\n\t\t\t\tif ( footer ) {\n\t\t\t\t\tscrollFoot.scrollLeft = scrollLeft;\n\t\t\t\t}\n\t\t\t} );\n\t\t}\n\t\n\t\t$(scrollBody).css(\n\t\t\tscrollY && scroll.bCollapse ? 'max-height' : 'height', \n\t\t\tscrollY\n\t\t);\n\t\n\t\tsettings.nScrollHead = scrollHead;\n\t\tsettings.nScrollBody = scrollBody;\n\t\tsettings.nScrollFoot = scrollFoot;\n\t\n\t\t// On redraw - align columns\n\t\tsettings.aoDrawCallback.push( {\n\t\t\t\"fn\": _fnScrollDraw,\n\t\t\t\"sName\": \"scrolling\"\n\t\t} );\n\t\n\t\treturn scroller[0];\n\t}\n\t\n\t\n\t\n\t/**\n\t * Update the header, footer and body tables for resizing - i.e. column\n\t * alignment.\n\t *\n\t * Welcome to the most horrible function DataTables. The process that this\n\t * function follows is basically:\n\t * 1. Re-create the table inside the scrolling div\n\t * 2. Take live measurements from the DOM\n\t * 3. Apply the measurements to align the columns\n\t * 4. Clean up\n\t *\n\t * @param {object} settings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnScrollDraw ( settings )\n\t{\n\t\t// Given that this is such a monster function, a lot of variables are use\n\t\t// to try and keep the minimised size as small as possible\n\t\tvar\n\t\t\tscroll = settings.oScroll,\n\t\t\tscrollX = scroll.sX,\n\t\t\tscrollXInner = scroll.sXInner,\n\t\t\tscrollY = scroll.sY,\n\t\t\tbarWidth = scroll.iBarWidth,\n\t\t\tdivHeader = $(settings.nScrollHead),\n\t\t\tdivHeaderStyle = divHeader[0].style,\n\t\t\tdivHeaderInner = divHeader.children('div'),\n\t\t\tdivHeaderInnerStyle = divHeaderInner[0].style,\n\t\t\tdivHeaderTable = divHeaderInner.children('table'),\n\t\t\tdivBodyEl = settings.nScrollBody,\n\t\t\tdivBody = $(divBodyEl),\n\t\t\tdivBodyStyle = divBodyEl.style,\n\t\t\tdivFooter = $(settings.nScrollFoot),\n\t\t\tdivFooterInner = divFooter.children('div'),\n\t\t\tdivFooterTable = divFooterInner.children('table'),\n\t\t\theader = $(settings.nTHead),\n\t\t\ttable = $(settings.nTable),\n\t\t\ttableEl = table[0],\n\t\t\ttableStyle = tableEl.style,\n\t\t\tfooter = settings.nTFoot ? $(settings.nTFoot) : null,\n\t\t\tbrowser = settings.oBrowser,\n\t\t\tie67 = browser.bScrollOversize,\n\t\t\tdtHeaderCells = _pluck( settings.aoColumns, 'nTh' ),\n\t\t\theaderTrgEls, footerTrgEls,\n\t\t\theaderSrcEls, footerSrcEls,\n\t\t\theaderCopy, footerCopy,\n\t\t\theaderWidths=[], footerWidths=[],\n\t\t\theaderContent=[], footerContent=[],\n\t\t\tidx, correction, sanityWidth,\n\t\t\tzeroOut = function(nSizer) {\n\t\t\t\tvar style = nSizer.style;\n\t\t\t\tstyle.paddingTop = \"0\";\n\t\t\t\tstyle.paddingBottom = \"0\";\n\t\t\t\tstyle.borderTopWidth = \"0\";\n\t\t\t\tstyle.borderBottomWidth = \"0\";\n\t\t\t\tstyle.height = 0;\n\t\t\t};\n\t\n\t\t// If the scrollbar visibility has changed from the last draw, we need to\n\t\t// adjust the column sizes as the table width will have changed to account\n\t\t// for the scrollbar\n\t\tvar scrollBarVis = divBodyEl.scrollHeight > divBodyEl.clientHeight;\n\t\t\n\t\tif ( settings.scrollBarVis !== scrollBarVis && settings.scrollBarVis !== undefined ) {\n\t\t\tsettings.scrollBarVis = scrollBarVis;\n\t\t\t_fnAdjustColumnSizing( settings );\n\t\t\treturn; // adjust column sizing will call this function again\n\t\t}\n\t\telse {\n\t\t\tsettings.scrollBarVis = scrollBarVis;\n\t\t}\n\t\n\t\t/*\n\t\t * 1. Re-create the table inside the scrolling div\n\t\t */\n\t\n\t\t// Remove the old minimised thead and tfoot elements in the inner table\n\t\ttable.children('thead, tfoot').remove();\n\t\n\t\tif ( footer ) {\n\t\t\tfooterCopy = footer.clone().prependTo( table );\n\t\t\tfooterTrgEls = footer.find('tr'); // the original tfoot is in its own table and must be sized\n\t\t\tfooterSrcEls = footerCopy.find('tr');\n\t\t}\n\t\n\t\t// Clone the current header and footer elements and then place it into the inner table\n\t\theaderCopy = header.clone().prependTo( table );\n\t\theaderTrgEls = header.find('tr'); // original header is in its own table\n\t\theaderSrcEls = headerCopy.find('tr');\n\t\theaderCopy.find('th, td').removeAttr('tabindex');\n\t\n\t\n\t\t/*\n\t\t * 2. Take live measurements from the DOM - do not alter the DOM itself!\n\t\t */\n\t\n\t\t// Remove old sizing and apply the calculated column widths\n\t\t// Get the unique column headers in the newly created (cloned) header. We want to apply the\n\t\t// calculated sizes to this header\n\t\tif ( ! scrollX )\n\t\t{\n\t\t\tdivBodyStyle.width = '100%';\n\t\t\tdivHeader[0].style.width = '100%';\n\t\t}\n\t\n\t\t$.each( _fnGetUniqueThs( settings, headerCopy ), function ( i, el ) {\n\t\t\tidx = _fnVisibleToColumnIndex( settings, i );\n\t\t\tel.style.width = settings.aoColumns[idx].sWidth;\n\t\t} );\n\t\n\t\tif ( footer ) {\n\t\t\t_fnApplyToChildren( function(n) {\n\t\t\t\tn.style.width = \"\";\n\t\t\t}, footerSrcEls );\n\t\t}\n\t\n\t\t// Size the table as a whole\n\t\tsanityWidth = table.outerWidth();\n\t\tif ( scrollX === \"\" ) {\n\t\t\t// No x scrolling\n\t\t\ttableStyle.width = \"100%\";\n\t\n\t\t\t// IE7 will make the width of the table when 100% include the scrollbar\n\t\t\t// - which is shouldn't. When there is a scrollbar we need to take this\n\t\t\t// into account.\n\t\t\tif ( ie67 && (table.find('tbody').height() > divBodyEl.offsetHeight ||\n\t\t\t\tdivBody.css('overflow-y') == \"scroll\")\n\t\t\t) {\n\t\t\t\ttableStyle.width = _fnStringToCss( table.outerWidth() - barWidth);\n\t\t\t}\n\t\n\t\t\t// Recalculate the sanity width\n\t\t\tsanityWidth = table.outerWidth();\n\t\t}\n\t\telse if ( scrollXInner !== \"\" ) {\n\t\t\t// legacy x scroll inner has been given - use it\n\t\t\ttableStyle.width = _fnStringToCss(scrollXInner);\n\t\n\t\t\t// Recalculate the sanity width\n\t\t\tsanityWidth = table.outerWidth();\n\t\t}\n\t\n\t\t// Hidden header should have zero height, so remove padding and borders. Then\n\t\t// set the width based on the real headers\n\t\n\t\t// Apply all styles in one pass\n\t\t_fnApplyToChildren( zeroOut, headerSrcEls );\n\t\n\t\t// Read all widths in next pass\n\t\t_fnApplyToChildren( function(nSizer) {\n\t\t\theaderContent.push( nSizer.innerHTML );\n\t\t\theaderWidths.push( _fnStringToCss( $(nSizer).css('width') ) );\n\t\t}, headerSrcEls );\n\t\n\t\t// Apply all widths in final pass\n\t\t_fnApplyToChildren( function(nToSize, i) {\n\t\t\t// Only apply widths to the DataTables detected header cells - this\n\t\t\t// prevents complex headers from having contradictory sizes applied\n\t\t\tif ( $.inArray( nToSize, dtHeaderCells ) !== -1 ) {\n\t\t\t\tnToSize.style.width = headerWidths[i];\n\t\t\t}\n\t\t}, headerTrgEls );\n\t\n\t\t$(headerSrcEls).height(0);\n\t\n\t\t/* Same again with the footer if we have one */\n\t\tif ( footer )\n\t\t{\n\t\t\t_fnApplyToChildren( zeroOut, footerSrcEls );\n\t\n\t\t\t_fnApplyToChildren( function(nSizer) {\n\t\t\t\tfooterContent.push( nSizer.innerHTML );\n\t\t\t\tfooterWidths.push( _fnStringToCss( $(nSizer).css('width') ) );\n\t\t\t}, footerSrcEls );\n\t\n\t\t\t_fnApplyToChildren( function(nToSize, i) {\n\t\t\t\tnToSize.style.width = footerWidths[i];\n\t\t\t}, footerTrgEls );\n\t\n\t\t\t$(footerSrcEls).height(0);\n\t\t}\n\t\n\t\n\t\t/*\n\t\t * 3. Apply the measurements\n\t\t */\n\t\n\t\t// \"Hide\" the header and footer that we used for the sizing. We need to keep\n\t\t// the content of the cell so that the width applied to the header and body\n\t\t// both match, but we want to hide it completely. We want to also fix their\n\t\t// width to what they currently are\n\t\t_fnApplyToChildren( function(nSizer, i) {\n\t\t\tnSizer.innerHTML = '<div class=\"dataTables_sizing\" style=\"height:0;overflow:hidden;\">'+headerContent[i]+'</div>';\n\t\t\tnSizer.style.width = headerWidths[i];\n\t\t}, headerSrcEls );\n\t\n\t\tif ( footer )\n\t\t{\n\t\t\t_fnApplyToChildren( function(nSizer, i) {\n\t\t\t\tnSizer.innerHTML = '<div class=\"dataTables_sizing\" style=\"height:0;overflow:hidden;\">'+footerContent[i]+'</div>';\n\t\t\t\tnSizer.style.width = footerWidths[i];\n\t\t\t}, footerSrcEls );\n\t\t}\n\t\n\t\t// Sanity check that the table is of a sensible width. If not then we are going to get\n\t\t// misalignment - try to prevent this by not allowing the table to shrink below its min width\n\t\tif ( table.outerWidth() < sanityWidth )\n\t\t{\n\t\t\t// The min width depends upon if we have a vertical scrollbar visible or not */\n\t\t\tcorrection = ((divBodyEl.scrollHeight > divBodyEl.offsetHeight ||\n\t\t\t\tdivBody.css('overflow-y') == \"scroll\")) ?\n\t\t\t\t\tsanityWidth+barWidth :\n\t\t\t\t\tsanityWidth;\n\t\n\t\t\t// IE6/7 are a law unto themselves...\n\t\t\tif ( ie67 && (divBodyEl.scrollHeight >\n\t\t\t\tdivBodyEl.offsetHeight || divBody.css('overflow-y') == \"scroll\")\n\t\t\t) {\n\t\t\t\ttableStyle.width = _fnStringToCss( correction-barWidth );\n\t\t\t}\n\t\n\t\t\t// And give the user a warning that we've stopped the table getting too small\n\t\t\tif ( scrollX === \"\" || scrollXInner !== \"\" ) {\n\t\t\t\t_fnLog( settings, 1, 'Possible column misalignment', 6 );\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tcorrection = '100%';\n\t\t}\n\t\n\t\t// Apply to the container elements\n\t\tdivBodyStyle.width = _fnStringToCss( correction );\n\t\tdivHeaderStyle.width = _fnStringToCss( correction );\n\t\n\t\tif ( footer ) {\n\t\t\tsettings.nScrollFoot.style.width = _fnStringToCss( correction );\n\t\t}\n\t\n\t\n\t\t/*\n\t\t * 4. Clean up\n\t\t */\n\t\tif ( ! scrollY ) {\n\t\t\t/* IE7< puts a vertical scrollbar in place (when it shouldn't be) due to subtracting\n\t\t\t * the scrollbar height from the visible display, rather than adding it on. We need to\n\t\t\t * set the height in order to sort this. Don't want to do it in any other browsers.\n\t\t\t */\n\t\t\tif ( ie67 ) {\n\t\t\t\tdivBodyStyle.height = _fnStringToCss( tableEl.offsetHeight+barWidth );\n\t\t\t}\n\t\t}\n\t\n\t\t/* Finally set the width's of the header and footer tables */\n\t\tvar iOuterWidth = table.outerWidth();\n\t\tdivHeaderTable[0].style.width = _fnStringToCss( iOuterWidth );\n\t\tdivHeaderInnerStyle.width = _fnStringToCss( iOuterWidth );\n\t\n\t\t// Figure out if there are scrollbar present - if so then we need a the header and footer to\n\t\t// provide a bit more space to allow \"overflow\" scrolling (i.e. past the scrollbar)\n\t\tvar bScrolling = table.height() > divBodyEl.clientHeight || divBody.css('overflow-y') == \"scroll\";\n\t\tvar padding = 'padding' + (browser.bScrollbarLeft ? 'Left' : 'Right' );\n\t\tdivHeaderInnerStyle[ padding ] = bScrolling ? barWidth+\"px\" : \"0px\";\n\t\n\t\tif ( footer ) {\n\t\t\tdivFooterTable[0].style.width = _fnStringToCss( iOuterWidth );\n\t\t\tdivFooterInner[0].style.width = _fnStringToCss( iOuterWidth );\n\t\t\tdivFooterInner[0].style[padding] = bScrolling ? barWidth+\"px\" : \"0px\";\n\t\t}\n\t\n\t\t// Correct DOM ordering for colgroup - comes before the thead\n\t\ttable.children('colgroup').insertBefore( table.children('thead') );\n\t\n\t\t/* Adjust the position of the header in case we loose the y-scrollbar */\n\t\tdivBody.scroll();\n\t\n\t\t// If sorting or filtering has occurred, jump the scrolling back to the top\n\t\t// only if we aren't holding the position\n\t\tif ( (settings.bSorted || settings.bFiltered) && ! settings._drawHold ) {\n\t\t\tdivBodyEl.scrollTop = 0;\n\t\t}\n\t}\n\t\n\t\n\t\n\t/**\n\t * Apply a given function to the display child nodes of an element array (typically\n\t * TD children of TR rows\n\t * @param {function} fn Method to apply to the objects\n\t * @param array {nodes} an1 List of elements to look through for display children\n\t * @param array {nodes} an2 Another list (identical structure to the first) - optional\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnApplyToChildren( fn, an1, an2 )\n\t{\n\t\tvar index=0, i=0, iLen=an1.length;\n\t\tvar nNode1, nNode2;\n\t\n\t\twhile ( i < iLen ) {\n\t\t\tnNode1 = an1[i].firstChild;\n\t\t\tnNode2 = an2 ? an2[i].firstChild : null;\n\t\n\t\t\twhile ( nNode1 ) {\n\t\t\t\tif ( nNode1.nodeType === 1 ) {\n\t\t\t\t\tif ( an2 ) {\n\t\t\t\t\t\tfn( nNode1, nNode2, index );\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tfn( nNode1, index );\n\t\t\t\t\t}\n\t\n\t\t\t\t\tindex++;\n\t\t\t\t}\n\t\n\t\t\t\tnNode1 = nNode1.nextSibling;\n\t\t\t\tnNode2 = an2 ? nNode2.nextSibling : null;\n\t\t\t}\n\t\n\t\t\ti++;\n\t\t}\n\t}\n\t\n\t\n\t\n\tvar __re_html_remove = /<.*?>/g;\n\t\n\t\n\t/**\n\t * Calculate the width of columns for the table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnCalculateColumnWidths ( oSettings )\n\t{\n\t\tvar\n\t\t\ttable = oSettings.nTable,\n\t\t\tcolumns = oSettings.aoColumns,\n\t\t\tscroll = oSettings.oScroll,\n\t\t\tscrollY = scroll.sY,\n\t\t\tscrollX = scroll.sX,\n\t\t\tscrollXInner = scroll.sXInner,\n\t\t\tcolumnCount = columns.length,\n\t\t\tvisibleColumns = _fnGetColumns( oSettings, 'bVisible' ),\n\t\t\theaderCells = $('th', oSettings.nTHead),\n\t\t\ttableWidthAttr = table.getAttribute('width'), // from DOM element\n\t\t\ttableContainer = table.parentNode,\n\t\t\tuserInputs = false,\n\t\t\ti, column, columnIdx, width, outerWidth,\n\t\t\tbrowser = oSettings.oBrowser,\n\t\t\tie67 = browser.bScrollOversize;\n\t\n\t\tvar styleWidth = table.style.width;\n\t\tif ( styleWidth && styleWidth.indexOf('%') !== -1 ) {\n\t\t\ttableWidthAttr = styleWidth;\n\t\t}\n\t\n\t\t/* Convert any user input sizes into pixel sizes */\n\t\tfor ( i=0 ; i<visibleColumns.length ; i++ ) {\n\t\t\tcolumn = columns[ visibleColumns[i] ];\n\t\n\t\t\tif ( column.sWidth !== null ) {\n\t\t\t\tcolumn.sWidth = _fnConvertToWidth( column.sWidthOrig, tableContainer );\n\t\n\t\t\t\tuserInputs = true;\n\t\t\t}\n\t\t}\n\t\n\t\t/* If the number of columns in the DOM equals the number that we have to\n\t\t * process in DataTables, then we can use the offsets that are created by\n\t\t * the web- browser. No custom sizes can be set in order for this to happen,\n\t\t * nor scrolling used\n\t\t */\n\t\tif ( ie67 || ! userInputs && ! scrollX && ! scrollY &&\n\t\t columnCount == _fnVisbleColumns( oSettings ) &&\n\t\t columnCount == headerCells.length\n\t\t) {\n\t\t\tfor ( i=0 ; i<columnCount ; i++ ) {\n\t\t\t\tvar colIdx = _fnVisibleToColumnIndex( oSettings, i );\n\t\n\t\t\t\tif ( colIdx !== null ) {\n\t\t\t\t\tcolumns[ colIdx ].sWidth = _fnStringToCss( headerCells.eq(i).width() );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\t// Otherwise construct a single row, worst case, table with the widest\n\t\t\t// node in the data, assign any user defined widths, then insert it into\n\t\t\t// the DOM and allow the browser to do all the hard work of calculating\n\t\t\t// table widths\n\t\t\tvar tmpTable = $(table).clone() // don't use cloneNode - IE8 will remove events on the main table\n\t\t\t\t.css( 'visibility', 'hidden' )\n\t\t\t\t.removeAttr( 'id' );\n\t\n\t\t\t// Clean up the table body\n\t\t\ttmpTable.find('tbody tr').remove();\n\t\t\tvar tr = $('<tr/>').appendTo( tmpTable.find('tbody') );\n\t\n\t\t\t// Clone the table header and footer - we can't use the header / footer\n\t\t\t// from the cloned table, since if scrolling is active, the table's\n\t\t\t// real header and footer are contained in different table tags\n\t\t\ttmpTable.find('thead, tfoot').remove();\n\t\t\ttmpTable\n\t\t\t\t.append( $(oSettings.nTHead).clone() )\n\t\t\t\t.append( $(oSettings.nTFoot).clone() );\n\t\n\t\t\t// Remove any assigned widths from the footer (from scrolling)\n\t\t\ttmpTable.find('tfoot th, tfoot td').css('width', '');\n\t\n\t\t\t// Apply custom sizing to the cloned header\n\t\t\theaderCells = _fnGetUniqueThs( oSettings, tmpTable.find('thead')[0] );\n\t\n\t\t\tfor ( i=0 ; i<visibleColumns.length ; i++ ) {\n\t\t\t\tcolumn = columns[ visibleColumns[i] ];\n\t\n\t\t\t\theaderCells[i].style.width = column.sWidthOrig !== null && column.sWidthOrig !== '' ?\n\t\t\t\t\t_fnStringToCss( column.sWidthOrig ) :\n\t\t\t\t\t'';\n\t\n\t\t\t\t// For scrollX we need to force the column width otherwise the\n\t\t\t\t// browser will collapse it. If this width is smaller than the\n\t\t\t\t// width the column requires, then it will have no effect\n\t\t\t\tif ( column.sWidthOrig && scrollX ) {\n\t\t\t\t\t$( headerCells[i] ).append( $('<div/>').css( {\n\t\t\t\t\t\twidth: column.sWidthOrig,\n\t\t\t\t\t\tmargin: 0,\n\t\t\t\t\t\tpadding: 0,\n\t\t\t\t\t\tborder: 0,\n\t\t\t\t\t\theight: 1\n\t\t\t\t\t} ) );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// Find the widest cell for each column and put it into the table\n\t\t\tif ( oSettings.aoData.length ) {\n\t\t\t\tfor ( i=0 ; i<visibleColumns.length ; i++ ) {\n\t\t\t\t\tcolumnIdx = visibleColumns[i];\n\t\t\t\t\tcolumn = columns[ columnIdx ];\n\t\n\t\t\t\t\t$( _fnGetWidestNode( oSettings, columnIdx ) )\n\t\t\t\t\t\t.clone( false )\n\t\t\t\t\t\t.append( column.sContentPadding )\n\t\t\t\t\t\t.appendTo( tr );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// Tidy the temporary table - remove name attributes so there aren't\n\t\t\t// duplicated in the dom (radio elements for example)\n\t\t\t$('[name]', tmpTable).removeAttr('name');\n\t\n\t\t\t// Table has been built, attach to the document so we can work with it.\n\t\t\t// A holding element is used, positioned at the top of the container\n\t\t\t// with minimal height, so it has no effect on if the container scrolls\n\t\t\t// or not. Otherwise it might trigger scrolling when it actually isn't\n\t\t\t// needed\n\t\t\tvar holder = $('<div/>').css( scrollX || scrollY ?\n\t\t\t\t\t{\n\t\t\t\t\t\tposition: 'absolute',\n\t\t\t\t\t\ttop: 0,\n\t\t\t\t\t\tleft: 0,\n\t\t\t\t\t\theight: 1,\n\t\t\t\t\t\tright: 0,\n\t\t\t\t\t\toverflow: 'hidden'\n\t\t\t\t\t} :\n\t\t\t\t\t{}\n\t\t\t\t)\n\t\t\t\t.append( tmpTable )\n\t\t\t\t.appendTo( tableContainer );\n\t\n\t\t\t// When scrolling (X or Y) we want to set the width of the table as \n\t\t\t// appropriate. However, when not scrolling leave the table width as it\n\t\t\t// is. This results in slightly different, but I think correct behaviour\n\t\t\tif ( scrollX && scrollXInner ) {\n\t\t\t\ttmpTable.width( scrollXInner );\n\t\t\t}\n\t\t\telse if ( scrollX ) {\n\t\t\t\ttmpTable.css( 'width', 'auto' );\n\t\t\t\ttmpTable.removeAttr('width');\n\t\n\t\t\t\t// If there is no width attribute or style, then allow the table to\n\t\t\t\t// collapse\n\t\t\t\tif ( tmpTable.width() < tableContainer.clientWidth && tableWidthAttr ) {\n\t\t\t\t\ttmpTable.width( tableContainer.clientWidth );\n\t\t\t\t}\n\t\t\t}\n\t\t\telse if ( scrollY ) {\n\t\t\t\ttmpTable.width( tableContainer.clientWidth );\n\t\t\t}\n\t\t\telse if ( tableWidthAttr ) {\n\t\t\t\ttmpTable.width( tableWidthAttr );\n\t\t\t}\n\t\n\t\t\t// Get the width of each column in the constructed table - we need to\n\t\t\t// know the inner width (so it can be assigned to the other table's\n\t\t\t// cells) and the outer width so we can calculate the full width of the\n\t\t\t// table. This is safe since DataTables requires a unique cell for each\n\t\t\t// column, but if ever a header can span multiple columns, this will\n\t\t\t// need to be modified.\n\t\t\tvar total = 0;\n\t\t\tfor ( i=0 ; i<visibleColumns.length ; i++ ) {\n\t\t\t\tvar cell = $(headerCells[i]);\n\t\t\t\tvar border = cell.outerWidth() - cell.width();\n\t\n\t\t\t\t// Use getBounding... where possible (not IE8-) because it can give\n\t\t\t\t// sub-pixel accuracy, which we then want to round up!\n\t\t\t\tvar bounding = browser.bBounding ?\n\t\t\t\t\tMath.ceil( headerCells[i].getBoundingClientRect().width ) :\n\t\t\t\t\tcell.outerWidth();\n\t\n\t\t\t\t// Total is tracked to remove any sub-pixel errors as the outerWidth\n\t\t\t\t// of the table might not equal the total given here (IE!).\n\t\t\t\ttotal += bounding;\n\t\n\t\t\t\t// Width for each column to use\n\t\t\t\tcolumns[ visibleColumns[i] ].sWidth = _fnStringToCss( bounding - border );\n\t\t\t}\n\t\n\t\t\ttable.style.width = _fnStringToCss( total );\n\t\n\t\t\t// Finished with the table - ditch it\n\t\t\tholder.remove();\n\t\t}\n\t\n\t\t// If there is a width attr, we want to attach an event listener which\n\t\t// allows the table sizing to automatically adjust when the window is\n\t\t// resized. Use the width attr rather than CSS, since we can't know if the\n\t\t// CSS is a relative value or absolute - DOM read is always px.\n\t\tif ( tableWidthAttr ) {\n\t\t\ttable.style.width = _fnStringToCss( tableWidthAttr );\n\t\t}\n\t\n\t\tif ( (tableWidthAttr || scrollX) && ! oSettings._reszEvt ) {\n\t\t\tvar bindResize = function () {\n\t\t\t\t$(window).bind('resize.DT-'+oSettings.sInstance, _fnThrottle( function () {\n\t\t\t\t\t_fnAdjustColumnSizing( oSettings );\n\t\t\t\t} ) );\n\t\t\t};\n\t\n\t\t\t// IE6/7 will crash if we bind a resize event handler on page load.\n\t\t\t// To be removed in 1.11 which drops IE6/7 support\n\t\t\tif ( ie67 ) {\n\t\t\t\tsetTimeout( bindResize, 1000 );\n\t\t\t}\n\t\t\telse {\n\t\t\t\tbindResize();\n\t\t\t}\n\t\n\t\t\toSettings._reszEvt = true;\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Throttle the calls to a function. Arguments and context are maintained for\n\t * the throttled function\n\t * @param {function} fn Function to be called\n\t * @param {int} [freq=200] call frequency in mS\n\t * @returns {function} wrapped function\n\t * @memberof DataTable#oApi\n\t */\n\tvar _fnThrottle = DataTable.util.throttle;\n\t\n\t\n\t/**\n\t * Convert a CSS unit width to pixels (e.g. 2em)\n\t * @param {string} width width to be converted\n\t * @param {node} parent parent to get the with for (required for relative widths) - optional\n\t * @returns {int} width in pixels\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnConvertToWidth ( width, parent )\n\t{\n\t\tif ( ! width ) {\n\t\t\treturn 0;\n\t\t}\n\t\n\t\tvar n = $('<div/>')\n\t\t\t.css( 'width', _fnStringToCss( width ) )\n\t\t\t.appendTo( parent || document.body );\n\t\n\t\tvar val = n[0].offsetWidth;\n\t\tn.remove();\n\t\n\t\treturn val;\n\t}\n\t\n\t\n\t/**\n\t * Get the widest node\n\t * @param {object} settings dataTables settings object\n\t * @param {int} colIdx column of interest\n\t * @returns {node} widest table node\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetWidestNode( settings, colIdx )\n\t{\n\t\tvar idx = _fnGetMaxLenString( settings, colIdx );\n\t\tif ( idx < 0 ) {\n\t\t\treturn null;\n\t\t}\n\t\n\t\tvar data = settings.aoData[ idx ];\n\t\treturn ! data.nTr ? // Might not have been created when deferred rendering\n\t\t\t$('<td/>').html( _fnGetCellData( settings, idx, colIdx, 'display' ) )[0] :\n\t\t\tdata.anCells[ colIdx ];\n\t}\n\t\n\t\n\t/**\n\t * Get the maximum strlen for each data column\n\t * @param {object} settings dataTables settings object\n\t * @param {int} colIdx column of interest\n\t * @returns {string} max string length for each column\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnGetMaxLenString( settings, colIdx )\n\t{\n\t\tvar s, max=-1, maxIdx = -1;\n\t\n\t\tfor ( var i=0, ien=settings.aoData.length ; i<ien ; i++ ) {\n\t\t\ts = _fnGetCellData( settings, i, colIdx, 'display' )+'';\n\t\t\ts = s.replace( __re_html_remove, '' );\n\t\t\ts = s.replace( / /g, ' ' );\n\t\n\t\t\tif ( s.length > max ) {\n\t\t\t\tmax = s.length;\n\t\t\t\tmaxIdx = i;\n\t\t\t}\n\t\t}\n\t\n\t\treturn maxIdx;\n\t}\n\t\n\t\n\t/**\n\t * Append a CSS unit (only if required) to a string\n\t * @param {string} value to css-ify\n\t * @returns {string} value with css unit\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnStringToCss( s )\n\t{\n\t\tif ( s === null ) {\n\t\t\treturn '0px';\n\t\t}\n\t\n\t\tif ( typeof s == 'number' ) {\n\t\t\treturn s < 0 ?\n\t\t\t\t'0px' :\n\t\t\t\ts+'px';\n\t\t}\n\t\n\t\t// Check it has a unit character already\n\t\treturn s.match(/\\d$/) ?\n\t\t\ts+'px' :\n\t\t\ts;\n\t}\n\t\n\t\n\t\n\tfunction _fnSortFlatten ( settings )\n\t{\n\t\tvar\n\t\t\ti, iLen, k, kLen,\n\t\t\taSort = [],\n\t\t\taiOrig = [],\n\t\t\taoColumns = settings.aoColumns,\n\t\t\taDataSort, iCol, sType, srcCol,\n\t\t\tfixed = settings.aaSortingFixed,\n\t\t\tfixedObj = $.isPlainObject( fixed ),\n\t\t\tnestedSort = [],\n\t\t\tadd = function ( a ) {\n\t\t\t\tif ( a.length && ! $.isArray( a[0] ) ) {\n\t\t\t\t\t// 1D array\n\t\t\t\t\tnestedSort.push( a );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\t// 2D array\n\t\t\t\t\t$.merge( nestedSort, a );\n\t\t\t\t}\n\t\t\t};\n\t\n\t\t// Build the sort array, with pre-fix and post-fix options if they have been\n\t\t// specified\n\t\tif ( $.isArray( fixed ) ) {\n\t\t\tadd( fixed );\n\t\t}\n\t\n\t\tif ( fixedObj && fixed.pre ) {\n\t\t\tadd( fixed.pre );\n\t\t}\n\t\n\t\tadd( settings.aaSorting );\n\t\n\t\tif (fixedObj && fixed.post ) {\n\t\t\tadd( fixed.post );\n\t\t}\n\t\n\t\tfor ( i=0 ; i<nestedSort.length ; i++ )\n\t\t{\n\t\t\tsrcCol = nestedSort[i][0];\n\t\t\taDataSort = aoColumns[ srcCol ].aDataSort;\n\t\n\t\t\tfor ( k=0, kLen=aDataSort.length ; k<kLen ; k++ )\n\t\t\t{\n\t\t\t\tiCol = aDataSort[k];\n\t\t\t\tsType = aoColumns[ iCol ].sType || 'string';\n\t\n\t\t\t\tif ( nestedSort[i]._idx === undefined ) {\n\t\t\t\t\tnestedSort[i]._idx = $.inArray( nestedSort[i][1], aoColumns[iCol].asSorting );\n\t\t\t\t}\n\t\n\t\t\t\taSort.push( {\n\t\t\t\t\tsrc: srcCol,\n\t\t\t\t\tcol: iCol,\n\t\t\t\t\tdir: nestedSort[i][1],\n\t\t\t\t\tindex: nestedSort[i]._idx,\n\t\t\t\t\ttype: sType,\n\t\t\t\t\tformatter: DataTable.ext.type.order[ sType+\"-pre\" ]\n\t\t\t\t} );\n\t\t\t}\n\t\t}\n\t\n\t\treturn aSort;\n\t}\n\t\n\t/**\n\t * Change the order of the table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t * @todo This really needs split up!\n\t */\n\tfunction _fnSort ( oSettings )\n\t{\n\t\tvar\n\t\t\ti, ien, iLen, j, jLen, k, kLen,\n\t\t\tsDataType, nTh,\n\t\t\taiOrig = [],\n\t\t\toExtSort = DataTable.ext.type.order,\n\t\t\taoData = oSettings.aoData,\n\t\t\taoColumns = oSettings.aoColumns,\n\t\t\taDataSort, data, iCol, sType, oSort,\n\t\t\tformatters = 0,\n\t\t\tsortCol,\n\t\t\tdisplayMaster = oSettings.aiDisplayMaster,\n\t\t\taSort;\n\t\n\t\t// Resolve any column types that are unknown due to addition or invalidation\n\t\t// @todo Can this be moved into a 'data-ready' handler which is called when\n\t\t// data is going to be used in the table?\n\t\t_fnColumnTypes( oSettings );\n\t\n\t\taSort = _fnSortFlatten( oSettings );\n\t\n\t\tfor ( i=0, ien=aSort.length ; i<ien ; i++ ) {\n\t\t\tsortCol = aSort[i];\n\t\n\t\t\t// Track if we can use the fast sort algorithm\n\t\t\tif ( sortCol.formatter ) {\n\t\t\t\tformatters++;\n\t\t\t}\n\t\n\t\t\t// Load the data needed for the sort, for each cell\n\t\t\t_fnSortData( oSettings, sortCol.col );\n\t\t}\n\t\n\t\t/* No sorting required if server-side or no sorting array */\n\t\tif ( _fnDataSource( oSettings ) != 'ssp' && aSort.length !== 0 )\n\t\t{\n\t\t\t// Create a value - key array of the current row positions such that we can use their\n\t\t\t// current position during the sort, if values match, in order to perform stable sorting\n\t\t\tfor ( i=0, iLen=displayMaster.length ; i<iLen ; i++ ) {\n\t\t\t\taiOrig[ displayMaster[i] ] = i;\n\t\t\t}\n\t\n\t\t\t/* Do the sort - here we want multi-column sorting based on a given data source (column)\n\t\t\t * and sorting function (from oSort) in a certain direction. It's reasonably complex to\n\t\t\t * follow on it's own, but this is what we want (example two column sorting):\n\t\t\t * fnLocalSorting = function(a,b){\n\t\t\t * var iTest;\n\t\t\t * iTest = oSort['string-asc']('data11', 'data12');\n\t\t\t * if (iTest !== 0)\n\t\t\t * return iTest;\n\t\t\t * iTest = oSort['numeric-desc']('data21', 'data22');\n\t\t\t * if (iTest !== 0)\n\t\t\t * return iTest;\n\t\t\t * return oSort['numeric-asc']( aiOrig[a], aiOrig[b] );\n\t\t\t * }\n\t\t\t * Basically we have a test for each sorting column, if the data in that column is equal,\n\t\t\t * test the next column. If all columns match, then we use a numeric sort on the row\n\t\t\t * positions in the original data array to provide a stable sort.\n\t\t\t *\n\t\t\t * Note - I know it seems excessive to have two sorting methods, but the first is around\n\t\t\t * 15% faster, so the second is only maintained for backwards compatibility with sorting\n\t\t\t * methods which do not have a pre-sort formatting function.\n\t\t\t */\n\t\t\tif ( formatters === aSort.length ) {\n\t\t\t\t// All sort types have formatting functions\n\t\t\t\tdisplayMaster.sort( function ( a, b ) {\n\t\t\t\t\tvar\n\t\t\t\t\t\tx, y, k, test, sort,\n\t\t\t\t\t\tlen=aSort.length,\n\t\t\t\t\t\tdataA = aoData[a]._aSortData,\n\t\t\t\t\t\tdataB = aoData[b]._aSortData;\n\t\n\t\t\t\t\tfor ( k=0 ; k<len ; k++ ) {\n\t\t\t\t\t\tsort = aSort[k];\n\t\n\t\t\t\t\t\tx = dataA[ sort.col ];\n\t\t\t\t\t\ty = dataB[ sort.col ];\n\t\n\t\t\t\t\t\ttest = x<y ? -1 : x>y ? 1 : 0;\n\t\t\t\t\t\tif ( test !== 0 ) {\n\t\t\t\t\t\t\treturn sort.dir === 'asc' ? test : -test;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\n\t\t\t\t\tx = aiOrig[a];\n\t\t\t\t\ty = aiOrig[b];\n\t\t\t\t\treturn x<y ? -1 : x>y ? 1 : 0;\n\t\t\t\t} );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Depreciated - remove in 1.11 (providing a plug-in option)\n\t\t\t\t// Not all sort types have formatting methods, so we have to call their sorting\n\t\t\t\t// methods.\n\t\t\t\tdisplayMaster.sort( function ( a, b ) {\n\t\t\t\t\tvar\n\t\t\t\t\t\tx, y, k, l, test, sort, fn,\n\t\t\t\t\t\tlen=aSort.length,\n\t\t\t\t\t\tdataA = aoData[a]._aSortData,\n\t\t\t\t\t\tdataB = aoData[b]._aSortData;\n\t\n\t\t\t\t\tfor ( k=0 ; k<len ; k++ ) {\n\t\t\t\t\t\tsort = aSort[k];\n\t\n\t\t\t\t\t\tx = dataA[ sort.col ];\n\t\t\t\t\t\ty = dataB[ sort.col ];\n\t\n\t\t\t\t\t\tfn = oExtSort[ sort.type+\"-\"+sort.dir ] || oExtSort[ \"string-\"+sort.dir ];\n\t\t\t\t\t\ttest = fn( x, y );\n\t\t\t\t\t\tif ( test !== 0 ) {\n\t\t\t\t\t\t\treturn test;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\n\t\t\t\t\tx = aiOrig[a];\n\t\t\t\t\ty = aiOrig[b];\n\t\t\t\t\treturn x<y ? -1 : x>y ? 1 : 0;\n\t\t\t\t} );\n\t\t\t}\n\t\t}\n\t\n\t\t/* Tell the draw function that we have sorted the data */\n\t\toSettings.bSorted = true;\n\t}\n\t\n\t\n\tfunction _fnSortAria ( settings )\n\t{\n\t\tvar label;\n\t\tvar nextSort;\n\t\tvar columns = settings.aoColumns;\n\t\tvar aSort = _fnSortFlatten( settings );\n\t\tvar oAria = settings.oLanguage.oAria;\n\t\n\t\t// ARIA attributes - need to loop all columns, to update all (removing old\n\t\t// attributes as needed)\n\t\tfor ( var i=0, iLen=columns.length ; i<iLen ; i++ )\n\t\t{\n\t\t\tvar col = columns[i];\n\t\t\tvar asSorting = col.asSorting;\n\t\t\tvar sTitle = col.sTitle.replace( /<.*?>/g, \"\" );\n\t\t\tvar th = col.nTh;\n\t\n\t\t\t// IE7 is throwing an error when setting these properties with jQuery's\n\t\t\t// attr() and removeAttr() methods...\n\t\t\tth.removeAttribute('aria-sort');\n\t\n\t\t\t/* In ARIA only the first sorting column can be marked as sorting - no multi-sort option */\n\t\t\tif ( col.bSortable ) {\n\t\t\t\tif ( aSort.length > 0 && aSort[0].col == i ) {\n\t\t\t\t\tth.setAttribute('aria-sort', aSort[0].dir==\"asc\" ? \"ascending\" : \"descending\" );\n\t\t\t\t\tnextSort = asSorting[ aSort[0].index+1 ] || asSorting[0];\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tnextSort = asSorting[0];\n\t\t\t\t}\n\t\n\t\t\t\tlabel = sTitle + ( nextSort === \"asc\" ?\n\t\t\t\t\toAria.sSortAscending :\n\t\t\t\t\toAria.sSortDescending\n\t\t\t\t);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tlabel = sTitle;\n\t\t\t}\n\t\n\t\t\tth.setAttribute('aria-label', label);\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Function to run on user sort request\n\t * @param {object} settings dataTables settings object\n\t * @param {node} attachTo node to attach the handler to\n\t * @param {int} colIdx column sorting index\n\t * @param {boolean} [append=false] Append the requested sort to the existing\n\t * sort if true (i.e. multi-column sort)\n\t * @param {function} [callback] callback function\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSortListener ( settings, colIdx, append, callback )\n\t{\n\t\tvar col = settings.aoColumns[ colIdx ];\n\t\tvar sorting = settings.aaSorting;\n\t\tvar asSorting = col.asSorting;\n\t\tvar nextSortIdx;\n\t\tvar next = function ( a, overflow ) {\n\t\t\tvar idx = a._idx;\n\t\t\tif ( idx === undefined ) {\n\t\t\t\tidx = $.inArray( a[1], asSorting );\n\t\t\t}\n\t\n\t\t\treturn idx+1 < asSorting.length ?\n\t\t\t\tidx+1 :\n\t\t\t\toverflow ?\n\t\t\t\t\tnull :\n\t\t\t\t\t0;\n\t\t};\n\t\n\t\t// Convert to 2D array if needed\n\t\tif ( typeof sorting[0] === 'number' ) {\n\t\t\tsorting = settings.aaSorting = [ sorting ];\n\t\t}\n\t\n\t\t// If appending the sort then we are multi-column sorting\n\t\tif ( append && settings.oFeatures.bSortMulti ) {\n\t\t\t// Are we already doing some kind of sort on this column?\n\t\t\tvar sortIdx = $.inArray( colIdx, _pluck(sorting, '0') );\n\t\n\t\t\tif ( sortIdx !== -1 ) {\n\t\t\t\t// Yes, modify the sort\n\t\t\t\tnextSortIdx = next( sorting[sortIdx], true );\n\t\n\t\t\t\tif ( nextSortIdx === null && sorting.length === 1 ) {\n\t\t\t\t\tnextSortIdx = 0; // can't remove sorting completely\n\t\t\t\t}\n\t\n\t\t\t\tif ( nextSortIdx === null ) {\n\t\t\t\t\tsorting.splice( sortIdx, 1 );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tsorting[sortIdx][1] = asSorting[ nextSortIdx ];\n\t\t\t\t\tsorting[sortIdx]._idx = nextSortIdx;\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// No sort on this column yet\n\t\t\t\tsorting.push( [ colIdx, asSorting[0], 0 ] );\n\t\t\t\tsorting[sorting.length-1]._idx = 0;\n\t\t\t}\n\t\t}\n\t\telse if ( sorting.length && sorting[0][0] == colIdx ) {\n\t\t\t// Single column - already sorting on this column, modify the sort\n\t\t\tnextSortIdx = next( sorting[0] );\n\t\n\t\t\tsorting.length = 1;\n\t\t\tsorting[0][1] = asSorting[ nextSortIdx ];\n\t\t\tsorting[0]._idx = nextSortIdx;\n\t\t}\n\t\telse {\n\t\t\t// Single column - sort only on this column\n\t\t\tsorting.length = 0;\n\t\t\tsorting.push( [ colIdx, asSorting[0] ] );\n\t\t\tsorting[0]._idx = 0;\n\t\t}\n\t\n\t\t// Run the sort by calling a full redraw\n\t\t_fnReDraw( settings );\n\t\n\t\t// callback used for async user interaction\n\t\tif ( typeof callback == 'function' ) {\n\t\t\tcallback( settings );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Attach a sort handler (click) to a node\n\t * @param {object} settings dataTables settings object\n\t * @param {node} attachTo node to attach the handler to\n\t * @param {int} colIdx column sorting index\n\t * @param {function} [callback] callback function\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSortAttachListener ( settings, attachTo, colIdx, callback )\n\t{\n\t\tvar col = settings.aoColumns[ colIdx ];\n\t\n\t\t_fnBindAction( attachTo, {}, function (e) {\n\t\t\t/* If the column is not sortable - don't to anything */\n\t\t\tif ( col.bSortable === false ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\n\t\t\t// If processing is enabled use a timeout to allow the processing\n\t\t\t// display to be shown - otherwise to it synchronously\n\t\t\tif ( settings.oFeatures.bProcessing ) {\n\t\t\t\t_fnProcessingDisplay( settings, true );\n\t\n\t\t\t\tsetTimeout( function() {\n\t\t\t\t\t_fnSortListener( settings, colIdx, e.shiftKey, callback );\n\t\n\t\t\t\t\t// In server-side processing, the draw callback will remove the\n\t\t\t\t\t// processing display\n\t\t\t\t\tif ( _fnDataSource( settings ) !== 'ssp' ) {\n\t\t\t\t\t\t_fnProcessingDisplay( settings, false );\n\t\t\t\t\t}\n\t\t\t\t}, 0 );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t_fnSortListener( settings, colIdx, e.shiftKey, callback );\n\t\t\t}\n\t\t} );\n\t}\n\t\n\t\n\t/**\n\t * Set the sorting classes on table's body, Note: it is safe to call this function\n\t * when bSort and bSortClasses are false\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSortingClasses( settings )\n\t{\n\t\tvar oldSort = settings.aLastSort;\n\t\tvar sortClass = settings.oClasses.sSortColumn;\n\t\tvar sort = _fnSortFlatten( settings );\n\t\tvar features = settings.oFeatures;\n\t\tvar i, ien, colIdx;\n\t\n\t\tif ( features.bSort && features.bSortClasses ) {\n\t\t\t// Remove old sorting classes\n\t\t\tfor ( i=0, ien=oldSort.length ; i<ien ; i++ ) {\n\t\t\t\tcolIdx = oldSort[i].src;\n\t\n\t\t\t\t// Remove column sorting\n\t\t\t\t$( _pluck( settings.aoData, 'anCells', colIdx ) )\n\t\t\t\t\t.removeClass( sortClass + (i<2 ? i+1 : 3) );\n\t\t\t}\n\t\n\t\t\t// Add new column sorting\n\t\t\tfor ( i=0, ien=sort.length ; i<ien ; i++ ) {\n\t\t\t\tcolIdx = sort[i].src;\n\t\n\t\t\t\t$( _pluck( settings.aoData, 'anCells', colIdx ) )\n\t\t\t\t\t.addClass( sortClass + (i<2 ? i+1 : 3) );\n\t\t\t}\n\t\t}\n\t\n\t\tsettings.aLastSort = sort;\n\t}\n\t\n\t\n\t// Get the data to sort a column, be it from cache, fresh (populating the\n\t// cache), or from a sort formatter\n\tfunction _fnSortData( settings, idx )\n\t{\n\t\t// Custom sorting function - provided by the sort data type\n\t\tvar column = settings.aoColumns[ idx ];\n\t\tvar customSort = DataTable.ext.order[ column.sSortDataType ];\n\t\tvar customData;\n\t\n\t\tif ( customSort ) {\n\t\t\tcustomData = customSort.call( settings.oInstance, settings, idx,\n\t\t\t\t_fnColumnIndexToVisible( settings, idx )\n\t\t\t);\n\t\t}\n\t\n\t\t// Use / populate cache\n\t\tvar row, cellData;\n\t\tvar formatter = DataTable.ext.type.order[ column.sType+\"-pre\" ];\n\t\n\t\tfor ( var i=0, ien=settings.aoData.length ; i<ien ; i++ ) {\n\t\t\trow = settings.aoData[i];\n\t\n\t\t\tif ( ! row._aSortData ) {\n\t\t\t\trow._aSortData = [];\n\t\t\t}\n\t\n\t\t\tif ( ! row._aSortData[idx] || customSort ) {\n\t\t\t\tcellData = customSort ?\n\t\t\t\t\tcustomData[i] : // If there was a custom sort function, use data from there\n\t\t\t\t\t_fnGetCellData( settings, i, idx, 'sort' );\n\t\n\t\t\t\trow._aSortData[ idx ] = formatter ?\n\t\t\t\t\tformatter( cellData ) :\n\t\t\t\t\tcellData;\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\t\n\t/**\n\t * Save the state of a table\n\t * @param {object} oSettings dataTables settings object\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSaveState ( settings )\n\t{\n\t\tif ( !settings.oFeatures.bStateSave || settings.bDestroying )\n\t\t{\n\t\t\treturn;\n\t\t}\n\t\n\t\t/* Store the interesting variables */\n\t\tvar state = {\n\t\t\ttime: +new Date(),\n\t\t\tstart: settings._iDisplayStart,\n\t\t\tlength: settings._iDisplayLength,\n\t\t\torder: $.extend( true, [], settings.aaSorting ),\n\t\t\tsearch: _fnSearchToCamel( settings.oPreviousSearch ),\n\t\t\tcolumns: $.map( settings.aoColumns, function ( col, i ) {\n\t\t\t\treturn {\n\t\t\t\t\tvisible: col.bVisible,\n\t\t\t\t\tsearch: _fnSearchToCamel( settings.aoPreSearchCols[i] )\n\t\t\t\t};\n\t\t\t} )\n\t\t};\n\t\n\t\t_fnCallbackFire( settings, \"aoStateSaveParams\", 'stateSaveParams', [settings, state] );\n\t\n\t\tsettings.oSavedState = state;\n\t\tsettings.fnStateSaveCallback.call( settings.oInstance, settings, state );\n\t}\n\t\n\t\n\t/**\n\t * Attempt to load a saved table state\n\t * @param {object} oSettings dataTables settings object\n\t * @param {object} oInit DataTables init object so we can override settings\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnLoadState ( settings, oInit )\n\t{\n\t\tvar i, ien;\n\t\tvar columns = settings.aoColumns;\n\t\n\t\tif ( ! settings.oFeatures.bStateSave ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar state = settings.fnStateLoadCallback.call( settings.oInstance, settings );\n\t\tif ( ! state || ! state.time ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\t/* Allow custom and plug-in manipulation functions to alter the saved data set and\n\t\t * cancelling of loading by returning false\n\t\t */\n\t\tvar abStateLoad = _fnCallbackFire( settings, 'aoStateLoadParams', 'stateLoadParams', [settings, state] );\n\t\tif ( $.inArray( false, abStateLoad ) !== -1 ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\t/* Reject old data */\n\t\tvar duration = settings.iStateDuration;\n\t\tif ( duration > 0 && state.time < +new Date() - (duration*1000) ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\t// Number of columns have changed - all bets are off, no restore of settings\n\t\tif ( columns.length !== state.columns.length ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\t// Store the saved state so it might be accessed at any time\n\t\tsettings.oLoadedState = $.extend( true, {}, state );\n\t\n\t\t// Restore key features - todo - for 1.11 this needs to be done by\n\t\t// subscribed events\n\t\tif ( state.start !== undefined ) {\n\t\t\tsettings._iDisplayStart = state.start;\n\t\t\tsettings.iInitDisplayStart = state.start;\n\t\t}\n\t\tif ( state.length !== undefined ) {\n\t\t\tsettings._iDisplayLength = state.length;\n\t\t}\n\t\n\t\t// Order\n\t\tif ( state.order !== undefined ) {\n\t\t\tsettings.aaSorting = [];\n\t\t\t$.each( state.order, function ( i, col ) {\n\t\t\t\tsettings.aaSorting.push( col[0] >= columns.length ?\n\t\t\t\t\t[ 0, col[1] ] :\n\t\t\t\t\tcol\n\t\t\t\t);\n\t\t\t} );\n\t\t}\n\t\n\t\t// Search\n\t\tif ( state.search !== undefined ) {\n\t\t\t$.extend( settings.oPreviousSearch, _fnSearchToHung( state.search ) );\n\t\t}\n\t\n\t\t// Columns\n\t\tfor ( i=0, ien=state.columns.length ; i<ien ; i++ ) {\n\t\t\tvar col = state.columns[i];\n\t\n\t\t\t// Visibility\n\t\t\tif ( col.visible !== undefined ) {\n\t\t\t\tcolumns[i].bVisible = col.visible;\n\t\t\t}\n\t\n\t\t\t// Search\n\t\t\tif ( col.search !== undefined ) {\n\t\t\t\t$.extend( settings.aoPreSearchCols[i], _fnSearchToHung( col.search ) );\n\t\t\t}\n\t\t}\n\t\n\t\t_fnCallbackFire( settings, 'aoStateLoaded', 'stateLoaded', [settings, state] );\n\t}\n\t\n\t\n\t/**\n\t * Return the settings object for a particular table\n\t * @param {node} table table we are using as a dataTable\n\t * @returns {object} Settings object - or null if not found\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnSettingsFromNode ( table )\n\t{\n\t\tvar settings = DataTable.settings;\n\t\tvar idx = $.inArray( table, _pluck( settings, 'nTable' ) );\n\t\n\t\treturn idx !== -1 ?\n\t\t\tsettings[ idx ] :\n\t\t\tnull;\n\t}\n\t\n\t\n\t/**\n\t * Log an error message\n\t * @param {object} settings dataTables settings object\n\t * @param {int} level log error messages, or display them to the user\n\t * @param {string} msg error message\n\t * @param {int} tn Technical note id to get more information about the error.\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnLog( settings, level, msg, tn )\n\t{\n\t\tmsg = 'DataTables warning: '+\n\t\t\t(settings ? 'table id='+settings.sTableId+' - ' : '')+msg;\n\t\n\t\tif ( tn ) {\n\t\t\tmsg += '. For more information about this error, please see '+\n\t\t\t'http://datatables.net/tn/'+tn;\n\t\t}\n\t\n\t\tif ( ! level ) {\n\t\t\t// Backwards compatibility pre 1.10\n\t\t\tvar ext = DataTable.ext;\n\t\t\tvar type = ext.sErrMode || ext.errMode;\n\t\n\t\t\tif ( settings ) {\n\t\t\t\t_fnCallbackFire( settings, null, 'error', [ settings, tn, msg ] );\n\t\t\t}\n\t\n\t\t\tif ( type == 'alert' ) {\n\t\t\t\talert( msg );\n\t\t\t}\n\t\t\telse if ( type == 'throw' ) {\n\t\t\t\tthrow new Error(msg);\n\t\t\t}\n\t\t\telse if ( typeof type == 'function' ) {\n\t\t\t\ttype( settings, tn, msg );\n\t\t\t}\n\t\t}\n\t\telse if ( window.console && console.log ) {\n\t\t\tconsole.log( msg );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * See if a property is defined on one object, if so assign it to the other object\n\t * @param {object} ret target object\n\t * @param {object} src source object\n\t * @param {string} name property\n\t * @param {string} [mappedName] name to map too - optional, name used if not given\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnMap( ret, src, name, mappedName )\n\t{\n\t\tif ( $.isArray( name ) ) {\n\t\t\t$.each( name, function (i, val) {\n\t\t\t\tif ( $.isArray( val ) ) {\n\t\t\t\t\t_fnMap( ret, src, val[0], val[1] );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\t_fnMap( ret, src, val );\n\t\t\t\t}\n\t\t\t} );\n\t\n\t\t\treturn;\n\t\t}\n\t\n\t\tif ( mappedName === undefined ) {\n\t\t\tmappedName = name;\n\t\t}\n\t\n\t\tif ( src[name] !== undefined ) {\n\t\t\tret[mappedName] = src[name];\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Extend objects - very similar to jQuery.extend, but deep copy objects, and\n\t * shallow copy arrays. The reason we need to do this, is that we don't want to\n\t * deep copy array init values (such as aaSorting) since the dev wouldn't be\n\t * able to override them, but we do want to deep copy arrays.\n\t * @param {object} out Object to extend\n\t * @param {object} extender Object from which the properties will be applied to\n\t * out\n\t * @param {boolean} breakRefs If true, then arrays will be sliced to take an\n\t * independent copy with the exception of the `data` or `aaData` parameters\n\t * if they are present. This is so you can pass in a collection to\n\t * DataTables and have that used as your data source without breaking the\n\t * references\n\t * @returns {object} out Reference, just for convenience - out === the return.\n\t * @memberof DataTable#oApi\n\t * @todo This doesn't take account of arrays inside the deep copied objects.\n\t */\n\tfunction _fnExtend( out, extender, breakRefs )\n\t{\n\t\tvar val;\n\t\n\t\tfor ( var prop in extender ) {\n\t\t\tif ( extender.hasOwnProperty(prop) ) {\n\t\t\t\tval = extender[prop];\n\t\n\t\t\t\tif ( $.isPlainObject( val ) ) {\n\t\t\t\t\tif ( ! $.isPlainObject( out[prop] ) ) {\n\t\t\t\t\t\tout[prop] = {};\n\t\t\t\t\t}\n\t\t\t\t\t$.extend( true, out[prop], val );\n\t\t\t\t}\n\t\t\t\telse if ( breakRefs && prop !== 'data' && prop !== 'aaData' && $.isArray(val) ) {\n\t\t\t\t\tout[prop] = val.slice();\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tout[prop] = val;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\treturn out;\n\t}\n\t\n\t\n\t/**\n\t * Bind an event handers to allow a click or return key to activate the callback.\n\t * This is good for accessibility since a return on the keyboard will have the\n\t * same effect as a click, if the element has focus.\n\t * @param {element} n Element to bind the action to\n\t * @param {object} oData Data object to pass to the triggered function\n\t * @param {function} fn Callback function for when the event is triggered\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnBindAction( n, oData, fn )\n\t{\n\t\t$(n)\n\t\t\t.bind( 'click.DT', oData, function (e) {\n\t\t\t\t\tn.blur(); // Remove focus outline for mouse users\n\t\t\t\t\tfn(e);\n\t\t\t\t} )\n\t\t\t.bind( 'keypress.DT', oData, function (e){\n\t\t\t\t\tif ( e.which === 13 ) {\n\t\t\t\t\t\te.preventDefault();\n\t\t\t\t\t\tfn(e);\n\t\t\t\t\t}\n\t\t\t\t} )\n\t\t\t.bind( 'selectstart.DT', function () {\n\t\t\t\t\t/* Take the brutal approach to cancelling text selection */\n\t\t\t\t\treturn false;\n\t\t\t\t} );\n\t}\n\t\n\t\n\t/**\n\t * Register a callback function. Easily allows a callback function to be added to\n\t * an array store of callback functions that can then all be called together.\n\t * @param {object} oSettings dataTables settings object\n\t * @param {string} sStore Name of the array storage for the callbacks in oSettings\n\t * @param {function} fn Function to be called back\n\t * @param {string} sName Identifying name for the callback (i.e. a label)\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnCallbackReg( oSettings, sStore, fn, sName )\n\t{\n\t\tif ( fn )\n\t\t{\n\t\t\toSettings[sStore].push( {\n\t\t\t\t\"fn\": fn,\n\t\t\t\t\"sName\": sName\n\t\t\t} );\n\t\t}\n\t}\n\t\n\t\n\t/**\n\t * Fire callback functions and trigger events. Note that the loop over the\n\t * callback array store is done backwards! Further note that you do not want to\n\t * fire off triggers in time sensitive applications (for example cell creation)\n\t * as its slow.\n\t * @param {object} settings dataTables settings object\n\t * @param {string} callbackArr Name of the array storage for the callbacks in\n\t * oSettings\n\t * @param {string} eventName Name of the jQuery custom event to trigger. If\n\t * null no trigger is fired\n\t * @param {array} args Array of arguments to pass to the callback function /\n\t * trigger\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnCallbackFire( settings, callbackArr, eventName, args )\n\t{\n\t\tvar ret = [];\n\t\n\t\tif ( callbackArr ) {\n\t\t\tret = $.map( settings[callbackArr].slice().reverse(), function (val, i) {\n\t\t\t\treturn val.fn.apply( settings.oInstance, args );\n\t\t\t} );\n\t\t}\n\t\n\t\tif ( eventName !== null ) {\n\t\t\tvar e = $.Event( eventName+'.dt' );\n\t\n\t\t\t$(settings.nTable).trigger( e, args );\n\t\n\t\t\tret.push( e.result );\n\t\t}\n\t\n\t\treturn ret;\n\t}\n\t\n\t\n\tfunction _fnLengthOverflow ( settings )\n\t{\n\t\tvar\n\t\t\tstart = settings._iDisplayStart,\n\t\t\tend = settings.fnDisplayEnd(),\n\t\t\tlen = settings._iDisplayLength;\n\t\n\t\t/* If we have space to show extra rows (backing up from the end point - then do so */\n\t\tif ( start >= end )\n\t\t{\n\t\t\tstart = end - len;\n\t\t}\n\t\n\t\t// Keep the start record on the current page\n\t\tstart -= (start % len);\n\t\n\t\tif ( len === -1 || start < 0 )\n\t\t{\n\t\t\tstart = 0;\n\t\t}\n\t\n\t\tsettings._iDisplayStart = start;\n\t}\n\t\n\t\n\tfunction _fnRenderer( settings, type )\n\t{\n\t\tvar renderer = settings.renderer;\n\t\tvar host = DataTable.ext.renderer[type];\n\t\n\t\tif ( $.isPlainObject( renderer ) && renderer[type] ) {\n\t\t\t// Specific renderer for this type. If available use it, otherwise use\n\t\t\t// the default.\n\t\t\treturn host[renderer[type]] || host._;\n\t\t}\n\t\telse if ( typeof renderer === 'string' ) {\n\t\t\t// Common renderer - if there is one available for this type use it,\n\t\t\t// otherwise use the default\n\t\t\treturn host[renderer] || host._;\n\t\t}\n\t\n\t\t// Use the default\n\t\treturn host._;\n\t}\n\t\n\t\n\t/**\n\t * Detect the data source being used for the table. Used to simplify the code\n\t * a little (ajax) and to make it compress a little smaller.\n\t *\n\t * @param {object} settings dataTables settings object\n\t * @returns {string} Data source\n\t * @memberof DataTable#oApi\n\t */\n\tfunction _fnDataSource ( settings )\n\t{\n\t\tif ( settings.oFeatures.bServerSide ) {\n\t\t\treturn 'ssp';\n\t\t}\n\t\telse if ( settings.ajax || settings.sAjaxSource ) {\n\t\t\treturn 'ajax';\n\t\t}\n\t\treturn 'dom';\n\t}\n\t\n\n\t\n\t\n\t/**\n\t * Computed structure of the DataTables API, defined by the options passed to\n\t * `DataTable.Api.register()` when building the API.\n\t *\n\t * The structure is built in order to speed creation and extension of the Api\n\t * objects since the extensions are effectively pre-parsed.\n\t *\n\t * The array is an array of objects with the following structure, where this\n\t * base array represents the Api prototype base:\n\t *\n\t * [\n\t * {\n\t * name: 'data' -- string - Property name\n\t * val: function () {}, -- function - Api method (or undefined if just an object\n\t * methodExt: [ ... ], -- array - Array of Api object definitions to extend the method result\n\t * propExt: [ ... ] -- array - Array of Api object definitions to extend the property\n\t * },\n\t * {\n\t * name: 'row'\n\t * val: {},\n\t * methodExt: [ ... ],\n\t * propExt: [\n\t * {\n\t * name: 'data'\n\t * val: function () {},\n\t * methodExt: [ ... ],\n\t * propExt: [ ... ]\n\t * },\n\t * ...\n\t * ]\n\t * }\n\t * ]\n\t *\n\t * @type {Array}\n\t * @ignore\n\t */\n\tvar __apiStruct = [];\n\t\n\t\n\t/**\n\t * `Array.prototype` reference.\n\t *\n\t * @type object\n\t * @ignore\n\t */\n\tvar __arrayProto = Array.prototype;\n\t\n\t\n\t/**\n\t * Abstraction for `context` parameter of the `Api` constructor to allow it to\n\t * take several different forms for ease of use.\n\t *\n\t * Each of the input parameter types will be converted to a DataTables settings\n\t * object where possible.\n\t *\n\t * @param {string|node|jQuery|object} mixed DataTable identifier. Can be one\n\t * of:\n\t *\n\t * * `string` - jQuery selector. Any DataTables' matching the given selector\n\t * with be found and used.\n\t * * `node` - `TABLE` node which has already been formed into a DataTable.\n\t * * `jQuery` - A jQuery object of `TABLE` nodes.\n\t * * `object` - DataTables settings object\n\t * * `DataTables.Api` - API instance\n\t * @return {array|null} Matching DataTables settings objects. `null` or\n\t * `undefined` is returned if no matching DataTable is found.\n\t * @ignore\n\t */\n\tvar _toSettings = function ( mixed )\n\t{\n\t\tvar idx, jq;\n\t\tvar settings = DataTable.settings;\n\t\tvar tables = $.map( settings, function (el, i) {\n\t\t\treturn el.nTable;\n\t\t} );\n\t\n\t\tif ( ! mixed ) {\n\t\t\treturn [];\n\t\t}\n\t\telse if ( mixed.nTable && mixed.oApi ) {\n\t\t\t// DataTables settings object\n\t\t\treturn [ mixed ];\n\t\t}\n\t\telse if ( mixed.nodeName && mixed.nodeName.toLowerCase() === 'table' ) {\n\t\t\t// Table node\n\t\t\tidx = $.inArray( mixed, tables );\n\t\t\treturn idx !== -1 ? [ settings[idx] ] : null;\n\t\t}\n\t\telse if ( mixed && typeof mixed.settings === 'function' ) {\n\t\t\treturn mixed.settings().toArray();\n\t\t}\n\t\telse if ( typeof mixed === 'string' ) {\n\t\t\t// jQuery selector\n\t\t\tjq = $(mixed);\n\t\t}\n\t\telse if ( mixed instanceof $ ) {\n\t\t\t// jQuery object (also DataTables instance)\n\t\t\tjq = mixed;\n\t\t}\n\t\n\t\tif ( jq ) {\n\t\t\treturn jq.map( function(i) {\n\t\t\t\tidx = $.inArray( this, tables );\n\t\t\t\treturn idx !== -1 ? settings[idx] : null;\n\t\t\t} ).toArray();\n\t\t}\n\t};\n\t\n\t\n\t/**\n\t * DataTables API class - used to control and interface with one or more\n\t * DataTables enhanced tables.\n\t *\n\t * The API class is heavily based on jQuery, presenting a chainable interface\n\t * that you can use to interact with tables. Each instance of the API class has\n\t * a \"context\" - i.e. the tables that it will operate on. This could be a single\n\t * table, all tables on a page or a sub-set thereof.\n\t *\n\t * Additionally the API is designed to allow you to easily work with the data in\n\t * the tables, retrieving and manipulating it as required. This is done by\n\t * presenting the API class as an array like interface. The contents of the\n\t * array depend upon the actions requested by each method (for example\n\t * `rows().nodes()` will return an array of nodes, while `rows().data()` will\n\t * return an array of objects or arrays depending upon your table's\n\t * configuration). The API object has a number of array like methods (`push`,\n\t * `pop`, `reverse` etc) as well as additional helper methods (`each`, `pluck`,\n\t * `unique` etc) to assist your working with the data held in a table.\n\t *\n\t * Most methods (those which return an Api instance) are chainable, which means\n\t * the return from a method call also has all of the methods available that the\n\t * top level object had. For example, these two calls are equivalent:\n\t *\n\t * // Not chained\n\t * api.row.add( {...} );\n\t * api.draw();\n\t *\n\t * // Chained\n\t * api.row.add( {...} ).draw();\n\t *\n\t * @class DataTable.Api\n\t * @param {array|object|string|jQuery} context DataTable identifier. This is\n\t * used to define which DataTables enhanced tables this API will operate on.\n\t * Can be one of:\n\t *\n\t * * `string` - jQuery selector. Any DataTables' matching the given selector\n\t * with be found and used.\n\t * * `node` - `TABLE` node which has already been formed into a DataTable.\n\t * * `jQuery` - A jQuery object of `TABLE` nodes.\n\t * * `object` - DataTables settings object\n\t * @param {array} [data] Data to initialise the Api instance with.\n\t *\n\t * @example\n\t * // Direct initialisation during DataTables construction\n\t * var api = $('#example').DataTable();\n\t *\n\t * @example\n\t * // Initialisation using a DataTables jQuery object\n\t * var api = $('#example').dataTable().api();\n\t *\n\t * @example\n\t * // Initialisation as a constructor\n\t * var api = new $.fn.DataTable.Api( 'table.dataTable' );\n\t */\n\t_Api = function ( context, data )\n\t{\n\t\tif ( ! (this instanceof _Api) ) {\n\t\t\treturn new _Api( context, data );\n\t\t}\n\t\n\t\tvar settings = [];\n\t\tvar ctxSettings = function ( o ) {\n\t\t\tvar a = _toSettings( o );\n\t\t\tif ( a ) {\n\t\t\t\tsettings = settings.concat( a );\n\t\t\t}\n\t\t};\n\t\n\t\tif ( $.isArray( context ) ) {\n\t\t\tfor ( var i=0, ien=context.length ; i<ien ; i++ ) {\n\t\t\t\tctxSettings( context[i] );\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tctxSettings( context );\n\t\t}\n\t\n\t\t// Remove duplicates\n\t\tthis.context = _unique( settings );\n\t\n\t\t// Initial data\n\t\tif ( data ) {\n\t\t\t$.merge( this, data );\n\t\t}\n\t\n\t\t// selector\n\t\tthis.selector = {\n\t\t\trows: null,\n\t\t\tcols: null,\n\t\t\topts: null\n\t\t};\n\t\n\t\t_Api.extend( this, this, __apiStruct );\n\t};\n\t\n\tDataTable.Api = _Api;\n\t\n\t// Don't destroy the existing prototype, just extend it. Required for jQuery 2's\n\t// isPlainObject.\n\t$.extend( _Api.prototype, {\n\t\tany: function ()\n\t\t{\n\t\t\treturn this.count() !== 0;\n\t\t},\n\t\n\t\n\t\tconcat: __arrayProto.concat,\n\t\n\t\n\t\tcontext: [], // array of table settings objects\n\t\n\t\n\t\tcount: function ()\n\t\t{\n\t\t\treturn this.flatten().length;\n\t\t},\n\t\n\t\n\t\teach: function ( fn )\n\t\t{\n\t\t\tfor ( var i=0, ien=this.length ; i<ien; i++ ) {\n\t\t\t\tfn.call( this, this[i], i, this );\n\t\t\t}\n\t\n\t\t\treturn this;\n\t\t},\n\t\n\t\n\t\teq: function ( idx )\n\t\t{\n\t\t\tvar ctx = this.context;\n\t\n\t\t\treturn ctx.length > idx ?\n\t\t\t\tnew _Api( ctx[idx], this[idx] ) :\n\t\t\t\tnull;\n\t\t},\n\t\n\t\n\t\tfilter: function ( fn )\n\t\t{\n\t\t\tvar a = [];\n\t\n\t\t\tif ( __arrayProto.filter ) {\n\t\t\t\ta = __arrayProto.filter.call( this, fn, this );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Compatibility for browsers without EMCA-252-5 (JS 1.6)\n\t\t\t\tfor ( var i=0, ien=this.length ; i<ien ; i++ ) {\n\t\t\t\t\tif ( fn.call( this, this[i], i, this ) ) {\n\t\t\t\t\t\ta.push( this[i] );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\treturn new _Api( this.context, a );\n\t\t},\n\t\n\t\n\t\tflatten: function ()\n\t\t{\n\t\t\tvar a = [];\n\t\t\treturn new _Api( this.context, a.concat.apply( a, this.toArray() ) );\n\t\t},\n\t\n\t\n\t\tjoin: __arrayProto.join,\n\t\n\t\n\t\tindexOf: __arrayProto.indexOf || function (obj, start)\n\t\t{\n\t\t\tfor ( var i=(start || 0), ien=this.length ; i<ien ; i++ ) {\n\t\t\t\tif ( this[i] === obj ) {\n\t\t\t\t\treturn i;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn -1;\n\t\t},\n\t\n\t\titerator: function ( flatten, type, fn, alwaysNew ) {\n\t\t\tvar\n\t\t\t\ta = [], ret,\n\t\t\t\ti, ien, j, jen,\n\t\t\t\tcontext = this.context,\n\t\t\t\trows, items, item,\n\t\t\t\tselector = this.selector;\n\t\n\t\t\t// Argument shifting\n\t\t\tif ( typeof flatten === 'string' ) {\n\t\t\t\talwaysNew = fn;\n\t\t\t\tfn = type;\n\t\t\t\ttype = flatten;\n\t\t\t\tflatten = false;\n\t\t\t}\n\t\n\t\t\tfor ( i=0, ien=context.length ; i<ien ; i++ ) {\n\t\t\t\tvar apiInst = new _Api( context[i] );\n\t\n\t\t\t\tif ( type === 'table' ) {\n\t\t\t\t\tret = fn.call( apiInst, context[i], i );\n\t\n\t\t\t\t\tif ( ret !== undefined ) {\n\t\t\t\t\t\ta.push( ret );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse if ( type === 'columns' || type === 'rows' ) {\n\t\t\t\t\t// this has same length as context - one entry for each table\n\t\t\t\t\tret = fn.call( apiInst, context[i], this[i], i );\n\t\n\t\t\t\t\tif ( ret !== undefined ) {\n\t\t\t\t\t\ta.push( ret );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse if ( type === 'column' || type === 'column-rows' || type === 'row' || type === 'cell' ) {\n\t\t\t\t\t// columns and rows share the same structure.\n\t\t\t\t\t// 'this' is an array of column indexes for each context\n\t\t\t\t\titems = this[i];\n\t\n\t\t\t\t\tif ( type === 'column-rows' ) {\n\t\t\t\t\t\trows = _selector_row_indexes( context[i], selector.opts );\n\t\t\t\t\t}\n\t\n\t\t\t\t\tfor ( j=0, jen=items.length ; j<jen ; j++ ) {\n\t\t\t\t\t\titem = items[j];\n\t\n\t\t\t\t\t\tif ( type === 'cell' ) {\n\t\t\t\t\t\t\tret = fn.call( apiInst, context[i], item.row, item.column, i, j );\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tret = fn.call( apiInst, context[i], item, i, j, rows );\n\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\tif ( ret !== undefined ) {\n\t\t\t\t\t\t\ta.push( ret );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\tif ( a.length || alwaysNew ) {\n\t\t\t\tvar api = new _Api( context, flatten ? a.concat.apply( [], a ) : a );\n\t\t\t\tvar apiSelector = api.selector;\n\t\t\t\tapiSelector.rows = selector.rows;\n\t\t\t\tapiSelector.cols = selector.cols;\n\t\t\t\tapiSelector.opts = selector.opts;\n\t\t\t\treturn api;\n\t\t\t}\n\t\t\treturn this;\n\t\t},\n\t\n\t\n\t\tlastIndexOf: __arrayProto.lastIndexOf || function (obj, start)\n\t\t{\n\t\t\t// Bit cheeky...\n\t\t\treturn this.indexOf.apply( this.toArray.reverse(), arguments );\n\t\t},\n\t\n\t\n\t\tlength: 0,\n\t\n\t\n\t\tmap: function ( fn )\n\t\t{\n\t\t\tvar a = [];\n\t\n\t\t\tif ( __arrayProto.map ) {\n\t\t\t\ta = __arrayProto.map.call( this, fn, this );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Compatibility for browsers without EMCA-252-5 (JS 1.6)\n\t\t\t\tfor ( var i=0, ien=this.length ; i<ien ; i++ ) {\n\t\t\t\t\ta.push( fn.call( this, this[i], i ) );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\treturn new _Api( this.context, a );\n\t\t},\n\t\n\t\n\t\tpluck: function ( prop )\n\t\t{\n\t\t\treturn this.map( function ( el ) {\n\t\t\t\treturn el[ prop ];\n\t\t\t} );\n\t\t},\n\t\n\t\tpop: __arrayProto.pop,\n\t\n\t\n\t\tpush: __arrayProto.push,\n\t\n\t\n\t\t// Does not return an API instance\n\t\treduce: __arrayProto.reduce || function ( fn, init )\n\t\t{\n\t\t\treturn _fnReduce( this, fn, init, 0, this.length, 1 );\n\t\t},\n\t\n\t\n\t\treduceRight: __arrayProto.reduceRight || function ( fn, init )\n\t\t{\n\t\t\treturn _fnReduce( this, fn, init, this.length-1, -1, -1 );\n\t\t},\n\t\n\t\n\t\treverse: __arrayProto.reverse,\n\t\n\t\n\t\t// Object with rows, columns and opts\n\t\tselector: null,\n\t\n\t\n\t\tshift: __arrayProto.shift,\n\t\n\t\n\t\tsort: __arrayProto.sort, // ? name - order?\n\t\n\t\n\t\tsplice: __arrayProto.splice,\n\t\n\t\n\t\ttoArray: function ()\n\t\t{\n\t\t\treturn __arrayProto.slice.call( this );\n\t\t},\n\t\n\t\n\t\tto$: function ()\n\t\t{\n\t\t\treturn $( this );\n\t\t},\n\t\n\t\n\t\ttoJQuery: function ()\n\t\t{\n\t\t\treturn $( this );\n\t\t},\n\t\n\t\n\t\tunique: function ()\n\t\t{\n\t\t\treturn new _Api( this.context, _unique(this) );\n\t\t},\n\t\n\t\n\t\tunshift: __arrayProto.unshift\n\t} );\n\t\n\t\n\t_Api.extend = function ( scope, obj, ext )\n\t{\n\t\t// Only extend API instances and static properties of the API\n\t\tif ( ! ext.length || ! obj || ( ! (obj instanceof _Api) && ! obj.__dt_wrapper ) ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar\n\t\t\ti, ien,\n\t\t\tj, jen,\n\t\t\tstruct, inner,\n\t\t\tmethodScoping = function ( scope, fn, struc ) {\n\t\t\t\treturn function () {\n\t\t\t\t\tvar ret = fn.apply( scope, arguments );\n\t\n\t\t\t\t\t// Method extension\n\t\t\t\t\t_Api.extend( ret, ret, struc.methodExt );\n\t\t\t\t\treturn ret;\n\t\t\t\t};\n\t\t\t};\n\t\n\t\tfor ( i=0, ien=ext.length ; i<ien ; i++ ) {\n\t\t\tstruct = ext[i];\n\t\n\t\t\t// Value\n\t\t\tobj[ struct.name ] = typeof struct.val === 'function' ?\n\t\t\t\tmethodScoping( scope, struct.val, struct ) :\n\t\t\t\t$.isPlainObject( struct.val ) ?\n\t\t\t\t\t{} :\n\t\t\t\t\tstruct.val;\n\t\n\t\t\tobj[ struct.name ].__dt_wrapper = true;\n\t\n\t\t\t// Property extension\n\t\t\t_Api.extend( scope, obj[ struct.name ], struct.propExt );\n\t\t}\n\t};\n\t\n\t\n\t// @todo - Is there need for an augment function?\n\t// _Api.augment = function ( inst, name )\n\t// {\n\t// \t// Find src object in the structure from the name\n\t// \tvar parts = name.split('.');\n\t\n\t// \t_Api.extend( inst, obj );\n\t// };\n\t\n\t\n\t// [\n\t// {\n\t// name: 'data' -- string - Property name\n\t// val: function () {}, -- function - Api method (or undefined if just an object\n\t// methodExt: [ ... ], -- array - Array of Api object definitions to extend the method result\n\t// propExt: [ ... ] -- array - Array of Api object definitions to extend the property\n\t// },\n\t// {\n\t// name: 'row'\n\t// val: {},\n\t// methodExt: [ ... ],\n\t// propExt: [\n\t// {\n\t// name: 'data'\n\t// val: function () {},\n\t// methodExt: [ ... ],\n\t// propExt: [ ... ]\n\t// },\n\t// ...\n\t// ]\n\t// }\n\t// ]\n\t\n\t_Api.register = _api_register = function ( name, val )\n\t{\n\t\tif ( $.isArray( name ) ) {\n\t\t\tfor ( var j=0, jen=name.length ; j<jen ; j++ ) {\n\t\t\t\t_Api.register( name[j], val );\n\t\t\t}\n\t\t\treturn;\n\t\t}\n\t\n\t\tvar\n\t\t\ti, ien,\n\t\t\their = name.split('.'),\n\t\t\tstruct = __apiStruct,\n\t\t\tkey, method;\n\t\n\t\tvar find = function ( src, name ) {\n\t\t\tfor ( var i=0, ien=src.length ; i<ien ; i++ ) {\n\t\t\t\tif ( src[i].name === name ) {\n\t\t\t\t\treturn src[i];\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn null;\n\t\t};\n\t\n\t\tfor ( i=0, ien=heir.length ; i<ien ; i++ ) {\n\t\t\tmethod = heir[i].indexOf('()') !== -1;\n\t\t\tkey = method ?\n\t\t\t\their[i].replace('()', '') :\n\t\t\t\their[i];\n\t\n\t\t\tvar src = find( struct, key );\n\t\t\tif ( ! src ) {\n\t\t\t\tsrc = {\n\t\t\t\t\tname: key,\n\t\t\t\t\tval: {},\n\t\t\t\t\tmethodExt: [],\n\t\t\t\t\tpropExt: []\n\t\t\t\t};\n\t\t\t\tstruct.push( src );\n\t\t\t}\n\t\n\t\t\tif ( i === ien-1 ) {\n\t\t\t\tsrc.val = val;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tstruct = method ?\n\t\t\t\t\tsrc.methodExt :\n\t\t\t\t\tsrc.propExt;\n\t\t\t}\n\t\t}\n\t};\n\t\n\t\n\t_Api.registerPlural = _api_registerPlural = function ( pluralName, singularName, val ) {\n\t\t_Api.register( pluralName, val );\n\t\n\t\t_Api.register( singularName, function () {\n\t\t\tvar ret = val.apply( this, arguments );\n\t\n\t\t\tif ( ret === this ) {\n\t\t\t\t// Returned item is the API instance that was passed in, return it\n\t\t\t\treturn this;\n\t\t\t}\n\t\t\telse if ( ret instanceof _Api ) {\n\t\t\t\t// New API instance returned, want the value from the first item\n\t\t\t\t// in the returned array for the singular result.\n\t\t\t\treturn ret.length ?\n\t\t\t\t\t$.isArray( ret[0] ) ?\n\t\t\t\t\t\tnew _Api( ret.context, ret[0] ) : // Array results are 'enhanced'\n\t\t\t\t\t\tret[0] :\n\t\t\t\t\tundefined;\n\t\t\t}\n\t\n\t\t\t// Non-API return - just fire it back\n\t\t\treturn ret;\n\t\t} );\n\t};\n\t\n\t\n\t/**\n\t * Selector for HTML tables. Apply the given selector to the give array of\n\t * DataTables settings objects.\n\t *\n\t * @param {string|integer} [selector] jQuery selector string or integer\n\t * @param {array} Array of DataTables settings objects to be filtered\n\t * @return {array}\n\t * @ignore\n\t */\n\tvar __table_selector = function ( selector, a )\n\t{\n\t\t// Integer is used to pick out a table by index\n\t\tif ( typeof selector === 'number' ) {\n\t\t\treturn [ a[ selector ] ];\n\t\t}\n\t\n\t\t// Perform a jQuery selector on the table nodes\n\t\tvar nodes = $.map( a, function (el, i) {\n\t\t\treturn el.nTable;\n\t\t} );\n\t\n\t\treturn $(nodes)\n\t\t\t.filter( selector )\n\t\t\t.map( function (i) {\n\t\t\t\t// Need to translate back from the table node to the settings\n\t\t\t\tvar idx = $.inArray( this, nodes );\n\t\t\t\treturn a[ idx ];\n\t\t\t} )\n\t\t\t.toArray();\n\t};\n\t\n\t\n\t\n\t/**\n\t * Context selector for the API's context (i.e. the tables the API instance\n\t * refers to.\n\t *\n\t * @name DataTable.Api#tables\n\t * @param {string|integer} [selector] Selector to pick which tables the iterator\n\t * should operate on. If not given, all tables in the current context are\n\t * used. This can be given as a jQuery selector (for example `':gt(0)'`) to\n\t * select multiple tables or as an integer to select a single table.\n\t * @returns {DataTable.Api} Returns a new API instance if a selector is given.\n\t */\n\t_api_register( 'tables()', function ( selector ) {\n\t\t// A new instance is created if there was a selector specified\n\t\treturn selector ?\n\t\t\tnew _Api( __table_selector( selector, this.context ) ) :\n\t\t\tthis;\n\t} );\n\t\n\t\n\t_api_register( 'table()', function ( selector ) {\n\t\tvar tables = this.tables( selector );\n\t\tvar ctx = tables.context;\n\t\n\t\t// Truncate to the first matched table\n\t\treturn ctx.length ?\n\t\t\tnew _Api( ctx[0] ) :\n\t\t\ttables;\n\t} );\n\t\n\t\n\t_api_registerPlural( 'tables().nodes()', 'table().node()' , function () {\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\treturn ctx.nTable;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'tables().body()', 'table().body()' , function () {\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\treturn ctx.nTBody;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'tables().header()', 'table().header()' , function () {\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\treturn ctx.nTHead;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'tables().footer()', 'table().footer()' , function () {\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\treturn ctx.nTFoot;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'tables().containers()', 'table().container()' , function () {\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\treturn ctx.nTableWrapper;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t\n\t/**\n\t * Redraw the tables in the current context.\n\t */\n\t_api_register( 'draw()', function ( paging ) {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tif ( paging === 'page' ) {\n\t\t\t\t_fnDraw( settings );\n\t\t\t}\n\t\t\telse {\n\t\t\t\tif ( typeof paging === 'string' ) {\n\t\t\t\t\tpaging = paging === 'full-hold' ?\n\t\t\t\t\t\tfalse :\n\t\t\t\t\t\ttrue;\n\t\t\t\t}\n\t\n\t\t\t\t_fnReDraw( settings, paging===false );\n\t\t\t}\n\t\t} );\n\t} );\n\t\n\t\n\t\n\t/**\n\t * Get the current page index.\n\t *\n\t * @return {integer} Current page index (zero based)\n\t *//**\n\t * Set the current page.\n\t *\n\t * Note that if you attempt to show a page which does not exist, DataTables will\n\t * not throw an error, but rather reset the paging.\n\t *\n\t * @param {integer|string} action The paging action to take. This can be one of:\n\t * * `integer` - The page index to jump to\n\t * * `string` - An action to take:\n\t * * `first` - Jump to first page.\n\t * * `next` - Jump to the next page\n\t * * `previous` - Jump to previous page\n\t * * `last` - Jump to the last page.\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'page()', function ( action ) {\n\t\tif ( action === undefined ) {\n\t\t\treturn this.page.info().page; // not an expensive call\n\t\t}\n\t\n\t\t// else, have an action to take on all tables\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnPageChange( settings, action );\n\t\t} );\n\t} );\n\t\n\t\n\t/**\n\t * Paging information for the first table in the current context.\n\t *\n\t * If you require paging information for another table, use the `table()` method\n\t * with a suitable selector.\n\t *\n\t * @return {object} Object with the following properties set:\n\t * * `page` - Current page index (zero based - i.e. the first page is `0`)\n\t * * `pages` - Total number of pages\n\t * * `start` - Display index for the first record shown on the current page\n\t * * `end` - Display index for the last record shown on the current page\n\t * * `length` - Display length (number of records). Note that generally `start\n\t * + length = end`, but this is not always true, for example if there are\n\t * only 2 records to show on the final page, with a length of 10.\n\t * * `recordsTotal` - Full data set length\n\t * * `recordsDisplay` - Data set length once the current filtering criterion\n\t * are applied.\n\t */\n\t_api_register( 'page.info()', function ( action ) {\n\t\tif ( this.context.length === 0 ) {\n\t\t\treturn undefined;\n\t\t}\n\t\n\t\tvar\n\t\t\tsettings = this.context[0],\n\t\t\tstart = settings._iDisplayStart,\n\t\t\tlen = settings.oFeatures.bPaginate ? settings._iDisplayLength : -1,\n\t\t\tvisRecords = settings.fnRecordsDisplay(),\n\t\t\tall = len === -1;\n\t\n\t\treturn {\n\t\t\t\"page\": all ? 0 : Math.floor( start / len ),\n\t\t\t\"pages\": all ? 1 : Math.ceil( visRecords / len ),\n\t\t\t\"start\": start,\n\t\t\t\"end\": settings.fnDisplayEnd(),\n\t\t\t\"length\": len,\n\t\t\t\"recordsTotal\": settings.fnRecordsTotal(),\n\t\t\t\"recordsDisplay\": visRecords,\n\t\t\t\"serverSide\": _fnDataSource( settings ) === 'ssp'\n\t\t};\n\t} );\n\t\n\t\n\t/**\n\t * Get the current page length.\n\t *\n\t * @return {integer} Current page length. Note `-1` indicates that all records\n\t * are to be shown.\n\t *//**\n\t * Set the current page length.\n\t *\n\t * @param {integer} Page length to set. Use `-1` to show all records.\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'page.len()', function ( len ) {\n\t\t// Note that we can't call this function 'length()' because `length`\n\t\t// is a Javascript property of functions which defines how many arguments\n\t\t// the function expects.\n\t\tif ( len === undefined ) {\n\t\t\treturn this.context.length !== 0 ?\n\t\t\t\tthis.context[0]._iDisplayLength :\n\t\t\t\tundefined;\n\t\t}\n\t\n\t\t// else, set the page length\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnLengthChange( settings, len );\n\t\t} );\n\t} );\n\t\n\t\n\t\n\tvar __reload = function ( settings, holdPosition, callback ) {\n\t\t// Use the draw event to trigger a callback\n\t\tif ( callback ) {\n\t\t\tvar api = new _Api( settings );\n\t\n\t\t\tapi.one( 'draw', function () {\n\t\t\t\tcallback( api.ajax.json() );\n\t\t\t} );\n\t\t}\n\t\n\t\tif ( _fnDataSource( settings ) == 'ssp' ) {\n\t\t\t_fnReDraw( settings, holdPosition );\n\t\t}\n\t\telse {\n\t\t\t_fnProcessingDisplay( settings, true );\n\t\n\t\t\t// Cancel an existing request\n\t\t\tvar xhr = settings.jqXHR;\n\t\t\tif ( xhr && xhr.readyState !== 4 ) {\n\t\t\t\txhr.abort();\n\t\t\t}\n\t\n\t\t\t// Trigger xhr\n\t\t\t_fnBuildAjax( settings, [], function( json ) {\n\t\t\t\t_fnClearTable( settings );\n\t\n\t\t\t\tvar data = _fnAjaxDataSrc( settings, json );\n\t\t\t\tfor ( var i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t\t\t_fnAddData( settings, data[i] );\n\t\t\t\t}\n\t\n\t\t\t\t_fnReDraw( settings, holdPosition );\n\t\t\t\t_fnProcessingDisplay( settings, false );\n\t\t\t} );\n\t\t}\n\t};\n\t\n\t\n\t/**\n\t * Get the JSON response from the last Ajax request that DataTables made to the\n\t * server. Note that this returns the JSON from the first table in the current\n\t * context.\n\t *\n\t * @return {object} JSON received from the server.\n\t */\n\t_api_register( 'ajax.json()', function () {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( ctx.length > 0 ) {\n\t\t\treturn ctx[0].json;\n\t\t}\n\t\n\t\t// else return undefined;\n\t} );\n\t\n\t\n\t/**\n\t * Get the data submitted in the last Ajax request\n\t */\n\t_api_register( 'ajax.params()', function () {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( ctx.length > 0 ) {\n\t\t\treturn ctx[0].oAjaxData;\n\t\t}\n\t\n\t\t// else return undefined;\n\t} );\n\t\n\t\n\t/**\n\t * Reload tables from the Ajax data source. Note that this function will\n\t * automatically re-draw the table when the remote data has been loaded.\n\t *\n\t * @param {boolean} [reset=true] Reset (default) or hold the current paging\n\t * position. A full re-sort and re-filter is performed when this method is\n\t * called, which is why the pagination reset is the default action.\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'ajax.reload()', function ( callback, resetPaging ) {\n\t\treturn this.iterator( 'table', function (settings) {\n\t\t\t__reload( settings, resetPaging===false, callback );\n\t\t} );\n\t} );\n\t\n\t\n\t/**\n\t * Get the current Ajax URL. Note that this returns the URL from the first\n\t * table in the current context.\n\t *\n\t * @return {string} Current Ajax source URL\n\t *//**\n\t * Set the Ajax URL. Note that this will set the URL for all tables in the\n\t * current context.\n\t *\n\t * @param {string} url URL to set.\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'ajax.url()', function ( url ) {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( url === undefined ) {\n\t\t\t// get\n\t\t\tif ( ctx.length === 0 ) {\n\t\t\t\treturn undefined;\n\t\t\t}\n\t\t\tctx = ctx[0];\n\t\n\t\t\treturn ctx.ajax ?\n\t\t\t\t$.isPlainObject( ctx.ajax ) ?\n\t\t\t\t\tctx.ajax.url :\n\t\t\t\t\tctx.ajax :\n\t\t\t\tctx.sAjaxSource;\n\t\t}\n\t\n\t\t// set\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tif ( $.isPlainObject( settings.ajax ) ) {\n\t\t\t\tsettings.ajax.url = url;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tsettings.ajax = url;\n\t\t\t}\n\t\t\t// No need to consider sAjaxSource here since DataTables gives priority\n\t\t\t// to `ajax` over `sAjaxSource`. So setting `ajax` here, renders any\n\t\t\t// value of `sAjaxSource` redundant.\n\t\t} );\n\t} );\n\t\n\t\n\t/**\n\t * Load data from the newly set Ajax URL. Note that this method is only\n\t * available when `ajax.url()` is used to set a URL. Additionally, this method\n\t * has the same effect as calling `ajax.reload()` but is provided for\n\t * convenience when setting a new URL. Like `ajax.reload()` it will\n\t * automatically redraw the table once the remote data has been loaded.\n\t *\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'ajax.url().load()', function ( callback, resetPaging ) {\n\t\t// Same as a reload, but makes sense to present it for easy access after a\n\t\t// url change\n\t\treturn this.iterator( 'table', function ( ctx ) {\n\t\t\t__reload( ctx, resetPaging===false, callback );\n\t\t} );\n\t} );\n\t\n\t\n\t\n\t\n\tvar _selector_run = function ( type, selector, selectFn, settings, opts )\n\t{\n\t\tvar\n\t\t\tout = [], res,\n\t\t\ta, i, ien, j, jen,\n\t\t\tselectorType = typeof selector;\n\t\n\t\t// Can't just check for isArray here, as an API or jQuery instance might be\n\t\t// given with their array like look\n\t\tif ( ! selector || selectorType === 'string' || selectorType === 'function' || selector.length === undefined ) {\n\t\t\tselector = [ selector ];\n\t\t}\n\t\n\t\tfor ( i=0, ien=selector.length ; i<ien ; i++ ) {\n\t\t\ta = selector[i] && selector[i].split ?\n\t\t\t\tselector[i].split(',') :\n\t\t\t\t[ selector[i] ];\n\t\n\t\t\tfor ( j=0, jen=a.length ; j<jen ; j++ ) {\n\t\t\t\tres = selectFn( typeof a[j] === 'string' ? $.trim(a[j]) : a[j] );\n\t\n\t\t\t\tif ( res && res.length ) {\n\t\t\t\t\tout = out.concat( res );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\t// selector extensions\n\t\tvar ext = _ext.selector[ type ];\n\t\tif ( ext.length ) {\n\t\t\tfor ( i=0, ien=ext.length ; i<ien ; i++ ) {\n\t\t\t\tout = ext[i]( settings, opts, out );\n\t\t\t}\n\t\t}\n\t\n\t\treturn _unique( out );\n\t};\n\t\n\t\n\tvar _selector_opts = function ( opts )\n\t{\n\t\tif ( ! opts ) {\n\t\t\topts = {};\n\t\t}\n\t\n\t\t// Backwards compatibility for 1.9- which used the terminology filter rather\n\t\t// than search\n\t\tif ( opts.filter && opts.search === undefined ) {\n\t\t\topts.search = opts.filter;\n\t\t}\n\t\n\t\treturn $.extend( {\n\t\t\tsearch: 'none',\n\t\t\torder: 'current',\n\t\t\tpage: 'all'\n\t\t}, opts );\n\t};\n\t\n\t\n\tvar _selector_first = function ( inst )\n\t{\n\t\t// Reduce the API instance to the first item found\n\t\tfor ( var i=0, ien=inst.length ; i<ien ; i++ ) {\n\t\t\tif ( inst[i].length > 0 ) {\n\t\t\t\t// Assign the first element to the first item in the instance\n\t\t\t\t// and truncate the instance and context\n\t\t\t\tinst[0] = inst[i];\n\t\t\t\tinst[0].length = 1;\n\t\t\t\tinst.length = 1;\n\t\t\t\tinst.context = [ inst.context[i] ];\n\t\n\t\t\t\treturn inst;\n\t\t\t}\n\t\t}\n\t\n\t\t// Not found - return an empty instance\n\t\tinst.length = 0;\n\t\treturn inst;\n\t};\n\t\n\t\n\tvar _selector_row_indexes = function ( settings, opts )\n\t{\n\t\tvar\n\t\t\ti, ien, tmp, a=[],\n\t\t\tdisplayFiltered = settings.aiDisplay,\n\t\t\tdisplayMaster = settings.aiDisplayMaster;\n\t\n\t\tvar\n\t\t\tsearch = opts.search, // none, applied, removed\n\t\t\torder = opts.order, // applied, current, index (original - compatibility with 1.9)\n\t\t\tpage = opts.page; // all, current\n\t\n\t\tif ( _fnDataSource( settings ) == 'ssp' ) {\n\t\t\t// In server-side processing mode, most options are irrelevant since\n\t\t\t// rows not shown don't exist and the index order is the applied order\n\t\t\t// Removed is a special case - for consistency just return an empty\n\t\t\t// array\n\t\t\treturn search === 'removed' ?\n\t\t\t\t[] :\n\t\t\t\t_range( 0, displayMaster.length );\n\t\t}\n\t\telse if ( page == 'current' ) {\n\t\t\t// Current page implies that order=current and fitler=applied, since it is\n\t\t\t// fairly senseless otherwise, regardless of what order and search actually\n\t\t\t// are\n\t\t\tfor ( i=settings._iDisplayStart, ien=settings.fnDisplayEnd() ; i<ien ; i++ ) {\n\t\t\t\ta.push( displayFiltered[i] );\n\t\t\t}\n\t\t}\n\t\telse if ( order == 'current' || order == 'applied' ) {\n\t\t\ta = search == 'none' ?\n\t\t\t\tdisplayMaster.slice() : // no search\n\t\t\t\tsearch == 'applied' ?\n\t\t\t\t\tdisplayFiltered.slice() : // applied search\n\t\t\t\t\t$.map( displayMaster, function (el, i) { // removed search\n\t\t\t\t\t\treturn $.inArray( el, displayFiltered ) === -1 ? el : null;\n\t\t\t\t\t} );\n\t\t}\n\t\telse if ( order == 'index' || order == 'original' ) {\n\t\t\tfor ( i=0, ien=settings.aoData.length ; i<ien ; i++ ) {\n\t\t\t\tif ( search == 'none' ) {\n\t\t\t\t\ta.push( i );\n\t\t\t\t}\n\t\t\t\telse { // applied | removed\n\t\t\t\t\ttmp = $.inArray( i, displayFiltered );\n\t\n\t\t\t\t\tif ((tmp === -1 && search == 'removed') ||\n\t\t\t\t\t\t(tmp >= 0 && search == 'applied') )\n\t\t\t\t\t{\n\t\t\t\t\t\ta.push( i );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\n\t\treturn a;\n\t};\n\t\n\t\n\t/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *\n\t * Rows\n\t *\n\t * {} - no selector - use all available rows\n\t * {integer} - row aoData index\n\t * {node} - TR node\n\t * {string} - jQuery selector to apply to the TR elements\n\t * {array} - jQuery array of nodes, or simply an array of TR nodes\n\t *\n\t */\n\t\n\t\n\tvar __row_selector = function ( settings, selector, opts )\n\t{\n\t\tvar run = function ( sel ) {\n\t\t\tvar selInt = _intVal( sel );\n\t\t\tvar i, ien;\n\t\n\t\t\t// Short cut - selector is a number and no options provided (default is\n\t\t\t// all records, so no need to check if the index is in there, since it\n\t\t\t// must be - dev error if the index doesn't exist).\n\t\t\tif ( selInt !== null && ! opts ) {\n\t\t\t\treturn [ selInt ];\n\t\t\t}\n\t\n\t\t\tvar rows = _selector_row_indexes( settings, opts );\n\t\n\t\t\tif ( selInt !== null && $.inArray( selInt, rows ) !== -1 ) {\n\t\t\t\t// Selector - integer\n\t\t\t\treturn [ selInt ];\n\t\t\t}\n\t\t\telse if ( ! sel ) {\n\t\t\t\t// Selector - none\n\t\t\t\treturn rows;\n\t\t\t}\n\t\n\t\t\t// Selector - function\n\t\t\tif ( typeof sel === 'function' ) {\n\t\t\t\treturn $.map( rows, function (idx) {\n\t\t\t\t\tvar row = settings.aoData[ idx ];\n\t\t\t\t\treturn sel( idx, row._aData, row.nTr ) ? idx : null;\n\t\t\t\t} );\n\t\t\t}\n\t\n\t\t\t// Get nodes in the order from the `rows` array with null values removed\n\t\t\tvar nodes = _removeEmpty(\n\t\t\t\t_pluck_order( settings.aoData, rows, 'nTr' )\n\t\t\t);\n\t\n\t\t\t// Selector - node\n\t\t\tif ( sel.nodeName ) {\n\t\t\t\tif ( sel._DT_RowIndex !== undefined ) {\n\t\t\t\t\treturn [ sel._DT_RowIndex ]; // Property added by DT for fast lookup\n\t\t\t\t}\n\t\t\t\telse if ( sel._DT_CellIndex ) {\n\t\t\t\t\treturn [ sel._DT_CellIndex.row ];\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tvar host = $(sel).closest('*[data-dt-row]');\n\t\t\t\t\treturn host.length ?\n\t\t\t\t\t\t[ host.data('dt-row') ] :\n\t\t\t\t\t\t[];\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// ID selector. Want to always be able to select rows by id, regardless\n\t\t\t// of if the tr element has been created or not, so can't rely upon\n\t\t\t// jQuery here - hence a custom implementation. This does not match\n\t\t\t// Sizzle's fast selector or HTML4 - in HTML5 the ID can be anything,\n\t\t\t// but to select it using a CSS selector engine (like Sizzle or\n\t\t\t// querySelect) it would need to need to be escaped for some characters.\n\t\t\t// DataTables simplifies this for row selectors since you can select\n\t\t\t// only a row. A # indicates an id any anything that follows is the id -\n\t\t\t// unescaped.\n\t\t\tif ( typeof sel === 'string' && sel.charAt(0) === '#' ) {\n\t\t\t\t// get row index from id\n\t\t\t\tvar rowObj = settings.aIds[ sel.replace( /^#/, '' ) ];\n\t\t\t\tif ( rowObj !== undefined ) {\n\t\t\t\t\treturn [ rowObj.idx ];\n\t\t\t\t}\n\t\n\t\t\t\t// need to fall through to jQuery in case there is DOM id that\n\t\t\t\t// matches\n\t\t\t}\n\t\n\t\t\t// Selector - jQuery selector string, array of nodes or jQuery object/\n\t\t\t// As jQuery's .filter() allows jQuery objects to be passed in filter,\n\t\t\t// it also allows arrays, so this will cope with all three options\n\t\t\treturn $(nodes)\n\t\t\t\t.filter( sel )\n\t\t\t\t.map( function () {\n\t\t\t\t\treturn this._DT_RowIndex;\n\t\t\t\t} )\n\t\t\t\t.toArray();\n\t\t};\n\t\n\t\treturn _selector_run( 'row', selector, run, settings, opts );\n\t};\n\t\n\t\n\t_api_register( 'rows()', function ( selector, opts ) {\n\t\t// argument shifting\n\t\tif ( selector === undefined ) {\n\t\t\tselector = '';\n\t\t}\n\t\telse if ( $.isPlainObject( selector ) ) {\n\t\t\topts = selector;\n\t\t\tselector = '';\n\t\t}\n\t\n\t\topts = _selector_opts( opts );\n\t\n\t\tvar inst = this.iterator( 'table', function ( settings ) {\n\t\t\treturn __row_selector( settings, selector, opts );\n\t\t}, 1 );\n\t\n\t\t// Want argument shifting here and in __row_selector?\n\t\tinst.selector.rows = selector;\n\t\tinst.selector.opts = opts;\n\t\n\t\treturn inst;\n\t} );\n\t\n\t_api_register( 'rows().nodes()', function () {\n\t\treturn this.iterator( 'row', function ( settings, row ) {\n\t\t\treturn settings.aoData[ row ].nTr || undefined;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_register( 'rows().data()', function () {\n\t\treturn this.iterator( true, 'rows', function ( settings, rows ) {\n\t\t\treturn _pluck_order( settings.aoData, rows, '_aData' );\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'rows().cache()', 'row().cache()', function ( type ) {\n\t\treturn this.iterator( 'row', function ( settings, row ) {\n\t\t\tvar r = settings.aoData[ row ];\n\t\t\treturn type === 'search' ? r._aFilterData : r._aSortData;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'rows().invalidate()', 'row().invalidate()', function ( src ) {\n\t\treturn this.iterator( 'row', function ( settings, row ) {\n\t\t\t_fnInvalidate( settings, row, src );\n\t\t} );\n\t} );\n\t\n\t_api_registerPlural( 'rows().indexes()', 'row().index()', function () {\n\t\treturn this.iterator( 'row', function ( settings, row ) {\n\t\t\treturn row;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'rows().ids()', 'row().id()', function ( hash ) {\n\t\tvar a = [];\n\t\tvar context = this.context;\n\t\n\t\t// `iterator` will drop undefined values, but in this case we want them\n\t\tfor ( var i=0, ien=context.length ; i<ien ; i++ ) {\n\t\t\tfor ( var j=0, jen=this[i].length ; j<jen ; j++ ) {\n\t\t\t\tvar id = context[i].rowIdFn( context[i].aoData[ this[i][j] ]._aData );\n\t\t\t\ta.push( (hash === true ? '#' : '' )+ id );\n\t\t\t}\n\t\t}\n\t\n\t\treturn new _Api( context, a );\n\t} );\n\t\n\t_api_registerPlural( 'rows().remove()', 'row().remove()', function () {\n\t\tvar that = this;\n\t\n\t\tthis.iterator( 'row', function ( settings, row, thatIdx ) {\n\t\t\tvar data = settings.aoData;\n\t\t\tvar rowData = data[ row ];\n\t\t\tvar i, ien, j, jen;\n\t\t\tvar loopRow, loopCells;\n\t\n\t\t\tdata.splice( row, 1 );\n\t\n\t\t\t// Update the cached indexes\n\t\t\tfor ( i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t\tloopRow = data[i];\n\t\t\t\tloopCells = loopRow.anCells;\n\t\n\t\t\t\t// Rows\n\t\t\t\tif ( loopRow.nTr !== null ) {\n\t\t\t\t\tloopRow.nTr._DT_RowIndex = i;\n\t\t\t\t}\n\t\n\t\t\t\t// Cells\n\t\t\t\tif ( loopCells !== null ) {\n\t\t\t\t\tfor ( j=0, jen=loopCells.length ; j<jen ; j++ ) {\n\t\t\t\t\t\tloopCells[j]._DT_CellIndex.row = i;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// Delete from the display arrays\n\t\t\t_fnDeleteIndex( settings.aiDisplayMaster, row );\n\t\t\t_fnDeleteIndex( settings.aiDisplay, row );\n\t\t\t_fnDeleteIndex( that[ thatIdx ], row, false ); // maintain local indexes\n\t\n\t\t\t// Check for an 'overflow' they case for displaying the table\n\t\t\t_fnLengthOverflow( settings );\n\t\n\t\t\t// Remove the row's ID reference if there is one\n\t\t\tvar id = settings.rowIdFn( rowData._aData );\n\t\t\tif ( id !== undefined ) {\n\t\t\t\tdelete settings.aIds[ id ];\n\t\t\t}\n\t\t} );\n\t\n\t\tthis.iterator( 'table', function ( settings ) {\n\t\t\tfor ( var i=0, ien=settings.aoData.length ; i<ien ; i++ ) {\n\t\t\t\tsettings.aoData[i].idx = i;\n\t\t\t}\n\t\t} );\n\t\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( 'rows.add()', function ( rows ) {\n\t\tvar newRows = this.iterator( 'table', function ( settings ) {\n\t\t\t\tvar row, i, ien;\n\t\t\t\tvar out = [];\n\t\n\t\t\t\tfor ( i=0, ien=rows.length ; i<ien ; i++ ) {\n\t\t\t\t\trow = rows[i];\n\t\n\t\t\t\t\tif ( row.nodeName && row.nodeName.toUpperCase() === 'TR' ) {\n\t\t\t\t\t\tout.push( _fnAddTr( settings, row )[0] );\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tout.push( _fnAddData( settings, row ) );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\treturn out;\n\t\t\t}, 1 );\n\t\n\t\t// Return an Api.rows() extended instance, so rows().nodes() etc can be used\n\t\tvar modRows = this.rows( -1 );\n\t\tmodRows.pop();\n\t\t$.merge( modRows, newRows );\n\t\n\t\treturn modRows;\n\t} );\n\t\n\t\n\t\n\t\n\t\n\t/**\n\t *\n\t */\n\t_api_register( 'row()', function ( selector, opts ) {\n\t\treturn _selector_first( this.rows( selector, opts ) );\n\t} );\n\t\n\t\n\t_api_register( 'row().data()', function ( data ) {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( data === undefined ) {\n\t\t\t// Get\n\t\t\treturn ctx.length && this.length ?\n\t\t\t\tctx[0].aoData[ this[0] ]._aData :\n\t\t\t\tundefined;\n\t\t}\n\t\n\t\t// Set\n\t\tctx[0].aoData[ this[0] ]._aData = data;\n\t\n\t\t// Automatically invalidate\n\t\t_fnInvalidate( ctx[0], this[0], 'data' );\n\t\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( 'row().node()', function () {\n\t\tvar ctx = this.context;\n\t\n\t\treturn ctx.length && this.length ?\n\t\t\tctx[0].aoData[ this[0] ].nTr || null :\n\t\t\tnull;\n\t} );\n\t\n\t\n\t_api_register( 'row.add()', function ( row ) {\n\t\t// Allow a jQuery object to be passed in - only a single row is added from\n\t\t// it though - the first element in the set\n\t\tif ( row instanceof $ && row.length ) {\n\t\t\trow = row[0];\n\t\t}\n\t\n\t\tvar rows = this.iterator( 'table', function ( settings ) {\n\t\t\tif ( row.nodeName && row.nodeName.toUpperCase() === 'TR' ) {\n\t\t\t\treturn _fnAddTr( settings, row )[0];\n\t\t\t}\n\t\t\treturn _fnAddData( settings, row );\n\t\t} );\n\t\n\t\t// Return an Api.rows() extended instance, with the newly added row selected\n\t\treturn this.row( rows[0] );\n\t} );\n\t\n\t\n\t\n\tvar __details_add = function ( ctx, row, data, klass )\n\t{\n\t\t// Convert to array of TR elements\n\t\tvar rows = [];\n\t\tvar addRow = function ( r, k ) {\n\t\t\t// Recursion to allow for arrays of jQuery objects\n\t\t\tif ( $.isArray( r ) || r instanceof $ ) {\n\t\t\t\tfor ( var i=0, ien=r.length ; i<ien ; i++ ) {\n\t\t\t\t\taddRow( r[i], k );\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\t\n\t\t\t// If we get a TR element, then just add it directly - up to the dev\n\t\t\t// to add the correct number of columns etc\n\t\t\tif ( r.nodeName && r.nodeName.toLowerCase() === 'tr' ) {\n\t\t\t\trows.push( r );\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Otherwise create a row with a wrapper\n\t\t\t\tvar created = $('<tr><td/></tr>').addClass( k );\n\t\t\t\t$('td', created)\n\t\t\t\t\t.addClass( k )\n\t\t\t\t\t.html( r )\n\t\t\t\t\t[0].colSpan = _fnVisbleColumns( ctx );\n\t\n\t\t\t\trows.push( created[0] );\n\t\t\t}\n\t\t};\n\t\n\t\taddRow( data, klass );\n\t\n\t\tif ( row._details ) {\n\t\t\trow._details.remove();\n\t\t}\n\t\n\t\trow._details = $(rows);\n\t\n\t\t// If the children were already shown, that state should be retained\n\t\tif ( row._detailsShow ) {\n\t\t\trow._details.insertAfter( row.nTr );\n\t\t}\n\t};\n\t\n\t\n\tvar __details_remove = function ( api, idx )\n\t{\n\t\tvar ctx = api.context;\n\t\n\t\tif ( ctx.length ) {\n\t\t\tvar row = ctx[0].aoData[ idx !== undefined ? idx : api[0] ];\n\t\n\t\t\tif ( row && row._details ) {\n\t\t\t\trow._details.remove();\n\t\n\t\t\t\trow._detailsShow = undefined;\n\t\t\t\trow._details = undefined;\n\t\t\t}\n\t\t}\n\t};\n\t\n\t\n\tvar __details_display = function ( api, show ) {\n\t\tvar ctx = api.context;\n\t\n\t\tif ( ctx.length && api.length ) {\n\t\t\tvar row = ctx[0].aoData[ api[0] ];\n\t\n\t\t\tif ( row._details ) {\n\t\t\t\trow._detailsShow = show;\n\t\n\t\t\t\tif ( show ) {\n\t\t\t\t\trow._details.insertAfter( row.nTr );\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\trow._details.detach();\n\t\t\t\t}\n\t\n\t\t\t\t__details_events( ctx[0] );\n\t\t\t}\n\t\t}\n\t};\n\t\n\t\n\tvar __details_events = function ( settings )\n\t{\n\t\tvar api = new _Api( settings );\n\t\tvar namespace = '.dt.DT_details';\n\t\tvar drawEvent = 'draw'+namespace;\n\t\tvar colvisEvent = 'column-visibility'+namespace;\n\t\tvar destroyEvent = 'destroy'+namespace;\n\t\tvar data = settings.aoData;\n\t\n\t\tapi.off( drawEvent +' '+ colvisEvent +' '+ destroyEvent );\n\t\n\t\tif ( _pluck( data, '_details' ).length > 0 ) {\n\t\t\t// On each draw, insert the required elements into the document\n\t\t\tapi.on( drawEvent, function ( e, ctx ) {\n\t\t\t\tif ( settings !== ctx ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\n\t\t\t\tapi.rows( {page:'current'} ).eq(0).each( function (idx) {\n\t\t\t\t\t// Internal data grab\n\t\t\t\t\tvar row = data[ idx ];\n\t\n\t\t\t\t\tif ( row._detailsShow ) {\n\t\t\t\t\t\trow._details.insertAfter( row.nTr );\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t} );\n\t\n\t\t\t// Column visibility change - update the colspan\n\t\t\tapi.on( colvisEvent, function ( e, ctx, idx, vis ) {\n\t\t\t\tif ( settings !== ctx ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\n\t\t\t\t// Update the colspan for the details rows (note, only if it already has\n\t\t\t\t// a colspan)\n\t\t\t\tvar row, visible = _fnVisbleColumns( ctx );\n\t\n\t\t\t\tfor ( var i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t\t\trow = data[i];\n\t\n\t\t\t\t\tif ( row._details ) {\n\t\t\t\t\t\trow._details.children('td[colspan]').attr('colspan', visible );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} );\n\t\n\t\t\t// Table destroyed - nuke any child rows\n\t\t\tapi.on( destroyEvent, function ( e, ctx ) {\n\t\t\t\tif ( settings !== ctx ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\n\t\t\t\tfor ( var i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t\t\tif ( data[i]._details ) {\n\t\t\t\t\t\t__details_remove( api, i );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} );\n\t\t}\n\t};\n\t\n\t// Strings for the method names to help minification\n\tvar _emp = '';\n\tvar _child_obj = _emp+'row().child';\n\tvar _child_mth = _child_obj+'()';\n\t\n\t// data can be:\n\t// tr\n\t// string\n\t// jQuery or array of any of the above\n\t_api_register( _child_mth, function ( data, klass ) {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( data === undefined ) {\n\t\t\t// get\n\t\t\treturn ctx.length && this.length ?\n\t\t\t\tctx[0].aoData[ this[0] ]._details :\n\t\t\t\tundefined;\n\t\t}\n\t\telse if ( data === true ) {\n\t\t\t// show\n\t\t\tthis.child.show();\n\t\t}\n\t\telse if ( data === false ) {\n\t\t\t// remove\n\t\t\t__details_remove( this );\n\t\t}\n\t\telse if ( ctx.length && this.length ) {\n\t\t\t// set\n\t\t\t__details_add( ctx[0], ctx[0].aoData[ this[0] ], data, klass );\n\t\t}\n\t\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( [\n\t\t_child_obj+'.show()',\n\t\t_child_mth+'.show()' // only when `child()` was called with parameters (without\n\t], function ( show ) { // it returns an object and this method is not executed)\n\t\t__details_display( this, true );\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( [\n\t\t_child_obj+'.hide()',\n\t\t_child_mth+'.hide()' // only when `child()` was called with parameters (without\n\t], function () { // it returns an object and this method is not executed)\n\t\t__details_display( this, false );\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( [\n\t\t_child_obj+'.remove()',\n\t\t_child_mth+'.remove()' // only when `child()` was called with parameters (without\n\t], function () { // it returns an object and this method is not executed)\n\t\t__details_remove( this );\n\t\treturn this;\n\t} );\n\t\n\t\n\t_api_register( _child_obj+'.isShown()', function () {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( ctx.length && this.length ) {\n\t\t\t// _detailsShown as false or undefined will fall through to return false\n\t\t\treturn ctx[0].aoData[ this[0] ]._detailsShow || false;\n\t\t}\n\t\treturn false;\n\t} );\n\t\n\t\n\t\n\t/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *\n\t * Columns\n\t *\n\t * {integer} - column index (>=0 count from left, <0 count from right)\n\t * \"{integer}:visIdx\" - visible column index (i.e. translate to column index) (>=0 count from left, <0 count from right)\n\t * \"{integer}:visible\" - alias for {integer}:visIdx (>=0 count from left, <0 count from right)\n\t * \"{string}:name\" - column name\n\t * \"{string}\" - jQuery selector on column header nodes\n\t *\n\t */\n\t\n\t// can be an array of these items, comma separated list, or an array of comma\n\t// separated lists\n\t\n\tvar __re_column_selector = /^(.+):(name|visIdx|visible)$/;\n\t\n\t\n\t// r1 and r2 are redundant - but it means that the parameters match for the\n\t// iterator callback in columns().data()\n\tvar __columnData = function ( settings, column, r1, r2, rows ) {\n\t\tvar a = [];\n\t\tfor ( var row=0, ien=rows.length ; row<ien ; row++ ) {\n\t\t\ta.push( _fnGetCellData( settings, rows[row], column ) );\n\t\t}\n\t\treturn a;\n\t};\n\t\n\t\n\tvar __column_selector = function ( settings, selector, opts )\n\t{\n\t\tvar\n\t\t\tcolumns = settings.aoColumns,\n\t\t\tnames = _pluck( columns, 'sName' ),\n\t\t\tnodes = _pluck( columns, 'nTh' );\n\t\n\t\tvar run = function ( s ) {\n\t\t\tvar selInt = _intVal( s );\n\t\n\t\t\t// Selector - all\n\t\t\tif ( s === '' ) {\n\t\t\t\treturn _range( columns.length );\n\t\t\t}\n\t\n\t\t\t// Selector - index\n\t\t\tif ( selInt !== null ) {\n\t\t\t\treturn [ selInt >= 0 ?\n\t\t\t\t\tselInt : // Count from left\n\t\t\t\t\tcolumns.length + selInt // Count from right (+ because its a negative value)\n\t\t\t\t];\n\t\t\t}\n\t\n\t\t\t// Selector = function\n\t\t\tif ( typeof s === 'function' ) {\n\t\t\t\tvar rows = _selector_row_indexes( settings, opts );\n\t\n\t\t\t\treturn $.map( columns, function (col, idx) {\n\t\t\t\t\treturn s(\n\t\t\t\t\t\t\tidx,\n\t\t\t\t\t\t\t__columnData( settings, idx, 0, 0, rows ),\n\t\t\t\t\t\t\tnodes[ idx ]\n\t\t\t\t\t\t) ? idx : null;\n\t\t\t\t} );\n\t\t\t}\n\t\n\t\t\t// jQuery or string selector\n\t\t\tvar match = typeof s === 'string' ?\n\t\t\t\ts.match( __re_column_selector ) :\n\t\t\t\t'';\n\t\n\t\t\tif ( match ) {\n\t\t\t\tswitch( match[2] ) {\n\t\t\t\t\tcase 'visIdx':\n\t\t\t\t\tcase 'visible':\n\t\t\t\t\t\tvar idx = parseInt( match[1], 10 );\n\t\t\t\t\t\t// Visible index given, convert to column index\n\t\t\t\t\t\tif ( idx < 0 ) {\n\t\t\t\t\t\t\t// Counting from the right\n\t\t\t\t\t\t\tvar visColumns = $.map( columns, function (col,i) {\n\t\t\t\t\t\t\t\treturn col.bVisible ? i : null;\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t\treturn [ visColumns[ visColumns.length + idx ] ];\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// Counting from the left\n\t\t\t\t\t\treturn [ _fnVisibleToColumnIndex( settings, idx ) ];\n\t\n\t\t\t\t\tcase 'name':\n\t\t\t\t\t\t// match by name. `names` is column index complete and in order\n\t\t\t\t\t\treturn $.map( names, function (name, i) {\n\t\t\t\t\t\t\treturn name === match[1] ? i : null;\n\t\t\t\t\t\t} );\n\t\n\t\t\t\t\tdefault:\n\t\t\t\t\t\treturn [];\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t// Cell in the table body\n\t\t\tif ( s.nodeName && s._DT_CellIndex ) {\n\t\t\t\treturn [ s._DT_CellIndex.column ];\n\t\t\t}\n\t\n\t\t\t// jQuery selector on the TH elements for the columns\n\t\t\tvar jqResult = $( nodes )\n\t\t\t\t.filter( s )\n\t\t\t\t.map( function () {\n\t\t\t\t\treturn $.inArray( this, nodes ); // `nodes` is column index complete and in order\n\t\t\t\t} )\n\t\t\t\t.toArray();\n\t\n\t\t\tif ( jqResult.length || ! s.nodeName ) {\n\t\t\t\treturn jqResult;\n\t\t\t}\n\t\n\t\t\t// Otherwise a node which might have a `dt-column` data attribute, or be\n\t\t\t// a child or such an element\n\t\t\tvar host = $(s).closest('*[data-dt-column]');\n\t\t\treturn host.length ?\n\t\t\t\t[ host.data('dt-column') ] :\n\t\t\t\t[];\n\t\t};\n\t\n\t\treturn _selector_run( 'column', selector, run, settings, opts );\n\t};\n\t\n\t\n\tvar __setColumnVis = function ( settings, column, vis ) {\n\t\tvar\n\t\t\tcols = settings.aoColumns,\n\t\t\tcol = cols[ column ],\n\t\t\tdata = settings.aoData,\n\t\t\trow, cells, i, ien, tr;\n\t\n\t\t// Get\n\t\tif ( vis === undefined ) {\n\t\t\treturn col.bVisible;\n\t\t}\n\t\n\t\t// Set\n\t\t// No change\n\t\tif ( col.bVisible === vis ) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tif ( vis ) {\n\t\t\t// Insert column\n\t\t\t// Need to decide if we should use appendChild or insertBefore\n\t\t\tvar insertBefore = $.inArray( true, _pluck(cols, 'bVisible'), column+1 );\n\t\n\t\t\tfor ( i=0, ien=data.length ; i<ien ; i++ ) {\n\t\t\t\ttr = data[i].nTr;\n\t\t\t\tcells = data[i].anCells;\n\t\n\t\t\t\tif ( tr ) {\n\t\t\t\t\t// insertBefore can act like appendChild if 2nd arg is null\n\t\t\t\t\ttr.insertBefore( cells[ column ], cells[ insertBefore ] || null );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\t// Remove column\n\t\t\t$( _pluck( settings.aoData, 'anCells', column ) ).detach();\n\t\t}\n\t\n\t\t// Common actions\n\t\tcol.bVisible = vis;\n\t\t_fnDrawHead( settings, settings.aoHeader );\n\t\t_fnDrawHead( settings, settings.aoFooter );\n\t\n\t\t_fnSaveState( settings );\n\t};\n\t\n\t\n\t_api_register( 'columns()', function ( selector, opts ) {\n\t\t// argument shifting\n\t\tif ( selector === undefined ) {\n\t\t\tselector = '';\n\t\t}\n\t\telse if ( $.isPlainObject( selector ) ) {\n\t\t\topts = selector;\n\t\t\tselector = '';\n\t\t}\n\t\n\t\topts = _selector_opts( opts );\n\t\n\t\tvar inst = this.iterator( 'table', function ( settings ) {\n\t\t\treturn __column_selector( settings, selector, opts );\n\t\t}, 1 );\n\t\n\t\t// Want argument shifting here and in _row_selector?\n\t\tinst.selector.cols = selector;\n\t\tinst.selector.opts = opts;\n\t\n\t\treturn inst;\n\t} );\n\t\n\t_api_registerPlural( 'columns().header()', 'column().header()', function ( selector, opts ) {\n\t\treturn this.iterator( 'column', function ( settings, column ) {\n\t\t\treturn settings.aoColumns[column].nTh;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().footer()', 'column().footer()', function ( selector, opts ) {\n\t\treturn this.iterator( 'column', function ( settings, column ) {\n\t\t\treturn settings.aoColumns[column].nTf;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().data()', 'column().data()', function () {\n\t\treturn this.iterator( 'column-rows', __columnData, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().dataSrc()', 'column().dataSrc()', function () {\n\t\treturn this.iterator( 'column', function ( settings, column ) {\n\t\t\treturn settings.aoColumns[column].mData;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().cache()', 'column().cache()', function ( type ) {\n\t\treturn this.iterator( 'column-rows', function ( settings, column, i, j, rows ) {\n\t\t\treturn _pluck_order( settings.aoData, rows,\n\t\t\t\ttype === 'search' ? '_aFilterData' : '_aSortData', column\n\t\t\t);\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().nodes()', 'column().nodes()', function () {\n\t\treturn this.iterator( 'column-rows', function ( settings, column, i, j, rows ) {\n\t\t\treturn _pluck_order( settings.aoData, rows, 'anCells', column ) ;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_registerPlural( 'columns().visible()', 'column().visible()', function ( vis, calc ) {\n\t\tvar ret = this.iterator( 'column', function ( settings, column ) {\n\t\t\tif ( vis === undefined ) {\n\t\t\t\treturn settings.aoColumns[ column ].bVisible;\n\t\t\t} // else\n\t\t\t__setColumnVis( settings, column, vis );\n\t\t} );\n\t\n\t\t// Group the column visibility changes\n\t\tif ( vis !== undefined ) {\n\t\t\t// Second loop once the first is done for events\n\t\t\tthis.iterator( 'column', function ( settings, column ) {\n\t\t\t\t_fnCallbackFire( settings, null, 'column-visibility', [settings, column, vis, calc] );\n\t\t\t} );\n\t\n\t\t\tif ( calc === undefined || calc ) {\n\t\t\t\tthis.columns.adjust();\n\t\t\t}\n\t\t}\n\t\n\t\treturn ret;\n\t} );\n\t\n\t_api_registerPlural( 'columns().indexes()', 'column().index()', function ( type ) {\n\t\treturn this.iterator( 'column', function ( settings, column ) {\n\t\t\treturn type === 'visible' ?\n\t\t\t\t_fnColumnIndexToVisible( settings, column ) :\n\t\t\t\tcolumn;\n\t\t}, 1 );\n\t} );\n\t\n\t_api_register( 'columns.adjust()', function () {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnAdjustColumnSizing( settings );\n\t\t}, 1 );\n\t} );\n\t\n\t_api_register( 'column.index()', function ( type, idx ) {\n\t\tif ( this.context.length !== 0 ) {\n\t\t\tvar ctx = this.context[0];\n\t\n\t\t\tif ( type === 'fromVisible' || type === 'toData' ) {\n\t\t\t\treturn _fnVisibleToColumnIndex( ctx, idx );\n\t\t\t}\n\t\t\telse if ( type === 'fromData' || type === 'toVisible' ) {\n\t\t\t\treturn _fnColumnIndexToVisible( ctx, idx );\n\t\t\t}\n\t\t}\n\t} );\n\t\n\t_api_register( 'column()', function ( selector, opts ) {\n\t\treturn _selector_first( this.columns( selector, opts ) );\n\t} );\n\t\n\t\n\t\n\tvar __cell_selector = function ( settings, selector, opts )\n\t{\n\t\tvar data = settings.aoData;\n\t\tvar rows = _selector_row_indexes( settings, opts );\n\t\tvar cells = _removeEmpty( _pluck_order( data, rows, 'anCells' ) );\n\t\tvar allCells = $( [].concat.apply([], cells) );\n\t\tvar row;\n\t\tvar columns = settings.aoColumns.length;\n\t\tvar a, i, ien, j, o, host;\n\t\n\t\tvar run = function ( s ) {\n\t\t\tvar fnSelector = typeof s === 'function';\n\t\n\t\t\tif ( s === null || s === undefined || fnSelector ) {\n\t\t\t\t// All cells and function selectors\n\t\t\t\ta = [];\n\t\n\t\t\t\tfor ( i=0, ien=rows.length ; i<ien ; i++ ) {\n\t\t\t\t\trow = rows[i];\n\t\n\t\t\t\t\tfor ( j=0 ; j<columns ; j++ ) {\n\t\t\t\t\t\to = {\n\t\t\t\t\t\t\trow: row,\n\t\t\t\t\t\t\tcolumn: j\n\t\t\t\t\t\t};\n\t\n\t\t\t\t\t\tif ( fnSelector ) {\n\t\t\t\t\t\t\t// Selector - function\n\t\t\t\t\t\t\thost = data[ row ];\n\t\n\t\t\t\t\t\t\tif ( s( o, _fnGetCellData(settings, row, j), host.anCells ? host.anCells[j] : null ) ) {\n\t\t\t\t\t\t\t\ta.push( o );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t// Selector - all\n\t\t\t\t\t\t\ta.push( o );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\n\t\t\t\treturn a;\n\t\t\t}\n\t\t\t\n\t\t\t// Selector - index\n\t\t\tif ( $.isPlainObject( s ) ) {\n\t\t\t\treturn [s];\n\t\t\t}\n\t\n\t\t\t// Selector - jQuery filtered cells\n\t\t\tvar jqResult = allCells\n\t\t\t\t.filter( s )\n\t\t\t\t.map( function (i, el) {\n\t\t\t\t\treturn { // use a new object, in case someone changes the values\n\t\t\t\t\t\trow: el._DT_CellIndex.row,\n\t\t\t\t\t\tcolumn: el._DT_CellIndex.column\n\t \t\t\t\t};\n\t\t\t\t} )\n\t\t\t\t.toArray();\n\t\n\t\t\tif ( jqResult.length || ! s.nodeName ) {\n\t\t\t\treturn jqResult;\n\t\t\t}\n\t\n\t\t\t// Otherwise the selector is a node, and there is one last option - the\n\t\t\t// element might be a child of an element which has dt-row and dt-column\n\t\t\t// data attributes\n\t\t\thost = $(s).closest('*[data-dt-row]');\n\t\t\treturn host.length ?\n\t\t\t\t[ {\n\t\t\t\t\trow: host.data('dt-row'),\n\t\t\t\t\tcolumn: host.data('dt-column')\n\t\t\t\t} ] :\n\t\t\t\t[];\n\t\t};\n\t\n\t\treturn _selector_run( 'cell', selector, run, settings, opts );\n\t};\n\t\n\t\n\t\n\t\n\t_api_register( 'cells()', function ( rowSelector, columnSelector, opts ) {\n\t\t// Argument shifting\n\t\tif ( $.isPlainObject( rowSelector ) ) {\n\t\t\t// Indexes\n\t\t\tif ( rowSelector.row === undefined ) {\n\t\t\t\t// Selector options in first parameter\n\t\t\t\topts = rowSelector;\n\t\t\t\trowSelector = null;\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Cell index objects in first parameter\n\t\t\t\topts = columnSelector;\n\t\t\t\tcolumnSelector = null;\n\t\t\t}\n\t\t}\n\t\tif ( $.isPlainObject( columnSelector ) ) {\n\t\t\topts = columnSelector;\n\t\t\tcolumnSelector = null;\n\t\t}\n\t\n\t\t// Cell selector\n\t\tif ( columnSelector === null || columnSelector === undefined ) {\n\t\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t\treturn __cell_selector( settings, rowSelector, _selector_opts( opts ) );\n\t\t\t} );\n\t\t}\n\t\n\t\t// Row + column selector\n\t\tvar columns = this.columns( columnSelector, opts );\n\t\tvar rows = this.rows( rowSelector, opts );\n\t\tvar a, i, ien, j, jen;\n\t\n\t\tvar cells = this.iterator( 'table', function ( settings, idx ) {\n\t\t\ta = [];\n\t\n\t\t\tfor ( i=0, ien=rows[idx].length ; i<ien ; i++ ) {\n\t\t\t\tfor ( j=0, jen=columns[idx].length ; j<jen ; j++ ) {\n\t\t\t\t\ta.push( {\n\t\t\t\t\t\trow: rows[idx][i],\n\t\t\t\t\t\tcolumn: columns[idx][j]\n\t\t\t\t\t} );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\treturn a;\n\t\t}, 1 );\n\t\n\t\t$.extend( cells.selector, {\n\t\t\tcols: columnSelector,\n\t\t\trows: rowSelector,\n\t\t\topts: opts\n\t\t} );\n\t\n\t\treturn cells;\n\t} );\n\t\n\t\n\t_api_registerPlural( 'cells().nodes()', 'cell().node()', function () {\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\tvar data = settings.aoData[ row ];\n\t\n\t\t\treturn data && data.anCells ?\n\t\t\t\tdata.anCells[ column ] :\n\t\t\t\tundefined;\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_register( 'cells().data()', function () {\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\treturn _fnGetCellData( settings, row, column );\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'cells().cache()', 'cell().cache()', function ( type ) {\n\t\ttype = type === 'search' ? '_aFilterData' : '_aSortData';\n\t\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\treturn settings.aoData[ row ][ type ][ column ];\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'cells().render()', 'cell().render()', function ( type ) {\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\treturn _fnGetCellData( settings, row, column, type );\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'cells().indexes()', 'cell().index()', function () {\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\treturn {\n\t\t\t\trow: row,\n\t\t\t\tcolumn: column,\n\t\t\t\tcolumnVisible: _fnColumnIndexToVisible( settings, column )\n\t\t\t};\n\t\t}, 1 );\n\t} );\n\t\n\t\n\t_api_registerPlural( 'cells().invalidate()', 'cell().invalidate()', function ( src ) {\n\t\treturn this.iterator( 'cell', function ( settings, row, column ) {\n\t\t\t_fnInvalidate( settings, row, src, column );\n\t\t} );\n\t} );\n\t\n\t\n\t\n\t_api_register( 'cell()', function ( rowSelector, columnSelector, opts ) {\n\t\treturn _selector_first( this.cells( rowSelector, columnSelector, opts ) );\n\t} );\n\t\n\t\n\t_api_register( 'cell().data()', function ( data ) {\n\t\tvar ctx = this.context;\n\t\tvar cell = this[0];\n\t\n\t\tif ( data === undefined ) {\n\t\t\t// Get\n\t\t\treturn ctx.length && cell.length ?\n\t\t\t\t_fnGetCellData( ctx[0], cell[0].row, cell[0].column ) :\n\t\t\t\tundefined;\n\t\t}\n\t\n\t\t// Set\n\t\t_fnSetCellData( ctx[0], cell[0].row, cell[0].column, data );\n\t\t_fnInvalidate( ctx[0], cell[0].row, 'data', cell[0].column );\n\t\n\t\treturn this;\n\t} );\n\t\n\t\n\t\n\t/**\n\t * Get current ordering (sorting) that has been applied to the table.\n\t *\n\t * @returns {array} 2D array containing the sorting information for the first\n\t * table in the current context. Each element in the parent array represents\n\t * a column being sorted upon (i.e. multi-sorting with two columns would have\n\t * 2 inner arrays). The inner arrays may have 2 or 3 elements. The first is\n\t * the column index that the sorting condition applies to, the second is the\n\t * direction of the sort (`desc` or `asc`) and, optionally, the third is the\n\t * index of the sorting order from the `column.sorting` initialisation array.\n\t *//**\n\t * Set the ordering for the table.\n\t *\n\t * @param {integer} order Column index to sort upon.\n\t * @param {string} direction Direction of the sort to be applied (`asc` or `desc`)\n\t * @returns {DataTables.Api} this\n\t *//**\n\t * Set the ordering for the table.\n\t *\n\t * @param {array} order 1D array of sorting information to be applied.\n\t * @param {array} [...] Optional additional sorting conditions\n\t * @returns {DataTables.Api} this\n\t *//**\n\t * Set the ordering for the table.\n\t *\n\t * @param {array} order 2D array of sorting information to be applied.\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'order()', function ( order, dir ) {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( order === undefined ) {\n\t\t\t// get\n\t\t\treturn ctx.length !== 0 ?\n\t\t\t\tctx[0].aaSorting :\n\t\t\t\tundefined;\n\t\t}\n\t\n\t\t// set\n\t\tif ( typeof order === 'number' ) {\n\t\t\t// Simple column / direction passed in\n\t\t\torder = [ [ order, dir ] ];\n\t\t}\n\t\telse if ( order.length && ! $.isArray( order[0] ) ) {\n\t\t\t// Arguments passed in (list of 1D arrays)\n\t\t\torder = Array.prototype.slice.call( arguments );\n\t\t}\n\t\t// otherwise a 2D array was passed in\n\t\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tsettings.aaSorting = order.slice();\n\t\t} );\n\t} );\n\t\n\t\n\t/**\n\t * Attach a sort listener to an element for a given column\n\t *\n\t * @param {node|jQuery|string} node Identifier for the element(s) to attach the\n\t * listener to. This can take the form of a single DOM node, a jQuery\n\t * collection of nodes or a jQuery selector which will identify the node(s).\n\t * @param {integer} column the column that a click on this node will sort on\n\t * @param {function} [callback] callback function when sort is run\n\t * @returns {DataTables.Api} this\n\t */\n\t_api_register( 'order.listener()', function ( node, column, callback ) {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnSortAttachListener( settings, node, column, callback );\n\t\t} );\n\t} );\n\t\n\t\n\t_api_register( 'order.fixed()', function ( set ) {\n\t\tif ( ! set ) {\n\t\t\tvar ctx = this.context;\n\t\t\tvar fixed = ctx.length ?\n\t\t\t\tctx[0].aaSortingFixed :\n\t\t\t\tundefined;\n\t\n\t\t\treturn $.isArray( fixed ) ?\n\t\t\t\t{ pre: fixed } :\n\t\t\t\tfixed;\n\t\t}\n\t\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tsettings.aaSortingFixed = $.extend( true, {}, set );\n\t\t} );\n\t} );\n\t\n\t\n\t// Order by the selected column(s)\n\t_api_register( [\n\t\t'columns().order()',\n\t\t'column().order()'\n\t], function ( dir ) {\n\t\tvar that = this;\n\t\n\t\treturn this.iterator( 'table', function ( settings, i ) {\n\t\t\tvar sort = [];\n\t\n\t\t\t$.each( that[i], function (j, col) {\n\t\t\t\tsort.push( [ col, dir ] );\n\t\t\t} );\n\t\n\t\t\tsettings.aaSorting = sort;\n\t\t} );\n\t} );\n\t\n\t\n\t\n\t_api_register( 'search()', function ( input, regex, smart, caseInsen ) {\n\t\tvar ctx = this.context;\n\t\n\t\tif ( input === undefined ) {\n\t\t\t// get\n\t\t\treturn ctx.length !== 0 ?\n\t\t\t\tctx[0].oPreviousSearch.sSearch :\n\t\t\t\tundefined;\n\t\t}\n\t\n\t\t// set\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tif ( ! settings.oFeatures.bFilter ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\n\t\t\t_fnFilterComplete( settings, $.extend( {}, settings.oPreviousSearch, {\n\t\t\t\t\"sSearch\": input+\"\",\n\t\t\t\t\"bRegex\": regex === null ? false : regex,\n\t\t\t\t\"bSmart\": smart === null ? true : smart,\n\t\t\t\t\"bCaseInsensitive\": caseInsen === null ? true : caseInsen\n\t\t\t} ), 1 );\n\t\t} );\n\t} );\n\t\n\t\n\t_api_registerPlural(\n\t\t'columns().search()',\n\t\t'column().search()',\n\t\tfunction ( input, regex, smart, caseInsen ) {\n\t\t\treturn this.iterator( 'column', function ( settings, column ) {\n\t\t\t\tvar preSearch = settings.aoPreSearchCols;\n\t\n\t\t\t\tif ( input === undefined ) {\n\t\t\t\t\t// get\n\t\t\t\t\treturn preSearch[ column ].sSearch;\n\t\t\t\t}\n\t\n\t\t\t\t// set\n\t\t\t\tif ( ! settings.oFeatures.bFilter ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\n\t\t\t\t$.extend( preSearch[ column ], {\n\t\t\t\t\t\"sSearch\": input+\"\",\n\t\t\t\t\t\"bRegex\": regex === null ? false : regex,\n\t\t\t\t\t\"bSmart\": smart === null ? true : smart,\n\t\t\t\t\t\"bCaseInsensitive\": caseInsen === null ? true : caseInsen\n\t\t\t\t} );\n\t\n\t\t\t\t_fnFilterComplete( settings, settings.oPreviousSearch, 1 );\n\t\t\t} );\n\t\t}\n\t);\n\t\n\t/*\n\t * State API methods\n\t */\n\t\n\t_api_register( 'state()', function () {\n\t\treturn this.context.length ?\n\t\t\tthis.context[0].oSavedState :\n\t\t\tnull;\n\t} );\n\t\n\t\n\t_api_register( 'state.clear()', function () {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t// Save an empty object\n\t\t\tsettings.fnStateSaveCallback.call( settings.oInstance, settings, {} );\n\t\t} );\n\t} );\n\t\n\t\n\t_api_register( 'state.loaded()', function () {\n\t\treturn this.context.length ?\n\t\t\tthis.context[0].oLoadedState :\n\t\t\tnull;\n\t} );\n\t\n\t\n\t_api_register( 'state.save()', function () {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnSaveState( settings );\n\t\t} );\n\t} );\n\t\n\t\n\t\n\t/**\n\t * Provide a common method for plug-ins to check the version of DataTables being\n\t * used, in order to ensure compatibility.\n\t *\n\t * @param {string} version Version string to check for, in the format \"X.Y.Z\".\n\t * Note that the formats \"X\" and \"X.Y\" are also acceptable.\n\t * @returns {boolean} true if this version of DataTables is greater or equal to\n\t * the required version, or false if this version of DataTales is not\n\t * suitable\n\t * @static\n\t * @dtopt API-Static\n\t *\n\t * @example\n\t * alert( $.fn.dataTable.versionCheck( '1.9.0' ) );\n\t */\n\tDataTable.versionCheck = DataTable.fnVersionCheck = function( version )\n\t{\n\t\tvar aThis = DataTable.version.split('.');\n\t\tvar aThat = version.split('.');\n\t\tvar iThis, iThat;\n\t\n\t\tfor ( var i=0, iLen=aThat.length ; i<iLen ; i++ ) {\n\t\t\tiThis = parseInt( aThis[i], 10 ) || 0;\n\t\t\tiThat = parseInt( aThat[i], 10 ) || 0;\n\t\n\t\t\t// Parts are the same, keep comparing\n\t\t\tif (iThis === iThat) {\n\t\t\t\tcontinue;\n\t\t\t}\n\t\n\t\t\t// Parts are different, return immediately\n\t\t\treturn iThis > iThat;\n\t\t}\n\t\n\t\treturn true;\n\t};\n\t\n\t\n\t/**\n\t * Check if a `<table>` node is a DataTable table already or not.\n\t *\n\t * @param {node|jquery|string} table Table node, jQuery object or jQuery\n\t * selector for the table to test. Note that if more than more than one\n\t * table is passed on, only the first will be checked\n\t * @returns {boolean} true the table given is a DataTable, or false otherwise\n\t * @static\n\t * @dtopt API-Static\n\t *\n\t * @example\n\t * if ( ! $.fn.DataTable.isDataTable( '#example' ) ) {\n\t * $('#example').dataTable();\n\t * }\n\t */\n\tDataTable.isDataTable = DataTable.fnIsDataTable = function ( table )\n\t{\n\t\tvar t = $(table).get(0);\n\t\tvar is = false;\n\t\n\t\t$.each( DataTable.settings, function (i, o) {\n\t\t\tvar head = o.nScrollHead ? $('table', o.nScrollHead)[0] : null;\n\t\t\tvar foot = o.nScrollFoot ? $('table', o.nScrollFoot)[0] : null;\n\t\n\t\t\tif ( o.nTable === t || head === t || foot === t ) {\n\t\t\t\tis = true;\n\t\t\t}\n\t\t} );\n\t\n\t\treturn is;\n\t};\n\t\n\t\n\t/**\n\t * Get all DataTable tables that have been initialised - optionally you can\n\t * select to get only currently visible tables.\n\t *\n\t * @param {boolean} [visible=false] Flag to indicate if you want all (default)\n\t * or visible tables only.\n\t * @returns {array} Array of `table` nodes (not DataTable instances) which are\n\t * DataTables\n\t * @static\n\t * @dtopt API-Static\n\t *\n\t * @example\n\t * $.each( $.fn.dataTable.tables(true), function () {\n\t * $(table).DataTable().columns.adjust();\n\t * } );\n\t */\n\tDataTable.tables = DataTable.fnTables = function ( visible )\n\t{\n\t\tvar api = false;\n\t\n\t\tif ( $.isPlainObject( visible ) ) {\n\t\t\tapi = visible.api;\n\t\t\tvisible = visible.visible;\n\t\t}\n\t\n\t\tvar a = $.map( DataTable.settings, function (o) {\n\t\t\tif ( !visible || (visible && $(o.nTable).is(':visible')) ) {\n\t\t\t\treturn o.nTable;\n\t\t\t}\n\t\t} );\n\t\n\t\treturn api ?\n\t\t\tnew _Api( a ) :\n\t\t\ta;\n\t};\n\t\n\t\n\t/**\n\t * Convert from camel case parameters to Hungarian notation. This is made public\n\t * for the extensions to provide the same ability as DataTables core to accept\n\t * either the 1.9 style Hungarian notation, or the 1.10+ style camelCase\n\t * parameters.\n\t *\n\t * @param {object} src The model object which holds all parameters that can be\n\t * mapped.\n\t * @param {object} user The object to convert from camel case to Hungarian.\n\t * @param {boolean} force When set to `true`, properties which already have a\n\t * Hungarian value in the `user` object will be overwritten. Otherwise they\n\t * won't be.\n\t */\n\tDataTable.camelToHungarian = _fnCamelToHungarian;\n\t\n\t\n\t\n\t/**\n\t *\n\t */\n\t_api_register( '$()', function ( selector, opts ) {\n\t\tvar\n\t\t\trows = this.rows( opts ).nodes(), // Get all rows\n\t\t\tjqRows = $(rows);\n\t\n\t\treturn $( [].concat(\n\t\t\tjqRows.filter( selector ).toArray(),\n\t\t\tjqRows.find( selector ).toArray()\n\t\t) );\n\t} );\n\t\n\t\n\t// jQuery functions to operate on the tables\n\t$.each( [ 'on', 'one', 'off' ], function (i, key) {\n\t\t_api_register( key+'()', function ( /* event, handler */ ) {\n\t\t\tvar args = Array.prototype.slice.call(arguments);\n\t\n\t\t\t// Add the `dt` namespace automatically if it isn't already present\n\t\t\tif ( ! args[0].match(/\\.dt\\b/) ) {\n\t\t\t\targs[0] += '.dt';\n\t\t\t}\n\t\n\t\t\tvar inst = $( this.tables().nodes() );\n\t\t\tinst[key].apply( inst, args );\n\t\t\treturn this;\n\t\t} );\n\t} );\n\t\n\t\n\t_api_register( 'clear()', function () {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\t_fnClearTable( settings );\n\t\t} );\n\t} );\n\t\n\t\n\t_api_register( 'settings()', function () {\n\t\treturn new _Api( this.context, this.context );\n\t} );\n\t\n\t\n\t_api_register( 'init()', function () {\n\t\tvar ctx = this.context;\n\t\treturn ctx.length ? ctx[0].oInit : null;\n\t} );\n\t\n\t\n\t_api_register( 'data()', function () {\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\treturn _pluck( settings.aoData, '_aData' );\n\t\t} ).flatten();\n\t} );\n\t\n\t\n\t_api_register( 'destroy()', function ( remove ) {\n\t\tremove = remove || false;\n\t\n\t\treturn this.iterator( 'table', function ( settings ) {\n\t\t\tvar orig = settings.nTableWrapper.parentNode;\n\t\t\tvar classes = settings.oClasses;\n\t\t\tvar table = settings.nTable;\n\t\t\tvar tbody = settings.nTBody;\n\t\t\tvar thead = settings.nTHead;\n\t\t\tvar tfoot = settings.nTFoot;\n\t\t\tvar jqTable = $(table);\n\t\t\tvar jqTbody = $(tbody);\n\t\t\tvar jqWrapper = $(settings.nTableWrapper);\n\t\t\tvar rows = $.map( settings.aoData, function (r) { return r.nTr; } );\n\t\t\tvar i, ien;\n\t\n\t\t\t// Flag to note that the table is currently being destroyed - no action\n\t\t\t// should be taken\n\t\t\tsettings.bDestroying = true;\n\t\n\t\t\t// Fire off the destroy callbacks for plug-ins etc\n\t\t\t_fnCallbackFire( settings, \"aoDestroyCallback\", \"destroy\", [settings] );\n\t\n\t\t\t// If not being removed from the document, make all columns visible\n\t\t\tif ( ! remove ) {\n\t\t\t\tnew _Api( settings ).columns().visible( true );\n\t\t\t}\n\t\n\t\t\t// Blitz all `DT` namespaced events (these are internal events, the\n\t\t\t// lowercase, `dt` events are user subscribed and they are responsible\n\t\t\t// for removing them\n\t\t\tjqWrapper.unbind('.DT').find(':not(tbody *)').unbind('.DT');\n\t\t\t$(window).unbind('.DT-'+settings.sInstance);\n\t\n\t\t\t// When scrolling we had to break the table up - restore it\n\t\t\tif ( table != thead.parentNode ) {\n\t\t\t\tjqTable.children('thead').detach();\n\t\t\t\tjqTable.append( thead );\n\t\t\t}\n\t\n\t\t\tif ( tfoot && table != tfoot.parentNode ) {\n\t\t\t\tjqTable.children('tfoot').detach();\n\t\t\t\tjqTable.append( tfoot );\n\t\t\t}\n\t\n\t\t\tsettings.aaSorting = [];\n\t\t\tsettings.aaSortingFixed = [];\n\t\t\t_fnSortingClasses( settings );\n\t\n\t\t\t$( rows ).removeClass( settings.asStripeClasses.join(' ') );\n\t\n\t\t\t$('th, td', thead).removeClass( classes.sSortable+' '+\n\t\t\t\tclasses.sSortableAsc+' '+classes.sSortableDesc+' '+classes.sSortableNone\n\t\t\t);\n\t\n\t\t\tif ( settings.bJUI ) {\n\t\t\t\t$('th span.'+classes.sSortIcon+ ', td span.'+classes.sSortIcon, thead).detach();\n\t\t\t\t$('th, td', thead).each( function () {\n\t\t\t\t\tvar wrapper = $('div.'+classes.sSortJUIWrapper, this);\n\t\t\t\t\t$(this).append( wrapper.contents() );\n\t\t\t\t\twrapper.detach();\n\t\t\t\t} );\n\t\t\t}\n\t\n\t\t\t// Add the TR elements back into the table in their original order\n\t\t\tjqTbody.children().detach();\n\t\t\tjqTbody.append( rows );\n\t\n\t\t\t// Remove the DataTables generated nodes, events and classes\n\t\t\tvar removedMethod = remove ? 'remove' : 'detach';\n\t\t\tjqTable[ removedMethod ]();\n\t\t\tjqWrapper[ removedMethod ]();\n\t\n\t\t\t// If we need to reattach the table to the document\n\t\t\tif ( ! remove && orig ) {\n\t\t\t\t// insertBefore acts like appendChild if !arg[1]\n\t\t\t\torig.insertBefore( table, settings.nTableReinsertBefore );\n\t\n\t\t\t\t// Restore the width of the original table - was read from the style property,\n\t\t\t\t// so we can restore directly to that\n\t\t\t\tjqTable\n\t\t\t\t\t.css( 'width', settings.sDestroyWidth )\n\t\t\t\t\t.removeClass( classes.sTable );\n\t\n\t\t\t\t// If the were originally stripe classes - then we add them back here.\n\t\t\t\t// Note this is not fool proof (for example if not all rows had stripe\n\t\t\t\t// classes - but it's a good effort without getting carried away\n\t\t\t\tien = settings.asDestroyStripes.length;\n\t\n\t\t\t\tif ( ien ) {\n\t\t\t\t\tjqTbody.children().each( function (i) {\n\t\t\t\t\t\t$(this).addClass( settings.asDestroyStripes[i % ien] );\n\t\t\t\t\t} );\n\t\t\t\t}\n\t\t\t}\n\t\n\t\t\t/* Remove the settings object from the settings array */\n\t\t\tvar idx = $.inArray( settings, DataTable.settings );\n\t\t\tif ( idx !== -1 ) {\n\t\t\t\tDataTable.settings.splice( idx, 1 );\n\t\t\t}\n\t\t} );\n\t} );\n\t\n\t\n\t// Add the `every()` method for rows, columns and cells in a compact form\n\t$.each( [ 'column', 'row', 'cell' ], function ( i, type ) {\n\t\t_api_register( type+'s().every()', function ( fn ) {\n\t\t\tvar opts = this.selector.opts;\n\t\t\tvar api = this;\n\t\n\t\t\treturn this.iterator( type, function ( settings, arg1, arg2, arg3, arg4 ) {\n\t\t\t\t// Rows and columns:\n\t\t\t\t// arg1 - index\n\t\t\t\t// arg2 - table counter\n\t\t\t\t// arg3 - loop counter\n\t\t\t\t// arg4 - undefined\n\t\t\t\t// Cells:\n\t\t\t\t// arg1 - row index\n\t\t\t\t// arg2 - column index\n\t\t\t\t// arg3 - table counter\n\t\t\t\t// arg4 - loop counter\n\t\t\t\tfn.call(\n\t\t\t\t\tapi[ type ](\n\t\t\t\t\t\targ1,\n\t\t\t\t\t\ttype==='cell' ? arg2 : opts,\n\t\t\t\t\t\ttype==='cell' ? opts : undefined\n\t\t\t\t\t),\n\t\t\t\t\targ1, arg2, arg3, arg4\n\t\t\t\t);\n\t\t\t} );\n\t\t} );\n\t} );\n\t\n\t\n\t// i18n method for extensions to be able to use the language object from the\n\t// DataTable\n\t_api_register( 'i18n()', function ( token, def, plural ) {\n\t\tvar ctx = this.context[0];\n\t\tvar resolved = _fnGetObjectDataFn( token )( ctx.oLanguage );\n\t\n\t\tif ( resolved === undefined ) {\n\t\t\tresolved = def;\n\t\t}\n\t\n\t\tif ( plural !== undefined && $.isPlainObject( resolved ) ) {\n\t\t\tresolved = resolved[ plural ] !== undefined ?\n\t\t\t\tresolved[ plural ] :\n\t\t\t\tresolved._;\n\t\t}\n\t\n\t\treturn resolved.replace( '%d', plural ); // nb: plural might be undefined,\n\t} );\n\t/**\n\t * Version string for plug-ins to check compatibility. Allowed format is\n\t * `a.b.c-d` where: a:int, b:int, c:int, d:string(dev|beta|alpha). `d` is used\n\t * only for non-release builds. See http://semver.org/ for more information.\n\t * @member\n\t * @type string\n\t * @default Version number\n\t */\n\tDataTable.version = \"1.10.12\";\n\n\t/**\n\t * Private data store, containing all of the settings objects that are\n\t * created for the tables on a given page.\n\t *\n\t * Note that the `DataTable.settings` object is aliased to\n\t * `jQuery.fn.dataTableExt` through which it may be accessed and\n\t * manipulated, or `jQuery.fn.dataTable.settings`.\n\t * @member\n\t * @type array\n\t * @default []\n\t * @private\n\t */\n\tDataTable.settings = [];\n\n\t/**\n\t * Object models container, for the various models that DataTables has\n\t * available to it. These models define the objects that are used to hold\n\t * the active state and configuration of the table.\n\t * @namespace\n\t */\n\tDataTable.models = {};\n\t\n\t\n\t\n\t/**\n\t * Template object for the way in which DataTables holds information about\n\t * search information for the global filter and individual column filters.\n\t * @namespace\n\t */\n\tDataTable.models.oSearch = {\n\t\t/**\n\t\t * Flag to indicate if the filtering should be case insensitive or not\n\t\t * @type boolean\n\t\t * @default true\n\t\t */\n\t\t\"bCaseInsensitive\": true,\n\t\n\t\t/**\n\t\t * Applied search term\n\t\t * @type string\n\t\t * @default <i>Empty string</i>\n\t\t */\n\t\t\"sSearch\": \"\",\n\t\n\t\t/**\n\t\t * Flag to indicate if the search term should be interpreted as a\n\t\t * regular expression (true) or not (false) and therefore and special\n\t\t * regex characters escaped.\n\t\t * @type boolean\n\t\t * @default false\n\t\t */\n\t\t\"bRegex\": false,\n\t\n\t\t/**\n\t\t * Flag to indicate if DataTables is to use its smart filtering or not.\n\t\t * @type boolean\n\t\t * @default true\n\t\t */\n\t\t\"bSmart\": true\n\t};\n\t\n\t\n\t\n\t\n\t/**\n\t * Template object for the way in which DataTables holds information about\n\t * each individual row. This is the object format used for the settings\n\t * aoData array.\n\t * @namespace\n\t */\n\tDataTable.models.oRow = {\n\t\t/**\n\t\t * TR element for the row\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTr\": null,\n\t\n\t\t/**\n\t\t * Array of TD elements for each row. This is null until the row has been\n\t\t * created.\n\t\t * @type array nodes\n\t\t * @default []\n\t\t */\n\t\t\"anCells\": null,\n\t\n\t\t/**\n\t\t * Data object from the original data source for the row. This is either\n\t\t * an array if using the traditional form of DataTables, or an object if\n\t\t * using mData options. The exact type will depend on the passed in\n\t\t * data from the data source, or will be an array if using DOM a data\n\t\t * source.\n\t\t * @type array|object\n\t\t * @default []\n\t\t */\n\t\t\"_aData\": [],\n\t\n\t\t/**\n\t\t * Sorting data cache - this array is ostensibly the same length as the\n\t\t * number of columns (although each index is generated only as it is\n\t\t * needed), and holds the data that is used for sorting each column in the\n\t\t * row. We do this cache generation at the start of the sort in order that\n\t\t * the formatting of the sort data need be done only once for each cell\n\t\t * per sort. This array should not be read from or written to by anything\n\t\t * other than the master sorting methods.\n\t\t * @type array\n\t\t * @default null\n\t\t * @private\n\t\t */\n\t\t\"_aSortData\": null,\n\t\n\t\t/**\n\t\t * Per cell filtering data cache. As per the sort data cache, used to\n\t\t * increase the performance of the filtering in DataTables\n\t\t * @type array\n\t\t * @default null\n\t\t * @private\n\t\t */\n\t\t\"_aFilterData\": null,\n\t\n\t\t/**\n\t\t * Filtering data cache. This is the same as the cell filtering cache, but\n\t\t * in this case a string rather than an array. This is easily computed with\n\t\t * a join on `_aFilterData`, but is provided as a cache so the join isn't\n\t\t * needed on every search (memory traded for performance)\n\t\t * @type array\n\t\t * @default null\n\t\t * @private\n\t\t */\n\t\t\"_sFilterRow\": null,\n\t\n\t\t/**\n\t\t * Cache of the class name that DataTables has applied to the row, so we\n\t\t * can quickly look at this variable rather than needing to do a DOM check\n\t\t * on className for the nTr property.\n\t\t * @type string\n\t\t * @default <i>Empty string</i>\n\t\t * @private\n\t\t */\n\t\t\"_sRowStripe\": \"\",\n\t\n\t\t/**\n\t\t * Denote if the original data source was from the DOM, or the data source\n\t\t * object. This is used for invalidating data, so DataTables can\n\t\t * automatically read data from the original source, unless uninstructed\n\t\t * otherwise.\n\t\t * @type string\n\t\t * @default null\n\t\t * @private\n\t\t */\n\t\t\"src\": null,\n\t\n\t\t/**\n\t\t * Index in the aoData array. This saves an indexOf lookup when we have the\n\t\t * object, but want to know the index\n\t\t * @type integer\n\t\t * @default -1\n\t\t * @private\n\t\t */\n\t\t\"idx\": -1\n\t};\n\t\n\t\n\t/**\n\t * Template object for the column information object in DataTables. This object\n\t * is held in the settings aoColumns array and contains all the information that\n\t * DataTables needs about each individual column.\n\t *\n\t * Note that this object is related to {@link DataTable.defaults.column}\n\t * but this one is the internal data store for DataTables's cache of columns.\n\t * It should NOT be manipulated outside of DataTables. Any configuration should\n\t * be done through the initialisation options.\n\t * @namespace\n\t */\n\tDataTable.models.oColumn = {\n\t\t/**\n\t\t * Column index. This could be worked out on-the-fly with $.inArray, but it\n\t\t * is faster to just hold it as a variable\n\t\t * @type integer\n\t\t * @default null\n\t\t */\n\t\t\"idx\": null,\n\t\n\t\t/**\n\t\t * A list of the columns that sorting should occur on when this column\n\t\t * is sorted. That this property is an array allows multi-column sorting\n\t\t * to be defined for a column (for example first name / last name columns\n\t\t * would benefit from this). The values are integers pointing to the\n\t\t * columns to be sorted on (typically it will be a single integer pointing\n\t\t * at itself, but that doesn't need to be the case).\n\t\t * @type array\n\t\t */\n\t\t\"aDataSort\": null,\n\t\n\t\t/**\n\t\t * Define the sorting directions that are applied to the column, in sequence\n\t\t * as the column is repeatedly sorted upon - i.e. the first value is used\n\t\t * as the sorting direction when the column if first sorted (clicked on).\n\t\t * Sort it again (click again) and it will move on to the next index.\n\t\t * Repeat until loop.\n\t\t * @type array\n\t\t */\n\t\t\"asSorting\": null,\n\t\n\t\t/**\n\t\t * Flag to indicate if the column is searchable, and thus should be included\n\t\t * in the filtering or not.\n\t\t * @type boolean\n\t\t */\n\t\t\"bSearchable\": null,\n\t\n\t\t/**\n\t\t * Flag to indicate if the column is sortable or not.\n\t\t * @type boolean\n\t\t */\n\t\t\"bSortable\": null,\n\t\n\t\t/**\n\t\t * Flag to indicate if the column is currently visible in the table or not\n\t\t * @type boolean\n\t\t */\n\t\t\"bVisible\": null,\n\t\n\t\t/**\n\t\t * Store for manual type assignment using the `column.type` option. This\n\t\t * is held in store so we can manipulate the column's `sType` property.\n\t\t * @type string\n\t\t * @default null\n\t\t * @private\n\t\t */\n\t\t\"_sManualType\": null,\n\t\n\t\t/**\n\t\t * Flag to indicate if HTML5 data attributes should be used as the data\n\t\t * source for filtering or sorting. True is either are.\n\t\t * @type boolean\n\t\t * @default false\n\t\t * @private\n\t\t */\n\t\t\"_bAttrSrc\": false,\n\t\n\t\t/**\n\t\t * Developer definable function that is called whenever a cell is created (Ajax source,\n\t\t * etc) or processed for input (DOM source). This can be used as a compliment to mRender\n\t\t * allowing you to modify the DOM element (add background colour for example) when the\n\t\t * element is available.\n\t\t * @type function\n\t\t * @param {element} nTd The TD node that has been created\n\t\t * @param {*} sData The Data for the cell\n\t\t * @param {array|object} oData The data for the whole row\n\t\t * @param {int} iRow The row index for the aoData data store\n\t\t * @default null\n\t\t */\n\t\t\"fnCreatedCell\": null,\n\t\n\t\t/**\n\t\t * Function to get data from a cell in a column. You should <b>never</b>\n\t\t * access data directly through _aData internally in DataTables - always use\n\t\t * the method attached to this property. It allows mData to function as\n\t\t * required. This function is automatically assigned by the column\n\t\t * initialisation method\n\t\t * @type function\n\t\t * @param {array|object} oData The data array/object for the array\n\t\t * (i.e. aoData[]._aData)\n\t\t * @param {string} sSpecific The specific data type you want to get -\n\t\t * 'display', 'type' 'filter' 'sort'\n\t\t * @returns {*} The data for the cell from the given row's data\n\t\t * @default null\n\t\t */\n\t\t\"fnGetData\": null,\n\t\n\t\t/**\n\t\t * Function to set data for a cell in the column. You should <b>never</b>\n\t\t * set the data directly to _aData internally in DataTables - always use\n\t\t * this method. It allows mData to function as required. This function\n\t\t * is automatically assigned by the column initialisation method\n\t\t * @type function\n\t\t * @param {array|object} oData The data array/object for the array\n\t\t * (i.e. aoData[]._aData)\n\t\t * @param {*} sValue Value to set\n\t\t * @default null\n\t\t */\n\t\t\"fnSetData\": null,\n\t\n\t\t/**\n\t\t * Property to read the value for the cells in the column from the data\n\t\t * source array / object. If null, then the default content is used, if a\n\t\t * function is given then the return from the function is used.\n\t\t * @type function|int|string|null\n\t\t * @default null\n\t\t */\n\t\t\"mData\": null,\n\t\n\t\t/**\n\t\t * Partner property to mData which is used (only when defined) to get\n\t\t * the data - i.e. it is basically the same as mData, but without the\n\t\t * 'set' option, and also the data fed to it is the result from mData.\n\t\t * This is the rendering method to match the data method of mData.\n\t\t * @type function|int|string|null\n\t\t * @default null\n\t\t */\n\t\t\"mRender\": null,\n\t\n\t\t/**\n\t\t * Unique header TH/TD element for this column - this is what the sorting\n\t\t * listener is attached to (if sorting is enabled.)\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTh\": null,\n\t\n\t\t/**\n\t\t * Unique footer TH/TD element for this column (if there is one). Not used\n\t\t * in DataTables as such, but can be used for plug-ins to reference the\n\t\t * footer for each column.\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTf\": null,\n\t\n\t\t/**\n\t\t * The class to apply to all TD elements in the table's TBODY for the column\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sClass\": null,\n\t\n\t\t/**\n\t\t * When DataTables calculates the column widths to assign to each column,\n\t\t * it finds the longest string in each column and then constructs a\n\t\t * temporary table and reads the widths from that. The problem with this\n\t\t * is that \"mmm\" is much wider then \"iiii\", but the latter is a longer\n\t\t * string - thus the calculation can go wrong (doing it properly and putting\n\t\t * it into an DOM object and measuring that is horribly(!) slow). Thus as\n\t\t * a \"work around\" we provide this option. It will append its value to the\n\t\t * text that is found to be the longest string for the column - i.e. padding.\n\t\t * @type string\n\t\t */\n\t\t\"sContentPadding\": null,\n\t\n\t\t/**\n\t\t * Allows a default value to be given for a column's data, and will be used\n\t\t * whenever a null data source is encountered (this can be because mData\n\t\t * is set to null, or because the data source itself is null).\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sDefaultContent\": null,\n\t\n\t\t/**\n\t\t * Name for the column, allowing reference to the column by name as well as\n\t\t * by index (needs a lookup to work by name).\n\t\t * @type string\n\t\t */\n\t\t\"sName\": null,\n\t\n\t\t/**\n\t\t * Custom sorting data type - defines which of the available plug-ins in\n\t\t * afnSortData the custom sorting will use - if any is defined.\n\t\t * @type string\n\t\t * @default std\n\t\t */\n\t\t\"sSortDataType\": 'std',\n\t\n\t\t/**\n\t\t * Class to be applied to the header element when sorting on this column\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sSortingClass\": null,\n\t\n\t\t/**\n\t\t * Class to be applied to the header element when sorting on this column -\n\t\t * when jQuery UI theming is used.\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sSortingClassJUI\": null,\n\t\n\t\t/**\n\t\t * Title of the column - what is seen in the TH element (nTh).\n\t\t * @type string\n\t\t */\n\t\t\"sTitle\": null,\n\t\n\t\t/**\n\t\t * Column sorting and filtering type\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sType\": null,\n\t\n\t\t/**\n\t\t * Width of the column\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sWidth\": null,\n\t\n\t\t/**\n\t\t * Width of the column when it was first \"encountered\"\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sWidthOrig\": null\n\t};\n\t\n\t\n\t/*\n\t * Developer note: The properties of the object below are given in Hungarian\n\t * notation, that was used as the interface for DataTables prior to v1.10, however\n\t * from v1.10 onwards the primary interface is camel case. In order to avoid\n\t * breaking backwards compatibility utterly with this change, the Hungarian\n\t * version is still, internally the primary interface, but is is not documented\n\t * - hence the @name tags in each doc comment. This allows a Javascript function\n\t * to create a map from Hungarian notation to camel case (going the other direction\n\t * would require each property to be listed, which would at around 3K to the size\n\t * of DataTables, while this method is about a 0.5K hit.\n\t *\n\t * Ultimately this does pave the way for Hungarian notation to be dropped\n\t * completely, but that is a massive amount of work and will break current\n\t * installs (therefore is on-hold until v2).\n\t */\n\t\n\t/**\n\t * Initialisation options that can be given to DataTables at initialisation\n\t * time.\n\t * @namespace\n\t */\n\tDataTable.defaults = {\n\t\t/**\n\t\t * An array of data to use for the table, passed in at initialisation which\n\t\t * will be used in preference to any data which is already in the DOM. This is\n\t\t * particularly useful for constructing tables purely in Javascript, for\n\t\t * example with a custom Ajax call.\n\t\t * @type array\n\t\t * @default null\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.data\n\t\t *\n\t\t * @example\n\t\t * // Using a 2D array data source\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"data\": [\n\t\t * ['Trident', 'Internet Explorer 4.0', 'Win 95+', 4, 'X'],\n\t\t * ['Trident', 'Internet Explorer 5.0', 'Win 95+', 5, 'C'],\n\t\t * ],\n\t\t * \"columns\": [\n\t\t * { \"title\": \"Engine\" },\n\t\t * { \"title\": \"Browser\" },\n\t\t * { \"title\": \"Platform\" },\n\t\t * { \"title\": \"Version\" },\n\t\t * { \"title\": \"Grade\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using an array of objects as a data source (`data`)\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"data\": [\n\t\t * {\n\t\t * \"engine\": \"Trident\",\n\t\t * \"browser\": \"Internet Explorer 4.0\",\n\t\t * \"platform\": \"Win 95+\",\n\t\t * \"version\": 4,\n\t\t * \"grade\": \"X\"\n\t\t * },\n\t\t * {\n\t\t * \"engine\": \"Trident\",\n\t\t * \"browser\": \"Internet Explorer 5.0\",\n\t\t * \"platform\": \"Win 95+\",\n\t\t * \"version\": 5,\n\t\t * \"grade\": \"C\"\n\t\t * }\n\t\t * ],\n\t\t * \"columns\": [\n\t\t * { \"title\": \"Engine\", \"data\": \"engine\" },\n\t\t * { \"title\": \"Browser\", \"data\": \"browser\" },\n\t\t * { \"title\": \"Platform\", \"data\": \"platform\" },\n\t\t * { \"title\": \"Version\", \"data\": \"version\" },\n\t\t * { \"title\": \"Grade\", \"data\": \"grade\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"aaData\": null,\n\t\n\t\n\t\t/**\n\t\t * If ordering is enabled, then DataTables will perform a first pass sort on\n\t\t * initialisation. You can define which column(s) the sort is performed\n\t\t * upon, and the sorting direction, with this variable. The `sorting` array\n\t\t * should contain an array for each column to be sorted initially containing\n\t\t * the column's index and a direction string ('asc' or 'desc').\n\t\t * @type array\n\t\t * @default [[0,'asc']]\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.order\n\t\t *\n\t\t * @example\n\t\t * // Sort by 3rd column first, and then 4th column\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"order\": [[2,'asc'], [3,'desc']]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * // No initial sorting\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"order\": []\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"aaSorting\": [[0,'asc']],\n\t\n\t\n\t\t/**\n\t\t * This parameter is basically identical to the `sorting` parameter, but\n\t\t * cannot be overridden by user interaction with the table. What this means\n\t\t * is that you could have a column (visible or hidden) which the sorting\n\t\t * will always be forced on first - any sorting after that (from the user)\n\t\t * will then be performed as required. This can be useful for grouping rows\n\t\t * together.\n\t\t * @type array\n\t\t * @default null\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.orderFixed\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"orderFixed\": [[0,'asc']]\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"aaSortingFixed\": [],\n\t\n\t\n\t\t/**\n\t\t * DataTables can be instructed to load data to display in the table from a\n\t\t * Ajax source. This option defines how that Ajax call is made and where to.\n\t\t *\n\t\t * The `ajax` property has three different modes of operation, depending on\n\t\t * how it is defined. These are:\n\t\t *\n\t\t * * `string` - Set the URL from where the data should be loaded from.\n\t\t * * `object` - Define properties for `jQuery.ajax`.\n\t\t * * `function` - Custom data get function\n\t\t *\n\t\t * `string`\n\t\t * --------\n\t\t *\n\t\t * As a string, the `ajax` property simply defines the URL from which\n\t\t * DataTables will load data.\n\t\t *\n\t\t * `object`\n\t\t * --------\n\t\t *\n\t\t * As an object, the parameters in the object are passed to\n\t\t * [jQuery.ajax](http://api.jquery.com/jQuery.ajax/) allowing fine control\n\t\t * of the Ajax request. DataTables has a number of default parameters which\n\t\t * you can override using this option. Please refer to the jQuery\n\t\t * documentation for a full description of the options available, although\n\t\t * the following parameters provide additional options in DataTables or\n\t\t * require special consideration:\n\t\t *\n\t\t * * `data` - As with jQuery, `data` can be provided as an object, but it\n\t\t * can also be used as a function to manipulate the data DataTables sends\n\t\t * to the server. The function takes a single parameter, an object of\n\t\t * parameters with the values that DataTables has readied for sending. An\n\t\t * object may be returned which will be merged into the DataTables\n\t\t * defaults, or you can add the items to the object that was passed in and\n\t\t * not return anything from the function. This supersedes `fnServerParams`\n\t\t * from DataTables 1.9-.\n\t\t *\n\t\t * * `dataSrc` - By default DataTables will look for the property `data` (or\n\t\t * `aaData` for compatibility with DataTables 1.9-) when obtaining data\n\t\t * from an Ajax source or for server-side processing - this parameter\n\t\t * allows that property to be changed. You can use Javascript dotted\n\t\t * object notation to get a data source for multiple levels of nesting, or\n\t\t * it my be used as a function. As a function it takes a single parameter,\n\t\t * the JSON returned from the server, which can be manipulated as\n\t\t * required, with the returned value being that used by DataTables as the\n\t\t * data source for the table. This supersedes `sAjaxDataProp` from\n\t\t * DataTables 1.9-.\n\t\t *\n\t\t * * `success` - Should not be overridden it is used internally in\n\t\t * DataTables. To manipulate / transform the data returned by the server\n\t\t * use `ajax.dataSrc`, or use `ajax` as a function (see below).\n\t\t *\n\t\t * `function`\n\t\t * ----------\n\t\t *\n\t\t * As a function, making the Ajax call is left up to yourself allowing\n\t\t * complete control of the Ajax request. Indeed, if desired, a method other\n\t\t * than Ajax could be used to obtain the required data, such as Web storage\n\t\t * or an AIR database.\n\t\t *\n\t\t * The function is given four parameters and no return is required. The\n\t\t * parameters are:\n\t\t *\n\t\t * 1. _object_ - Data to send to the server\n\t\t * 2. _function_ - Callback function that must be executed when the required\n\t\t * data has been obtained. That data should be passed into the callback\n\t\t * as the only parameter\n\t\t * 3. _object_ - DataTables settings object for the table\n\t\t *\n\t\t * Note that this supersedes `fnServerData` from DataTables 1.9-.\n\t\t *\n\t\t * @type string|object|function\n\t\t * @default null\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.ajax\n\t\t * @since 1.10.0\n\t\t *\n\t\t * @example\n\t\t * // Get JSON data from a file via Ajax.\n\t\t * // Note DataTables expects data in the form `{ data: [ ...data... ] }` by default).\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": \"data.json\"\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Get JSON data from a file via Ajax, using `dataSrc` to change\n\t\t * // `data` to `tableData` (i.e. `{ tableData: [ ...data... ] }`)\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": {\n\t\t * \"url\": \"data.json\",\n\t\t * \"dataSrc\": \"tableData\"\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Get JSON data from a file via Ajax, using `dataSrc` to read data\n\t\t * // from a plain array rather than an array in an object\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": {\n\t\t * \"url\": \"data.json\",\n\t\t * \"dataSrc\": \"\"\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Manipulate the data returned from the server - add a link to data\n\t\t * // (note this can, should, be done using `render` for the column - this\n\t\t * // is just a simple example of how the data can be manipulated).\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": {\n\t\t * \"url\": \"data.json\",\n\t\t * \"dataSrc\": function ( json ) {\n\t\t * for ( var i=0, ien=json.length ; i<ien ; i++ ) {\n\t\t * json[i][0] = '<a href=\"/message/'+json[i][0]+'>View message</a>';\n\t\t * }\n\t\t * return json;\n\t\t * }\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Add data to the request\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": {\n\t\t * \"url\": \"data.json\",\n\t\t * \"data\": function ( d ) {\n\t\t * return {\n\t\t * \"extra_search\": $('#extra').val()\n\t\t * };\n\t\t * }\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Send request as POST\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": {\n\t\t * \"url\": \"data.json\",\n\t\t * \"type\": \"POST\"\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Get the data from localStorage (could interface with a form for\n\t\t * // adding, editing and removing rows).\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": function (data, callback, settings) {\n\t\t * callback(\n\t\t * JSON.parse( localStorage.getItem('dataTablesData') )\n\t\t * );\n\t\t * }\n\t\t * } );\n\t\t */\n\t\t\"ajax\": null,\n\t\n\t\n\t\t/**\n\t\t * This parameter allows you to readily specify the entries in the length drop\n\t\t * down menu that DataTables shows when pagination is enabled. It can be\n\t\t * either a 1D array of options which will be used for both the displayed\n\t\t * option and the value, or a 2D array which will use the array in the first\n\t\t * position as the value, and the array in the second position as the\n\t\t * displayed options (useful for language strings such as 'All').\n\t\t *\n\t\t * Note that the `pageLength` property will be automatically set to the\n\t\t * first value given in this array, unless `pageLength` is also provided.\n\t\t * @type array\n\t\t * @default [ 10, 25, 50, 100 ]\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.lengthMenu\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"lengthMenu\": [[10, 25, 50, -1], [10, 25, 50, \"All\"]]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"aLengthMenu\": [ 10, 25, 50, 100 ],\n\t\n\t\n\t\t/**\n\t\t * The `columns` option in the initialisation parameter allows you to define\n\t\t * details about the way individual columns behave. For a full list of\n\t\t * column options that can be set, please see\n\t\t * {@link DataTable.defaults.column}. Note that if you use `columns` to\n\t\t * define your columns, you must have an entry in the array for every single\n\t\t * column that you have in your table (these can be null if you don't which\n\t\t * to specify any options).\n\t\t * @member\n\t\t *\n\t\t * @name DataTable.defaults.column\n\t\t */\n\t\t\"aoColumns\": null,\n\t\n\t\t/**\n\t\t * Very similar to `columns`, `columnDefs` allows you to target a specific\n\t\t * column, multiple columns, or all columns, using the `targets` property of\n\t\t * each object in the array. This allows great flexibility when creating\n\t\t * tables, as the `columnDefs` arrays can be of any length, targeting the\n\t\t * columns you specifically want. `columnDefs` may use any of the column\n\t\t * options available: {@link DataTable.defaults.column}, but it _must_\n\t\t * have `targets` defined in each object in the array. Values in the `targets`\n\t\t * array may be:\n\t\t * <ul>\n\t\t * <li>a string - class name will be matched on the TH for the column</li>\n\t\t * <li>0 or a positive integer - column index counting from the left</li>\n\t\t * <li>a negative integer - column index counting from the right</li>\n\t\t * <li>the string \"_all\" - all columns (i.e. assign a default)</li>\n\t\t * </ul>\n\t\t * @member\n\t\t *\n\t\t * @name DataTable.defaults.columnDefs\n\t\t */\n\t\t\"aoColumnDefs\": null,\n\t\n\t\n\t\t/**\n\t\t * Basically the same as `search`, this parameter defines the individual column\n\t\t * filtering state at initialisation time. The array must be of the same size\n\t\t * as the number of columns, and each element be an object with the parameters\n\t\t * `search` and `escapeRegex` (the latter is optional). 'null' is also\n\t\t * accepted and the default will be used.\n\t\t * @type array\n\t\t * @default []\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.searchCols\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"searchCols\": [\n\t\t * null,\n\t\t * { \"search\": \"My filter\" },\n\t\t * null,\n\t\t * { \"search\": \"^[0-9]\", \"escapeRegex\": false }\n\t\t * ]\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"aoSearchCols\": [],\n\t\n\t\n\t\t/**\n\t\t * An array of CSS classes that should be applied to displayed rows. This\n\t\t * array may be of any length, and DataTables will apply each class\n\t\t * sequentially, looping when required.\n\t\t * @type array\n\t\t * @default null <i>Will take the values determined by the `oClasses.stripe*`\n\t\t * options</i>\n\t\t *\n\t\t * @dtopt Option\n\t\t * @name DataTable.defaults.stripeClasses\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stripeClasses\": [ 'strip1', 'strip2', 'strip3' ]\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"asStripeClasses\": null,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable automatic column width calculation. This can be disabled\n\t\t * as an optimisation (it takes some time to calculate the widths) if the\n\t\t * tables widths are passed in using `columns`.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.autoWidth\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"autoWidth\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bAutoWidth\": true,\n\t\n\t\n\t\t/**\n\t\t * Deferred rendering can provide DataTables with a huge speed boost when you\n\t\t * are using an Ajax or JS data source for the table. This option, when set to\n\t\t * true, will cause DataTables to defer the creation of the table elements for\n\t\t * each row until they are needed for a draw - saving a significant amount of\n\t\t * time.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.deferRender\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"ajax\": \"sources/arrays.txt\",\n\t\t * \"deferRender\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bDeferRender\": false,\n\t\n\t\n\t\t/**\n\t\t * Replace a DataTable which matches the given selector and replace it with\n\t\t * one which has the properties of the new initialisation object passed. If no\n\t\t * table matches the selector, then the new DataTable will be constructed as\n\t\t * per normal.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.destroy\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"srollY\": \"200px\",\n\t\t * \"paginate\": false\n\t\t * } );\n\t\t *\n\t\t * // Some time later....\n\t\t * $('#example').dataTable( {\n\t\t * \"filter\": false,\n\t\t * \"destroy\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bDestroy\": false,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable filtering of data. Filtering in DataTables is \"smart\" in\n\t\t * that it allows the end user to input multiple words (space separated) and\n\t\t * will match a row containing those words, even if not in the order that was\n\t\t * specified (this allow matching across multiple columns). Note that if you\n\t\t * wish to use filtering in DataTables this must remain 'true' - to remove the\n\t\t * default filtering input box and retain filtering abilities, please use\n\t\t * {@link DataTable.defaults.dom}.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.searching\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"searching\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bFilter\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable the table information display. This shows information\n\t\t * about the data that is currently visible on the page, including information\n\t\t * about filtered data if that action is being performed.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.info\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"info\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bInfo\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable jQuery UI ThemeRoller support (required as ThemeRoller requires some\n\t\t * slightly different and additional mark-up from what DataTables has\n\t\t * traditionally used).\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.jQueryUI\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"jQueryUI\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bJQueryUI\": false,\n\t\n\t\n\t\t/**\n\t\t * Allows the end user to select the size of a formatted page from a select\n\t\t * menu (sizes are 10, 25, 50 and 100). Requires pagination (`paginate`).\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.lengthChange\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"lengthChange\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bLengthChange\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable pagination.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.paging\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"paging\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bPaginate\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable the display of a 'processing' indicator when the table is\n\t\t * being processed (e.g. a sort). This is particularly useful for tables with\n\t\t * large amounts of data where it can take a noticeable amount of time to sort\n\t\t * the entries.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.processing\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"processing\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bProcessing\": false,\n\t\n\t\n\t\t/**\n\t\t * Retrieve the DataTables object for the given selector. Note that if the\n\t\t * table has already been initialised, this parameter will cause DataTables\n\t\t * to simply return the object that has already been set up - it will not take\n\t\t * account of any changes you might have made to the initialisation object\n\t\t * passed to DataTables (setting this parameter to true is an acknowledgement\n\t\t * that you understand this). `destroy` can be used to reinitialise a table if\n\t\t * you need.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.retrieve\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * initTable();\n\t\t * tableActions();\n\t\t * } );\n\t\t *\n\t\t * function initTable ()\n\t\t * {\n\t\t * return $('#example').dataTable( {\n\t\t * \"scrollY\": \"200px\",\n\t\t * \"paginate\": false,\n\t\t * \"retrieve\": true\n\t\t * } );\n\t\t * }\n\t\t *\n\t\t * function tableActions ()\n\t\t * {\n\t\t * var table = initTable();\n\t\t * // perform API operations with oTable\n\t\t * }\n\t\t */\n\t\t\"bRetrieve\": false,\n\t\n\t\n\t\t/**\n\t\t * When vertical (y) scrolling is enabled, DataTables will force the height of\n\t\t * the table's viewport to the given height at all times (useful for layout).\n\t\t * However, this can look odd when filtering data down to a small data set,\n\t\t * and the footer is left \"floating\" further down. This parameter (when\n\t\t * enabled) will cause DataTables to collapse the table's viewport down when\n\t\t * the result set will fit within the given Y height.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.scrollCollapse\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"scrollY\": \"200\",\n\t\t * \"scrollCollapse\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bScrollCollapse\": false,\n\t\n\t\n\t\t/**\n\t\t * Configure DataTables to use server-side processing. Note that the\n\t\t * `ajax` parameter must also be given in order to give DataTables a\n\t\t * source to obtain the required data for each draw.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Features\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.serverSide\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"serverSide\": true,\n\t\t * \"ajax\": \"xhr.php\"\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bServerSide\": false,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable sorting of columns. Sorting of individual columns can be\n\t\t * disabled by the `sortable` option for each column.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.ordering\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"ordering\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bSort\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or display DataTables' ability to sort multiple columns at the\n\t\t * same time (activated by shift-click by the user).\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.orderMulti\n\t\t *\n\t\t * @example\n\t\t * // Disable multiple column sorting ability\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"orderMulti\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bSortMulti\": true,\n\t\n\t\n\t\t/**\n\t\t * Allows control over whether DataTables should use the top (true) unique\n\t\t * cell that is found for a single column, or the bottom (false - default).\n\t\t * This is useful when using complex headers.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.orderCellsTop\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"orderCellsTop\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bSortCellsTop\": false,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable the addition of the classes `sorting\\_1`, `sorting\\_2` and\n\t\t * `sorting\\_3` to the columns which are currently being sorted on. This is\n\t\t * presented as a feature switch as it can increase processing time (while\n\t\t * classes are removed and added) so for large data sets you might want to\n\t\t * turn this off.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.orderClasses\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"orderClasses\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bSortClasses\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable state saving. When enabled HTML5 `localStorage` will be\n\t\t * used to save table display information such as pagination information,\n\t\t * display length, filtering and sorting. As such when the end user reloads\n\t\t * the page the display display will match what thy had previously set up.\n\t\t *\n\t\t * Due to the use of `localStorage` the default state saving is not supported\n\t\t * in IE6 or 7. If state saving is required in those browsers, use\n\t\t * `stateSaveCallback` to provide a storage solution such as cookies.\n\t\t * @type boolean\n\t\t * @default false\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.stateSave\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function () {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"bStateSave\": false,\n\t\n\t\n\t\t/**\n\t\t * This function is called when a TR element is created (and all TD child\n\t\t * elements have been inserted), or registered if using a DOM source, allowing\n\t\t * manipulation of the TR element (adding classes etc).\n\t\t * @type function\n\t\t * @param {node} row \"TR\" element for the current row\n\t\t * @param {array} data Raw data array for this row\n\t\t * @param {int} dataIndex The index of this row in the internal aoData array\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.createdRow\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"createdRow\": function( row, data, dataIndex ) {\n\t\t * // Bold the grade for all 'A' grade browsers\n\t\t * if ( data[4] == \"A\" )\n\t\t * {\n\t\t * $('td:eq(4)', row).html( '<b>A</b>' );\n\t\t * }\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnCreatedRow\": null,\n\t\n\t\n\t\t/**\n\t\t * This function is called on every 'draw' event, and allows you to\n\t\t * dynamically modify any aspect you want about the created DOM.\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.drawCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"drawCallback\": function( settings ) {\n\t\t * alert( 'DataTables has redrawn the table' );\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnDrawCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * Identical to fnHeaderCallback() but for the table footer this function\n\t\t * allows you to modify the table footer on every 'draw' event.\n\t\t * @type function\n\t\t * @param {node} foot \"TR\" element for the footer\n\t\t * @param {array} data Full table data (as derived from the original HTML)\n\t\t * @param {int} start Index for the current display starting point in the\n\t\t * display array\n\t\t * @param {int} end Index for the current display ending point in the\n\t\t * display array\n\t\t * @param {array int} display Index array to translate the visual position\n\t\t * to the full data array\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.footerCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"footerCallback\": function( tfoot, data, start, end, display ) {\n\t\t * tfoot.getElementsByTagName('th')[0].innerHTML = \"Starting index is \"+start;\n\t\t * }\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"fnFooterCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * When rendering large numbers in the information element for the table\n\t\t * (i.e. \"Showing 1 to 10 of 57 entries\") DataTables will render large numbers\n\t\t * to have a comma separator for the 'thousands' units (e.g. 1 million is\n\t\t * rendered as \"1,000,000\") to help readability for the end user. This\n\t\t * function will override the default method DataTables uses.\n\t\t * @type function\n\t\t * @member\n\t\t * @param {int} toFormat number to be formatted\n\t\t * @returns {string} formatted string for DataTables to show the number\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.formatNumber\n\t\t *\n\t\t * @example\n\t\t * // Format a number using a single quote for the separator (note that\n\t\t * // this can also be done with the language.thousands option)\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"formatNumber\": function ( toFormat ) {\n\t\t * return toFormat.toString().replace(\n\t\t * /\\B(?=(\\d{3})+(?!\\d))/g, \"'\"\n\t\t * );\n\t\t * };\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnFormatNumber\": function ( toFormat ) {\n\t\t\treturn toFormat.toString().replace(\n\t\t\t\t/\\B(?=(\\d{3})+(?!\\d))/g,\n\t\t\t\tthis.oLanguage.sThousands\n\t\t\t);\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * This function is called on every 'draw' event, and allows you to\n\t\t * dynamically modify the header row. This can be used to calculate and\n\t\t * display useful information about the table.\n\t\t * @type function\n\t\t * @param {node} head \"TR\" element for the header\n\t\t * @param {array} data Full table data (as derived from the original HTML)\n\t\t * @param {int} start Index for the current display starting point in the\n\t\t * display array\n\t\t * @param {int} end Index for the current display ending point in the\n\t\t * display array\n\t\t * @param {array int} display Index array to translate the visual position\n\t\t * to the full data array\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.headerCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"fheaderCallback\": function( head, data, start, end, display ) {\n\t\t * head.getElementsByTagName('th')[0].innerHTML = \"Displaying \"+(end-start)+\" records\";\n\t\t * }\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"fnHeaderCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * The information element can be used to convey information about the current\n\t\t * state of the table. Although the internationalisation options presented by\n\t\t * DataTables are quite capable of dealing with most customisations, there may\n\t\t * be times where you wish to customise the string further. This callback\n\t\t * allows you to do exactly that.\n\t\t * @type function\n\t\t * @param {object} oSettings DataTables settings object\n\t\t * @param {int} start Starting position in data for the draw\n\t\t * @param {int} end End position in data for the draw\n\t\t * @param {int} max Total number of rows in the table (regardless of\n\t\t * filtering)\n\t\t * @param {int} total Total number of rows in the data set, after filtering\n\t\t * @param {string} pre The string that DataTables has formatted using it's\n\t\t * own rules\n\t\t * @returns {string} The string to be displayed in the information element.\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.infoCallback\n\t\t *\n\t\t * @example\n\t\t * $('#example').dataTable( {\n\t\t * \"infoCallback\": function( settings, start, end, max, total, pre ) {\n\t\t * return start +\" to \"+ end;\n\t\t * }\n\t\t * } );\n\t\t */\n\t\t\"fnInfoCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * Called when the table has been initialised. Normally DataTables will\n\t\t * initialise sequentially and there will be no need for this function,\n\t\t * however, this does not hold true when using external language information\n\t\t * since that is obtained using an async XHR call.\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t * @param {object} json The JSON object request from the server - only\n\t\t * present if client-side Ajax sourced data is used\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.initComplete\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"initComplete\": function(settings, json) {\n\t\t * alert( 'DataTables has finished its initialisation.' );\n\t\t * }\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"fnInitComplete\": null,\n\t\n\t\n\t\t/**\n\t\t * Called at the very start of each table draw and can be used to cancel the\n\t\t * draw by returning false, any other return (including undefined) results in\n\t\t * the full draw occurring).\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t * @returns {boolean} False will cancel the draw, anything else (including no\n\t\t * return) will allow it to complete.\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.preDrawCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"preDrawCallback\": function( settings ) {\n\t\t * if ( $('#test').val() == 1 ) {\n\t\t * return false;\n\t\t * }\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnPreDrawCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * This function allows you to 'post process' each row after it have been\n\t\t * generated for each table draw, but before it is rendered on screen. This\n\t\t * function might be used for setting the row class name etc.\n\t\t * @type function\n\t\t * @param {node} row \"TR\" element for the current row\n\t\t * @param {array} data Raw data array for this row\n\t\t * @param {int} displayIndex The display index for the current table draw\n\t\t * @param {int} displayIndexFull The index of the data in the full list of\n\t\t * rows (after filtering)\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.rowCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"rowCallback\": function( row, data, displayIndex, displayIndexFull ) {\n\t\t * // Bold the grade for all 'A' grade browsers\n\t\t * if ( data[4] == \"A\" ) {\n\t\t * $('td:eq(4)', row).html( '<b>A</b>' );\n\t\t * }\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnRowCallback\": null,\n\t\n\t\n\t\t/**\n\t\t * __Deprecated__ The functionality provided by this parameter has now been\n\t\t * superseded by that provided through `ajax`, which should be used instead.\n\t\t *\n\t\t * This parameter allows you to override the default function which obtains\n\t\t * the data from the server so something more suitable for your application.\n\t\t * For example you could use POST data, or pull information from a Gears or\n\t\t * AIR database.\n\t\t * @type function\n\t\t * @member\n\t\t * @param {string} source HTTP source to obtain the data from (`ajax`)\n\t\t * @param {array} data A key/value pair object containing the data to send\n\t\t * to the server\n\t\t * @param {function} callback to be called on completion of the data get\n\t\t * process that will draw the data on the page.\n\t\t * @param {object} settings DataTables settings object\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.serverData\n\t\t *\n\t\t * @deprecated 1.10. Please use `ajax` for this functionality now.\n\t\t */\n\t\t\"fnServerData\": null,\n\t\n\t\n\t\t/**\n\t\t * __Deprecated__ The functionality provided by this parameter has now been\n\t\t * superseded by that provided through `ajax`, which should be used instead.\n\t\t *\n\t\t * It is often useful to send extra data to the server when making an Ajax\n\t\t * request - for example custom filtering information, and this callback\n\t\t * function makes it trivial to send extra information to the server. The\n\t\t * passed in parameter is the data set that has been constructed by\n\t\t * DataTables, and you can add to this or modify it as you require.\n\t\t * @type function\n\t\t * @param {array} data Data array (array of objects which are name/value\n\t\t * pairs) that has been constructed by DataTables and will be sent to the\n\t\t * server. In the case of Ajax sourced data with server-side processing\n\t\t * this will be an empty array, for server-side processing there will be a\n\t\t * significant number of parameters!\n\t\t * @returns {undefined} Ensure that you modify the data array passed in,\n\t\t * as this is passed by reference.\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.serverParams\n\t\t *\n\t\t * @deprecated 1.10. Please use `ajax` for this functionality now.\n\t\t */\n\t\t\"fnServerParams\": null,\n\t\n\t\n\t\t/**\n\t\t * Load the table state. With this function you can define from where, and how, the\n\t\t * state of a table is loaded. By default DataTables will load from `localStorage`\n\t\t * but you might wish to use a server-side database or cookies.\n\t\t * @type function\n\t\t * @member\n\t\t * @param {object} settings DataTables settings object\n\t\t * @return {object} The DataTables state object to be loaded\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.stateLoadCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateLoadCallback\": function (settings) {\n\t\t * var o;\n\t\t *\n\t\t * // Send an Ajax request to the server to get the data. Note that\n\t\t * // this is a synchronous request.\n\t\t * $.ajax( {\n\t\t * \"url\": \"/state_load\",\n\t\t * \"async\": false,\n\t\t * \"dataType\": \"json\",\n\t\t * \"success\": function (json) {\n\t\t * o = json;\n\t\t * }\n\t\t * } );\n\t\t *\n\t\t * return o;\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnStateLoadCallback\": function ( settings ) {\n\t\t\ttry {\n\t\t\t\treturn JSON.parse(\n\t\t\t\t\t(settings.iStateDuration === -1 ? sessionStorage : localStorage).getItem(\n\t\t\t\t\t\t'DataTables_'+settings.sInstance+'_'+location.pathname\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\t} catch (e) {}\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Callback which allows modification of the saved state prior to loading that state.\n\t\t * This callback is called when the table is loading state from the stored data, but\n\t\t * prior to the settings object being modified by the saved state. Note that for\n\t\t * plug-in authors, you should use the `stateLoadParams` event to load parameters for\n\t\t * a plug-in.\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t * @param {object} data The state object that is to be loaded\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.stateLoadParams\n\t\t *\n\t\t * @example\n\t\t * // Remove a saved filter, so filtering is never loaded\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateLoadParams\": function (settings, data) {\n\t\t * data.oSearch.sSearch = \"\";\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Disallow state loading by returning false\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateLoadParams\": function (settings, data) {\n\t\t * return false;\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnStateLoadParams\": null,\n\t\n\t\n\t\t/**\n\t\t * Callback that is called when the state has been loaded from the state saving method\n\t\t * and the DataTables settings object has been modified as a result of the loaded state.\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t * @param {object} data The state object that was loaded\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.stateLoaded\n\t\t *\n\t\t * @example\n\t\t * // Show an alert with the filtering value that was saved\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateLoaded\": function (settings, data) {\n\t\t * alert( 'Saved filter was: '+data.oSearch.sSearch );\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnStateLoaded\": null,\n\t\n\t\n\t\t/**\n\t\t * Save the table state. This function allows you to define where and how the state\n\t\t * information for the table is stored By default DataTables will use `localStorage`\n\t\t * but you might wish to use a server-side database or cookies.\n\t\t * @type function\n\t\t * @member\n\t\t * @param {object} settings DataTables settings object\n\t\t * @param {object} data The state object to be saved\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.stateSaveCallback\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateSaveCallback\": function (settings, data) {\n\t\t * // Send an Ajax request to the server with the state object\n\t\t * $.ajax( {\n\t\t * \"url\": \"/state_save\",\n\t\t * \"data\": data,\n\t\t * \"dataType\": \"json\",\n\t\t * \"method\": \"POST\"\n\t\t * \"success\": function () {}\n\t\t * } );\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnStateSaveCallback\": function ( settings, data ) {\n\t\t\ttry {\n\t\t\t\t(settings.iStateDuration === -1 ? sessionStorage : localStorage).setItem(\n\t\t\t\t\t'DataTables_'+settings.sInstance+'_'+location.pathname,\n\t\t\t\t\tJSON.stringify( data )\n\t\t\t\t);\n\t\t\t} catch (e) {}\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Callback which allows modification of the state to be saved. Called when the table\n\t\t * has changed state a new state save is required. This method allows modification of\n\t\t * the state saving object prior to actually doing the save, including addition or\n\t\t * other state properties or modification. Note that for plug-in authors, you should\n\t\t * use the `stateSaveParams` event to save parameters for a plug-in.\n\t\t * @type function\n\t\t * @param {object} settings DataTables settings object\n\t\t * @param {object} data The state object to be saved\n\t\t *\n\t\t * @dtopt Callbacks\n\t\t * @name DataTable.defaults.stateSaveParams\n\t\t *\n\t\t * @example\n\t\t * // Remove a saved filter, so filtering is never saved\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateSave\": true,\n\t\t * \"stateSaveParams\": function (settings, data) {\n\t\t * data.oSearch.sSearch = \"\";\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"fnStateSaveParams\": null,\n\t\n\t\n\t\t/**\n\t\t * Duration for which the saved state information is considered valid. After this period\n\t\t * has elapsed the state will be returned to the default.\n\t\t * Value is given in seconds.\n\t\t * @type int\n\t\t * @default 7200 <i>(2 hours)</i>\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.stateDuration\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"stateDuration\": 60*60*24; // 1 day\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"iStateDuration\": 7200,\n\t\n\t\n\t\t/**\n\t\t * When enabled DataTables will not make a request to the server for the first\n\t\t * page draw - rather it will use the data already on the page (no sorting etc\n\t\t * will be applied to it), thus saving on an XHR at load time. `deferLoading`\n\t\t * is used to indicate that deferred loading is required, but it is also used\n\t\t * to tell DataTables how many records there are in the full table (allowing\n\t\t * the information element and pagination to be displayed correctly). In the case\n\t\t * where a filtering is applied to the table on initial load, this can be\n\t\t * indicated by giving the parameter as an array, where the first element is\n\t\t * the number of records available after filtering and the second element is the\n\t\t * number of records without filtering (allowing the table information element\n\t\t * to be shown correctly).\n\t\t * @type int | array\n\t\t * @default null\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.deferLoading\n\t\t *\n\t\t * @example\n\t\t * // 57 records available in the table, no filtering applied\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"serverSide\": true,\n\t\t * \"ajax\": \"scripts/server_processing.php\",\n\t\t * \"deferLoading\": 57\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // 57 records after filtering, 100 without filtering (an initial filter applied)\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"serverSide\": true,\n\t\t * \"ajax\": \"scripts/server_processing.php\",\n\t\t * \"deferLoading\": [ 57, 100 ],\n\t\t * \"search\": {\n\t\t * \"search\": \"my_filter\"\n\t\t * }\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"iDeferLoading\": null,\n\t\n\t\n\t\t/**\n\t\t * Number of rows to display on a single page when using pagination. If\n\t\t * feature enabled (`lengthChange`) then the end user will be able to override\n\t\t * this to a custom setting using a pop-up menu.\n\t\t * @type int\n\t\t * @default 10\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.pageLength\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"pageLength\": 50\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"iDisplayLength\": 10,\n\t\n\t\n\t\t/**\n\t\t * Define the starting point for data display when using DataTables with\n\t\t * pagination. Note that this parameter is the number of records, rather than\n\t\t * the page number, so if you have 10 records per page and want to start on\n\t\t * the third page, it should be \"20\".\n\t\t * @type int\n\t\t * @default 0\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.displayStart\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"displayStart\": 20\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"iDisplayStart\": 0,\n\t\n\t\n\t\t/**\n\t\t * By default DataTables allows keyboard navigation of the table (sorting, paging,\n\t\t * and filtering) by adding a `tabindex` attribute to the required elements. This\n\t\t * allows you to tab through the controls and press the enter key to activate them.\n\t\t * The tabindex is default 0, meaning that the tab follows the flow of the document.\n\t\t * You can overrule this using this parameter if you wish. Use a value of -1 to\n\t\t * disable built-in keyboard navigation.\n\t\t * @type int\n\t\t * @default 0\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.tabIndex\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"tabIndex\": 1\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"iTabIndex\": 0,\n\t\n\t\n\t\t/**\n\t\t * Classes that DataTables assigns to the various components and features\n\t\t * that it adds to the HTML table. This allows classes to be configured\n\t\t * during initialisation in addition to through the static\n\t\t * {@link DataTable.ext.oStdClasses} object).\n\t\t * @namespace\n\t\t * @name DataTable.defaults.classes\n\t\t */\n\t\t\"oClasses\": {},\n\t\n\t\n\t\t/**\n\t\t * All strings that DataTables uses in the user interface that it creates\n\t\t * are defined in this object, allowing you to modified them individually or\n\t\t * completely replace them all as required.\n\t\t * @namespace\n\t\t * @name DataTable.defaults.language\n\t\t */\n\t\t\"oLanguage\": {\n\t\t\t/**\n\t\t\t * Strings that are used for WAI-ARIA labels and controls only (these are not\n\t\t\t * actually visible on the page, but will be read by screenreaders, and thus\n\t\t\t * must be internationalised as well).\n\t\t\t * @namespace\n\t\t\t * @name DataTable.defaults.language.aria\n\t\t\t */\n\t\t\t\"oAria\": {\n\t\t\t\t/**\n\t\t\t\t * ARIA label that is added to the table headers when the column may be\n\t\t\t\t * sorted ascending by activing the column (click or return when focused).\n\t\t\t\t * Note that the column header is prefixed to this string.\n\t\t\t\t * @type string\n\t\t\t\t * @default : activate to sort column ascending\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.aria.sortAscending\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"aria\": {\n\t\t\t\t * \"sortAscending\": \" - click/return to sort ascending\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sSortAscending\": \": activate to sort column ascending\",\n\t\n\t\t\t\t/**\n\t\t\t\t * ARIA label that is added to the table headers when the column may be\n\t\t\t\t * sorted descending by activing the column (click or return when focused).\n\t\t\t\t * Note that the column header is prefixed to this string.\n\t\t\t\t * @type string\n\t\t\t\t * @default : activate to sort column ascending\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.aria.sortDescending\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"aria\": {\n\t\t\t\t * \"sortDescending\": \" - click/return to sort descending\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sSortDescending\": \": activate to sort column descending\"\n\t\t\t},\n\t\n\t\t\t/**\n\t\t\t * Pagination string used by DataTables for the built-in pagination\n\t\t\t * control types.\n\t\t\t * @namespace\n\t\t\t * @name DataTable.defaults.language.paginate\n\t\t\t */\n\t\t\t\"oPaginate\": {\n\t\t\t\t/**\n\t\t\t\t * Text to use when using the 'full_numbers' type of pagination for the\n\t\t\t\t * button to take the user to the first page.\n\t\t\t\t * @type string\n\t\t\t\t * @default First\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.paginate.first\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"paginate\": {\n\t\t\t\t * \"first\": \"First page\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sFirst\": \"First\",\n\t\n\t\n\t\t\t\t/**\n\t\t\t\t * Text to use when using the 'full_numbers' type of pagination for the\n\t\t\t\t * button to take the user to the last page.\n\t\t\t\t * @type string\n\t\t\t\t * @default Last\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.paginate.last\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"paginate\": {\n\t\t\t\t * \"last\": \"Last page\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sLast\": \"Last\",\n\t\n\t\n\t\t\t\t/**\n\t\t\t\t * Text to use for the 'next' pagination button (to take the user to the\n\t\t\t\t * next page).\n\t\t\t\t * @type string\n\t\t\t\t * @default Next\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.paginate.next\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"paginate\": {\n\t\t\t\t * \"next\": \"Next page\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sNext\": \"Next\",\n\t\n\t\n\t\t\t\t/**\n\t\t\t\t * Text to use for the 'previous' pagination button (to take the user to\n\t\t\t\t * the previous page).\n\t\t\t\t * @type string\n\t\t\t\t * @default Previous\n\t\t\t\t *\n\t\t\t\t * @dtopt Language\n\t\t\t\t * @name DataTable.defaults.language.paginate.previous\n\t\t\t\t *\n\t\t\t\t * @example\n\t\t\t\t * $(document).ready( function() {\n\t\t\t\t * $('#example').dataTable( {\n\t\t\t\t * \"language\": {\n\t\t\t\t * \"paginate\": {\n\t\t\t\t * \"previous\": \"Previous page\"\n\t\t\t\t * }\n\t\t\t\t * }\n\t\t\t\t * } );\n\t\t\t\t * } );\n\t\t\t\t */\n\t\t\t\t\"sPrevious\": \"Previous\"\n\t\t\t},\n\t\n\t\t\t/**\n\t\t\t * This string is shown in preference to `zeroRecords` when the table is\n\t\t\t * empty of data (regardless of filtering). Note that this is an optional\n\t\t\t * parameter - if it is not given, the value of `zeroRecords` will be used\n\t\t\t * instead (either the default or given value).\n\t\t\t * @type string\n\t\t\t * @default No data available in table\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.emptyTable\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"emptyTable\": \"No data available in table\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sEmptyTable\": \"No data available in table\",\n\t\n\t\n\t\t\t/**\n\t\t\t * This string gives information to the end user about the information\n\t\t\t * that is current on display on the page. The following tokens can be\n\t\t\t * used in the string and will be dynamically replaced as the table\n\t\t\t * display updates. This tokens can be placed anywhere in the string, or\n\t\t\t * removed as needed by the language requires:\n\t\t\t *\n\t\t\t * * `\\_START\\_` - Display index of the first record on the current page\n\t\t\t * * `\\_END\\_` - Display index of the last record on the current page\n\t\t\t * * `\\_TOTAL\\_` - Number of records in the table after filtering\n\t\t\t * * `\\_MAX\\_` - Number of records in the table without filtering\n\t\t\t * * `\\_PAGE\\_` - Current page number\n\t\t\t * * `\\_PAGES\\_` - Total number of pages of data in the table\n\t\t\t *\n\t\t\t * @type string\n\t\t\t * @default Showing _START_ to _END_ of _TOTAL_ entries\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.info\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"info\": \"Showing page _PAGE_ of _PAGES_\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sInfo\": \"Showing _START_ to _END_ of _TOTAL_ entries\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Display information string for when the table is empty. Typically the\n\t\t\t * format of this string should match `info`.\n\t\t\t * @type string\n\t\t\t * @default Showing 0 to 0 of 0 entries\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.infoEmpty\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"infoEmpty\": \"No entries to show\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sInfoEmpty\": \"Showing 0 to 0 of 0 entries\",\n\t\n\t\n\t\t\t/**\n\t\t\t * When a user filters the information in a table, this string is appended\n\t\t\t * to the information (`info`) to give an idea of how strong the filtering\n\t\t\t * is. The variable _MAX_ is dynamically updated.\n\t\t\t * @type string\n\t\t\t * @default (filtered from _MAX_ total entries)\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.infoFiltered\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"infoFiltered\": \" - filtering from _MAX_ records\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sInfoFiltered\": \"(filtered from _MAX_ total entries)\",\n\t\n\t\n\t\t\t/**\n\t\t\t * If can be useful to append extra information to the info string at times,\n\t\t\t * and this variable does exactly that. This information will be appended to\n\t\t\t * the `info` (`infoEmpty` and `infoFiltered` in whatever combination they are\n\t\t\t * being used) at all times.\n\t\t\t * @type string\n\t\t\t * @default <i>Empty string</i>\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.infoPostFix\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"infoPostFix\": \"All records shown are derived from real information.\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sInfoPostFix\": \"\",\n\t\n\t\n\t\t\t/**\n\t\t\t * This decimal place operator is a little different from the other\n\t\t\t * language options since DataTables doesn't output floating point\n\t\t\t * numbers, so it won't ever use this for display of a number. Rather,\n\t\t\t * what this parameter does is modify the sort methods of the table so\n\t\t\t * that numbers which are in a format which has a character other than\n\t\t\t * a period (`.`) as a decimal place will be sorted numerically.\n\t\t\t *\n\t\t\t * Note that numbers with different decimal places cannot be shown in\n\t\t\t * the same table and still be sortable, the table must be consistent.\n\t\t\t * However, multiple different tables on the page can use different\n\t\t\t * decimal place characters.\n\t\t\t * @type string\n\t\t\t * @default \n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.decimal\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"decimal\": \",\"\n\t\t\t * \"thousands\": \".\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sDecimal\": \"\",\n\t\n\t\n\t\t\t/**\n\t\t\t * DataTables has a build in number formatter (`formatNumber`) which is\n\t\t\t * used to format large numbers that are used in the table information.\n\t\t\t * By default a comma is used, but this can be trivially changed to any\n\t\t\t * character you wish with this parameter.\n\t\t\t * @type string\n\t\t\t * @default ,\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.thousands\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"thousands\": \"'\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sThousands\": \",\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Detail the action that will be taken when the drop down menu for the\n\t\t\t * pagination length option is changed. The '_MENU_' variable is replaced\n\t\t\t * with a default select list of 10, 25, 50 and 100, and can be replaced\n\t\t\t * with a custom select box if required.\n\t\t\t * @type string\n\t\t\t * @default Show _MENU_ entries\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.lengthMenu\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Language change only\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"lengthMenu\": \"Display _MENU_ records\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Language and options change\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"lengthMenu\": 'Display <select>'+\n\t\t\t * '<option value=\"10\">10</option>'+\n\t\t\t * '<option value=\"20\">20</option>'+\n\t\t\t * '<option value=\"30\">30</option>'+\n\t\t\t * '<option value=\"40\">40</option>'+\n\t\t\t * '<option value=\"50\">50</option>'+\n\t\t\t * '<option value=\"-1\">All</option>'+\n\t\t\t * '</select> records'\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sLengthMenu\": \"Show _MENU_ entries\",\n\t\n\t\n\t\t\t/**\n\t\t\t * When using Ajax sourced data and during the first draw when DataTables is\n\t\t\t * gathering the data, this message is shown in an empty row in the table to\n\t\t\t * indicate to the end user the the data is being loaded. Note that this\n\t\t\t * parameter is not used when loading data by server-side processing, just\n\t\t\t * Ajax sourced data with client-side processing.\n\t\t\t * @type string\n\t\t\t * @default Loading...\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.loadingRecords\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"loadingRecords\": \"Please wait - loading...\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sLoadingRecords\": \"Loading...\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Text which is displayed when the table is processing a user action\n\t\t\t * (usually a sort command or similar).\n\t\t\t * @type string\n\t\t\t * @default Processing...\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.processing\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"processing\": \"DataTables is currently busy\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sProcessing\": \"Processing...\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Details the actions that will be taken when the user types into the\n\t\t\t * filtering input text box. The variable \"_INPUT_\", if used in the string,\n\t\t\t * is replaced with the HTML text box for the filtering input allowing\n\t\t\t * control over where it appears in the string. If \"_INPUT_\" is not given\n\t\t\t * then the input box is appended to the string automatically.\n\t\t\t * @type string\n\t\t\t * @default Search:\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.search\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Input text box will be appended at the end automatically\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"search\": \"Filter records:\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Specify where the filter should appear\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"search\": \"Apply filter _INPUT_ to table\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sSearch\": \"Search:\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Assign a `placeholder` attribute to the search `input` element\n\t\t\t * @type string\n\t\t\t * @default \n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.searchPlaceholder\n\t\t\t */\n\t\t\t\"sSearchPlaceholder\": \"\",\n\t\n\t\n\t\t\t/**\n\t\t\t * All of the language information can be stored in a file on the\n\t\t\t * server-side, which DataTables will look up if this parameter is passed.\n\t\t\t * It must store the URL of the language file, which is in a JSON format,\n\t\t\t * and the object has the same properties as the oLanguage object in the\n\t\t\t * initialiser object (i.e. the above parameters). Please refer to one of\n\t\t\t * the example language files to see how this works in action.\n\t\t\t * @type string\n\t\t\t * @default <i>Empty string - i.e. disabled</i>\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.url\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"url\": \"http://www.sprymedia.co.uk/dataTables/lang.txt\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sUrl\": \"\",\n\t\n\t\n\t\t\t/**\n\t\t\t * Text shown inside the table records when the is no information to be\n\t\t\t * displayed after filtering. `emptyTable` is shown when there is simply no\n\t\t\t * information in the table at all (regardless of filtering).\n\t\t\t * @type string\n\t\t\t * @default No matching records found\n\t\t\t *\n\t\t\t * @dtopt Language\n\t\t\t * @name DataTable.defaults.language.zeroRecords\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $(document).ready( function() {\n\t\t\t * $('#example').dataTable( {\n\t\t\t * \"language\": {\n\t\t\t * \"zeroRecords\": \"No records to display\"\n\t\t\t * }\n\t\t\t * } );\n\t\t\t * } );\n\t\t\t */\n\t\t\t\"sZeroRecords\": \"No matching records found\"\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * This parameter allows you to have define the global filtering state at\n\t\t * initialisation time. As an object the `search` parameter must be\n\t\t * defined, but all other parameters are optional. When `regex` is true,\n\t\t * the search string will be treated as a regular expression, when false\n\t\t * (default) it will be treated as a straight string. When `smart`\n\t\t * DataTables will use it's smart filtering methods (to word match at\n\t\t * any point in the data), when false this will not be done.\n\t\t * @namespace\n\t\t * @extends DataTable.models.oSearch\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.search\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"search\": {\"search\": \"Initial search\"}\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"oSearch\": $.extend( {}, DataTable.models.oSearch ),\n\t\n\t\n\t\t/**\n\t\t * __Deprecated__ The functionality provided by this parameter has now been\n\t\t * superseded by that provided through `ajax`, which should be used instead.\n\t\t *\n\t\t * By default DataTables will look for the property `data` (or `aaData` for\n\t\t * compatibility with DataTables 1.9-) when obtaining data from an Ajax\n\t\t * source or for server-side processing - this parameter allows that\n\t\t * property to be changed. You can use Javascript dotted object notation to\n\t\t * get a data source for multiple levels of nesting.\n\t\t * @type string\n\t\t * @default data\n\t\t *\n\t\t * @dtopt Options\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.ajaxDataProp\n\t\t *\n\t\t * @deprecated 1.10. Please use `ajax` for this functionality now.\n\t\t */\n\t\t\"sAjaxDataProp\": \"data\",\n\t\n\t\n\t\t/**\n\t\t * __Deprecated__ The functionality provided by this parameter has now been\n\t\t * superseded by that provided through `ajax`, which should be used instead.\n\t\t *\n\t\t * You can instruct DataTables to load data from an external\n\t\t * source using this parameter (use aData if you want to pass data in you\n\t\t * already have). Simply provide a url a JSON object can be obtained from.\n\t\t * @type string\n\t\t * @default null\n\t\t *\n\t\t * @dtopt Options\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.ajaxSource\n\t\t *\n\t\t * @deprecated 1.10. Please use `ajax` for this functionality now.\n\t\t */\n\t\t\"sAjaxSource\": null,\n\t\n\t\n\t\t/**\n\t\t * This initialisation variable allows you to specify exactly where in the\n\t\t * DOM you want DataTables to inject the various controls it adds to the page\n\t\t * (for example you might want the pagination controls at the top of the\n\t\t * table). DIV elements (with or without a custom class) can also be added to\n\t\t * aid styling. The follow syntax is used:\n\t\t * <ul>\n\t\t * <li>The following options are allowed:\n\t\t * <ul>\n\t\t * <li>'l' - Length changing</li>\n\t\t * <li>'f' - Filtering input</li>\n\t\t * <li>'t' - The table!</li>\n\t\t * <li>'i' - Information</li>\n\t\t * <li>'p' - Pagination</li>\n\t\t * <li>'r' - pRocessing</li>\n\t\t * </ul>\n\t\t * </li>\n\t\t * <li>The following constants are allowed:\n\t\t * <ul>\n\t\t * <li>'H' - jQueryUI theme \"header\" classes ('fg-toolbar ui-widget-header ui-corner-tl ui-corner-tr ui-helper-clearfix')</li>\n\t\t * <li>'F' - jQueryUI theme \"footer\" classes ('fg-toolbar ui-widget-header ui-corner-bl ui-corner-br ui-helper-clearfix')</li>\n\t\t * </ul>\n\t\t * </li>\n\t\t * <li>The following syntax is expected:\n\t\t * <ul>\n\t\t * <li>'<' and '>' - div elements</li>\n\t\t * <li>'<\"class\" and '>' - div with a class</li>\n\t\t * <li>'<\"#id\" and '>' - div with an ID</li>\n\t\t * </ul>\n\t\t * </li>\n\t\t * <li>Examples:\n\t\t * <ul>\n\t\t * <li>'<\"wrapper\"flipt>'</li>\n\t\t * <li>'<lf<t>ip>'</li>\n\t\t * </ul>\n\t\t * </li>\n\t\t * </ul>\n\t\t * @type string\n\t\t * @default lfrtip <i>(when `jQueryUI` is false)</i> <b>or</b>\n\t\t * <\"H\"lfr>t<\"F\"ip> <i>(when `jQueryUI` is true)</i>\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.dom\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"dom\": '<\"top\"i>rt<\"bottom\"flp><\"clear\">'\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sDom\": \"lfrtip\",\n\t\n\t\n\t\t/**\n\t\t * Search delay option. This will throttle full table searches that use the\n\t\t * DataTables provided search input element (it does not effect calls to\n\t\t * `dt-api search()`, providing a delay before the search is made.\n\t\t * @type integer\n\t\t * @default 0\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.searchDelay\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"searchDelay\": 200\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"searchDelay\": null,\n\t\n\t\n\t\t/**\n\t\t * DataTables features four different built-in options for the buttons to\n\t\t * display for pagination control:\n\t\t *\n\t\t * * `simple` - 'Previous' and 'Next' buttons only\n\t\t * * 'simple_numbers` - 'Previous' and 'Next' buttons, plus page numbers\n\t\t * * `full` - 'First', 'Previous', 'Next' and 'Last' buttons\n\t\t * * `full_numbers` - 'First', 'Previous', 'Next' and 'Last' buttons, plus\n\t\t * page numbers\n\t\t * \n\t\t * Further methods can be added using {@link DataTable.ext.oPagination}.\n\t\t * @type string\n\t\t * @default simple_numbers\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.pagingType\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"pagingType\": \"full_numbers\"\n\t\t * } );\n\t\t * } )\n\t\t */\n\t\t\"sPaginationType\": \"simple_numbers\",\n\t\n\t\n\t\t/**\n\t\t * Enable horizontal scrolling. When a table is too wide to fit into a\n\t\t * certain layout, or you have a large number of columns in the table, you\n\t\t * can enable x-scrolling to show the table in a viewport, which can be\n\t\t * scrolled. This property can be `true` which will allow the table to\n\t\t * scroll horizontally when needed, or any CSS unit, or a number (in which\n\t\t * case it will be treated as a pixel measurement). Setting as simply `true`\n\t\t * is recommended.\n\t\t * @type boolean|string\n\t\t * @default <i>blank string - i.e. disabled</i>\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.scrollX\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"scrollX\": true,\n\t\t * \"scrollCollapse\": true\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sScrollX\": \"\",\n\t\n\t\n\t\t/**\n\t\t * This property can be used to force a DataTable to use more width than it\n\t\t * might otherwise do when x-scrolling is enabled. For example if you have a\n\t\t * table which requires to be well spaced, this parameter is useful for\n\t\t * \"over-sizing\" the table, and thus forcing scrolling. This property can by\n\t\t * any CSS unit, or a number (in which case it will be treated as a pixel\n\t\t * measurement).\n\t\t * @type string\n\t\t * @default <i>blank string - i.e. disabled</i>\n\t\t *\n\t\t * @dtopt Options\n\t\t * @name DataTable.defaults.scrollXInner\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"scrollX\": \"100%\",\n\t\t * \"scrollXInner\": \"110%\"\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sScrollXInner\": \"\",\n\t\n\t\n\t\t/**\n\t\t * Enable vertical scrolling. Vertical scrolling will constrain the DataTable\n\t\t * to the given height, and enable scrolling for any data which overflows the\n\t\t * current viewport. This can be used as an alternative to paging to display\n\t\t * a lot of data in a small area (although paging and scrolling can both be\n\t\t * enabled at the same time). This property can be any CSS unit, or a number\n\t\t * (in which case it will be treated as a pixel measurement).\n\t\t * @type string\n\t\t * @default <i>blank string - i.e. disabled</i>\n\t\t *\n\t\t * @dtopt Features\n\t\t * @name DataTable.defaults.scrollY\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"scrollY\": \"200px\",\n\t\t * \"paginate\": false\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sScrollY\": \"\",\n\t\n\t\n\t\t/**\n\t\t * __Deprecated__ The functionality provided by this parameter has now been\n\t\t * superseded by that provided through `ajax`, which should be used instead.\n\t\t *\n\t\t * Set the HTTP method that is used to make the Ajax call for server-side\n\t\t * processing or Ajax sourced data.\n\t\t * @type string\n\t\t * @default GET\n\t\t *\n\t\t * @dtopt Options\n\t\t * @dtopt Server-side\n\t\t * @name DataTable.defaults.serverMethod\n\t\t *\n\t\t * @deprecated 1.10. Please use `ajax` for this functionality now.\n\t\t */\n\t\t\"sServerMethod\": \"GET\",\n\t\n\t\n\t\t/**\n\t\t * DataTables makes use of renderers when displaying HTML elements for\n\t\t * a table. These renderers can be added or modified by plug-ins to\n\t\t * generate suitable mark-up for a site. For example the Bootstrap\n\t\t * integration plug-in for DataTables uses a paging button renderer to\n\t\t * display pagination buttons in the mark-up required by Bootstrap.\n\t\t *\n\t\t * For further information about the renderers available see\n\t\t * DataTable.ext.renderer\n\t\t * @type string|object\n\t\t * @default null\n\t\t *\n\t\t * @name DataTable.defaults.renderer\n\t\t *\n\t\t */\n\t\t\"renderer\": null,\n\t\n\t\n\t\t/**\n\t\t * Set the data property name that DataTables should use to get a row's id\n\t\t * to set as the `id` property in the node.\n\t\t * @type string\n\t\t * @default DT_RowId\n\t\t *\n\t\t * @name DataTable.defaults.rowId\n\t\t */\n\t\t\"rowId\": \"DT_RowId\"\n\t};\n\t\n\t_fnHungarianMap( DataTable.defaults );\n\t\n\t\n\t\n\t/*\n\t * Developer note - See note in model.defaults.js about the use of Hungarian\n\t * notation and camel case.\n\t */\n\t\n\t/**\n\t * Column options that can be given to DataTables at initialisation time.\n\t * @namespace\n\t */\n\tDataTable.defaults.column = {\n\t\t/**\n\t\t * Define which column(s) an order will occur on for this column. This\n\t\t * allows a column's ordering to take multiple columns into account when\n\t\t * doing a sort or use the data from a different column. For example first\n\t\t * name / last name columns make sense to do a multi-column sort over the\n\t\t * two columns.\n\t\t * @type array|int\n\t\t * @default null <i>Takes the value of the column index automatically</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.orderData\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"orderData\": [ 0, 1 ], \"targets\": [ 0 ] },\n\t\t * { \"orderData\": [ 1, 0 ], \"targets\": [ 1 ] },\n\t\t * { \"orderData\": 2, \"targets\": [ 2 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"orderData\": [ 0, 1 ] },\n\t\t * { \"orderData\": [ 1, 0 ] },\n\t\t * { \"orderData\": 2 },\n\t\t * null,\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"aDataSort\": null,\n\t\t\"iDataSort\": -1,\n\t\n\t\n\t\t/**\n\t\t * You can control the default ordering direction, and even alter the\n\t\t * behaviour of the sort handler (i.e. only allow ascending ordering etc)\n\t\t * using this parameter.\n\t\t * @type array\n\t\t * @default [ 'asc', 'desc' ]\n\t\t *\n\t\t * @name DataTable.defaults.column.orderSequence\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"orderSequence\": [ \"asc\" ], \"targets\": [ 1 ] },\n\t\t * { \"orderSequence\": [ \"desc\", \"asc\", \"asc\" ], \"targets\": [ 2 ] },\n\t\t * { \"orderSequence\": [ \"desc\" ], \"targets\": [ 3 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * null,\n\t\t * { \"orderSequence\": [ \"asc\" ] },\n\t\t * { \"orderSequence\": [ \"desc\", \"asc\", \"asc\" ] },\n\t\t * { \"orderSequence\": [ \"desc\" ] },\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"asSorting\": [ 'asc', 'desc' ],\n\t\n\t\n\t\t/**\n\t\t * Enable or disable filtering on the data in this column.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @name DataTable.defaults.column.searchable\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"searchable\": false, \"targets\": [ 0 ] }\n\t\t * ] } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"searchable\": false },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ] } );\n\t\t * } );\n\t\t */\n\t\t\"bSearchable\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable ordering on this column.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @name DataTable.defaults.column.orderable\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"orderable\": false, \"targets\": [ 0 ] }\n\t\t * ] } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"orderable\": false },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ] } );\n\t\t * } );\n\t\t */\n\t\t\"bSortable\": true,\n\t\n\t\n\t\t/**\n\t\t * Enable or disable the display of this column.\n\t\t * @type boolean\n\t\t * @default true\n\t\t *\n\t\t * @name DataTable.defaults.column.visible\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"visible\": false, \"targets\": [ 0 ] }\n\t\t * ] } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"visible\": false },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ] } );\n\t\t * } );\n\t\t */\n\t\t\"bVisible\": true,\n\t\n\t\n\t\t/**\n\t\t * Developer definable function that is called whenever a cell is created (Ajax source,\n\t\t * etc) or processed for input (DOM source). This can be used as a compliment to mRender\n\t\t * allowing you to modify the DOM element (add background colour for example) when the\n\t\t * element is available.\n\t\t * @type function\n\t\t * @param {element} td The TD node that has been created\n\t\t * @param {*} cellData The Data for the cell\n\t\t * @param {array|object} rowData The data for the whole row\n\t\t * @param {int} row The row index for the aoData data store\n\t\t * @param {int} col The column index for aoColumns\n\t\t *\n\t\t * @name DataTable.defaults.column.createdCell\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [3],\n\t\t * \"createdCell\": function (td, cellData, rowData, row, col) {\n\t\t * if ( cellData == \"1.7\" ) {\n\t\t * $(td).css('color', 'blue')\n\t\t * }\n\t\t * }\n\t\t * } ]\n\t\t * });\n\t\t * } );\n\t\t */\n\t\t\"fnCreatedCell\": null,\n\t\n\t\n\t\t/**\n\t\t * This parameter has been replaced by `data` in DataTables to ensure naming\n\t\t * consistency. `dataProp` can still be used, as there is backwards\n\t\t * compatibility in DataTables for this option, but it is strongly\n\t\t * recommended that you use `data` in preference to `dataProp`.\n\t\t * @name DataTable.defaults.column.dataProp\n\t\t */\n\t\n\t\n\t\t/**\n\t\t * This property can be used to read data from any data source property,\n\t\t * including deeply nested objects / properties. `data` can be given in a\n\t\t * number of different ways which effect its behaviour:\n\t\t *\n\t\t * * `integer` - treated as an array index for the data source. This is the\n\t\t * default that DataTables uses (incrementally increased for each column).\n\t\t * * `string` - read an object property from the data source. There are\n\t\t * three 'special' options that can be used in the string to alter how\n\t\t * DataTables reads the data from the source object:\n\t\t * * `.` - Dotted Javascript notation. Just as you use a `.` in\n\t\t * Javascript to read from nested objects, so to can the options\n\t\t * specified in `data`. For example: `browser.version` or\n\t\t * `browser.name`. If your object parameter name contains a period, use\n\t\t * `\\\\` to escape it - i.e. `first\\\\.name`.\n\t\t * * `[]` - Array notation. DataTables can automatically combine data\n\t\t * from and array source, joining the data with the characters provided\n\t\t * between the two brackets. For example: `name[, ]` would provide a\n\t\t * comma-space separated list from the source array. If no characters\n\t\t * are provided between the brackets, the original array source is\n\t\t * returned.\n\t\t * * `()` - Function notation. Adding `()` to the end of a parameter will\n\t\t * execute a function of the name given. For example: `browser()` for a\n\t\t * simple function on the data source, `browser.version()` for a\n\t\t * function in a nested property or even `browser().version` to get an\n\t\t * object property if the function called returns an object. Note that\n\t\t * function notation is recommended for use in `render` rather than\n\t\t * `data` as it is much simpler to use as a renderer.\n\t\t * * `null` - use the original data source for the row rather than plucking\n\t\t * data directly from it. This action has effects on two other\n\t\t * initialisation options:\n\t\t * * `defaultContent` - When null is given as the `data` option and\n\t\t * `defaultContent` is specified for the column, the value defined by\n\t\t * `defaultContent` will be used for the cell.\n\t\t * * `render` - When null is used for the `data` option and the `render`\n\t\t * option is specified for the column, the whole data source for the\n\t\t * row is used for the renderer.\n\t\t * * `function` - the function given will be executed whenever DataTables\n\t\t * needs to set or get the data for a cell in the column. The function\n\t\t * takes three parameters:\n\t\t * * Parameters:\n\t\t * * `{array|object}` The data source for the row\n\t\t * * `{string}` The type call data requested - this will be 'set' when\n\t\t * setting data or 'filter', 'display', 'type', 'sort' or undefined\n\t\t * when gathering data. Note that when `undefined` is given for the\n\t\t * type DataTables expects to get the raw data for the object back<\n\t\t * * `{*}` Data to set when the second parameter is 'set'.\n\t\t * * Return:\n\t\t * * The return value from the function is not required when 'set' is\n\t\t * the type of call, but otherwise the return is what will be used\n\t\t * for the data requested.\n\t\t *\n\t\t * Note that `data` is a getter and setter option. If you just require\n\t\t * formatting of data for output, you will likely want to use `render` which\n\t\t * is simply a getter and thus simpler to use.\n\t\t *\n\t\t * Note that prior to DataTables 1.9.2 `data` was called `mDataProp`. The\n\t\t * name change reflects the flexibility of this property and is consistent\n\t\t * with the naming of mRender. If 'mDataProp' is given, then it will still\n\t\t * be used by DataTables, as it automatically maps the old name to the new\n\t\t * if required.\n\t\t *\n\t\t * @type string|int|function|null\n\t\t * @default null <i>Use automatically calculated column index</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.data\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Read table data from objects\n\t\t * // JSON structure for each row:\n\t\t * // {\n\t\t * // \"engine\": {value},\n\t\t * // \"browser\": {value},\n\t\t * // \"platform\": {value},\n\t\t * // \"version\": {value},\n\t\t * // \"grade\": {value}\n\t\t * // }\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"ajaxSource\": \"sources/objects.txt\",\n\t\t * \"columns\": [\n\t\t * { \"data\": \"engine\" },\n\t\t * { \"data\": \"browser\" },\n\t\t * { \"data\": \"platform\" },\n\t\t * { \"data\": \"version\" },\n\t\t * { \"data\": \"grade\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Read information from deeply nested objects\n\t\t * // JSON structure for each row:\n\t\t * // {\n\t\t * // \"engine\": {value},\n\t\t * // \"browser\": {value},\n\t\t * // \"platform\": {\n\t\t * // \"inner\": {value}\n\t\t * // },\n\t\t * // \"details\": [\n\t\t * // {value}, {value}\n\t\t * // ]\n\t\t * // }\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"ajaxSource\": \"sources/deep.txt\",\n\t\t * \"columns\": [\n\t\t * { \"data\": \"engine\" },\n\t\t * { \"data\": \"browser\" },\n\t\t * { \"data\": \"platform.inner\" },\n\t\t * { \"data\": \"platform.details.0\" },\n\t\t * { \"data\": \"platform.details.1\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `data` as a function to provide different information for\n\t\t * // sorting, filtering and display. In this case, currency (price)\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": function ( source, type, val ) {\n\t\t * if (type === 'set') {\n\t\t * source.price = val;\n\t\t * // Store the computed dislay and filter values for efficiency\n\t\t * source.price_display = val==\"\" ? \"\" : \"$\"+numberFormat(val);\n\t\t * source.price_filter = val==\"\" ? \"\" : \"$\"+numberFormat(val)+\" \"+val;\n\t\t * return;\n\t\t * }\n\t\t * else if (type === 'display') {\n\t\t * return source.price_display;\n\t\t * }\n\t\t * else if (type === 'filter') {\n\t\t * return source.price_filter;\n\t\t * }\n\t\t * // 'sort', 'type' and undefined all just use the integer\n\t\t * return source.price;\n\t\t * }\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using default content\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": null,\n\t\t * \"defaultContent\": \"Click to edit\"\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using array notation - outputting a list from an array\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": \"name[, ]\"\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t */\n\t\t\"mData\": null,\n\t\n\t\n\t\t/**\n\t\t * This property is the rendering partner to `data` and it is suggested that\n\t\t * when you want to manipulate data for display (including filtering,\n\t\t * sorting etc) without altering the underlying data for the table, use this\n\t\t * property. `render` can be considered to be the the read only companion to\n\t\t * `data` which is read / write (then as such more complex). Like `data`\n\t\t * this option can be given in a number of different ways to effect its\n\t\t * behaviour:\n\t\t *\n\t\t * * `integer` - treated as an array index for the data source. This is the\n\t\t * default that DataTables uses (incrementally increased for each column).\n\t\t * * `string` - read an object property from the data source. There are\n\t\t * three 'special' options that can be used in the string to alter how\n\t\t * DataTables reads the data from the source object:\n\t\t * * `.` - Dotted Javascript notation. Just as you use a `.` in\n\t\t * Javascript to read from nested objects, so to can the options\n\t\t * specified in `data`. For example: `browser.version` or\n\t\t * `browser.name`. If your object parameter name contains a period, use\n\t\t * `\\\\` to escape it - i.e. `first\\\\.name`.\n\t\t * * `[]` - Array notation. DataTables can automatically combine data\n\t\t * from and array source, joining the data with the characters provided\n\t\t * between the two brackets. For example: `name[, ]` would provide a\n\t\t * comma-space separated list from the source array. If no characters\n\t\t * are provided between the brackets, the original array source is\n\t\t * returned.\n\t\t * * `()` - Function notation. Adding `()` to the end of a parameter will\n\t\t * execute a function of the name given. For example: `browser()` for a\n\t\t * simple function on the data source, `browser.version()` for a\n\t\t * function in a nested property or even `browser().version` to get an\n\t\t * object property if the function called returns an object.\n\t\t * * `object` - use different data for the different data types requested by\n\t\t * DataTables ('filter', 'display', 'type' or 'sort'). The property names\n\t\t * of the object is the data type the property refers to and the value can\n\t\t * defined using an integer, string or function using the same rules as\n\t\t * `render` normally does. Note that an `_` option _must_ be specified.\n\t\t * This is the default value to use if you haven't specified a value for\n\t\t * the data type requested by DataTables.\n\t\t * * `function` - the function given will be executed whenever DataTables\n\t\t * needs to set or get the data for a cell in the column. The function\n\t\t * takes three parameters:\n\t\t * * Parameters:\n\t\t * * {array|object} The data source for the row (based on `data`)\n\t\t * * {string} The type call data requested - this will be 'filter',\n\t\t * 'display', 'type' or 'sort'.\n\t\t * * {array|object} The full data source for the row (not based on\n\t\t * `data`)\n\t\t * * Return:\n\t\t * * The return value from the function is what will be used for the\n\t\t * data requested.\n\t\t *\n\t\t * @type string|int|function|object|null\n\t\t * @default null Use the data source value.\n\t\t *\n\t\t * @name DataTable.defaults.column.render\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Create a comma separated list from an array of objects\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"ajaxSource\": \"sources/deep.txt\",\n\t\t * \"columns\": [\n\t\t * { \"data\": \"engine\" },\n\t\t * { \"data\": \"browser\" },\n\t\t * {\n\t\t * \"data\": \"platform\",\n\t\t * \"render\": \"[, ].name\"\n\t\t * }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Execute a function to obtain data\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": null, // Use the full data source object for the renderer's source\n\t\t * \"render\": \"browserName()\"\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // As an object, extracting different data for the different types\n\t\t * // This would be used with a data source such as:\n\t\t * // { \"phone\": 5552368, \"phone_filter\": \"5552368 555-2368\", \"phone_display\": \"555-2368\" }\n\t\t * // Here the `phone` integer is used for sorting and type detection, while `phone_filter`\n\t\t * // (which has both forms) is used for filtering for if a user inputs either format, while\n\t\t * // the formatted phone number is the one that is shown in the table.\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": null, // Use the full data source object for the renderer's source\n\t\t * \"render\": {\n\t\t * \"_\": \"phone\",\n\t\t * \"filter\": \"phone_filter\",\n\t\t * \"display\": \"phone_display\"\n\t\t * }\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Use as a function to create a link from the data source\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"data\": \"download_link\",\n\t\t * \"render\": function ( data, type, full ) {\n\t\t * return '<a href=\"'+data+'\">Download</a>';\n\t\t * }\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"mRender\": null,\n\t\n\t\n\t\t/**\n\t\t * Change the cell type created for the column - either TD cells or TH cells. This\n\t\t * can be useful as TH cells have semantic meaning in the table body, allowing them\n\t\t * to act as a header for a row (you may wish to add scope='row' to the TH elements).\n\t\t * @type string\n\t\t * @default td\n\t\t *\n\t\t * @name DataTable.defaults.column.cellType\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Make the first column use TH cells\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [ {\n\t\t * \"targets\": [ 0 ],\n\t\t * \"cellType\": \"th\"\n\t\t * } ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sCellType\": \"td\",\n\t\n\t\n\t\t/**\n\t\t * Class to give to each cell in this column.\n\t\t * @type string\n\t\t * @default <i>Empty string</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.class\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"class\": \"my_class\", \"targets\": [ 0 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"class\": \"my_class\" },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sClass\": \"\",\n\t\n\t\t/**\n\t\t * When DataTables calculates the column widths to assign to each column,\n\t\t * it finds the longest string in each column and then constructs a\n\t\t * temporary table and reads the widths from that. The problem with this\n\t\t * is that \"mmm\" is much wider then \"iiii\", but the latter is a longer\n\t\t * string - thus the calculation can go wrong (doing it properly and putting\n\t\t * it into an DOM object and measuring that is horribly(!) slow). Thus as\n\t\t * a \"work around\" we provide this option. It will append its value to the\n\t\t * text that is found to be the longest string for the column - i.e. padding.\n\t\t * Generally you shouldn't need this!\n\t\t * @type string\n\t\t * @default <i>Empty string<i>\n\t\t *\n\t\t * @name DataTable.defaults.column.contentPadding\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * {\n\t\t * \"contentPadding\": \"mmm\"\n\t\t * }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sContentPadding\": \"\",\n\t\n\t\n\t\t/**\n\t\t * Allows a default value to be given for a column's data, and will be used\n\t\t * whenever a null data source is encountered (this can be because `data`\n\t\t * is set to null, or because the data source itself is null).\n\t\t * @type string\n\t\t * @default null\n\t\t *\n\t\t * @name DataTable.defaults.column.defaultContent\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * {\n\t\t * \"data\": null,\n\t\t * \"defaultContent\": \"Edit\",\n\t\t * \"targets\": [ -1 ]\n\t\t * }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * {\n\t\t * \"data\": null,\n\t\t * \"defaultContent\": \"Edit\"\n\t\t * }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sDefaultContent\": null,\n\t\n\t\n\t\t/**\n\t\t * This parameter is only used in DataTables' server-side processing. It can\n\t\t * be exceptionally useful to know what columns are being displayed on the\n\t\t * client side, and to map these to database fields. When defined, the names\n\t\t * also allow DataTables to reorder information from the server if it comes\n\t\t * back in an unexpected order (i.e. if you switch your columns around on the\n\t\t * client-side, your server-side code does not also need updating).\n\t\t * @type string\n\t\t * @default <i>Empty string</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.name\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"name\": \"engine\", \"targets\": [ 0 ] },\n\t\t * { \"name\": \"browser\", \"targets\": [ 1 ] },\n\t\t * { \"name\": \"platform\", \"targets\": [ 2 ] },\n\t\t * { \"name\": \"version\", \"targets\": [ 3 ] },\n\t\t * { \"name\": \"grade\", \"targets\": [ 4 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"name\": \"engine\" },\n\t\t * { \"name\": \"browser\" },\n\t\t * { \"name\": \"platform\" },\n\t\t * { \"name\": \"version\" },\n\t\t * { \"name\": \"grade\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sName\": \"\",\n\t\n\t\n\t\t/**\n\t\t * Defines a data source type for the ordering which can be used to read\n\t\t * real-time information from the table (updating the internally cached\n\t\t * version) prior to ordering. This allows ordering to occur on user\n\t\t * editable elements such as form inputs.\n\t\t * @type string\n\t\t * @default std\n\t\t *\n\t\t * @name DataTable.defaults.column.orderDataType\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"orderDataType\": \"dom-text\", \"targets\": [ 2, 3 ] },\n\t\t * { \"type\": \"numeric\", \"targets\": [ 3 ] },\n\t\t * { \"orderDataType\": \"dom-select\", \"targets\": [ 4 ] },\n\t\t * { \"orderDataType\": \"dom-checkbox\", \"targets\": [ 5 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * null,\n\t\t * null,\n\t\t * { \"orderDataType\": \"dom-text\" },\n\t\t * { \"orderDataType\": \"dom-text\", \"type\": \"numeric\" },\n\t\t * { \"orderDataType\": \"dom-select\" },\n\t\t * { \"orderDataType\": \"dom-checkbox\" }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sSortDataType\": \"std\",\n\t\n\t\n\t\t/**\n\t\t * The title of this column.\n\t\t * @type string\n\t\t * @default null <i>Derived from the 'TH' value for this column in the\n\t\t * original HTML table.</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.title\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"title\": \"My column title\", \"targets\": [ 0 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"title\": \"My column title\" },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sTitle\": null,\n\t\n\t\n\t\t/**\n\t\t * The type allows you to specify how the data for this column will be\n\t\t * ordered. Four types (string, numeric, date and html (which will strip\n\t\t * HTML tags before ordering)) are currently available. Note that only date\n\t\t * formats understood by Javascript's Date() object will be accepted as type\n\t\t * date. For example: \"Mar 26, 2008 5:03 PM\". May take the values: 'string',\n\t\t * 'numeric', 'date' or 'html' (by default). Further types can be adding\n\t\t * through plug-ins.\n\t\t * @type string\n\t\t * @default null <i>Auto-detected from raw data</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.type\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"type\": \"html\", \"targets\": [ 0 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"type\": \"html\" },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sType\": null,\n\t\n\t\n\t\t/**\n\t\t * Defining the width of the column, this parameter may take any CSS value\n\t\t * (3em, 20px etc). DataTables applies 'smart' widths to columns which have not\n\t\t * been given a specific width through this interface ensuring that the table\n\t\t * remains readable.\n\t\t * @type string\n\t\t * @default null <i>Automatic</i>\n\t\t *\n\t\t * @name DataTable.defaults.column.width\n\t\t * @dtopt Columns\n\t\t *\n\t\t * @example\n\t\t * // Using `columnDefs`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columnDefs\": [\n\t\t * { \"width\": \"20%\", \"targets\": [ 0 ] }\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t *\n\t\t * @example\n\t\t * // Using `columns`\n\t\t * $(document).ready( function() {\n\t\t * $('#example').dataTable( {\n\t\t * \"columns\": [\n\t\t * { \"width\": \"20%\" },\n\t\t * null,\n\t\t * null,\n\t\t * null,\n\t\t * null\n\t\t * ]\n\t\t * } );\n\t\t * } );\n\t\t */\n\t\t\"sWidth\": null\n\t};\n\t\n\t_fnHungarianMap( DataTable.defaults.column );\n\t\n\t\n\t\n\t/**\n\t * DataTables settings object - this holds all the information needed for a\n\t * given table, including configuration, data and current application of the\n\t * table options. DataTables does not have a single instance for each DataTable\n\t * with the settings attached to that instance, but rather instances of the\n\t * DataTable \"class\" are created on-the-fly as needed (typically by a\n\t * $().dataTable() call) and the settings object is then applied to that\n\t * instance.\n\t *\n\t * Note that this object is related to {@link DataTable.defaults} but this\n\t * one is the internal data store for DataTables's cache of columns. It should\n\t * NOT be manipulated outside of DataTables. Any configuration should be done\n\t * through the initialisation options.\n\t * @namespace\n\t * @todo Really should attach the settings object to individual instances so we\n\t * don't need to create new instances on each $().dataTable() call (if the\n\t * table already exists). It would also save passing oSettings around and\n\t * into every single function. However, this is a very significant\n\t * architecture change for DataTables and will almost certainly break\n\t * backwards compatibility with older installations. This is something that\n\t * will be done in 2.0.\n\t */\n\tDataTable.models.oSettings = {\n\t\t/**\n\t\t * Primary features of DataTables and their enablement state.\n\t\t * @namespace\n\t\t */\n\t\t\"oFeatures\": {\n\t\n\t\t\t/**\n\t\t\t * Flag to say if DataTables should automatically try to calculate the\n\t\t\t * optimum table and columns widths (true) or not (false).\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bAutoWidth\": null,\n\t\n\t\t\t/**\n\t\t\t * Delay the creation of TR and TD elements until they are actually\n\t\t\t * needed by a driven page draw. This can give a significant speed\n\t\t\t * increase for Ajax source and Javascript source data, but makes no\n\t\t\t * difference at all fro DOM and server-side processing tables.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bDeferRender\": null,\n\t\n\t\t\t/**\n\t\t\t * Enable filtering on the table or not. Note that if this is disabled\n\t\t\t * then there is no filtering at all on the table, including fnFilter.\n\t\t\t * To just remove the filtering input use sDom and remove the 'f' option.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bFilter\": null,\n\t\n\t\t\t/**\n\t\t\t * Table information element (the 'Showing x of y records' div) enable\n\t\t\t * flag.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bInfo\": null,\n\t\n\t\t\t/**\n\t\t\t * Present a user control allowing the end user to change the page size\n\t\t\t * when pagination is enabled.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bLengthChange\": null,\n\t\n\t\t\t/**\n\t\t\t * Pagination enabled or not. Note that if this is disabled then length\n\t\t\t * changing must also be disabled.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bPaginate\": null,\n\t\n\t\t\t/**\n\t\t\t * Processing indicator enable flag whenever DataTables is enacting a\n\t\t\t * user request - typically an Ajax request for server-side processing.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bProcessing\": null,\n\t\n\t\t\t/**\n\t\t\t * Server-side processing enabled flag - when enabled DataTables will\n\t\t\t * get all data from the server for every draw - there is no filtering,\n\t\t\t * sorting or paging done on the client-side.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bServerSide\": null,\n\t\n\t\t\t/**\n\t\t\t * Sorting enablement flag.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bSort\": null,\n\t\n\t\t\t/**\n\t\t\t * Multi-column sorting\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bSortMulti\": null,\n\t\n\t\t\t/**\n\t\t\t * Apply a class to the columns which are being sorted to provide a\n\t\t\t * visual highlight or not. This can slow things down when enabled since\n\t\t\t * there is a lot of DOM interaction.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bSortClasses\": null,\n\t\n\t\t\t/**\n\t\t\t * State saving enablement flag.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bStateSave\": null\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Scrolling settings for a table.\n\t\t * @namespace\n\t\t */\n\t\t\"oScroll\": {\n\t\t\t/**\n\t\t\t * When the table is shorter in height than sScrollY, collapse the\n\t\t\t * table container down to the height of the table (when true).\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type boolean\n\t\t\t */\n\t\t\t\"bCollapse\": null,\n\t\n\t\t\t/**\n\t\t\t * Width of the scrollbar for the web-browser's platform. Calculated\n\t\t\t * during table initialisation.\n\t\t\t * @type int\n\t\t\t * @default 0\n\t\t\t */\n\t\t\t\"iBarWidth\": 0,\n\t\n\t\t\t/**\n\t\t\t * Viewport width for horizontal scrolling. Horizontal scrolling is\n\t\t\t * disabled if an empty string.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type string\n\t\t\t */\n\t\t\t\"sX\": null,\n\t\n\t\t\t/**\n\t\t\t * Width to expand the table to when using x-scrolling. Typically you\n\t\t\t * should not need to use this.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type string\n\t\t\t * @deprecated\n\t\t\t */\n\t\t\t\"sXInner\": null,\n\t\n\t\t\t/**\n\t\t\t * Viewport height for vertical scrolling. Vertical scrolling is disabled\n\t\t\t * if an empty string.\n\t\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t\t * set a default use {@link DataTable.defaults}.\n\t\t\t * @type string\n\t\t\t */\n\t\t\t\"sY\": null\n\t\t},\n\t\n\t\t/**\n\t\t * Language information for the table.\n\t\t * @namespace\n\t\t * @extends DataTable.defaults.oLanguage\n\t\t */\n\t\t\"oLanguage\": {\n\t\t\t/**\n\t\t\t * Information callback function. See\n\t\t\t * {@link DataTable.defaults.fnInfoCallback}\n\t\t\t * @type function\n\t\t\t * @default null\n\t\t\t */\n\t\t\t\"fnInfoCallback\": null\n\t\t},\n\t\n\t\t/**\n\t\t * Browser support parameters\n\t\t * @namespace\n\t\t */\n\t\t\"oBrowser\": {\n\t\t\t/**\n\t\t\t * Indicate if the browser incorrectly calculates width:100% inside a\n\t\t\t * scrolling element (IE6/7)\n\t\t\t * @type boolean\n\t\t\t * @default false\n\t\t\t */\n\t\t\t\"bScrollOversize\": false,\n\t\n\t\t\t/**\n\t\t\t * Determine if the vertical scrollbar is on the right or left of the\n\t\t\t * scrolling container - needed for rtl language layout, although not\n\t\t\t * all browsers move the scrollbar (Safari).\n\t\t\t * @type boolean\n\t\t\t * @default false\n\t\t\t */\n\t\t\t\"bScrollbarLeft\": false,\n\t\n\t\t\t/**\n\t\t\t * Flag for if `getBoundingClientRect` is fully supported or not\n\t\t\t * @type boolean\n\t\t\t * @default false\n\t\t\t */\n\t\t\t\"bBounding\": false,\n\t\n\t\t\t/**\n\t\t\t * Browser scrollbar width\n\t\t\t * @type integer\n\t\t\t * @default 0\n\t\t\t */\n\t\t\t\"barWidth\": 0\n\t\t},\n\t\n\t\n\t\t\"ajax\": null,\n\t\n\t\n\t\t/**\n\t\t * Array referencing the nodes which are used for the features. The\n\t\t * parameters of this object match what is allowed by sDom - i.e.\n\t\t * <ul>\n\t\t * <li>'l' - Length changing</li>\n\t\t * <li>'f' - Filtering input</li>\n\t\t * <li>'t' - The table!</li>\n\t\t * <li>'i' - Information</li>\n\t\t * <li>'p' - Pagination</li>\n\t\t * <li>'r' - pRocessing</li>\n\t\t * </ul>\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aanFeatures\": [],\n\t\n\t\t/**\n\t\t * Store data information - see {@link DataTable.models.oRow} for detailed\n\t\t * information.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoData\": [],\n\t\n\t\t/**\n\t\t * Array of indexes which are in the current display (after filtering etc)\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aiDisplay\": [],\n\t\n\t\t/**\n\t\t * Array of indexes for display - no filtering\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aiDisplayMaster\": [],\n\t\n\t\t/**\n\t\t * Map of row ids to data indexes\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\t\"aIds\": {},\n\t\n\t\t/**\n\t\t * Store information about each column that is in use\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoColumns\": [],\n\t\n\t\t/**\n\t\t * Store information about the table's header\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoHeader\": [],\n\t\n\t\t/**\n\t\t * Store information about the table's footer\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoFooter\": [],\n\t\n\t\t/**\n\t\t * Store the applied global search information in case we want to force a\n\t\t * research or compare the old search to a new one.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @namespace\n\t\t * @extends DataTable.models.oSearch\n\t\t */\n\t\t\"oPreviousSearch\": {},\n\t\n\t\t/**\n\t\t * Store the applied search for each column - see\n\t\t * {@link DataTable.models.oSearch} for the format that is used for the\n\t\t * filtering information for each column.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoPreSearchCols\": [],\n\t\n\t\t/**\n\t\t * Sorting that is applied to the table. Note that the inner arrays are\n\t\t * used in the following manner:\n\t\t * <ul>\n\t\t * <li>Index 0 - column number</li>\n\t\t * <li>Index 1 - current sorting direction</li>\n\t\t * </ul>\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type array\n\t\t * @todo These inner arrays should really be objects\n\t\t */\n\t\t\"aaSorting\": null,\n\t\n\t\t/**\n\t\t * Sorting that is always applied to the table (i.e. prefixed in front of\n\t\t * aaSorting).\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aaSortingFixed\": [],\n\t\n\t\t/**\n\t\t * Classes to use for the striping of a table.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"asStripeClasses\": null,\n\t\n\t\t/**\n\t\t * If restoring a table - we should restore its striping classes as well\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"asDestroyStripes\": [],\n\t\n\t\t/**\n\t\t * If restoring a table - we should restore its width\n\t\t * @type int\n\t\t * @default 0\n\t\t */\n\t\t\"sDestroyWidth\": 0,\n\t\n\t\t/**\n\t\t * Callback functions array for every time a row is inserted (i.e. on a draw).\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoRowCallback\": [],\n\t\n\t\t/**\n\t\t * Callback functions for the header on each draw.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoHeaderCallback\": [],\n\t\n\t\t/**\n\t\t * Callback function for the footer on each draw.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoFooterCallback\": [],\n\t\n\t\t/**\n\t\t * Array of callback functions for draw callback functions\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoDrawCallback\": [],\n\t\n\t\t/**\n\t\t * Array of callback functions for row created function\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoRowCreatedCallback\": [],\n\t\n\t\t/**\n\t\t * Callback functions for just before the table is redrawn. A return of\n\t\t * false will be used to cancel the draw.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoPreDrawCallback\": [],\n\t\n\t\t/**\n\t\t * Callback functions for when the table has been initialised.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoInitComplete\": [],\n\t\n\t\n\t\t/**\n\t\t * Callbacks for modifying the settings to be stored for state saving, prior to\n\t\t * saving state.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoStateSaveParams\": [],\n\t\n\t\t/**\n\t\t * Callbacks for modifying the settings that have been stored for state saving\n\t\t * prior to using the stored values to restore the state.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoStateLoadParams\": [],\n\t\n\t\t/**\n\t\t * Callbacks for operating on the settings object once the saved state has been\n\t\t * loaded\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoStateLoaded\": [],\n\t\n\t\t/**\n\t\t * Cache the table ID for quick access\n\t\t * @type string\n\t\t * @default <i>Empty string</i>\n\t\t */\n\t\t\"sTableId\": \"\",\n\t\n\t\t/**\n\t\t * The TABLE node for the main table\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTable\": null,\n\t\n\t\t/**\n\t\t * Permanent ref to the thead element\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTHead\": null,\n\t\n\t\t/**\n\t\t * Permanent ref to the tfoot element - if it exists\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTFoot\": null,\n\t\n\t\t/**\n\t\t * Permanent ref to the tbody element\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTBody\": null,\n\t\n\t\t/**\n\t\t * Cache the wrapper node (contains all DataTables controlled elements)\n\t\t * @type node\n\t\t * @default null\n\t\t */\n\t\t\"nTableWrapper\": null,\n\t\n\t\t/**\n\t\t * Indicate if when using server-side processing the loading of data\n\t\t * should be deferred until the second draw.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type boolean\n\t\t * @default false\n\t\t */\n\t\t\"bDeferLoading\": false,\n\t\n\t\t/**\n\t\t * Indicate if all required information has been read in\n\t\t * @type boolean\n\t\t * @default false\n\t\t */\n\t\t\"bInitialised\": false,\n\t\n\t\t/**\n\t\t * Information about open rows. Each object in the array has the parameters\n\t\t * 'nTr' and 'nParent'\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoOpenRows\": [],\n\t\n\t\t/**\n\t\t * Dictate the positioning of DataTables' control elements - see\n\t\t * {@link DataTable.model.oInit.sDom}.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sDom\": null,\n\t\n\t\t/**\n\t\t * Search delay (in mS)\n\t\t * @type integer\n\t\t * @default null\n\t\t */\n\t\t\"searchDelay\": null,\n\t\n\t\t/**\n\t\t * Which type of pagination should be used.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type string\n\t\t * @default two_button\n\t\t */\n\t\t\"sPaginationType\": \"two_button\",\n\t\n\t\t/**\n\t\t * The state duration (for `stateSave`) in seconds.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type int\n\t\t * @default 0\n\t\t */\n\t\t\"iStateDuration\": 0,\n\t\n\t\t/**\n\t\t * Array of callback functions for state saving. Each array element is an\n\t\t * object with the following parameters:\n\t\t * <ul>\n\t\t * <li>function:fn - function to call. Takes two parameters, oSettings\n\t\t * and the JSON string to save that has been thus far created. Returns\n\t\t * a JSON string to be inserted into a json object\n\t\t * (i.e. '\"param\": [ 0, 1, 2]')</li>\n\t\t * <li>string:sName - name of callback</li>\n\t\t * </ul>\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoStateSave\": [],\n\t\n\t\t/**\n\t\t * Array of callback functions for state loading. Each array element is an\n\t\t * object with the following parameters:\n\t\t * <ul>\n\t\t * <li>function:fn - function to call. Takes two parameters, oSettings\n\t\t * and the object stored. May return false to cancel state loading</li>\n\t\t * <li>string:sName - name of callback</li>\n\t\t * </ul>\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoStateLoad\": [],\n\t\n\t\t/**\n\t\t * State that was saved. Useful for back reference\n\t\t * @type object\n\t\t * @default null\n\t\t */\n\t\t\"oSavedState\": null,\n\t\n\t\t/**\n\t\t * State that was loaded. Useful for back reference\n\t\t * @type object\n\t\t * @default null\n\t\t */\n\t\t\"oLoadedState\": null,\n\t\n\t\t/**\n\t\t * Source url for AJAX data for the table.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sAjaxSource\": null,\n\t\n\t\t/**\n\t\t * Property from a given object from which to read the table data from. This\n\t\t * can be an empty string (when not server-side processing), in which case\n\t\t * it is assumed an an array is given directly.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type string\n\t\t */\n\t\t\"sAjaxDataProp\": null,\n\t\n\t\t/**\n\t\t * Note if draw should be blocked while getting data\n\t\t * @type boolean\n\t\t * @default true\n\t\t */\n\t\t\"bAjaxDataGet\": true,\n\t\n\t\t/**\n\t\t * The last jQuery XHR object that was used for server-side data gathering.\n\t\t * This can be used for working with the XHR information in one of the\n\t\t * callbacks\n\t\t * @type object\n\t\t * @default null\n\t\t */\n\t\t\"jqXHR\": null,\n\t\n\t\t/**\n\t\t * JSON returned from the server in the last Ajax request\n\t\t * @type object\n\t\t * @default undefined\n\t\t */\n\t\t\"json\": undefined,\n\t\n\t\t/**\n\t\t * Data submitted as part of the last Ajax request\n\t\t * @type object\n\t\t * @default undefined\n\t\t */\n\t\t\"oAjaxData\": undefined,\n\t\n\t\t/**\n\t\t * Function to get the server-side data.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type function\n\t\t */\n\t\t\"fnServerData\": null,\n\t\n\t\t/**\n\t\t * Functions which are called prior to sending an Ajax request so extra\n\t\t * parameters can easily be sent to the server\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoServerParams\": [],\n\t\n\t\t/**\n\t\t * Send the XHR HTTP method - GET or POST (could be PUT or DELETE if\n\t\t * required).\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type string\n\t\t */\n\t\t\"sServerMethod\": null,\n\t\n\t\t/**\n\t\t * Format numbers for display.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type function\n\t\t */\n\t\t\"fnFormatNumber\": null,\n\t\n\t\t/**\n\t\t * List of options that can be used for the user selectable length menu.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aLengthMenu\": null,\n\t\n\t\t/**\n\t\t * Counter for the draws that the table does. Also used as a tracker for\n\t\t * server-side processing\n\t\t * @type int\n\t\t * @default 0\n\t\t */\n\t\t\"iDraw\": 0,\n\t\n\t\t/**\n\t\t * Indicate if a redraw is being done - useful for Ajax\n\t\t * @type boolean\n\t\t * @default false\n\t\t */\n\t\t\"bDrawing\": false,\n\t\n\t\t/**\n\t\t * Draw index (iDraw) of the last error when parsing the returned data\n\t\t * @type int\n\t\t * @default -1\n\t\t */\n\t\t\"iDrawError\": -1,\n\t\n\t\t/**\n\t\t * Paging display length\n\t\t * @type int\n\t\t * @default 10\n\t\t */\n\t\t\"_iDisplayLength\": 10,\n\t\n\t\t/**\n\t\t * Paging start point - aiDisplay index\n\t\t * @type int\n\t\t * @default 0\n\t\t */\n\t\t\"_iDisplayStart\": 0,\n\t\n\t\t/**\n\t\t * Server-side processing - number of records in the result set\n\t\t * (i.e. before filtering), Use fnRecordsTotal rather than\n\t\t * this property to get the value of the number of records, regardless of\n\t\t * the server-side processing setting.\n\t\t * @type int\n\t\t * @default 0\n\t\t * @private\n\t\t */\n\t\t\"_iRecordsTotal\": 0,\n\t\n\t\t/**\n\t\t * Server-side processing - number of records in the current display set\n\t\t * (i.e. after filtering). Use fnRecordsDisplay rather than\n\t\t * this property to get the value of the number of records, regardless of\n\t\t * the server-side processing setting.\n\t\t * @type boolean\n\t\t * @default 0\n\t\t * @private\n\t\t */\n\t\t\"_iRecordsDisplay\": 0,\n\t\n\t\t/**\n\t\t * Flag to indicate if jQuery UI marking and classes should be used.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type boolean\n\t\t */\n\t\t\"bJUI\": null,\n\t\n\t\t/**\n\t\t * The classes to use for the table\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\t\"oClasses\": {},\n\t\n\t\t/**\n\t\t * Flag attached to the settings object so you can check in the draw\n\t\t * callback if filtering has been done in the draw. Deprecated in favour of\n\t\t * events.\n\t\t * @type boolean\n\t\t * @default false\n\t\t * @deprecated\n\t\t */\n\t\t\"bFiltered\": false,\n\t\n\t\t/**\n\t\t * Flag attached to the settings object so you can check in the draw\n\t\t * callback if sorting has been done in the draw. Deprecated in favour of\n\t\t * events.\n\t\t * @type boolean\n\t\t * @default false\n\t\t * @deprecated\n\t\t */\n\t\t\"bSorted\": false,\n\t\n\t\t/**\n\t\t * Indicate that if multiple rows are in the header and there is more than\n\t\t * one unique cell per column, if the top one (true) or bottom one (false)\n\t\t * should be used for sorting / title by DataTables.\n\t\t * Note that this parameter will be set by the initialisation routine. To\n\t\t * set a default use {@link DataTable.defaults}.\n\t\t * @type boolean\n\t\t */\n\t\t\"bSortCellsTop\": null,\n\t\n\t\t/**\n\t\t * Initialisation object that is used for the table\n\t\t * @type object\n\t\t * @default null\n\t\t */\n\t\t\"oInit\": null,\n\t\n\t\t/**\n\t\t * Destroy callback functions - for plug-ins to attach themselves to the\n\t\t * destroy so they can clean up markup and events.\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aoDestroyCallback\": [],\n\t\n\t\n\t\t/**\n\t\t * Get the number of records in the current record set, before filtering\n\t\t * @type function\n\t\t */\n\t\t\"fnRecordsTotal\": function ()\n\t\t{\n\t\t\treturn _fnDataSource( this ) == 'ssp' ?\n\t\t\t\tthis._iRecordsTotal * 1 :\n\t\t\t\tthis.aiDisplayMaster.length;\n\t\t},\n\t\n\t\t/**\n\t\t * Get the number of records in the current record set, after filtering\n\t\t * @type function\n\t\t */\n\t\t\"fnRecordsDisplay\": function ()\n\t\t{\n\t\t\treturn _fnDataSource( this ) == 'ssp' ?\n\t\t\t\tthis._iRecordsDisplay * 1 :\n\t\t\t\tthis.aiDisplay.length;\n\t\t},\n\t\n\t\t/**\n\t\t * Get the display end point - aiDisplay index\n\t\t * @type function\n\t\t */\n\t\t\"fnDisplayEnd\": function ()\n\t\t{\n\t\t\tvar\n\t\t\t\tlen = this._iDisplayLength,\n\t\t\t\tstart = this._iDisplayStart,\n\t\t\t\tcalc = start + len,\n\t\t\t\trecords = this.aiDisplay.length,\n\t\t\t\tfeatures = this.oFeatures,\n\t\t\t\tpaginate = features.bPaginate;\n\t\n\t\t\tif ( features.bServerSide ) {\n\t\t\t\treturn paginate === false || len === -1 ?\n\t\t\t\t\tstart + records :\n\t\t\t\t\tMath.min( start+len, this._iRecordsDisplay );\n\t\t\t}\n\t\t\telse {\n\t\t\t\treturn ! paginate || calc>records || len===-1 ?\n\t\t\t\t\trecords :\n\t\t\t\t\tcalc;\n\t\t\t}\n\t\t},\n\t\n\t\t/**\n\t\t * The DataTables object for this table\n\t\t * @type object\n\t\t * @default null\n\t\t */\n\t\t\"oInstance\": null,\n\t\n\t\t/**\n\t\t * Unique identifier for each instance of the DataTables object. If there\n\t\t * is an ID on the table node, then it takes that value, otherwise an\n\t\t * incrementing internal counter is used.\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"sInstance\": null,\n\t\n\t\t/**\n\t\t * tabindex attribute value that is added to DataTables control elements, allowing\n\t\t * keyboard navigation of the table and its controls.\n\t\t */\n\t\t\"iTabIndex\": 0,\n\t\n\t\t/**\n\t\t * DIV container for the footer scrolling table if scrolling\n\t\t */\n\t\t\"nScrollHead\": null,\n\t\n\t\t/**\n\t\t * DIV container for the footer scrolling table if scrolling\n\t\t */\n\t\t\"nScrollFoot\": null,\n\t\n\t\t/**\n\t\t * Last applied sort\n\t\t * @type array\n\t\t * @default []\n\t\t */\n\t\t\"aLastSort\": [],\n\t\n\t\t/**\n\t\t * Stored plug-in instances\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\t\"oPlugins\": {},\n\t\n\t\t/**\n\t\t * Function used to get a row's id from the row's data\n\t\t * @type function\n\t\t * @default null\n\t\t */\n\t\t\"rowIdFn\": null,\n\t\n\t\t/**\n\t\t * Data location where to store a row's id\n\t\t * @type string\n\t\t * @default null\n\t\t */\n\t\t\"rowId\": null\n\t};\n\n\t/**\n\t * Extension object for DataTables that is used to provide all extension\n\t * options.\n\t *\n\t * Note that the `DataTable.ext` object is available through\n\t * `jQuery.fn.dataTable.ext` where it may be accessed and manipulated. It is\n\t * also aliased to `jQuery.fn.dataTableExt` for historic reasons.\n\t * @namespace\n\t * @extends DataTable.models.ext\n\t */\n\t\n\t\n\t/**\n\t * DataTables extensions\n\t * \n\t * This namespace acts as a collection area for plug-ins that can be used to\n\t * extend DataTables capabilities. Indeed many of the build in methods\n\t * use this method to provide their own capabilities (sorting methods for\n\t * example).\n\t *\n\t * Note that this namespace is aliased to `jQuery.fn.dataTableExt` for legacy\n\t * reasons\n\t *\n\t * @namespace\n\t */\n\tDataTable.ext = _ext = {\n\t\t/**\n\t\t * Buttons. For use with the Buttons extension for DataTables. This is\n\t\t * defined here so other extensions can define buttons regardless of load\n\t\t * order. It is _not_ used by DataTables core.\n\t\t *\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\tbuttons: {},\n\t\n\t\n\t\t/**\n\t\t * Element class names\n\t\t *\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\tclasses: {},\n\t\n\t\n\t\t/**\n\t\t * DataTables build type (expanded by the download builder)\n\t\t *\n\t\t * @type string\n\t\t */\n\t\tbuilder: \"-source-\",\n\t\n\t\n\t\t/**\n\t\t * Error reporting.\n\t\t * \n\t\t * How should DataTables report an error. Can take the value 'alert',\n\t\t * 'throw', 'none' or a function.\n\t\t *\n\t\t * @type string|function\n\t\t * @default alert\n\t\t */\n\t\terrMode: \"alert\",\n\t\n\t\n\t\t/**\n\t\t * Feature plug-ins.\n\t\t * \n\t\t * This is an array of objects which describe the feature plug-ins that are\n\t\t * available to DataTables. These feature plug-ins are then available for\n\t\t * use through the `dom` initialisation option.\n\t\t * \n\t\t * Each feature plug-in is described by an object which must have the\n\t\t * following properties:\n\t\t * \n\t\t * * `fnInit` - function that is used to initialise the plug-in,\n\t\t * * `cFeature` - a character so the feature can be enabled by the `dom`\n\t\t * instillation option. This is case sensitive.\n\t\t *\n\t\t * The `fnInit` function has the following input parameters:\n\t\t *\n\t\t * 1. `{object}` DataTables settings object: see\n\t\t * {@link DataTable.models.oSettings}\n\t\t *\n\t\t * And the following return is expected:\n\t\t * \n\t\t * * {node|null} The element which contains your feature. Note that the\n\t\t * return may also be void if your plug-in does not require to inject any\n\t\t * DOM elements into DataTables control (`dom`) - for example this might\n\t\t * be useful when developing a plug-in which allows table control via\n\t\t * keyboard entry\n\t\t *\n\t\t * @type array\n\t\t *\n\t\t * @example\n\t\t * $.fn.dataTable.ext.features.push( {\n\t\t * \"fnInit\": function( oSettings ) {\n\t\t * return new TableTools( { \"oDTSettings\": oSettings } );\n\t\t * },\n\t\t * \"cFeature\": \"T\"\n\t\t * } );\n\t\t */\n\t\tfeature: [],\n\t\n\t\n\t\t/**\n\t\t * Row searching.\n\t\t * \n\t\t * This method of searching is complimentary to the default type based\n\t\t * searching, and a lot more comprehensive as it allows you complete control\n\t\t * over the searching logic. Each element in this array is a function\n\t\t * (parameters described below) that is called for every row in the table,\n\t\t * and your logic decides if it should be included in the searching data set\n\t\t * or not.\n\t\t *\n\t\t * Searching functions have the following input parameters:\n\t\t *\n\t\t * 1. `{object}` DataTables settings object: see\n\t\t * {@link DataTable.models.oSettings}\n\t\t * 2. `{array|object}` Data for the row to be processed (same as the\n\t\t * original format that was passed in as the data source, or an array\n\t\t * from a DOM data source\n\t\t * 3. `{int}` Row index ({@link DataTable.models.oSettings.aoData}), which\n\t\t * can be useful to retrieve the `TR` element if you need DOM interaction.\n\t\t *\n\t\t * And the following return is expected:\n\t\t *\n\t\t * * {boolean} Include the row in the searched result set (true) or not\n\t\t * (false)\n\t\t *\n\t\t * Note that as with the main search ability in DataTables, technically this\n\t\t * is \"filtering\", since it is subtractive. However, for consistency in\n\t\t * naming we call it searching here.\n\t\t *\n\t\t * @type array\n\t\t * @default []\n\t\t *\n\t\t * @example\n\t\t * // The following example shows custom search being applied to the\n\t\t * // fourth column (i.e. the data[3] index) based on two input values\n\t\t * // from the end-user, matching the data in a certain range.\n\t\t * $.fn.dataTable.ext.search.push(\n\t\t * function( settings, data, dataIndex ) {\n\t\t * var min = document.getElementById('min').value * 1;\n\t\t * var max = document.getElementById('max').value * 1;\n\t\t * var version = data[3] == \"-\" ? 0 : data[3]*1;\n\t\t *\n\t\t * if ( min == \"\" && max == \"\" ) {\n\t\t * return true;\n\t\t * }\n\t\t * else if ( min == \"\" && version < max ) {\n\t\t * return true;\n\t\t * }\n\t\t * else if ( min < version && \"\" == max ) {\n\t\t * return true;\n\t\t * }\n\t\t * else if ( min < version && version < max ) {\n\t\t * return true;\n\t\t * }\n\t\t * return false;\n\t\t * }\n\t\t * );\n\t\t */\n\t\tsearch: [],\n\t\n\t\n\t\t/**\n\t\t * Selector extensions\n\t\t *\n\t\t * The `selector` option can be used to extend the options available for the\n\t\t * selector modifier options (`selector-modifier` object data type) that\n\t\t * each of the three built in selector types offer (row, column and cell +\n\t\t * their plural counterparts). For example the Select extension uses this\n\t\t * mechanism to provide an option to select only rows, columns and cells\n\t\t * that have been marked as selected by the end user (`{selected: true}`),\n\t\t * which can be used in conjunction with the existing built in selector\n\t\t * options.\n\t\t *\n\t\t * Each property is an array to which functions can be pushed. The functions\n\t\t * take three attributes:\n\t\t *\n\t\t * * Settings object for the host table\n\t\t * * Options object (`selector-modifier` object type)\n\t\t * * Array of selected item indexes\n\t\t *\n\t\t * The return is an array of the resulting item indexes after the custom\n\t\t * selector has been applied.\n\t\t *\n\t\t * @type object\n\t\t */\n\t\tselector: {\n\t\t\tcell: [],\n\t\t\tcolumn: [],\n\t\t\trow: []\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Internal functions, exposed for used in plug-ins.\n\t\t * \n\t\t * Please note that you should not need to use the internal methods for\n\t\t * anything other than a plug-in (and even then, try to avoid if possible).\n\t\t * The internal function may change between releases.\n\t\t *\n\t\t * @type object\n\t\t * @default {}\n\t\t */\n\t\tinternal: {},\n\t\n\t\n\t\t/**\n\t\t * Legacy configuration options. Enable and disable legacy options that\n\t\t * are available in DataTables.\n\t\t *\n\t\t * @type object\n\t\t */\n\t\tlegacy: {\n\t\t\t/**\n\t\t\t * Enable / disable DataTables 1.9 compatible server-side processing\n\t\t\t * requests\n\t\t\t *\n\t\t\t * @type boolean\n\t\t\t * @default null\n\t\t\t */\n\t\t\tajax: null\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Pagination plug-in methods.\n\t\t * \n\t\t * Each entry in this object is a function and defines which buttons should\n\t\t * be shown by the pagination rendering method that is used for the table:\n\t\t * {@link DataTable.ext.renderer.pageButton}. The renderer addresses how the\n\t\t * buttons are displayed in the document, while the functions here tell it\n\t\t * what buttons to display. This is done by returning an array of button\n\t\t * descriptions (what each button will do).\n\t\t *\n\t\t * Pagination types (the four built in options and any additional plug-in\n\t\t * options defined here) can be used through the `paginationType`\n\t\t * initialisation parameter.\n\t\t *\n\t\t * The functions defined take two parameters:\n\t\t *\n\t\t * 1. `{int} page` The current page index\n\t\t * 2. `{int} pages` The number of pages in the table\n\t\t *\n\t\t * Each function is expected to return an array where each element of the\n\t\t * array can be one of:\n\t\t *\n\t\t * * `first` - Jump to first page when activated\n\t\t * * `last` - Jump to last page when activated\n\t\t * * `previous` - Show previous page when activated\n\t\t * * `next` - Show next page when activated\n\t\t * * `{int}` - Show page of the index given\n\t\t * * `{array}` - A nested array containing the above elements to add a\n\t\t * containing 'DIV' element (might be useful for styling).\n\t\t *\n\t\t * Note that DataTables v1.9- used this object slightly differently whereby\n\t\t * an object with two functions would be defined for each plug-in. That\n\t\t * ability is still supported by DataTables 1.10+ to provide backwards\n\t\t * compatibility, but this option of use is now decremented and no longer\n\t\t * documented in DataTables 1.10+.\n\t\t *\n\t\t * @type object\n\t\t * @default {}\n\t\t *\n\t\t * @example\n\t\t * // Show previous, next and current page buttons only\n\t\t * $.fn.dataTableExt.oPagination.current = function ( page, pages ) {\n\t\t * return [ 'previous', page, 'next' ];\n\t\t * };\n\t\t */\n\t\tpager: {},\n\t\n\t\n\t\trenderer: {\n\t\t\tpageButton: {},\n\t\t\theader: {}\n\t\t},\n\t\n\t\n\t\t/**\n\t\t * Ordering plug-ins - custom data source\n\t\t * \n\t\t * The extension options for ordering of data available here is complimentary\n\t\t * to the default type based ordering that DataTables typically uses. It\n\t\t * allows much greater control over the the data that is being used to\n\t\t * order a column, but is necessarily therefore more complex.\n\t\t * \n\t\t * This type of ordering is useful if you want to do ordering based on data\n\t\t * live from the DOM (for example the contents of an 'input' element) rather\n\t\t * than just the static string that DataTables knows of.\n\t\t * \n\t\t * The way these plug-ins work is that you create an array of the values you\n\t\t * wish to be ordering for the column in question and then return that\n\t\t * array. The data in the array much be in the index order of the rows in\n\t\t * the table (not the currently ordering order!). Which order data gathering\n\t\t * function is run here depends on the `dt-init columns.orderDataType`\n\t\t * parameter that is used for the column (if any).\n\t\t *\n\t\t * The functions defined take two parameters:\n\t\t *\n\t\t * 1. `{object}` DataTables settings object: see\n\t\t * {@link DataTable.models.oSettings}\n\t\t * 2. `{int}` Target column index\n\t\t *\n\t\t * Each function is expected to return an array:\n\t\t *\n\t\t * * `{array}` Data for the column to be ordering upon\n\t\t *\n\t\t * @type array\n\t\t *\n\t\t * @example\n\t\t * // Ordering using `input` node values\n\t\t * $.fn.dataTable.ext.order['dom-text'] = function ( settings, col )\n\t\t * {\n\t\t * return this.api().column( col, {order:'index'} ).nodes().map( function ( td, i ) {\n\t\t * return $('input', td).val();\n\t\t * } );\n\t\t * }\n\t\t */\n\t\torder: {},\n\t\n\t\n\t\t/**\n\t\t * Type based plug-ins.\n\t\t *\n\t\t * Each column in DataTables has a type assigned to it, either by automatic\n\t\t * detection or by direct assignment using the `type` option for the column.\n\t\t * The type of a column will effect how it is ordering and search (plug-ins\n\t\t * can also make use of the column type if required).\n\t\t *\n\t\t * @namespace\n\t\t */\n\t\ttype: {\n\t\t\t/**\n\t\t\t * Type detection functions.\n\t\t\t *\n\t\t\t * The functions defined in this object are used to automatically detect\n\t\t\t * a column's type, making initialisation of DataTables super easy, even\n\t\t\t * when complex data is in the table.\n\t\t\t *\n\t\t\t * The functions defined take two parameters:\n\t\t\t *\n\t\t * 1. `{*}` Data from the column cell to be analysed\n\t\t * 2. `{settings}` DataTables settings object. This can be used to\n\t\t * perform context specific type detection - for example detection\n\t\t * based on language settings such as using a comma for a decimal\n\t\t * place. Generally speaking the options from the settings will not\n\t\t * be required\n\t\t\t *\n\t\t\t * Each function is expected to return:\n\t\t\t *\n\t\t\t * * `{string|null}` Data type detected, or null if unknown (and thus\n\t\t\t * pass it on to the other type detection functions.\n\t\t\t *\n\t\t\t * @type array\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Currency type detection plug-in:\n\t\t\t * $.fn.dataTable.ext.type.detect.push(\n\t\t\t * function ( data, settings ) {\n\t\t\t * // Check the numeric part\n\t\t\t * if ( ! $.isNumeric( data.substring(1) ) ) {\n\t\t\t * return null;\n\t\t\t * }\n\t\t\t *\n\t\t\t * // Check prefixed by currency\n\t\t\t * if ( data.charAt(0) == '$' || data.charAt(0) == '£' ) {\n\t\t\t * return 'currency';\n\t\t\t * }\n\t\t\t * return null;\n\t\t\t * }\n\t\t\t * );\n\t\t\t */\n\t\t\tdetect: [],\n\t\n\t\n\t\t\t/**\n\t\t\t * Type based search formatting.\n\t\t\t *\n\t\t\t * The type based searching functions can be used to pre-format the\n\t\t\t * data to be search on. For example, it can be used to strip HTML\n\t\t\t * tags or to de-format telephone numbers for numeric only searching.\n\t\t\t *\n\t\t\t * Note that is a search is not defined for a column of a given type,\n\t\t\t * no search formatting will be performed.\n\t\t\t * \n\t\t\t * Pre-processing of searching data plug-ins - When you assign the sType\n\t\t\t * for a column (or have it automatically detected for you by DataTables\n\t\t\t * or a type detection plug-in), you will typically be using this for\n\t\t\t * custom sorting, but it can also be used to provide custom searching\n\t\t\t * by allowing you to pre-processing the data and returning the data in\n\t\t\t * the format that should be searched upon. This is done by adding\n\t\t\t * functions this object with a parameter name which matches the sType\n\t\t\t * for that target column. This is the corollary of <i>afnSortData</i>\n\t\t\t * for searching data.\n\t\t\t *\n\t\t\t * The functions defined take a single parameter:\n\t\t\t *\n\t\t * 1. `{*}` Data from the column cell to be prepared for searching\n\t\t\t *\n\t\t\t * Each function is expected to return:\n\t\t\t *\n\t\t\t * * `{string|null}` Formatted string that will be used for the searching.\n\t\t\t *\n\t\t\t * @type object\n\t\t\t * @default {}\n\t\t\t *\n\t\t\t * @example\n\t\t\t * $.fn.dataTable.ext.type.search['title-numeric'] = function ( d ) {\n\t\t\t * return d.replace(/\\n/g,\" \").replace( /<.*?>/g, \"\" );\n\t\t\t * }\n\t\t\t */\n\t\t\tsearch: {},\n\t\n\t\n\t\t\t/**\n\t\t\t * Type based ordering.\n\t\t\t *\n\t\t\t * The column type tells DataTables what ordering to apply to the table\n\t\t\t * when a column is sorted upon. The order for each type that is defined,\n\t\t\t * is defined by the functions available in this object.\n\t\t\t *\n\t\t\t * Each ordering option can be described by three properties added to\n\t\t\t * this object:\n\t\t\t *\n\t\t\t * * `{type}-pre` - Pre-formatting function\n\t\t\t * * `{type}-asc` - Ascending order function\n\t\t\t * * `{type}-desc` - Descending order function\n\t\t\t *\n\t\t\t * All three can be used together, only `{type}-pre` or only\n\t\t\t * `{type}-asc` and `{type}-desc` together. It is generally recommended\n\t\t\t * that only `{type}-pre` is used, as this provides the optimal\n\t\t\t * implementation in terms of speed, although the others are provided\n\t\t\t * for compatibility with existing Javascript sort functions.\n\t\t\t *\n\t\t\t * `{type}-pre`: Functions defined take a single parameter:\n\t\t\t *\n\t\t * 1. `{*}` Data from the column cell to be prepared for ordering\n\t\t\t *\n\t\t\t * And return:\n\t\t\t *\n\t\t\t * * `{*}` Data to be sorted upon\n\t\t\t *\n\t\t\t * `{type}-asc` and `{type}-desc`: Functions are typical Javascript sort\n\t\t\t * functions, taking two parameters:\n\t\t\t *\n\t\t * 1. `{*}` Data to compare to the second parameter\n\t\t * 2. `{*}` Data to compare to the first parameter\n\t\t\t *\n\t\t\t * And returning:\n\t\t\t *\n\t\t\t * * `{*}` Ordering match: <0 if first parameter should be sorted lower\n\t\t\t * than the second parameter, ===0 if the two parameters are equal and\n\t\t\t * >0 if the first parameter should be sorted height than the second\n\t\t\t * parameter.\n\t\t\t * \n\t\t\t * @type object\n\t\t\t * @default {}\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Numeric ordering of formatted numbers with a pre-formatter\n\t\t\t * $.extend( $.fn.dataTable.ext.type.order, {\n\t\t\t * \"string-pre\": function(x) {\n\t\t\t * a = (a === \"-\" || a === \"\") ? 0 : a.replace( /[^\\d\\-\\.]/g, \"\" );\n\t\t\t * return parseFloat( a );\n\t\t\t * }\n\t\t\t * } );\n\t\t\t *\n\t\t\t * @example\n\t\t\t * // Case-sensitive string ordering, with no pre-formatting method\n\t\t\t * $.extend( $.fn.dataTable.ext.order, {\n\t\t\t * \"string-case-asc\": function(x,y) {\n\t\t\t * return ((x < y) ? -1 : ((x > y) ? 1 : 0));\n\t\t\t * },\n\t\t\t * \"string-case-desc\": function(x,y) {\n\t\t\t * return ((x < y) ? 1 : ((x > y) ? -1 : 0));\n\t\t\t * }\n\t\t\t * } );\n\t\t\t */\n\t\t\torder: {}\n\t\t},\n\t\n\t\t/**\n\t\t * Unique DataTables instance counter\n\t\t *\n\t\t * @type int\n\t\t * @private\n\t\t */\n\t\t_unique: 0,\n\t\n\t\n\t\t//\n\t\t// Depreciated\n\t\t// The following properties are retained for backwards compatiblity only.\n\t\t// The should not be used in new projects and will be removed in a future\n\t\t// version\n\t\t//\n\t\n\t\t/**\n\t\t * Version check function.\n\t\t * @type function\n\t\t * @depreciated Since 1.10\n\t\t */\n\t\tfnVersionCheck: DataTable.fnVersionCheck,\n\t\n\t\n\t\t/**\n\t\t * Index for what 'this' index API functions should use\n\t\t * @type int\n\t\t * @deprecated Since v1.10\n\t\t */\n\t\tiApiIndex: 0,\n\t\n\t\n\t\t/**\n\t\t * jQuery UI class container\n\t\t * @type object\n\t\t * @deprecated Since v1.10\n\t\t */\n\t\toJUIClasses: {},\n\t\n\t\n\t\t/**\n\t\t * Software version\n\t\t * @type string\n\t\t * @deprecated Since v1.10\n\t\t */\n\t\tsVersion: DataTable.version\n\t};\n\t\n\t\n\t//\n\t// Backwards compatibility. Alias to pre 1.10 Hungarian notation counter parts\n\t//\n\t$.extend( _ext, {\n\t\tafnFiltering: _ext.search,\n\t\taTypes: _ext.type.detect,\n\t\tofnSearch: _ext.type.search,\n\t\toSort: _ext.type.order,\n\t\tafnSortData: _ext.order,\n\t\taoFeatures: _ext.feature,\n\t\toApi: _ext.internal,\n\t\toStdClasses: _ext.classes,\n\t\toPagination: _ext.pager\n\t} );\n\t\n\t\n\t$.extend( DataTable.ext.classes, {\n\t\t\"sTable\": \"dataTable\",\n\t\t\"sNoFooter\": \"no-footer\",\n\t\n\t\t/* Paging buttons */\n\t\t\"sPageButton\": \"paginate_button\",\n\t\t\"sPageButtonActive\": \"current\",\n\t\t\"sPageButtonDisabled\": \"disabled\",\n\t\n\t\t/* Striping classes */\n\t\t\"sStripeOdd\": \"odd\",\n\t\t\"sStripeEven\": \"even\",\n\t\n\t\t/* Empty row */\n\t\t\"sRowEmpty\": \"dataTables_empty\",\n\t\n\t\t/* Features */\n\t\t\"sWrapper\": \"dataTables_wrapper\",\n\t\t\"sFilter\": \"dataTables_filter\",\n\t\t\"sInfo\": \"dataTables_info\",\n\t\t\"sPaging\": \"dataTables_paginate paging_\", /* Note that the type is postfixed */\n\t\t\"sLength\": \"dataTables_length\",\n\t\t\"sProcessing\": \"dataTables_processing\",\n\t\n\t\t/* Sorting */\n\t\t\"sSortAsc\": \"sorting_asc\",\n\t\t\"sSortDesc\": \"sorting_desc\",\n\t\t\"sSortable\": \"sorting\", /* Sortable in both directions */\n\t\t\"sSortableAsc\": \"sorting_asc_disabled\",\n\t\t\"sSortableDesc\": \"sorting_desc_disabled\",\n\t\t\"sSortableNone\": \"sorting_disabled\",\n\t\t\"sSortColumn\": \"sorting_\", /* Note that an int is postfixed for the sorting order */\n\t\n\t\t/* Filtering */\n\t\t\"sFilterInput\": \"\",\n\t\n\t\t/* Page length */\n\t\t\"sLengthSelect\": \"\",\n\t\n\t\t/* Scrolling */\n\t\t\"sScrollWrapper\": \"dataTables_scroll\",\n\t\t\"sScrollHead\": \"dataTables_scrollHead\",\n\t\t\"sScrollHeadInner\": \"dataTables_scrollHeadInner\",\n\t\t\"sScrollBody\": \"dataTables_scrollBody\",\n\t\t\"sScrollFoot\": \"dataTables_scrollFoot\",\n\t\t\"sScrollFootInner\": \"dataTables_scrollFootInner\",\n\t\n\t\t/* Misc */\n\t\t\"sHeaderTH\": \"\",\n\t\t\"sFooterTH\": \"\",\n\t\n\t\t// Deprecated\n\t\t\"sSortJUIAsc\": \"\",\n\t\t\"sSortJUIDesc\": \"\",\n\t\t\"sSortJUI\": \"\",\n\t\t\"sSortJUIAscAllowed\": \"\",\n\t\t\"sSortJUIDescAllowed\": \"\",\n\t\t\"sSortJUIWrapper\": \"\",\n\t\t\"sSortIcon\": \"\",\n\t\t\"sJUIHeader\": \"\",\n\t\t\"sJUIFooter\": \"\"\n\t} );\n\t\n\t\n\t(function() {\n\t\n\t// Reused strings for better compression. Closure compiler appears to have a\n\t// weird edge case where it is trying to expand strings rather than use the\n\t// variable version. This results in about 200 bytes being added, for very\n\t// little preference benefit since it this run on script load only.\n\tvar _empty = '';\n\t_empty = '';\n\t\n\tvar _stateDefault = _empty + 'ui-state-default';\n\tvar _sortIcon = _empty + 'css_right ui-icon ui-icon-';\n\tvar _headerFooter = _empty + 'fg-toolbar ui-toolbar ui-widget-header ui-helper-clearfix';\n\t\n\t$.extend( DataTable.ext.oJUIClasses, DataTable.ext.classes, {\n\t\t/* Full numbers paging buttons */\n\t\t\"sPageButton\": \"fg-button ui-button \"+_stateDefault,\n\t\t\"sPageButtonActive\": \"ui-state-disabled\",\n\t\t\"sPageButtonDisabled\": \"ui-state-disabled\",\n\t\n\t\t/* Features */\n\t\t\"sPaging\": \"dataTables_paginate fg-buttonset ui-buttonset fg-buttonset-multi \"+\n\t\t\t\"ui-buttonset-multi paging_\", /* Note that the type is postfixed */\n\t\n\t\t/* Sorting */\n\t\t\"sSortAsc\": _stateDefault+\" sorting_asc\",\n\t\t\"sSortDesc\": _stateDefault+\" sorting_desc\",\n\t\t\"sSortable\": _stateDefault+\" sorting\",\n\t\t\"sSortableAsc\": _stateDefault+\" sorting_asc_disabled\",\n\t\t\"sSortableDesc\": _stateDefault+\" sorting_desc_disabled\",\n\t\t\"sSortableNone\": _stateDefault+\" sorting_disabled\",\n\t\t\"sSortJUIAsc\": _sortIcon+\"triangle-1-n\",\n\t\t\"sSortJUIDesc\": _sortIcon+\"triangle-1-s\",\n\t\t\"sSortJUI\": _sortIcon+\"carat-2-n-s\",\n\t\t\"sSortJUIAscAllowed\": _sortIcon+\"carat-1-n\",\n\t\t\"sSortJUIDescAllowed\": _sortIcon+\"carat-1-s\",\n\t\t\"sSortJUIWrapper\": \"DataTables_sort_wrapper\",\n\t\t\"sSortIcon\": \"DataTables_sort_icon\",\n\t\n\t\t/* Scrolling */\n\t\t\"sScrollHead\": \"dataTables_scrollHead \"+_stateDefault,\n\t\t\"sScrollFoot\": \"dataTables_scrollFoot \"+_stateDefault,\n\t\n\t\t/* Misc */\n\t\t\"sHeaderTH\": _stateDefault,\n\t\t\"sFooterTH\": _stateDefault,\n\t\t\"sJUIHeader\": _headerFooter+\" ui-corner-tl ui-corner-tr\",\n\t\t\"sJUIFooter\": _headerFooter+\" ui-corner-bl ui-corner-br\"\n\t} );\n\t\n\t}());\n\t\n\t\n\t\n\tvar extPagination = DataTable.ext.pager;\n\t\n\tfunction _numbers ( page, pages ) {\n\t\tvar\n\t\t\tnumbers = [],\n\t\t\tbuttons = extPagination.numbers_length,\n\t\t\thalf = Math.floor( buttons / 2 ),\n\t\t\ti = 1;\n\t\n\t\tif ( pages <= buttons ) {\n\t\t\tnumbers = _range( 0, pages );\n\t\t}\n\t\telse if ( page <= half ) {\n\t\t\tnumbers = _range( 0, buttons-2 );\n\t\t\tnumbers.push( 'ellipsis' );\n\t\t\tnumbers.push( pages-1 );\n\t\t}\n\t\telse if ( page >= pages - 1 - half ) {\n\t\t\tnumbers = _range( pages-(buttons-2), pages );\n\t\t\tnumbers.splice( 0, 0, 'ellipsis' ); // no unshift in ie6\n\t\t\tnumbers.splice( 0, 0, 0 );\n\t\t}\n\t\telse {\n\t\t\tnumbers = _range( page-half+2, page+half-1 );\n\t\t\tnumbers.push( 'ellipsis' );\n\t\t\tnumbers.push( pages-1 );\n\t\t\tnumbers.splice( 0, 0, 'ellipsis' );\n\t\t\tnumbers.splice( 0, 0, 0 );\n\t\t}\n\t\n\t\tnumbers.DT_el = 'span';\n\t\treturn numbers;\n\t}\n\t\n\t\n\t$.extend( extPagination, {\n\t\tsimple: function ( page, pages ) {\n\t\t\treturn [ 'previous', 'next' ];\n\t\t},\n\t\n\t\tfull: function ( page, pages ) {\n\t\t\treturn [ 'first', 'previous', 'next', 'last' ];\n\t\t},\n\t\n\t\tnumbers: function ( page, pages ) {\n\t\t\treturn [ _numbers(page, pages) ];\n\t\t},\n\t\n\t\tsimple_numbers: function ( page, pages ) {\n\t\t\treturn [ 'previous', _numbers(page, pages), 'next' ];\n\t\t},\n\t\n\t\tfull_numbers: function ( page, pages ) {\n\t\t\treturn [ 'first', 'previous', _numbers(page, pages), 'next', 'last' ];\n\t\t},\n\t\n\t\t// For testing and plug-ins to use\n\t\t_numbers: _numbers,\n\t\n\t\t// Number of number buttons (including ellipsis) to show. _Must be odd!_\n\t\tnumbers_length: 7\n\t} );\n\t\n\t\n\t$.extend( true, DataTable.ext.renderer, {\n\t\tpageButton: {\n\t\t\t_: function ( settings, host, idx, buttons, page, pages ) {\n\t\t\t\tvar classes = settings.oClasses;\n\t\t\t\tvar lang = settings.oLanguage.oPaginate;\n\t\t\t\tvar aria = settings.oLanguage.oAria.paginate || {};\n\t\t\t\tvar btnDisplay, btnClass, counter=0;\n\t\n\t\t\t\tvar attach = function( container, buttons ) {\n\t\t\t\t\tvar i, ien, node, button;\n\t\t\t\t\tvar clickHandler = function ( e ) {\n\t\t\t\t\t\t_fnPageChange( settings, e.data.action, true );\n\t\t\t\t\t};\n\t\n\t\t\t\t\tfor ( i=0, ien=buttons.length ; i<ien ; i++ ) {\n\t\t\t\t\t\tbutton = buttons[i];\n\t\n\t\t\t\t\t\tif ( $.isArray( button ) ) {\n\t\t\t\t\t\t\tvar inner = $( '<'+(button.DT_el || 'div')+'/>' )\n\t\t\t\t\t\t\t\t.appendTo( container );\n\t\t\t\t\t\t\tattach( inner, button );\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tbtnDisplay = null;\n\t\t\t\t\t\t\tbtnClass = '';\n\t\n\t\t\t\t\t\t\tswitch ( button ) {\n\t\t\t\t\t\t\t\tcase 'ellipsis':\n\t\t\t\t\t\t\t\t\tcontainer.append('<span class=\"ellipsis\">…</span>');\n\t\t\t\t\t\t\t\t\tbreak;\n\t\n\t\t\t\t\t\t\t\tcase 'first':\n\t\t\t\t\t\t\t\t\tbtnDisplay = lang.sFirst;\n\t\t\t\t\t\t\t\t\tbtnClass = button + (page > 0 ?\n\t\t\t\t\t\t\t\t\t\t'' : ' '+classes.sPageButtonDisabled);\n\t\t\t\t\t\t\t\t\tbreak;\n\t\n\t\t\t\t\t\t\t\tcase 'previous':\n\t\t\t\t\t\t\t\t\tbtnDisplay = lang.sPrevious;\n\t\t\t\t\t\t\t\t\tbtnClass = button + (page > 0 ?\n\t\t\t\t\t\t\t\t\t\t'' : ' '+classes.sPageButtonDisabled);\n\t\t\t\t\t\t\t\t\tbreak;\n\t\n\t\t\t\t\t\t\t\tcase 'next':\n\t\t\t\t\t\t\t\t\tbtnDisplay = lang.sNext;\n\t\t\t\t\t\t\t\t\tbtnClass = button + (page < pages-1 ?\n\t\t\t\t\t\t\t\t\t\t'' : ' '+classes.sPageButtonDisabled);\n\t\t\t\t\t\t\t\t\tbreak;\n\t\n\t\t\t\t\t\t\t\tcase 'last':\n\t\t\t\t\t\t\t\t\tbtnDisplay = lang.sLast;\n\t\t\t\t\t\t\t\t\tbtnClass = button + (page < pages-1 ?\n\t\t\t\t\t\t\t\t\t\t'' : ' '+classes.sPageButtonDisabled);\n\t\t\t\t\t\t\t\t\tbreak;\n\t\n\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\tbtnDisplay = button + 1;\n\t\t\t\t\t\t\t\t\tbtnClass = page === button ?\n\t\t\t\t\t\t\t\t\t\tclasses.sPageButtonActive : '';\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\t\n\t\t\t\t\t\t\tif ( btnDisplay !== null ) {\n\t\t\t\t\t\t\t\tnode = $('<a>', {\n\t\t\t\t\t\t\t\t\t\t'class': classes.sPageButton+' '+btnClass,\n\t\t\t\t\t\t\t\t\t\t'aria-controls': settings.sTableId,\n\t\t\t\t\t\t\t\t\t\t'aria-label': aria[ button ],\n\t\t\t\t\t\t\t\t\t\t'data-dt-idx': counter,\n\t\t\t\t\t\t\t\t\t\t'tabindex': settings.iTabIndex,\n\t\t\t\t\t\t\t\t\t\t'id': idx === 0 && typeof button === 'string' ?\n\t\t\t\t\t\t\t\t\t\t\tsettings.sTableId +'_'+ button :\n\t\t\t\t\t\t\t\t\t\t\tnull\n\t\t\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t\t\t\t.html( btnDisplay )\n\t\t\t\t\t\t\t\t\t.appendTo( container );\n\t\n\t\t\t\t\t\t\t\t_fnBindAction(\n\t\t\t\t\t\t\t\t\tnode, {action: button}, clickHandler\n\t\t\t\t\t\t\t\t);\n\t\n\t\t\t\t\t\t\t\tcounter++;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t};\n\t\n\t\t\t\t// IE9 throws an 'unknown error' if document.activeElement is used\n\t\t\t\t// inside an iframe or frame. Try / catch the error. Not good for\n\t\t\t\t// accessibility, but neither are frames.\n\t\t\t\tvar activeEl;\n\t\n\t\t\t\ttry {\n\t\t\t\t\t// Because this approach is destroying and recreating the paging\n\t\t\t\t\t// elements, focus is lost on the select button which is bad for\n\t\t\t\t\t// accessibility. So we want to restore focus once the draw has\n\t\t\t\t\t// completed\n\t\t\t\t\tactiveEl = $(host).find(document.activeElement).data('dt-idx');\n\t\t\t\t}\n\t\t\t\tcatch (e) {}\n\t\n\t\t\t\tattach( $(host).empty(), buttons );\n\t\n\t\t\t\tif ( activeEl ) {\n\t\t\t\t\t$(host).find( '[data-dt-idx='+activeEl+']' ).focus();\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t} );\n\t\n\t\n\t\n\t// Built in type detection. See model.ext.aTypes for information about\n\t// what is required from this methods.\n\t$.extend( DataTable.ext.type.detect, [\n\t\t// Plain numbers - first since V8 detects some plain numbers as dates\n\t\t// e.g. Date.parse('55') (but not all, e.g. Date.parse('22')...).\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\tvar decimal = settings.oLanguage.sDecimal;\n\t\t\treturn _isNumber( d, decimal ) ? 'num'+decimal : null;\n\t\t},\n\t\n\t\t// Dates (only those recognised by the browser's Date.parse)\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\t// V8 will remove any unknown characters at the start and end of the\n\t\t\t// expression, leading to false matches such as `$245.12` or `10%` being\n\t\t\t// a valid date. See forum thread 18941 for detail.\n\t\t\tif ( d && !(d instanceof Date) && ( ! _re_date_start.test(d) || ! _re_date_end.test(d) ) ) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\tvar parsed = Date.parse(d);\n\t\t\treturn (parsed !== null && !isNaN(parsed)) || _empty(d) ? 'date' : null;\n\t\t},\n\t\n\t\t// Formatted numbers\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\tvar decimal = settings.oLanguage.sDecimal;\n\t\t\treturn _isNumber( d, decimal, true ) ? 'num-fmt'+decimal : null;\n\t\t},\n\t\n\t\t// HTML numeric\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\tvar decimal = settings.oLanguage.sDecimal;\n\t\t\treturn _htmlNumeric( d, decimal ) ? 'html-num'+decimal : null;\n\t\t},\n\t\n\t\t// HTML numeric, formatted\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\tvar decimal = settings.oLanguage.sDecimal;\n\t\t\treturn _htmlNumeric( d, decimal, true ) ? 'html-num-fmt'+decimal : null;\n\t\t},\n\t\n\t\t// HTML (this is strict checking - there must be html)\n\t\tfunction ( d, settings )\n\t\t{\n\t\t\treturn _empty( d ) || (typeof d === 'string' && d.indexOf('<') !== -1) ?\n\t\t\t\t'html' : null;\n\t\t}\n\t] );\n\t\n\t\n\t\n\t// Filter formatting functions. See model.ext.ofnSearch for information about\n\t// what is required from these methods.\n\t// \n\t// Note that additional search methods are added for the html numbers and\n\t// html formatted numbers by `_addNumericSort()` when we know what the decimal\n\t// place is\n\t\n\t\n\t$.extend( DataTable.ext.type.search, {\n\t\thtml: function ( data ) {\n\t\t\treturn _empty(data) ?\n\t\t\t\tdata :\n\t\t\t\ttypeof data === 'string' ?\n\t\t\t\t\tdata\n\t\t\t\t\t\t.replace( _re_new_lines, \" \" )\n\t\t\t\t\t\t.replace( _re_html, \"\" ) :\n\t\t\t\t\t'';\n\t\t},\n\t\n\t\tstring: function ( data ) {\n\t\t\treturn _empty(data) ?\n\t\t\t\tdata :\n\t\t\t\ttypeof data === 'string' ?\n\t\t\t\t\tdata.replace( _re_new_lines, \" \" ) :\n\t\t\t\t\tdata;\n\t\t}\n\t} );\n\t\n\t\n\t\n\tvar __numericReplace = function ( d, decimalPlace, re1, re2 ) {\n\t\tif ( d !== 0 && (!d || d === '-') ) {\n\t\t\treturn -Infinity;\n\t\t}\n\t\n\t\t// If a decimal place other than `.` is used, it needs to be given to the\n\t\t// function so we can detect it and replace with a `.` which is the only\n\t\t// decimal place Javascript recognises - it is not locale aware.\n\t\tif ( decimalPlace ) {\n\t\t\td = _numToDecimal( d, decimalPlace );\n\t\t}\n\t\n\t\tif ( d.replace ) {\n\t\t\tif ( re1 ) {\n\t\t\t\td = d.replace( re1, '' );\n\t\t\t}\n\t\n\t\t\tif ( re2 ) {\n\t\t\t\td = d.replace( re2, '' );\n\t\t\t}\n\t\t}\n\t\n\t\treturn d * 1;\n\t};\n\t\n\t\n\t// Add the numeric 'deformatting' functions for sorting and search. This is done\n\t// in a function to provide an easy ability for the language options to add\n\t// additional methods if a non-period decimal place is used.\n\tfunction _addNumericSort ( decimalPlace ) {\n\t\t$.each(\n\t\t\t{\n\t\t\t\t// Plain numbers\n\t\t\t\t\"num\": function ( d ) {\n\t\t\t\t\treturn __numericReplace( d, decimalPlace );\n\t\t\t\t},\n\t\n\t\t\t\t// Formatted numbers\n\t\t\t\t\"num-fmt\": function ( d ) {\n\t\t\t\t\treturn __numericReplace( d, decimalPlace, _re_formatted_numeric );\n\t\t\t\t},\n\t\n\t\t\t\t// HTML numeric\n\t\t\t\t\"html-num\": function ( d ) {\n\t\t\t\t\treturn __numericReplace( d, decimalPlace, _re_html );\n\t\t\t\t},\n\t\n\t\t\t\t// HTML numeric, formatted\n\t\t\t\t\"html-num-fmt\": function ( d ) {\n\t\t\t\t\treturn __numericReplace( d, decimalPlace, _re_html, _re_formatted_numeric );\n\t\t\t\t}\n\t\t\t},\n\t\t\tfunction ( key, fn ) {\n\t\t\t\t// Add the ordering method\n\t\t\t\t_ext.type.order[ key+decimalPlace+'-pre' ] = fn;\n\t\n\t\t\t\t// For HTML types add a search formatter that will strip the HTML\n\t\t\t\tif ( key.match(/^html\\-/) ) {\n\t\t\t\t\t_ext.type.search[ key+decimalPlace ] = _ext.type.search.html;\n\t\t\t\t}\n\t\t\t}\n\t\t);\n\t}\n\t\n\t\n\t// Default sort methods\n\t$.extend( _ext.type.order, {\n\t\t// Dates\n\t\t\"date-pre\": function ( d ) {\n\t\t\treturn Date.parse( d ) || 0;\n\t\t},\n\t\n\t\t// html\n\t\t\"html-pre\": function ( a ) {\n\t\t\treturn _empty(a) ?\n\t\t\t\t'' :\n\t\t\t\ta.replace ?\n\t\t\t\t\ta.replace( /<.*?>/g, \"\" ).toLowerCase() :\n\t\t\t\t\ta+'';\n\t\t},\n\t\n\t\t// string\n\t\t\"string-pre\": function ( a ) {\n\t\t\t// This is a little complex, but faster than always calling toString,\n\t\t\t// http://jsperf.com/tostring-v-check\n\t\t\treturn _empty(a) ?\n\t\t\t\t'' :\n\t\t\t\ttypeof a === 'string' ?\n\t\t\t\t\ta.toLowerCase() :\n\t\t\t\t\t! a.toString ?\n\t\t\t\t\t\t'' :\n\t\t\t\t\t\ta.toString();\n\t\t},\n\t\n\t\t// string-asc and -desc are retained only for compatibility with the old\n\t\t// sort methods\n\t\t\"string-asc\": function ( x, y ) {\n\t\t\treturn ((x < y) ? -1 : ((x > y) ? 1 : 0));\n\t\t},\n\t\n\t\t\"string-desc\": function ( x, y ) {\n\t\t\treturn ((x < y) ? 1 : ((x > y) ? -1 : 0));\n\t\t}\n\t} );\n\t\n\t\n\t// Numeric sorting types - order doesn't matter here\n\t_addNumericSort( '' );\n\t\n\t\n\t$.extend( true, DataTable.ext.renderer, {\n\t\theader: {\n\t\t\t_: function ( settings, cell, column, classes ) {\n\t\t\t\t// No additional mark-up required\n\t\t\t\t// Attach a sort listener to update on sort - note that using the\n\t\t\t\t// `DT` namespace will allow the event to be removed automatically\n\t\t\t\t// on destroy, while the `dt` namespaced event is the one we are\n\t\t\t\t// listening for\n\t\t\t\t$(settings.nTable).on( 'order.dt.DT', function ( e, ctx, sorting, columns ) {\n\t\t\t\t\tif ( settings !== ctx ) { // need to check this this is the host\n\t\t\t\t\t\treturn; // table, not a nested one\n\t\t\t\t\t}\n\t\n\t\t\t\t\tvar colIdx = column.idx;\n\t\n\t\t\t\t\tcell\n\t\t\t\t\t\t.removeClass(\n\t\t\t\t\t\t\tcolumn.sSortingClass +' '+\n\t\t\t\t\t\t\tclasses.sSortAsc +' '+\n\t\t\t\t\t\t\tclasses.sSortDesc\n\t\t\t\t\t\t)\n\t\t\t\t\t\t.addClass( columns[ colIdx ] == 'asc' ?\n\t\t\t\t\t\t\tclasses.sSortAsc : columns[ colIdx ] == 'desc' ?\n\t\t\t\t\t\t\t\tclasses.sSortDesc :\n\t\t\t\t\t\t\t\tcolumn.sSortingClass\n\t\t\t\t\t\t);\n\t\t\t\t} );\n\t\t\t},\n\t\n\t\t\tjqueryui: function ( settings, cell, column, classes ) {\n\t\t\t\t$('<div/>')\n\t\t\t\t\t.addClass( classes.sSortJUIWrapper )\n\t\t\t\t\t.append( cell.contents() )\n\t\t\t\t\t.append( $('<span/>')\n\t\t\t\t\t\t.addClass( classes.sSortIcon+' '+column.sSortingClassJUI )\n\t\t\t\t\t)\n\t\t\t\t\t.appendTo( cell );\n\t\n\t\t\t\t// Attach a sort listener to update on sort\n\t\t\t\t$(settings.nTable).on( 'order.dt.DT', function ( e, ctx, sorting, columns ) {\n\t\t\t\t\tif ( settings !== ctx ) {\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\n\t\t\t\t\tvar colIdx = column.idx;\n\t\n\t\t\t\t\tcell\n\t\t\t\t\t\t.removeClass( classes.sSortAsc +\" \"+classes.sSortDesc )\n\t\t\t\t\t\t.addClass( columns[ colIdx ] == 'asc' ?\n\t\t\t\t\t\t\tclasses.sSortAsc : columns[ colIdx ] == 'desc' ?\n\t\t\t\t\t\t\t\tclasses.sSortDesc :\n\t\t\t\t\t\t\t\tcolumn.sSortingClass\n\t\t\t\t\t\t);\n\t\n\t\t\t\t\tcell\n\t\t\t\t\t\t.find( 'span.'+classes.sSortIcon )\n\t\t\t\t\t\t.removeClass(\n\t\t\t\t\t\t\tclasses.sSortJUIAsc +\" \"+\n\t\t\t\t\t\t\tclasses.sSortJUIDesc +\" \"+\n\t\t\t\t\t\t\tclasses.sSortJUI +\" \"+\n\t\t\t\t\t\t\tclasses.sSortJUIAscAllowed +\" \"+\n\t\t\t\t\t\t\tclasses.sSortJUIDescAllowed\n\t\t\t\t\t\t)\n\t\t\t\t\t\t.addClass( columns[ colIdx ] == 'asc' ?\n\t\t\t\t\t\t\tclasses.sSortJUIAsc : columns[ colIdx ] == 'desc' ?\n\t\t\t\t\t\t\t\tclasses.sSortJUIDesc :\n\t\t\t\t\t\t\t\tcolumn.sSortingClassJUI\n\t\t\t\t\t\t);\n\t\t\t\t} );\n\t\t\t}\n\t\t}\n\t} );\n\t\n\t/*\n\t * Public helper functions. These aren't used internally by DataTables, or\n\t * called by any of the options passed into DataTables, but they can be used\n\t * externally by developers working with DataTables. They are helper functions\n\t * to make working with DataTables a little bit easier.\n\t */\n\t\n\tvar __htmlEscapeEntities = function ( d ) {\n\t\treturn typeof d === 'string' ?\n\t\t\td.replace(/</g, '<').replace(/>/g, '>').replace(/\"/g, '"') :\n\t\t\td;\n\t};\n\t\n\t/**\n\t * Helpers for `columns.render`.\n\t *\n\t * The options defined here can be used with the `columns.render` initialisation\n\t * option to provide a display renderer. The following functions are defined:\n\t *\n\t * * `number` - Will format numeric data (defined by `columns.data`) for\n\t * display, retaining the original unformatted data for sorting and filtering.\n\t * It takes 5 parameters:\n\t * * `string` - Thousands grouping separator\n\t * * `string` - Decimal point indicator\n\t * * `integer` - Number of decimal points to show\n\t * * `string` (optional) - Prefix.\n\t * * `string` (optional) - Postfix (/suffix).\n\t * * `text` - Escape HTML to help prevent XSS attacks. It has no optional\n\t * parameters.\n\t *\n\t * @example\n\t * // Column definition using the number renderer\n\t * {\n\t * data: \"salary\",\n\t * render: $.fn.dataTable.render.number( '\\'', '.', 0, '$' )\n\t * }\n\t *\n\t * @namespace\n\t */\n\tDataTable.render = {\n\t\tnumber: function ( thousands, decimal, precision, prefix, postfix ) {\n\t\t\treturn {\n\t\t\t\tdisplay: function ( d ) {\n\t\t\t\t\tif ( typeof d !== 'number' && typeof d !== 'string' ) {\n\t\t\t\t\t\treturn d;\n\t\t\t\t\t}\n\t\n\t\t\t\t\tvar negative = d < 0 ? '-' : '';\n\t\t\t\t\tvar flo = parseFloat( d );\n\t\n\t\t\t\t\t// If NaN then there isn't much formatting that we can do - just\n\t\t\t\t\t// return immediately, escaping any HTML (this was supposed to\n\t\t\t\t\t// be a number after all)\n\t\t\t\t\tif ( isNaN( flo ) ) {\n\t\t\t\t\t\treturn __htmlEscapeEntities( d );\n\t\t\t\t\t}\n\t\n\t\t\t\t\td = Math.abs( flo );\n\t\n\t\t\t\t\tvar intPart = parseInt( d, 10 );\n\t\t\t\t\tvar floatPart = precision ?\n\t\t\t\t\t\tdecimal+(d - intPart).toFixed( precision ).substring( 2 ):\n\t\t\t\t\t\t'';\n\t\n\t\t\t\t\treturn negative + (prefix||'') +\n\t\t\t\t\t\tintPart.toString().replace(\n\t\t\t\t\t\t\t/\\B(?=(\\d{3})+(?!\\d))/g, thousands\n\t\t\t\t\t\t) +\n\t\t\t\t\t\tfloatPart +\n\t\t\t\t\t\t(postfix||'');\n\t\t\t\t}\n\t\t\t};\n\t\t},\n\t\n\t\ttext: function () {\n\t\t\treturn {\n\t\t\t\tdisplay: __htmlEscapeEntities\n\t\t\t};\n\t\t}\n\t};\n\t\n\t\n\t/*\n\t * This is really a good bit rubbish this method of exposing the internal methods\n\t * publicly... - To be fixed in 2.0 using methods on the prototype\n\t */\n\t\n\t\n\t/**\n\t * Create a wrapper function for exporting an internal functions to an external API.\n\t * @param {string} fn API function name\n\t * @returns {function} wrapped function\n\t * @memberof DataTable#internal\n\t */\n\tfunction _fnExternApiFunc (fn)\n\t{\n\t\treturn function() {\n\t\t\tvar args = [_fnSettingsFromNode( this[DataTable.ext.iApiIndex] )].concat(\n\t\t\t\tArray.prototype.slice.call(arguments)\n\t\t\t);\n\t\t\treturn DataTable.ext.internal[fn].apply( this, args );\n\t\t};\n\t}\n\t\n\t\n\t/**\n\t * Reference to internal functions for use by plug-in developers. Note that\n\t * these methods are references to internal functions and are considered to be\n\t * private. If you use these methods, be aware that they are liable to change\n\t * between versions.\n\t * @namespace\n\t */\n\t$.extend( DataTable.ext.internal, {\n\t\t_fnExternApiFunc: _fnExternApiFunc,\n\t\t_fnBuildAjax: _fnBuildAjax,\n\t\t_fnAjaxUpdate: _fnAjaxUpdate,\n\t\t_fnAjaxParameters: _fnAjaxParameters,\n\t\t_fnAjaxUpdateDraw: _fnAjaxUpdateDraw,\n\t\t_fnAjaxDataSrc: _fnAjaxDataSrc,\n\t\t_fnAddColumn: _fnAddColumn,\n\t\t_fnColumnOptions: _fnColumnOptions,\n\t\t_fnAdjustColumnSizing: _fnAdjustColumnSizing,\n\t\t_fnVisibleToColumnIndex: _fnVisibleToColumnIndex,\n\t\t_fnColumnIndexToVisible: _fnColumnIndexToVisible,\n\t\t_fnVisbleColumns: _fnVisbleColumns,\n\t\t_fnGetColumns: _fnGetColumns,\n\t\t_fnColumnTypes: _fnColumnTypes,\n\t\t_fnApplyColumnDefs: _fnApplyColumnDefs,\n\t\t_fnHungarianMap: _fnHungarianMap,\n\t\t_fnCamelToHungarian: _fnCamelToHungarian,\n\t\t_fnLanguageCompat: _fnLanguageCompat,\n\t\t_fnBrowserDetect: _fnBrowserDetect,\n\t\t_fnAddData: _fnAddData,\n\t\t_fnAddTr: _fnAddTr,\n\t\t_fnNodeToDataIndex: _fnNodeToDataIndex,\n\t\t_fnNodeToColumnIndex: _fnNodeToColumnIndex,\n\t\t_fnGetCellData: _fnGetCellData,\n\t\t_fnSetCellData: _fnSetCellData,\n\t\t_fnSplitObjNotation: _fnSplitObjNotation,\n\t\t_fnGetObjectDataFn: _fnGetObjectDataFn,\n\t\t_fnSetObjectDataFn: _fnSetObjectDataFn,\n\t\t_fnGetDataMaster: _fnGetDataMaster,\n\t\t_fnClearTable: _fnClearTable,\n\t\t_fnDeleteIndex: _fnDeleteIndex,\n\t\t_fnInvalidate: _fnInvalidate,\n\t\t_fnGetRowElements: _fnGetRowElements,\n\t\t_fnCreateTr: _fnCreateTr,\n\t\t_fnBuildHead: _fnBuildHead,\n\t\t_fnDrawHead: _fnDrawHead,\n\t\t_fnDraw: _fnDraw,\n\t\t_fnReDraw: _fnReDraw,\n\t\t_fnAddOptionsHtml: _fnAddOptionsHtml,\n\t\t_fnDetectHeader: _fnDetectHeader,\n\t\t_fnGetUniqueThs: _fnGetUniqueThs,\n\t\t_fnFeatureHtmlFilter: _fnFeatureHtmlFilter,\n\t\t_fnFilterComplete: _fnFilterComplete,\n\t\t_fnFilterCustom: _fnFilterCustom,\n\t\t_fnFilterColumn: _fnFilterColumn,\n\t\t_fnFilter: _fnFilter,\n\t\t_fnFilterCreateSearch: _fnFilterCreateSearch,\n\t\t_fnEscapeRegex: _fnEscapeRegex,\n\t\t_fnFilterData: _fnFilterData,\n\t\t_fnFeatureHtmlInfo: _fnFeatureHtmlInfo,\n\t\t_fnUpdateInfo: _fnUpdateInfo,\n\t\t_fnInfoMacros: _fnInfoMacros,\n\t\t_fnInitialise: _fnInitialise,\n\t\t_fnInitComplete: _fnInitComplete,\n\t\t_fnLengthChange: _fnLengthChange,\n\t\t_fnFeatureHtmlLength: _fnFeatureHtmlLength,\n\t\t_fnFeatureHtmlPaginate: _fnFeatureHtmlPaginate,\n\t\t_fnPageChange: _fnPageChange,\n\t\t_fnFeatureHtmlProcessing: _fnFeatureHtmlProcessing,\n\t\t_fnProcessingDisplay: _fnProcessingDisplay,\n\t\t_fnFeatureHtmlTable: _fnFeatureHtmlTable,\n\t\t_fnScrollDraw: _fnScrollDraw,\n\t\t_fnApplyToChildren: _fnApplyToChildren,\n\t\t_fnCalculateColumnWidths: _fnCalculateColumnWidths,\n\t\t_fnThrottle: _fnThrottle,\n\t\t_fnConvertToWidth: _fnConvertToWidth,\n\t\t_fnGetWidestNode: _fnGetWidestNode,\n\t\t_fnGetMaxLenString: _fnGetMaxLenString,\n\t\t_fnStringToCss: _fnStringToCss,\n\t\t_fnSortFlatten: _fnSortFlatten,\n\t\t_fnSort: _fnSort,\n\t\t_fnSortAria: _fnSortAria,\n\t\t_fnSortListener: _fnSortListener,\n\t\t_fnSortAttachListener: _fnSortAttachListener,\n\t\t_fnSortingClasses: _fnSortingClasses,\n\t\t_fnSortData: _fnSortData,\n\t\t_fnSaveState: _fnSaveState,\n\t\t_fnLoadState: _fnLoadState,\n\t\t_fnSettingsFromNode: _fnSettingsFromNode,\n\t\t_fnLog: _fnLog,\n\t\t_fnMap: _fnMap,\n\t\t_fnBindAction: _fnBindAction,\n\t\t_fnCallbackReg: _fnCallbackReg,\n\t\t_fnCallbackFire: _fnCallbackFire,\n\t\t_fnLengthOverflow: _fnLengthOverflow,\n\t\t_fnRenderer: _fnRenderer,\n\t\t_fnDataSource: _fnDataSource,\n\t\t_fnRowAttributes: _fnRowAttributes,\n\t\t_fnCalculateEnd: function () {} // Used by a lot of plug-ins, but redundant\n\t\t // in 1.10, so this dead-end function is\n\t\t // added to prevent errors\n\t} );\n\t\n\n\t// jQuery access\n\t$.fn.dataTable = DataTable;\n\n\t// Provide access to the host jQuery object (circular reference)\n\tDataTable.$ = $;\n\n\t// Legacy aliases\n\t$.fn.dataTableSettings = DataTable.settings;\n\t$.fn.dataTableExt = DataTable.ext;\n\n\t// With a capital `D` we return a DataTables API instance rather than a\n\t// jQuery object\n\t$.fn.DataTable = function ( opts ) {\n\t\treturn $(this).dataTable( opts ).api();\n\t};\n\n\t// All properties that are available to $.fn.dataTable should also be\n\t// available on $.fn.DataTable\n\t$.each( DataTable, function ( prop, val ) {\n\t\t$.fn.DataTable[ prop ] = val;\n\t} );\n\n\n\t// Information about events fired by DataTables - for documentation.\n\t/**\n\t * Draw event, fired whenever the table is redrawn on the page, at the same\n\t * point as fnDrawCallback. This may be useful for binding events or\n\t * performing calculations when the table is altered at all.\n\t * @name DataTable#draw.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * Search event, fired when the searching applied to the table (using the\n\t * built-in global search, or column filters) is altered.\n\t * @name DataTable#search.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * Page change event, fired when the paging of the table is altered.\n\t * @name DataTable#page.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * Order event, fired when the ordering applied to the table is altered.\n\t * @name DataTable#order.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * DataTables initialisation complete event, fired when the table is fully\n\t * drawn, including Ajax data loaded, if Ajax data is required.\n\t * @name DataTable#init.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} oSettings DataTables settings object\n\t * @param {object} json The JSON object request from the server - only\n\t * present if client-side Ajax sourced data is used</li></ol>\n\t */\n\n\t/**\n\t * State save event, fired when the table has changed state a new state save\n\t * is required. This event allows modification of the state saving object\n\t * prior to actually doing the save, including addition or other state\n\t * properties (for plug-ins) or modification of a DataTables core property.\n\t * @name DataTable#stateSaveParams.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} oSettings DataTables settings object\n\t * @param {object} json The state information to be saved\n\t */\n\n\t/**\n\t * State load event, fired when the table is loading state from the stored\n\t * data, but prior to the settings object being modified by the saved state\n\t * - allowing modification of the saved state is required or loading of\n\t * state for a plug-in.\n\t * @name DataTable#stateLoadParams.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} oSettings DataTables settings object\n\t * @param {object} json The saved state information\n\t */\n\n\t/**\n\t * State loaded event, fired when state has been loaded from stored data and\n\t * the settings object has been modified by the loaded data.\n\t * @name DataTable#stateLoaded.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} oSettings DataTables settings object\n\t * @param {object} json The saved state information\n\t */\n\n\t/**\n\t * Processing event, fired when DataTables is doing some kind of processing\n\t * (be it, order, searcg or anything else). It can be used to indicate to\n\t * the end user that there is something happening, or that something has\n\t * finished.\n\t * @name DataTable#processing.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} oSettings DataTables settings object\n\t * @param {boolean} bShow Flag for if DataTables is doing processing or not\n\t */\n\n\t/**\n\t * Ajax (XHR) event, fired whenever an Ajax request is completed from a\n\t * request to made to the server for new data. This event is called before\n\t * DataTables processed the returned data, so it can also be used to pre-\n\t * process the data returned from the server, if needed.\n\t *\n\t * Note that this trigger is called in `fnServerData`, if you override\n\t * `fnServerData` and which to use this event, you need to trigger it in you\n\t * success function.\n\t * @name DataTable#xhr.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t * @param {object} json JSON returned from the server\n\t *\n\t * @example\n\t * // Use a custom property returned from the server in another DOM element\n\t * $('#table').dataTable().on('xhr.dt', function (e, settings, json) {\n\t * $('#status').html( json.status );\n\t * } );\n\t *\n\t * @example\n\t * // Pre-process the data returned from the server\n\t * $('#table').dataTable().on('xhr.dt', function (e, settings, json) {\n\t * for ( var i=0, ien=json.aaData.length ; i<ien ; i++ ) {\n\t * json.aaData[i].sum = json.aaData[i].one + json.aaData[i].two;\n\t * }\n\t * // Note no return - manipulate the data directly in the JSON object.\n\t * } );\n\t */\n\n\t/**\n\t * Destroy event, fired when the DataTable is destroyed by calling fnDestroy\n\t * or passing the bDestroy:true parameter in the initialisation object. This\n\t * can be used to remove bound events, added DOM nodes, etc.\n\t * @name DataTable#destroy.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * Page length change event, fired when number of records to show on each\n\t * page (the length) is changed.\n\t * @name DataTable#length.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t * @param {integer} len New length\n\t */\n\n\t/**\n\t * Column sizing has changed.\n\t * @name DataTable#column-sizing.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t */\n\n\t/**\n\t * Column visibility has changed.\n\t * @name DataTable#column-visibility.dt\n\t * @event\n\t * @param {event} e jQuery event object\n\t * @param {object} o DataTables settings object {@link DataTable.models.oSettings}\n\t * @param {int} column Column index\n\t * @param {bool} vis `false` if column now hidden, or `true` if visible\n\t */\n\n\treturn $.fn.dataTable;\n}));\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nfunction EventEmitter() {\n this._events = this._events || {};\n this._maxListeners = this._maxListeners || undefined;\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nEventEmitter.defaultMaxListeners = 10;\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function(n) {\n if (!isNumber(n) || n < 0 || isNaN(n))\n throw TypeError('n must be a positive number');\n this._maxListeners = n;\n return this;\n};\n\nEventEmitter.prototype.emit = function(type) {\n var er, handler, len, args, i, listeners;\n\n if (!this._events)\n this._events = {};\n\n // If there is no 'error' event listener then throw.\n if (type === 'error') {\n if (!this._events.error ||\n (isObject(this._events.error) && !this._events.error.length)) {\n er = arguments[1];\n if (er instanceof Error) {\n throw er; // Unhandled 'error' event\n } else {\n // At least give some kind of context to the user\n var err = new Error('Uncaught, unspecified \"error\" event. (' + er + ')');\n err.context = er;\n throw err;\n }\n }\n }\n\n handler = this._events[type];\n\n if (isUndefined(handler))\n return false;\n\n if (isFunction(handler)) {\n switch (arguments.length) {\n // fast cases\n case 1:\n handler.call(this);\n break;\n case 2:\n handler.call(this, arguments[1]);\n break;\n case 3:\n handler.call(this, arguments[1], arguments[2]);\n break;\n // slower\n default:\n args = Array.prototype.slice.call(arguments, 1);\n handler.apply(this, args);\n }\n } else if (isObject(handler)) {\n args = Array.prototype.slice.call(arguments, 1);\n listeners = handler.slice();\n len = listeners.length;\n for (i = 0; i < len; i++)\n listeners[i].apply(this, args);\n }\n\n return true;\n};\n\nEventEmitter.prototype.addListener = function(type, listener) {\n var m;\n\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n if (!this._events)\n this._events = {};\n\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (this._events.newListener)\n this.emit('newListener', type,\n isFunction(listener.listener) ?\n listener.listener : listener);\n\n if (!this._events[type])\n // Optimize the case of one listener. Don't need the extra array object.\n this._events[type] = listener;\n else if (isObject(this._events[type]))\n // If we've already got an array, just append.\n this._events[type].push(listener);\n else\n // Adding the second element, need to change to array.\n this._events[type] = [this._events[type], listener];\n\n // Check for listener leak\n if (isObject(this._events[type]) && !this._events[type].warned) {\n if (!isUndefined(this._maxListeners)) {\n m = this._maxListeners;\n } else {\n m = EventEmitter.defaultMaxListeners;\n }\n\n if (m && m > 0 && this._events[type].length > m) {\n this._events[type].warned = true;\n console.error('(node) warning: possible EventEmitter memory ' +\n 'leak detected. %d listeners added. ' +\n 'Use emitter.setMaxListeners() to increase limit.',\n this._events[type].length);\n if (typeof console.trace === 'function') {\n // not supported in IE 10\n console.trace();\n }\n }\n }\n\n return this;\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.once = function(type, listener) {\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n var fired = false;\n\n function g() {\n this.removeListener(type, g);\n\n if (!fired) {\n fired = true;\n listener.apply(this, arguments);\n }\n }\n\n g.listener = listener;\n this.on(type, g);\n\n return this;\n};\n\n// emits a 'removeListener' event iff the listener was removed\nEventEmitter.prototype.removeListener = function(type, listener) {\n var list, position, length, i;\n\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n if (!this._events || !this._events[type])\n return this;\n\n list = this._events[type];\n length = list.length;\n position = -1;\n\n if (list === listener ||\n (isFunction(list.listener) && list.listener === listener)) {\n delete this._events[type];\n if (this._events.removeListener)\n this.emit('removeListener', type, listener);\n\n } else if (isObject(list)) {\n for (i = length; i-- > 0;) {\n if (list[i] === listener ||\n (list[i].listener && list[i].listener === listener)) {\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (list.length === 1) {\n list.length = 0;\n delete this._events[type];\n } else {\n list.splice(position, 1);\n }\n\n if (this._events.removeListener)\n this.emit('removeListener', type, listener);\n }\n\n return this;\n};\n\nEventEmitter.prototype.removeAllListeners = function(type) {\n var key, listeners;\n\n if (!this._events)\n return this;\n\n // not listening for removeListener, no need to emit\n if (!this._events.removeListener) {\n if (arguments.length === 0)\n this._events = {};\n else if (this._events[type])\n delete this._events[type];\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n for (key in this._events) {\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = {};\n return this;\n }\n\n listeners = this._events[type];\n\n if (isFunction(listeners)) {\n this.removeListener(type, listeners);\n } else if (listeners) {\n // LIFO order\n while (listeners.length)\n this.removeListener(type, listeners[listeners.length - 1]);\n }\n delete this._events[type];\n\n return this;\n};\n\nEventEmitter.prototype.listeners = function(type) {\n var ret;\n if (!this._events || !this._events[type])\n ret = [];\n else if (isFunction(this._events[type]))\n ret = [this._events[type]];\n else\n ret = this._events[type].slice();\n return ret;\n};\n\nEventEmitter.prototype.listenerCount = function(type) {\n if (this._events) {\n var evlistener = this._events[type];\n\n if (isFunction(evlistener))\n return 1;\n else if (evlistener)\n return evlistener.length;\n }\n return 0;\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n return emitter.listenerCount(type);\n};\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\n","var jQuery = require('jquery');\n\n/*!\n * jQuery UI Core 1.10.4\n * http://jqueryui.com\n *\n * Copyright 2014 jQuery Foundation and other contributors\n * Released under the MIT license.\n * http://jquery.org/license\n *\n * http://api.jqueryui.com/category/ui-core/\n */\n(function( $, undefined ) {\n\nvar uuid = 0,\n\truniqueId = /^ui-id-\\d+$/;\n\n// $.ui might exist from components with no dependencies, e.g., $.ui.position\n$.ui = $.ui || {};\n\n$.extend( $.ui, {\n\tversion: \"1.10.4\",\n\n\tkeyCode: {\n\t\tBACKSPACE: 8,\n\t\tCOMMA: 188,\n\t\tDELETE: 46,\n\t\tDOWN: 40,\n\t\tEND: 35,\n\t\tENTER: 13,\n\t\tESCAPE: 27,\n\t\tHOME: 36,\n\t\tLEFT: 37,\n\t\tNUMPAD_ADD: 107,\n\t\tNUMPAD_DECIMAL: 110,\n\t\tNUMPAD_DIVIDE: 111,\n\t\tNUMPAD_ENTER: 108,\n\t\tNUMPAD_MULTIPLY: 106,\n\t\tNUMPAD_SUBTRACT: 109,\n\t\tPAGE_DOWN: 34,\n\t\tPAGE_UP: 33,\n\t\tPERIOD: 190,\n\t\tRIGHT: 39,\n\t\tSPACE: 32,\n\t\tTAB: 9,\n\t\tUP: 38\n\t}\n});\n\n// plugins\n$.fn.extend({\n\tfocus: (function( orig ) {\n\t\treturn function( delay, fn ) {\n\t\t\treturn typeof delay === \"number\" ?\n\t\t\t\tthis.each(function() {\n\t\t\t\t\tvar elem = this;\n\t\t\t\t\tsetTimeout(function() {\n\t\t\t\t\t\t$( elem ).focus();\n\t\t\t\t\t\tif ( fn ) {\n\t\t\t\t\t\t\tfn.call( elem );\n\t\t\t\t\t\t}\n\t\t\t\t\t}, delay );\n\t\t\t\t}) :\n\t\t\t\torig.apply( this, arguments );\n\t\t};\n\t})( $.fn.focus ),\n\n\tscrollParent: function() {\n\t\tvar scrollParent;\n\t\tif (($.ui.ie && (/(static|relative)/).test(this.css(\"position\"))) || (/absolute/).test(this.css(\"position\"))) {\n\t\t\tscrollParent = this.parents().filter(function() {\n\t\t\t\treturn (/(relative|absolute|fixed)/).test($.css(this,\"position\")) && (/(auto|scroll)/).test($.css(this,\"overflow\")+$.css(this,\"overflow-y\")+$.css(this,\"overflow-x\"));\n\t\t\t}).eq(0);\n\t\t} else {\n\t\t\tscrollParent = this.parents().filter(function() {\n\t\t\t\treturn (/(auto|scroll)/).test($.css(this,\"overflow\")+$.css(this,\"overflow-y\")+$.css(this,\"overflow-x\"));\n\t\t\t}).eq(0);\n\t\t}\n\n\t\treturn (/fixed/).test(this.css(\"position\")) || !scrollParent.length ? $(document) : scrollParent;\n\t},\n\n\tzIndex: function( zIndex ) {\n\t\tif ( zIndex !== undefined ) {\n\t\t\treturn this.css( \"zIndex\", zIndex );\n\t\t}\n\n\t\tif ( this.length ) {\n\t\t\tvar elem = $( this[ 0 ] ), position, value;\n\t\t\twhile ( elem.length && elem[ 0 ] !== document ) {\n\t\t\t\t// Ignore z-index if position is set to a value where z-index is ignored by the browser\n\t\t\t\t// This makes behavior of this function consistent across browsers\n\t\t\t\t// WebKit always returns auto if the element is positioned\n\t\t\t\tposition = elem.css( \"position\" );\n\t\t\t\tif ( position === \"absolute\" || position === \"relative\" || position === \"fixed\" ) {\n\t\t\t\t\t// IE returns 0 when zIndex is not specified\n\t\t\t\t\t// other browsers return a string\n\t\t\t\t\t// we ignore the case of nested elements with an explicit value of 0\n\t\t\t\t\t// <div style=\"z-index: -10;\"><div style=\"z-index: 0;\"></div></div>\n\t\t\t\t\tvalue = parseInt( elem.css( \"zIndex\" ), 10 );\n\t\t\t\t\tif ( !isNaN( value ) && value !== 0 ) {\n\t\t\t\t\t\treturn value;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telem = elem.parent();\n\t\t\t}\n\t\t}\n\n\t\treturn 0;\n\t},\n\n\tuniqueId: function() {\n\t\treturn this.each(function() {\n\t\t\tif ( !this.id ) {\n\t\t\t\tthis.id = \"ui-id-\" + (++uuid);\n\t\t\t}\n\t\t});\n\t},\n\n\tremoveUniqueId: function() {\n\t\treturn this.each(function() {\n\t\t\tif ( runiqueId.test( this.id ) ) {\n\t\t\t\t$( this ).removeAttr( \"id\" );\n\t\t\t}\n\t\t});\n\t}\n});\n\n// selectors\nfunction focusable( element, isTabIndexNotNaN ) {\n\tvar map, mapName, img,\n\t\tnodeName = element.nodeName.toLowerCase();\n\tif ( \"area\" === nodeName ) {\n\t\tmap = element.parentNode;\n\t\tmapName = map.name;\n\t\tif ( !element.href || !mapName || map.nodeName.toLowerCase() !== \"map\" ) {\n\t\t\treturn false;\n\t\t}\n\t\timg = $( \"img[usemap=#\" + mapName + \"]\" )[0];\n\t\treturn !!img && visible( img );\n\t}\n\treturn ( /input|select|textarea|button|object/.test( nodeName ) ?\n\t\t!element.disabled :\n\t\t\"a\" === nodeName ?\n\t\t\telement.href || isTabIndexNotNaN :\n\t\t\tisTabIndexNotNaN) &&\n\t\t// the element and all of its ancestors must be visible\n\t\tvisible( element );\n}\n\nfunction visible( element ) {\n\treturn $.expr.filters.visible( element ) &&\n\t\t!$( element ).parents().addBack().filter(function() {\n\t\t\treturn $.css( this, \"visibility\" ) === \"hidden\";\n\t\t}).length;\n}\n\n$.extend( $.expr[ \":\" ], {\n\tdata: $.expr.createPseudo ?\n\t\t$.expr.createPseudo(function( dataName ) {\n\t\t\treturn function( elem ) {\n\t\t\t\treturn !!$.data( elem, dataName );\n\t\t\t};\n\t\t}) :\n\t\t// support: jQuery <1.8\n\t\tfunction( elem, i, match ) {\n\t\t\treturn !!$.data( elem, match[ 3 ] );\n\t\t},\n\n\tfocusable: function( element ) {\n\t\treturn focusable( element, !isNaN( $.attr( element, \"tabindex\" ) ) );\n\t},\n\n\ttabbable: function( element ) {\n\t\tvar tabIndex = $.attr( element, \"tabindex\" ),\n\t\t\tisTabIndexNaN = isNaN( tabIndex );\n\t\treturn ( isTabIndexNaN || tabIndex >= 0 ) && focusable( element, !isTabIndexNaN );\n\t}\n});\n\n// support: jQuery <1.8\nif ( !$( \"<a>\" ).outerWidth( 1 ).jquery ) {\n\t$.each( [ \"Width\", \"Height\" ], function( i, name ) {\n\t\tvar side = name === \"Width\" ? [ \"Left\", \"Right\" ] : [ \"Top\", \"Bottom\" ],\n\t\t\ttype = name.toLowerCase(),\n\t\t\torig = {\n\t\t\t\tinnerWidth: $.fn.innerWidth,\n\t\t\t\tinnerHeight: $.fn.innerHeight,\n\t\t\t\touterWidth: $.fn.outerWidth,\n\t\t\t\touterHeight: $.fn.outerHeight\n\t\t\t};\n\n\t\tfunction reduce( elem, size, border, margin ) {\n\t\t\t$.each( side, function() {\n\t\t\t\tsize -= parseFloat( $.css( elem, \"padding\" + this ) ) || 0;\n\t\t\t\tif ( border ) {\n\t\t\t\t\tsize -= parseFloat( $.css( elem, \"border\" + this + \"Width\" ) ) || 0;\n\t\t\t\t}\n\t\t\t\tif ( margin ) {\n\t\t\t\t\tsize -= parseFloat( $.css( elem, \"margin\" + this ) ) || 0;\n\t\t\t\t}\n\t\t\t});\n\t\t\treturn size;\n\t\t}\n\n\t\t$.fn[ \"inner\" + name ] = function( size ) {\n\t\t\tif ( size === undefined ) {\n\t\t\t\treturn orig[ \"inner\" + name ].call( this );\n\t\t\t}\n\n\t\t\treturn this.each(function() {\n\t\t\t\t$( this ).css( type, reduce( this, size ) + \"px\" );\n\t\t\t});\n\t\t};\n\n\t\t$.fn[ \"outer\" + name] = function( size, margin ) {\n\t\t\tif ( typeof size !== \"number\" ) {\n\t\t\t\treturn orig[ \"outer\" + name ].call( this, size );\n\t\t\t}\n\n\t\t\treturn this.each(function() {\n\t\t\t\t$( this).css( type, reduce( this, size, true, margin ) + \"px\" );\n\t\t\t});\n\t\t};\n\t});\n}\n\n// support: jQuery <1.8\nif ( !$.fn.addBack ) {\n\t$.fn.addBack = function( selector ) {\n\t\treturn this.add( selector == null ?\n\t\t\tthis.prevObject : this.prevObject.filter( selector )\n\t\t);\n\t};\n}\n\n// support: jQuery 1.6.1, 1.6.2 (http://bugs.jquery.com/ticket/9413)\nif ( $( \"<a>\" ).data( \"a-b\", \"a\" ).removeData( \"a-b\" ).data( \"a-b\" ) ) {\n\t$.fn.removeData = (function( removeData ) {\n\t\treturn function( key ) {\n\t\t\tif ( arguments.length ) {\n\t\t\t\treturn removeData.call( this, $.camelCase( key ) );\n\t\t\t} else {\n\t\t\t\treturn removeData.call( this );\n\t\t\t}\n\t\t};\n\t})( $.fn.removeData );\n}\n\n\n\n\n\n// deprecated\n$.ui.ie = !!/msie [\\w.]+/.exec( navigator.userAgent.toLowerCase() );\n\n$.support.selectstart = \"onselectstart\" in document.createElement( \"div\" );\n$.fn.extend({\n\tdisableSelection: function() {\n\t\treturn this.bind( ( $.support.selectstart ? \"selectstart\" : \"mousedown\" ) +\n\t\t\t\".ui-disableSelection\", function( event ) {\n\t\t\t\tevent.preventDefault();\n\t\t\t});\n\t},\n\n\tenableSelection: function() {\n\t\treturn this.unbind( \".ui-disableSelection\" );\n\t}\n});\n\n$.extend( $.ui, {\n\t// $.ui.plugin is deprecated. Use $.widget() extensions instead.\n\tplugin: {\n\t\tadd: function( module, option, set ) {\n\t\t\tvar i,\n\t\t\t\tproto = $.ui[ module ].prototype;\n\t\t\tfor ( i in set ) {\n\t\t\t\tproto.plugins[ i ] = proto.plugins[ i ] || [];\n\t\t\t\tproto.plugins[ i ].push( [ option, set[ i ] ] );\n\t\t\t}\n\t\t},\n\t\tcall: function( instance, name, args ) {\n\t\t\tvar i,\n\t\t\t\tset = instance.plugins[ name ];\n\t\t\tif ( !set || !instance.element[ 0 ].parentNode || instance.element[ 0 ].parentNode.nodeType === 11 ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tfor ( i = 0; i < set.length; i++ ) {\n\t\t\t\tif ( instance.options[ set[ i ][ 0 ] ] ) {\n\t\t\t\t\tset[ i ][ 1 ].apply( instance.element, args );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\t// only used by resizable\n\thasScroll: function( el, a ) {\n\n\t\t//If overflow is hidden, the element might have extra content, but the user wants to hide it\n\t\tif ( $( el ).css( \"overflow\" ) === \"hidden\") {\n\t\t\treturn false;\n\t\t}\n\n\t\tvar scroll = ( a && a === \"left\" ) ? \"scrollLeft\" : \"scrollTop\",\n\t\t\thas = false;\n\n\t\tif ( el[ scroll ] > 0 ) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// TODO: determine which cases actually cause this to happen\n\t\t// if the element doesn't have the scroll set, see if it's possible to\n\t\t// set the scroll\n\t\tel[ scroll ] = 1;\n\t\thas = ( el[ scroll ] > 0 );\n\t\tel[ scroll ] = 0;\n\t\treturn has;\n\t}\n});\n\n})( jQuery );\n","var jQuery = require('jquery');\nrequire('./widget');\n\n/*!\n * jQuery UI Mouse 1.10.4\n * http://jqueryui.com\n *\n * Copyright 2014 jQuery Foundation and other contributors\n * Released under the MIT license.\n * http://jquery.org/license\n *\n * http://api.jqueryui.com/mouse/\n *\n * Depends:\n *\tjquery.ui.widget.js\n */\n(function( $, undefined ) {\n\nvar mouseHandled = false;\n$( document ).mouseup( function() {\n\tmouseHandled = false;\n});\n\n$.widget(\"ui.mouse\", {\n\tversion: \"1.10.4\",\n\toptions: {\n\t\tcancel: \"input,textarea,button,select,option\",\n\t\tdistance: 1,\n\t\tdelay: 0\n\t},\n\t_mouseInit: function() {\n\t\tvar that = this;\n\n\t\tthis.element\n\t\t\t.bind(\"mousedown.\"+this.widgetName, function(event) {\n\t\t\t\treturn that._mouseDown(event);\n\t\t\t})\n\t\t\t.bind(\"click.\"+this.widgetName, function(event) {\n\t\t\t\tif (true === $.data(event.target, that.widgetName + \".preventClickEvent\")) {\n\t\t\t\t\t$.removeData(event.target, that.widgetName + \".preventClickEvent\");\n\t\t\t\t\tevent.stopImmediatePropagation();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t});\n\n\t\tthis.started = false;\n\t},\n\n\t// TODO: make sure destroying one instance of mouse doesn't mess with\n\t// other instances of mouse\n\t_mouseDestroy: function() {\n\t\tthis.element.unbind(\".\"+this.widgetName);\n\t\tif ( this._mouseMoveDelegate ) {\n\t\t\t$(document)\n\t\t\t\t.unbind(\"mousemove.\"+this.widgetName, this._mouseMoveDelegate)\n\t\t\t\t.unbind(\"mouseup.\"+this.widgetName, this._mouseUpDelegate);\n\t\t}\n\t},\n\n\t_mouseDown: function(event) {\n\t\t// don't let more than one widget handle mouseStart\n\t\tif( mouseHandled ) { return; }\n\n\t\t// we may have missed mouseup (out of window)\n\t\t(this._mouseStarted && this._mouseUp(event));\n\n\t\tthis._mouseDownEvent = event;\n\n\t\tvar that = this,\n\t\t\tbtnIsLeft = (event.which === 1),\n\t\t\t// event.target.nodeName works around a bug in IE 8 with\n\t\t\t// disabled inputs (#7620)\n\t\t\telIsCancel = (typeof this.options.cancel === \"string\" && event.target.nodeName ? $(event.target).closest(this.options.cancel).length : false);\n\t\tif (!btnIsLeft || elIsCancel || !this._mouseCapture(event)) {\n\t\t\treturn true;\n\t\t}\n\n\t\tthis.mouseDelayMet = !this.options.delay;\n\t\tif (!this.mouseDelayMet) {\n\t\t\tthis._mouseDelayTimer = setTimeout(function() {\n\t\t\t\tthat.mouseDelayMet = true;\n\t\t\t}, this.options.delay);\n\t\t}\n\n\t\tif (this._mouseDistanceMet(event) && this._mouseDelayMet(event)) {\n\t\t\tthis._mouseStarted = (this._mouseStart(event) !== false);\n\t\t\tif (!this._mouseStarted) {\n\t\t\t\tevent.preventDefault();\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\t// Click event may never have fired (Gecko & Opera)\n\t\tif (true === $.data(event.target, this.widgetName + \".preventClickEvent\")) {\n\t\t\t$.removeData(event.target, this.widgetName + \".preventClickEvent\");\n\t\t}\n\n\t\t// these delegates are required to keep context\n\t\tthis._mouseMoveDelegate = function(event) {\n\t\t\treturn that._mouseMove(event);\n\t\t};\n\t\tthis._mouseUpDelegate = function(event) {\n\t\t\treturn that._mouseUp(event);\n\t\t};\n\t\t$(document)\n\t\t\t.bind(\"mousemove.\"+this.widgetName, this._mouseMoveDelegate)\n\t\t\t.bind(\"mouseup.\"+this.widgetName, this._mouseUpDelegate);\n\n\t\tevent.preventDefault();\n\n\t\tmouseHandled = true;\n\t\treturn true;\n\t},\n\n\t_mouseMove: function(event) {\n\t\t// IE mouseup check - mouseup happened when mouse was out of window\n\t\tif ($.ui.ie && ( !document.documentMode || document.documentMode < 9 ) && !event.button) {\n\t\t\treturn this._mouseUp(event);\n\t\t}\n\n\t\tif (this._mouseStarted) {\n\t\t\tthis._mouseDrag(event);\n\t\t\treturn event.preventDefault();\n\t\t}\n\n\t\tif (this._mouseDistanceMet(event) && this._mouseDelayMet(event)) {\n\t\t\tthis._mouseStarted =\n\t\t\t\t(this._mouseStart(this._mouseDownEvent, event) !== false);\n\t\t\t(this._mouseStarted ? this._mouseDrag(event) : this._mouseUp(event));\n\t\t}\n\n\t\treturn !this._mouseStarted;\n\t},\n\n\t_mouseUp: function(event) {\n\t\t$(document)\n\t\t\t.unbind(\"mousemove.\"+this.widgetName, this._mouseMoveDelegate)\n\t\t\t.unbind(\"mouseup.\"+this.widgetName, this._mouseUpDelegate);\n\n\t\tif (this._mouseStarted) {\n\t\t\tthis._mouseStarted = false;\n\n\t\t\tif (event.target === this._mouseDownEvent.target) {\n\t\t\t\t$.data(event.target, this.widgetName + \".preventClickEvent\", true);\n\t\t\t}\n\n\t\t\tthis._mouseStop(event);\n\t\t}\n\n\t\treturn false;\n\t},\n\n\t_mouseDistanceMet: function(event) {\n\t\treturn (Math.max(\n\t\t\t\tMath.abs(this._mouseDownEvent.pageX - event.pageX),\n\t\t\t\tMath.abs(this._mouseDownEvent.pageY - event.pageY)\n\t\t\t) >= this.options.distance\n\t\t);\n\t},\n\n\t_mouseDelayMet: function(/* event */) {\n\t\treturn this.mouseDelayMet;\n\t},\n\n\t// These are placeholder methods, to be overriden by extending plugin\n\t_mouseStart: function(/* event */) {},\n\t_mouseDrag: function(/* event */) {},\n\t_mouseStop: function(/* event */) {},\n\t_mouseCapture: function(/* event */) { return true; }\n});\n\n})(jQuery);\n","var jQuery = require('jquery');\nrequire('./core');\nrequire('./mouse');\nrequire('./widget');\n\n/*!\n * jQuery UI Sortable 1.10.4\n * http://jqueryui.com\n *\n * Copyright 2014 jQuery Foundation and other contributors\n * Released under the MIT license.\n * http://jquery.org/license\n *\n * http://api.jqueryui.com/sortable/\n *\n * Depends:\n *\tjquery.ui.core.js\n *\tjquery.ui.mouse.js\n *\tjquery.ui.widget.js\n */\n(function( $, undefined ) {\n\nfunction isOverAxis( x, reference, size ) {\n\treturn ( x > reference ) && ( x < ( reference + size ) );\n}\n\nfunction isFloating(item) {\n\treturn (/left|right/).test(item.css(\"float\")) || (/inline|table-cell/).test(item.css(\"display\"));\n}\n\n$.widget(\"ui.sortable\", $.ui.mouse, {\n\tversion: \"1.10.4\",\n\twidgetEventPrefix: \"sort\",\n\tready: false,\n\toptions: {\n\t\tappendTo: \"parent\",\n\t\taxis: false,\n\t\tconnectWith: false,\n\t\tcontainment: false,\n\t\tcursor: \"auto\",\n\t\tcursorAt: false,\n\t\tdropOnEmpty: true,\n\t\tforcePlaceholderSize: false,\n\t\tforceHelperSize: false,\n\t\tgrid: false,\n\t\thandle: false,\n\t\thelper: \"original\",\n\t\titems: \"> *\",\n\t\topacity: false,\n\t\tplaceholder: false,\n\t\trevert: false,\n\t\tscroll: true,\n\t\tscrollSensitivity: 20,\n\t\tscrollSpeed: 20,\n\t\tscope: \"default\",\n\t\ttolerance: \"intersect\",\n\t\tzIndex: 1000,\n\n\t\t// callbacks\n\t\tactivate: null,\n\t\tbeforeStop: null,\n\t\tchange: null,\n\t\tdeactivate: null,\n\t\tout: null,\n\t\tover: null,\n\t\treceive: null,\n\t\tremove: null,\n\t\tsort: null,\n\t\tstart: null,\n\t\tstop: null,\n\t\tupdate: null\n\t},\n\t_create: function() {\n\n\t\tvar o = this.options;\n\t\tthis.containerCache = {};\n\t\tthis.element.addClass(\"ui-sortable\");\n\n\t\t//Get the items\n\t\tthis.refresh();\n\n\t\t//Let's determine if the items are being displayed horizontally\n\t\tthis.floating = this.items.length ? o.axis === \"x\" || isFloating(this.items[0].item) : false;\n\n\t\t//Let's determine the parent's offset\n\t\tthis.offset = this.element.offset();\n\n\t\t//Initialize mouse events for interaction\n\t\tthis._mouseInit();\n\n\t\t//We're ready to go\n\t\tthis.ready = true;\n\n\t},\n\n\t_destroy: function() {\n\t\tthis.element\n\t\t\t.removeClass(\"ui-sortable ui-sortable-disabled\");\n\t\tthis._mouseDestroy();\n\n\t\tfor ( var i = this.items.length - 1; i >= 0; i-- ) {\n\t\t\tthis.items[i].item.removeData(this.widgetName + \"-item\");\n\t\t}\n\n\t\treturn this;\n\t},\n\n\t_setOption: function(key, value){\n\t\tif ( key === \"disabled\" ) {\n\t\t\tthis.options[ key ] = value;\n\n\t\t\tthis.widget().toggleClass( \"ui-sortable-disabled\", !!value );\n\t\t} else {\n\t\t\t// Don't call widget base _setOption for disable as it adds ui-state-disabled class\n\t\t\t$.Widget.prototype._setOption.apply(this, arguments);\n\t\t}\n\t},\n\n\t_mouseCapture: function(event, overrideHandle) {\n\t\tvar currentItem = null,\n\t\t\tvalidHandle = false,\n\t\t\tthat = this;\n\n\t\tif (this.reverting) {\n\t\t\treturn false;\n\t\t}\n\n\t\tif(this.options.disabled || this.options.type === \"static\") {\n\t\t\treturn false;\n\t\t}\n\n\t\t//We have to refresh the items data once first\n\t\tthis._refreshItems(event);\n\n\t\t//Find out if the clicked node (or one of its parents) is a actual item in this.items\n\t\t$(event.target).parents().each(function() {\n\t\t\tif($.data(this, that.widgetName + \"-item\") === that) {\n\t\t\t\tcurrentItem = $(this);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t\tif($.data(event.target, that.widgetName + \"-item\") === that) {\n\t\t\tcurrentItem = $(event.target);\n\t\t}\n\n\t\tif(!currentItem) {\n\t\t\treturn false;\n\t\t}\n\t\tif(this.options.handle && !overrideHandle) {\n\t\t\t$(this.options.handle, currentItem).find(\"*\").addBack().each(function() {\n\t\t\t\tif(this === event.target) {\n\t\t\t\t\tvalidHandle = true;\n\t\t\t\t}\n\t\t\t});\n\t\t\tif(!validHandle) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tthis.currentItem = currentItem;\n\t\tthis._removeCurrentsFromItems();\n\t\treturn true;\n\n\t},\n\n\t_mouseStart: function(event, overrideHandle, noActivation) {\n\n\t\tvar i, body,\n\t\t\to = this.options;\n\n\t\tthis.currentContainer = this;\n\n\t\t//We only need to call refreshPositions, because the refreshItems call has been moved to mouseCapture\n\t\tthis.refreshPositions();\n\n\t\t//Create and append the visible helper\n\t\tthis.helper = this._createHelper(event);\n\n\t\t//Cache the helper size\n\t\tthis._cacheHelperProportions();\n\n\t\t/*\n\t\t * - Position generation -\n\t\t * This block generates everything position related - it's the core of draggables.\n\t\t */\n\n\t\t//Cache the margins of the original element\n\t\tthis._cacheMargins();\n\n\t\t//Get the next scrolling parent\n\t\tthis.scrollParent = this.helper.scrollParent();\n\n\t\t//The element's absolute position on the page minus margins\n\t\tthis.offset = this.currentItem.offset();\n\t\tthis.offset = {\n\t\t\ttop: this.offset.top - this.margins.top,\n\t\t\tleft: this.offset.left - this.margins.left\n\t\t};\n\n\t\t$.extend(this.offset, {\n\t\t\tclick: { //Where the click happened, relative to the element\n\t\t\t\tleft: event.pageX - this.offset.left,\n\t\t\t\ttop: event.pageY - this.offset.top\n\t\t\t},\n\t\t\tparent: this._getParentOffset(),\n\t\t\trelative: this._getRelativeOffset() //This is a relative to absolute position minus the actual position calculation - only used for relative positioned helper\n\t\t});\n\n\t\t// Only after we got the offset, we can change the helper's position to absolute\n\t\t// TODO: Still need to figure out a way to make relative sorting possible\n\t\tthis.helper.css(\"position\", \"absolute\");\n\t\tthis.cssPosition = this.helper.css(\"position\");\n\n\t\t//Generate the original position\n\t\tthis.originalPosition = this._generatePosition(event);\n\t\tthis.originalPageX = event.pageX;\n\t\tthis.originalPageY = event.pageY;\n\n\t\t//Adjust the mouse offset relative to the helper if \"cursorAt\" is supplied\n\t\t(o.cursorAt && this._adjustOffsetFromHelper(o.cursorAt));\n\n\t\t//Cache the former DOM position\n\t\tthis.domPosition = { prev: this.currentItem.prev()[0], parent: this.currentItem.parent()[0] };\n\n\t\t//If the helper is not the original, hide the original so it's not playing any role during the drag, won't cause anything bad this way\n\t\tif(this.helper[0] !== this.currentItem[0]) {\n\t\t\tthis.currentItem.hide();\n\t\t}\n\n\t\t//Create the placeholder\n\t\tthis._createPlaceholder();\n\n\t\t//Set a containment if given in the options\n\t\tif(o.containment) {\n\t\t\tthis._setContainment();\n\t\t}\n\n\t\tif( o.cursor && o.cursor !== \"auto\" ) { // cursor option\n\t\t\tbody = this.document.find( \"body\" );\n\n\t\t\t// support: IE\n\t\t\tthis.storedCursor = body.css( \"cursor\" );\n\t\t\tbody.css( \"cursor\", o.cursor );\n\n\t\t\tthis.storedStylesheet = $( \"<style>*{ cursor: \"+o.cursor+\" !important; }</style>\" ).appendTo( body );\n\t\t}\n\n\t\tif(o.opacity) { // opacity option\n\t\t\tif (this.helper.css(\"opacity\")) {\n\t\t\t\tthis._storedOpacity = this.helper.css(\"opacity\");\n\t\t\t}\n\t\t\tthis.helper.css(\"opacity\", o.opacity);\n\t\t}\n\n\t\tif(o.zIndex) { // zIndex option\n\t\t\tif (this.helper.css(\"zIndex\")) {\n\t\t\t\tthis._storedZIndex = this.helper.css(\"zIndex\");\n\t\t\t}\n\t\t\tthis.helper.css(\"zIndex\", o.zIndex);\n\t\t}\n\n\t\t//Prepare scrolling\n\t\tif(this.scrollParent[0] !== document && this.scrollParent[0].tagName !== \"HTML\") {\n\t\t\tthis.overflowOffset = this.scrollParent.offset();\n\t\t}\n\n\t\t//Call callbacks\n\t\tthis._trigger(\"start\", event, this._uiHash());\n\n\t\t//Recache the helper size\n\t\tif(!this._preserveHelperProportions) {\n\t\t\tthis._cacheHelperProportions();\n\t\t}\n\n\n\t\t//Post \"activate\" events to possible containers\n\t\tif( !noActivation ) {\n\t\t\tfor ( i = this.containers.length - 1; i >= 0; i-- ) {\n\t\t\t\tthis.containers[ i ]._trigger( \"activate\", event, this._uiHash( this ) );\n\t\t\t}\n\t\t}\n\n\t\t//Prepare possible droppables\n\t\tif($.ui.ddmanager) {\n\t\t\t$.ui.ddmanager.current = this;\n\t\t}\n\n\t\tif ($.ui.ddmanager && !o.dropBehaviour) {\n\t\t\t$.ui.ddmanager.prepareOffsets(this, event);\n\t\t}\n\n\t\tthis.dragging = true;\n\n\t\tthis.helper.addClass(\"ui-sortable-helper\");\n\t\tthis._mouseDrag(event); //Execute the drag once - this causes the helper not to be visible before getting its correct position\n\t\treturn true;\n\n\t},\n\n\t_mouseDrag: function(event) {\n\t\tvar i, item, itemElement, intersection,\n\t\t\to = this.options,\n\t\t\tscrolled = false;\n\n\t\t//Compute the helpers position\n\t\tthis.position = this._generatePosition(event);\n\t\tthis.positionAbs = this._convertPositionTo(\"absolute\");\n\n\t\tif (!this.lastPositionAbs) {\n\t\t\tthis.lastPositionAbs = this.positionAbs;\n\t\t}\n\n\t\t//Do scrolling\n\t\tif(this.options.scroll) {\n\t\t\tif(this.scrollParent[0] !== document && this.scrollParent[0].tagName !== \"HTML\") {\n\n\t\t\t\tif((this.overflowOffset.top + this.scrollParent[0].offsetHeight) - event.pageY < o.scrollSensitivity) {\n\t\t\t\t\tthis.scrollParent[0].scrollTop = scrolled = this.scrollParent[0].scrollTop + o.scrollSpeed;\n\t\t\t\t} else if(event.pageY - this.overflowOffset.top < o.scrollSensitivity) {\n\t\t\t\t\tthis.scrollParent[0].scrollTop = scrolled = this.scrollParent[0].scrollTop - o.scrollSpeed;\n\t\t\t\t}\n\n\t\t\t\tif((this.overflowOffset.left + this.scrollParent[0].offsetWidth) - event.pageX < o.scrollSensitivity) {\n\t\t\t\t\tthis.scrollParent[0].scrollLeft = scrolled = this.scrollParent[0].scrollLeft + o.scrollSpeed;\n\t\t\t\t} else if(event.pageX - this.overflowOffset.left < o.scrollSensitivity) {\n\t\t\t\t\tthis.scrollParent[0].scrollLeft = scrolled = this.scrollParent[0].scrollLeft - o.scrollSpeed;\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tif(event.pageY - $(document).scrollTop() < o.scrollSensitivity) {\n\t\t\t\t\tscrolled = $(document).scrollTop($(document).scrollTop() - o.scrollSpeed);\n\t\t\t\t} else if($(window).height() - (event.pageY - $(document).scrollTop()) < o.scrollSensitivity) {\n\t\t\t\t\tscrolled = $(document).scrollTop($(document).scrollTop() + o.scrollSpeed);\n\t\t\t\t}\n\n\t\t\t\tif(event.pageX - $(document).scrollLeft() < o.scrollSensitivity) {\n\t\t\t\t\tscrolled = $(document).scrollLeft($(document).scrollLeft() - o.scrollSpeed);\n\t\t\t\t} else if($(window).width() - (event.pageX - $(document).scrollLeft()) < o.scrollSensitivity) {\n\t\t\t\t\tscrolled = $(document).scrollLeft($(document).scrollLeft() + o.scrollSpeed);\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif(scrolled !== false && $.ui.ddmanager && !o.dropBehaviour) {\n\t\t\t\t$.ui.ddmanager.prepareOffsets(this, event);\n\t\t\t}\n\t\t}\n\n\t\t//Regenerate the absolute position used for position checks\n\t\tthis.positionAbs = this._convertPositionTo(\"absolute\");\n\n\t\t//Set the helper position\n\t\tif(!this.options.axis || this.options.axis !== \"y\") {\n\t\t\tthis.helper[0].style.left = this.position.left+\"px\";\n\t\t}\n\t\tif(!this.options.axis || this.options.axis !== \"x\") {\n\t\t\tthis.helper[0].style.top = this.position.top+\"px\";\n\t\t}\n\n\t\t//Rearrange\n\t\tfor (i = this.items.length - 1; i >= 0; i--) {\n\n\t\t\t//Cache variables and intersection, continue if no intersection\n\t\t\titem = this.items[i];\n\t\t\titemElement = item.item[0];\n\t\t\tintersection = this._intersectsWithPointer(item);\n\t\t\tif (!intersection) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// Only put the placeholder inside the current Container, skip all\n\t\t\t// items from other containers. This works because when moving\n\t\t\t// an item from one container to another the\n\t\t\t// currentContainer is switched before the placeholder is moved.\n\t\t\t//\n\t\t\t// Without this, moving items in \"sub-sortables\" can cause\n\t\t\t// the placeholder to jitter beetween the outer and inner container.\n\t\t\tif (item.instance !== this.currentContainer) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// cannot intersect with itself\n\t\t\t// no useless actions that have been done before\n\t\t\t// no action if the item moved is the parent of the item checked\n\t\t\tif (itemElement !== this.currentItem[0] &&\n\t\t\t\tthis.placeholder[intersection === 1 ? \"next\" : \"prev\"]()[0] !== itemElement &&\n\t\t\t\t!$.contains(this.placeholder[0], itemElement) &&\n\t\t\t\t(this.options.type === \"semi-dynamic\" ? !$.contains(this.element[0], itemElement) : true)\n\t\t\t) {\n\n\t\t\t\tthis.direction = intersection === 1 ? \"down\" : \"up\";\n\n\t\t\t\tif (this.options.tolerance === \"pointer\" || this._intersectsWithSides(item)) {\n\t\t\t\t\tthis._rearrange(event, item);\n\t\t\t\t} else {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tthis._trigger(\"change\", event, this._uiHash());\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\t//Post events to containers\n\t\tthis._contactContainers(event);\n\n\t\t//Interconnect with droppables\n\t\tif($.ui.ddmanager) {\n\t\t\t$.ui.ddmanager.drag(this, event);\n\t\t}\n\n\t\t//Call callbacks\n\t\tthis._trigger(\"sort\", event, this._uiHash());\n\n\t\tthis.lastPositionAbs = this.positionAbs;\n\t\treturn false;\n\n\t},\n\n\t_mouseStop: function(event, noPropagation) {\n\n\t\tif(!event) {\n\t\t\treturn;\n\t\t}\n\n\t\t//If we are using droppables, inform the manager about the drop\n\t\tif ($.ui.ddmanager && !this.options.dropBehaviour) {\n\t\t\t$.ui.ddmanager.drop(this, event);\n\t\t}\n\n\t\tif(this.options.revert) {\n\t\t\tvar that = this,\n\t\t\t\tcur = this.placeholder.offset(),\n\t\t\t\taxis = this.options.axis,\n\t\t\t\tanimation = {};\n\n\t\t\tif ( !axis || axis === \"x\" ) {\n\t\t\t\tanimation.left = cur.left - this.offset.parent.left - this.margins.left + (this.offsetParent[0] === document.body ? 0 : this.offsetParent[0].scrollLeft);\n\t\t\t}\n\t\t\tif ( !axis || axis === \"y\" ) {\n\t\t\t\tanimation.top = cur.top - this.offset.parent.top - this.margins.top + (this.offsetParent[0] === document.body ? 0 : this.offsetParent[0].scrollTop);\n\t\t\t}\n\t\t\tthis.reverting = true;\n\t\t\t$(this.helper).animate( animation, parseInt(this.options.revert, 10) || 500, function() {\n\t\t\t\tthat._clear(event);\n\t\t\t});\n\t\t} else {\n\t\t\tthis._clear(event, noPropagation);\n\t\t}\n\n\t\treturn false;\n\n\t},\n\n\tcancel: function() {\n\n\t\tif(this.dragging) {\n\n\t\t\tthis._mouseUp({ target: null });\n\n\t\t\tif(this.options.helper === \"original\") {\n\t\t\t\tthis.currentItem.css(this._storedCSS).removeClass(\"ui-sortable-helper\");\n\t\t\t} else {\n\t\t\t\tthis.currentItem.show();\n\t\t\t}\n\n\t\t\t//Post deactivating events to containers\n\t\t\tfor (var i = this.containers.length - 1; i >= 0; i--){\n\t\t\t\tthis.containers[i]._trigger(\"deactivate\", null, this._uiHash(this));\n\t\t\t\tif(this.containers[i].containerCache.over) {\n\t\t\t\t\tthis.containers[i]._trigger(\"out\", null, this._uiHash(this));\n\t\t\t\t\tthis.containers[i].containerCache.over = 0;\n\t\t\t\t}\n\t\t\t}\n\n\t\t}\n\n\t\tif (this.placeholder) {\n\t\t\t//$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node!\n\t\t\tif(this.placeholder[0].parentNode) {\n\t\t\t\tthis.placeholder[0].parentNode.removeChild(this.placeholder[0]);\n\t\t\t}\n\t\t\tif(this.options.helper !== \"original\" && this.helper && this.helper[0].parentNode) {\n\t\t\t\tthis.helper.remove();\n\t\t\t}\n\n\t\t\t$.extend(this, {\n\t\t\t\thelper: null,\n\t\t\t\tdragging: false,\n\t\t\t\treverting: false,\n\t\t\t\t_noFinalSort: null\n\t\t\t});\n\n\t\t\tif(this.domPosition.prev) {\n\t\t\t\t$(this.domPosition.prev).after(this.currentItem);\n\t\t\t} else {\n\t\t\t\t$(this.domPosition.parent).prepend(this.currentItem);\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tserialize: function(o) {\n\n\t\tvar items = this._getItemsAsjQuery(o && o.connected),\n\t\t\tstr = [];\n\t\to = o || {};\n\n\t\t$(items).each(function() {\n\t\t\tvar res = ($(o.item || this).attr(o.attribute || \"id\") || \"\").match(o.expression || (/(.+)[\\-=_](.+)/));\n\t\t\tif (res) {\n\t\t\t\tstr.push((o.key || res[1]+\"[]\")+\"=\"+(o.key && o.expression ? res[1] : res[2]));\n\t\t\t}\n\t\t});\n\n\t\tif(!str.length && o.key) {\n\t\t\tstr.push(o.key + \"=\");\n\t\t}\n\n\t\treturn str.join(\"&\");\n\n\t},\n\n\ttoArray: function(o) {\n\n\t\tvar items = this._getItemsAsjQuery(o && o.connected),\n\t\t\tret = [];\n\n\t\to = o || {};\n\n\t\titems.each(function() { ret.push($(o.item || this).attr(o.attribute || \"id\") || \"\"); });\n\t\treturn ret;\n\n\t},\n\n\t/* Be careful with the following core functions */\n\t_intersectsWith: function(item) {\n\n\t\tvar x1 = this.positionAbs.left,\n\t\t\tx2 = x1 + this.helperProportions.width,\n\t\t\ty1 = this.positionAbs.top,\n\t\t\ty2 = y1 + this.helperProportions.height,\n\t\t\tl = item.left,\n\t\t\tr = l + item.width,\n\t\t\tt = item.top,\n\t\t\tb = t + item.height,\n\t\t\tdyClick = this.offset.click.top,\n\t\t\tdxClick = this.offset.click.left,\n\t\t\tisOverElementHeight = ( this.options.axis === \"x\" ) || ( ( y1 + dyClick ) > t && ( y1 + dyClick ) < b ),\n\t\t\tisOverElementWidth = ( this.options.axis === \"y\" ) || ( ( x1 + dxClick ) > l && ( x1 + dxClick ) < r ),\n\t\t\tisOverElement = isOverElementHeight && isOverElementWidth;\n\n\t\tif ( this.options.tolerance === \"pointer\" ||\n\t\t\tthis.options.forcePointerForContainers ||\n\t\t\t(this.options.tolerance !== \"pointer\" && this.helperProportions[this.floating ? \"width\" : \"height\"] > item[this.floating ? \"width\" : \"height\"])\n\t\t) {\n\t\t\treturn isOverElement;\n\t\t} else {\n\n\t\t\treturn (l < x1 + (this.helperProportions.width / 2) && // Right Half\n\t\t\t\tx2 - (this.helperProportions.width / 2) < r && // Left Half\n\t\t\t\tt < y1 + (this.helperProportions.height / 2) && // Bottom Half\n\t\t\t\ty2 - (this.helperProportions.height / 2) < b ); // Top Half\n\n\t\t}\n\t},\n\n\t_intersectsWithPointer: function(item) {\n\n\t\tvar isOverElementHeight = (this.options.axis === \"x\") || isOverAxis(this.positionAbs.top + this.offset.click.top, item.top, item.height),\n\t\t\tisOverElementWidth = (this.options.axis === \"y\") || isOverAxis(this.positionAbs.left + this.offset.click.left, item.left, item.width),\n\t\t\tisOverElement = isOverElementHeight && isOverElementWidth,\n\t\t\tverticalDirection = this._getDragVerticalDirection(),\n\t\t\thorizontalDirection = this._getDragHorizontalDirection();\n\n\t\tif (!isOverElement) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn this.floating ?\n\t\t\t( ((horizontalDirection && horizontalDirection === \"right\") || verticalDirection === \"down\") ? 2 : 1 )\n\t\t\t: ( verticalDirection && (verticalDirection === \"down\" ? 2 : 1) );\n\n\t},\n\n\t_intersectsWithSides: function(item) {\n\n\t\tvar isOverBottomHalf = isOverAxis(this.positionAbs.top + this.offset.click.top, item.top + (item.height/2), item.height),\n\t\t\tisOverRightHalf = isOverAxis(this.positionAbs.left + this.offset.click.left, item.left + (item.width/2), item.width),\n\t\t\tverticalDirection = this._getDragVerticalDirection(),\n\t\t\thorizontalDirection = this._getDragHorizontalDirection();\n\n\t\tif (this.floating && horizontalDirection) {\n\t\t\treturn ((horizontalDirection === \"right\" && isOverRightHalf) || (horizontalDirection === \"left\" && !isOverRightHalf));\n\t\t} else {\n\t\t\treturn verticalDirection && ((verticalDirection === \"down\" && isOverBottomHalf) || (verticalDirection === \"up\" && !isOverBottomHalf));\n\t\t}\n\n\t},\n\n\t_getDragVerticalDirection: function() {\n\t\tvar delta = this.positionAbs.top - this.lastPositionAbs.top;\n\t\treturn delta !== 0 && (delta > 0 ? \"down\" : \"up\");\n\t},\n\n\t_getDragHorizontalDirection: function() {\n\t\tvar delta = this.positionAbs.left - this.lastPositionAbs.left;\n\t\treturn delta !== 0 && (delta > 0 ? \"right\" : \"left\");\n\t},\n\n\trefresh: function(event) {\n\t\tthis._refreshItems(event);\n\t\tthis.refreshPositions();\n\t\treturn this;\n\t},\n\n\t_connectWith: function() {\n\t\tvar options = this.options;\n\t\treturn options.connectWith.constructor === String ? [options.connectWith] : options.connectWith;\n\t},\n\n\t_getItemsAsjQuery: function(connected) {\n\n\t\tvar i, j, cur, inst,\n\t\t\titems = [],\n\t\t\tqueries = [],\n\t\t\tconnectWith = this._connectWith();\n\n\t\tif(connectWith && connected) {\n\t\t\tfor (i = connectWith.length - 1; i >= 0; i--){\n\t\t\t\tcur = $(connectWith[i]);\n\t\t\t\tfor ( j = cur.length - 1; j >= 0; j--){\n\t\t\t\t\tinst = $.data(cur[j], this.widgetFullName);\n\t\t\t\t\tif(inst && inst !== this && !inst.options.disabled) {\n\t\t\t\t\t\tqueries.push([$.isFunction(inst.options.items) ? inst.options.items.call(inst.element) : $(inst.options.items, inst.element).not(\".ui-sortable-helper\").not(\".ui-sortable-placeholder\"), inst]);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tqueries.push([$.isFunction(this.options.items) ? this.options.items.call(this.element, null, { options: this.options, item: this.currentItem }) : $(this.options.items, this.element).not(\".ui-sortable-helper\").not(\".ui-sortable-placeholder\"), this]);\n\n\t\tfunction addItems() {\n\t\t\titems.push( this );\n\t\t}\n\t\tfor (i = queries.length - 1; i >= 0; i--){\n\t\t\tqueries[i][0].each( addItems );\n\t\t}\n\n\t\treturn $(items);\n\n\t},\n\n\t_removeCurrentsFromItems: function() {\n\n\t\tvar list = this.currentItem.find(\":data(\" + this.widgetName + \"-item)\");\n\n\t\tthis.items = $.grep(this.items, function (item) {\n\t\t\tfor (var j=0; j < list.length; j++) {\n\t\t\t\tif(list[j] === item.item[0]) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t});\n\n\t},\n\n\t_refreshItems: function(event) {\n\n\t\tthis.items = [];\n\t\tthis.containers = [this];\n\n\t\tvar i, j, cur, inst, targetData, _queries, item, queriesLength,\n\t\t\titems = this.items,\n\t\t\tqueries = [[$.isFunction(this.options.items) ? this.options.items.call(this.element[0], event, { item: this.currentItem }) : $(this.options.items, this.element), this]],\n\t\t\tconnectWith = this._connectWith();\n\n\t\tif(connectWith && this.ready) { //Shouldn't be run the first time through due to massive slow-down\n\t\t\tfor (i = connectWith.length - 1; i >= 0; i--){\n\t\t\t\tcur = $(connectWith[i]);\n\t\t\t\tfor (j = cur.length - 1; j >= 0; j--){\n\t\t\t\t\tinst = $.data(cur[j], this.widgetFullName);\n\t\t\t\t\tif(inst && inst !== this && !inst.options.disabled) {\n\t\t\t\t\t\tqueries.push([$.isFunction(inst.options.items) ? inst.options.items.call(inst.element[0], event, { item: this.currentItem }) : $(inst.options.items, inst.element), inst]);\n\t\t\t\t\t\tthis.containers.push(inst);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tfor (i = queries.length - 1; i >= 0; i--) {\n\t\t\ttargetData = queries[i][1];\n\t\t\t_queries = queries[i][0];\n\n\t\t\tfor (j=0, queriesLength = _queries.length; j < queriesLength; j++) {\n\t\t\t\titem = $(_queries[j]);\n\n\t\t\t\titem.data(this.widgetName + \"-item\", targetData); // Data for target checking (mouse manager)\n\n\t\t\t\titems.push({\n\t\t\t\t\titem: item,\n\t\t\t\t\tinstance: targetData,\n\t\t\t\t\twidth: 0, height: 0,\n\t\t\t\t\tleft: 0, top: 0\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t},\n\n\trefreshPositions: function(fast) {\n\n\t\t//This has to be redone because due to the item being moved out/into the offsetParent, the offsetParent's position will change\n\t\tif(this.offsetParent && this.helper) {\n\t\t\tthis.offset.parent = this._getParentOffset();\n\t\t}\n\n\t\tvar i, item, t, p;\n\n\t\tfor (i = this.items.length - 1; i >= 0; i--){\n\t\t\titem = this.items[i];\n\n\t\t\t//We ignore calculating positions of all connected containers when we're not over them\n\t\t\tif(item.instance !== this.currentContainer && this.currentContainer && item.item[0] !== this.currentItem[0]) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tt = this.options.toleranceElement ? $(this.options.toleranceElement, item.item) : item.item;\n\n\t\t\tif (!fast) {\n\t\t\t\titem.width = t.outerWidth();\n\t\t\t\titem.height = t.outerHeight();\n\t\t\t}\n\n\t\t\tp = t.offset();\n\t\t\titem.left = p.left;\n\t\t\titem.top = p.top;\n\t\t}\n\n\t\tif(this.options.custom && this.options.custom.refreshContainers) {\n\t\t\tthis.options.custom.refreshContainers.call(this);\n\t\t} else {\n\t\t\tfor (i = this.containers.length - 1; i >= 0; i--){\n\t\t\t\tp = this.containers[i].element.offset();\n\t\t\t\tthis.containers[i].containerCache.left = p.left;\n\t\t\t\tthis.containers[i].containerCache.top = p.top;\n\t\t\t\tthis.containers[i].containerCache.width\t= this.containers[i].element.outerWidth();\n\t\t\t\tthis.containers[i].containerCache.height = this.containers[i].element.outerHeight();\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\t_createPlaceholder: function(that) {\n\t\tthat = that || this;\n\t\tvar className,\n\t\t\to = that.options;\n\n\t\tif(!o.placeholder || o.placeholder.constructor === String) {\n\t\t\tclassName = o.placeholder;\n\t\t\to.placeholder = {\n\t\t\t\telement: function() {\n\n\t\t\t\t\tvar nodeName = that.currentItem[0].nodeName.toLowerCase(),\n\t\t\t\t\t\telement = $( \"<\" + nodeName + \">\", that.document[0] )\n\t\t\t\t\t\t\t.addClass(className || that.currentItem[0].className+\" ui-sortable-placeholder\")\n\t\t\t\t\t\t\t.removeClass(\"ui-sortable-helper\");\n\n\t\t\t\t\tif ( nodeName === \"tr\" ) {\n\t\t\t\t\t\tthat.currentItem.children().each(function() {\n\t\t\t\t\t\t\t$( \"<td> </td>\", that.document[0] )\n\t\t\t\t\t\t\t\t.attr( \"colspan\", $( this ).attr( \"colspan\" ) || 1 )\n\t\t\t\t\t\t\t\t.appendTo( element );\n\t\t\t\t\t\t});\n\t\t\t\t\t} else if ( nodeName === \"img\" ) {\n\t\t\t\t\t\telement.attr( \"src\", that.currentItem.attr( \"src\" ) );\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( !className ) {\n\t\t\t\t\t\telement.css( \"visibility\", \"hidden\" );\n\t\t\t\t\t}\n\n\t\t\t\t\treturn element;\n\t\t\t\t},\n\t\t\t\tupdate: function(container, p) {\n\n\t\t\t\t\t// 1. If a className is set as 'placeholder option, we don't force sizes - the class is responsible for that\n\t\t\t\t\t// 2. The option 'forcePlaceholderSize can be enabled to force it even if a class name is specified\n\t\t\t\t\tif(className && !o.forcePlaceholderSize) {\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\t//If the element doesn't have a actual height by itself (without styles coming from a stylesheet), it receives the inline height from the dragged item\n\t\t\t\t\tif(!p.height()) { p.height(that.currentItem.innerHeight() - parseInt(that.currentItem.css(\"paddingTop\")||0, 10) - parseInt(that.currentItem.css(\"paddingBottom\")||0, 10)); }\n\t\t\t\t\tif(!p.width()) { p.width(that.currentItem.innerWidth() - parseInt(that.currentItem.css(\"paddingLeft\")||0, 10) - parseInt(that.currentItem.css(\"paddingRight\")||0, 10)); }\n\t\t\t\t}\n\t\t\t};\n\t\t}\n\n\t\t//Create the placeholder\n\t\tthat.placeholder = $(o.placeholder.element.call(that.element, that.currentItem));\n\n\t\t//Append it after the actual current item\n\t\tthat.currentItem.after(that.placeholder);\n\n\t\t//Update the size of the placeholder (TODO: Logic to fuzzy, see line 316/317)\n\t\to.placeholder.update(that, that.placeholder);\n\n\t},\n\n\t_contactContainers: function(event) {\n\t\tvar i, j, dist, itemWithLeastDistance, posProperty, sizeProperty, base, cur, nearBottom, floating,\n\t\t\tinnermostContainer = null,\n\t\t\tinnermostIndex = null;\n\n\t\t// get innermost container that intersects with item\n\t\tfor (i = this.containers.length - 1; i >= 0; i--) {\n\n\t\t\t// never consider a container that's located within the item itself\n\t\t\tif($.contains(this.currentItem[0], this.containers[i].element[0])) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif(this._intersectsWith(this.containers[i].containerCache)) {\n\n\t\t\t\t// if we've already found a container and it's more \"inner\" than this, then continue\n\t\t\t\tif(innermostContainer && $.contains(this.containers[i].element[0], innermostContainer.element[0])) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tinnermostContainer = this.containers[i];\n\t\t\t\tinnermostIndex = i;\n\n\t\t\t} else {\n\t\t\t\t// container doesn't intersect. trigger \"out\" event if necessary\n\t\t\t\tif(this.containers[i].containerCache.over) {\n\t\t\t\t\tthis.containers[i]._trigger(\"out\", event, this._uiHash(this));\n\t\t\t\t\tthis.containers[i].containerCache.over = 0;\n\t\t\t\t}\n\t\t\t}\n\n\t\t}\n\n\t\t// if no intersecting containers found, return\n\t\tif(!innermostContainer) {\n\t\t\treturn;\n\t\t}\n\n\t\t// move the item into the container if it's not there already\n\t\tif(this.containers.length === 1) {\n\t\t\tif (!this.containers[innermostIndex].containerCache.over) {\n\t\t\t\tthis.containers[innermostIndex]._trigger(\"over\", event, this._uiHash(this));\n\t\t\t\tthis.containers[innermostIndex].containerCache.over = 1;\n\t\t\t}\n\t\t} else {\n\n\t\t\t//When entering a new container, we will find the item with the least distance and append our item near it\n\t\t\tdist = 10000;\n\t\t\titemWithLeastDistance = null;\n\t\t\tfloating = innermostContainer.floating || isFloating(this.currentItem);\n\t\t\tposProperty = floating ? \"left\" : \"top\";\n\t\t\tsizeProperty = floating ? \"width\" : \"height\";\n\t\t\tbase = this.positionAbs[posProperty] + this.offset.click[posProperty];\n\t\t\tfor (j = this.items.length - 1; j >= 0; j--) {\n\t\t\t\tif(!$.contains(this.containers[innermostIndex].element[0], this.items[j].item[0])) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tif(this.items[j].item[0] === this.currentItem[0]) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tif (floating && !isOverAxis(this.positionAbs.top + this.offset.click.top, this.items[j].top, this.items[j].height)) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tcur = this.items[j].item.offset()[posProperty];\n\t\t\t\tnearBottom = false;\n\t\t\t\tif(Math.abs(cur - base) > Math.abs(cur + this.items[j][sizeProperty] - base)){\n\t\t\t\t\tnearBottom = true;\n\t\t\t\t\tcur += this.items[j][sizeProperty];\n\t\t\t\t}\n\n\t\t\t\tif(Math.abs(cur - base) < dist) {\n\t\t\t\t\tdist = Math.abs(cur - base); itemWithLeastDistance = this.items[j];\n\t\t\t\t\tthis.direction = nearBottom ? \"up\": \"down\";\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t//Check if dropOnEmpty is enabled\n\t\t\tif(!itemWithLeastDistance && !this.options.dropOnEmpty) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif(this.currentContainer === this.containers[innermostIndex]) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\titemWithLeastDistance ? this._rearrange(event, itemWithLeastDistance, null, true) : this._rearrange(event, null, this.containers[innermostIndex].element, true);\n\t\t\tthis._trigger(\"change\", event, this._uiHash());\n\t\t\tthis.containers[innermostIndex]._trigger(\"change\", event, this._uiHash(this));\n\t\t\tthis.currentContainer = this.containers[innermostIndex];\n\n\t\t\t//Update the placeholder\n\t\t\tthis.options.placeholder.update(this.currentContainer, this.placeholder);\n\n\t\t\tthis.containers[innermostIndex]._trigger(\"over\", event, this._uiHash(this));\n\t\t\tthis.containers[innermostIndex].containerCache.over = 1;\n\t\t}\n\n\n\t},\n\n\t_createHelper: function(event) {\n\n\t\tvar o = this.options,\n\t\t\thelper = $.isFunction(o.helper) ? $(o.helper.apply(this.element[0], [event, this.currentItem])) : (o.helper === \"clone\" ? this.currentItem.clone() : this.currentItem);\n\n\t\t//Add the helper to the DOM if that didn't happen already\n\t\tif(!helper.parents(\"body\").length) {\n\t\t\t$(o.appendTo !== \"parent\" ? o.appendTo : this.currentItem[0].parentNode)[0].appendChild(helper[0]);\n\t\t}\n\n\t\tif(helper[0] === this.currentItem[0]) {\n\t\t\tthis._storedCSS = { width: this.currentItem[0].style.width, height: this.currentItem[0].style.height, position: this.currentItem.css(\"position\"), top: this.currentItem.css(\"top\"), left: this.currentItem.css(\"left\") };\n\t\t}\n\n\t\tif(!helper[0].style.width || o.forceHelperSize) {\n\t\t\thelper.width(this.currentItem.width());\n\t\t}\n\t\tif(!helper[0].style.height || o.forceHelperSize) {\n\t\t\thelper.height(this.currentItem.height());\n\t\t}\n\n\t\treturn helper;\n\n\t},\n\n\t_adjustOffsetFromHelper: function(obj) {\n\t\tif (typeof obj === \"string\") {\n\t\t\tobj = obj.split(\" \");\n\t\t}\n\t\tif ($.isArray(obj)) {\n\t\t\tobj = {left: +obj[0], top: +obj[1] || 0};\n\t\t}\n\t\tif (\"left\" in obj) {\n\t\t\tthis.offset.click.left = obj.left + this.margins.left;\n\t\t}\n\t\tif (\"right\" in obj) {\n\t\t\tthis.offset.click.left = this.helperProportions.width - obj.right + this.margins.left;\n\t\t}\n\t\tif (\"top\" in obj) {\n\t\t\tthis.offset.click.top = obj.top + this.margins.top;\n\t\t}\n\t\tif (\"bottom\" in obj) {\n\t\t\tthis.offset.click.top = this.helperProportions.height - obj.bottom + this.margins.top;\n\t\t}\n\t},\n\n\t_getParentOffset: function() {\n\n\n\t\t//Get the offsetParent and cache its position\n\t\tthis.offsetParent = this.helper.offsetParent();\n\t\tvar po = this.offsetParent.offset();\n\n\t\t// This is a special case where we need to modify a offset calculated on start, since the following happened:\n\t\t// 1. The position of the helper is absolute, so it's position is calculated based on the next positioned parent\n\t\t// 2. The actual offset parent is a child of the scroll parent, and the scroll parent isn't the document, which means that\n\t\t// the scroll is included in the initial calculation of the offset of the parent, and never recalculated upon drag\n\t\tif(this.cssPosition === \"absolute\" && this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) {\n\t\t\tpo.left += this.scrollParent.scrollLeft();\n\t\t\tpo.top += this.scrollParent.scrollTop();\n\t\t}\n\n\t\t// This needs to be actually done for all browsers, since pageX/pageY includes this information\n\t\t// with an ugly IE fix\n\t\tif( this.offsetParent[0] === document.body || (this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() === \"html\" && $.ui.ie)) {\n\t\t\tpo = { top: 0, left: 0 };\n\t\t}\n\n\t\treturn {\n\t\t\ttop: po.top + (parseInt(this.offsetParent.css(\"borderTopWidth\"),10) || 0),\n\t\t\tleft: po.left + (parseInt(this.offsetParent.css(\"borderLeftWidth\"),10) || 0)\n\t\t};\n\n\t},\n\n\t_getRelativeOffset: function() {\n\n\t\tif(this.cssPosition === \"relative\") {\n\t\t\tvar p = this.currentItem.position();\n\t\t\treturn {\n\t\t\t\ttop: p.top - (parseInt(this.helper.css(\"top\"),10) || 0) + this.scrollParent.scrollTop(),\n\t\t\t\tleft: p.left - (parseInt(this.helper.css(\"left\"),10) || 0) + this.scrollParent.scrollLeft()\n\t\t\t};\n\t\t} else {\n\t\t\treturn { top: 0, left: 0 };\n\t\t}\n\n\t},\n\n\t_cacheMargins: function() {\n\t\tthis.margins = {\n\t\t\tleft: (parseInt(this.currentItem.css(\"marginLeft\"),10) || 0),\n\t\t\ttop: (parseInt(this.currentItem.css(\"marginTop\"),10) || 0)\n\t\t};\n\t},\n\n\t_cacheHelperProportions: function() {\n\t\tthis.helperProportions = {\n\t\t\twidth: this.helper.outerWidth(),\n\t\t\theight: this.helper.outerHeight()\n\t\t};\n\t},\n\n\t_setContainment: function() {\n\n\t\tvar ce, co, over,\n\t\t\to = this.options;\n\t\tif(o.containment === \"parent\") {\n\t\t\to.containment = this.helper[0].parentNode;\n\t\t}\n\t\tif(o.containment === \"document\" || o.containment === \"window\") {\n\t\t\tthis.containment = [\n\t\t\t\t0 - this.offset.relative.left - this.offset.parent.left,\n\t\t\t\t0 - this.offset.relative.top - this.offset.parent.top,\n\t\t\t\t$(o.containment === \"document\" ? document : window).width() - this.helperProportions.width - this.margins.left,\n\t\t\t\t($(o.containment === \"document\" ? document : window).height() || document.body.parentNode.scrollHeight) - this.helperProportions.height - this.margins.top\n\t\t\t];\n\t\t}\n\n\t\tif(!(/^(document|window|parent)$/).test(o.containment)) {\n\t\t\tce = $(o.containment)[0];\n\t\t\tco = $(o.containment).offset();\n\t\t\tover = ($(ce).css(\"overflow\") !== \"hidden\");\n\n\t\t\tthis.containment = [\n\t\t\t\tco.left + (parseInt($(ce).css(\"borderLeftWidth\"),10) || 0) + (parseInt($(ce).css(\"paddingLeft\"),10) || 0) - this.margins.left,\n\t\t\t\tco.top + (parseInt($(ce).css(\"borderTopWidth\"),10) || 0) + (parseInt($(ce).css(\"paddingTop\"),10) || 0) - this.margins.top,\n\t\t\t\tco.left+(over ? Math.max(ce.scrollWidth,ce.offsetWidth) : ce.offsetWidth) - (parseInt($(ce).css(\"borderLeftWidth\"),10) || 0) - (parseInt($(ce).css(\"paddingRight\"),10) || 0) - this.helperProportions.width - this.margins.left,\n\t\t\t\tco.top+(over ? Math.max(ce.scrollHeight,ce.offsetHeight) : ce.offsetHeight) - (parseInt($(ce).css(\"borderTopWidth\"),10) || 0) - (parseInt($(ce).css(\"paddingBottom\"),10) || 0) - this.helperProportions.height - this.margins.top\n\t\t\t];\n\t\t}\n\n\t},\n\n\t_convertPositionTo: function(d, pos) {\n\n\t\tif(!pos) {\n\t\t\tpos = this.position;\n\t\t}\n\t\tvar mod = d === \"absolute\" ? 1 : -1,\n\t\t\tscroll = this.cssPosition === \"absolute\" && !(this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent : this.scrollParent,\n\t\t\tscrollIsRootNode = (/(html|body)/i).test(scroll[0].tagName);\n\n\t\treturn {\n\t\t\ttop: (\n\t\t\t\tpos.top\t+\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t// The absolute mouse position\n\t\t\t\tthis.offset.relative.top * mod +\t\t\t\t\t\t\t\t\t\t// Only for relative positioned nodes: Relative offset from element to offset parent\n\t\t\t\tthis.offset.parent.top * mod -\t\t\t\t\t\t\t\t\t\t\t// The offsetParent's offset without borders (offset + border)\n\t\t\t\t( ( this.cssPosition === \"fixed\" ? -this.scrollParent.scrollTop() : ( scrollIsRootNode ? 0 : scroll.scrollTop() ) ) * mod)\n\t\t\t),\n\t\t\tleft: (\n\t\t\t\tpos.left +\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t// The absolute mouse position\n\t\t\t\tthis.offset.relative.left * mod +\t\t\t\t\t\t\t\t\t\t// Only for relative positioned nodes: Relative offset from element to offset parent\n\t\t\t\tthis.offset.parent.left * mod\t-\t\t\t\t\t\t\t\t\t\t// The offsetParent's offset without borders (offset + border)\n\t\t\t\t( ( this.cssPosition === \"fixed\" ? -this.scrollParent.scrollLeft() : scrollIsRootNode ? 0 : scroll.scrollLeft() ) * mod)\n\t\t\t)\n\t\t};\n\n\t},\n\n\t_generatePosition: function(event) {\n\n\t\tvar top, left,\n\t\t\to = this.options,\n\t\t\tpageX = event.pageX,\n\t\t\tpageY = event.pageY,\n\t\t\tscroll = this.cssPosition === \"absolute\" && !(this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent : this.scrollParent, scrollIsRootNode = (/(html|body)/i).test(scroll[0].tagName);\n\n\t\t// This is another very weird special case that only happens for relative elements:\n\t\t// 1. If the css position is relative\n\t\t// 2. and the scroll parent is the document or similar to the offset parent\n\t\t// we have to refresh the relative offset during the scroll so there are no jumps\n\t\tif(this.cssPosition === \"relative\" && !(this.scrollParent[0] !== document && this.scrollParent[0] !== this.offsetParent[0])) {\n\t\t\tthis.offset.relative = this._getRelativeOffset();\n\t\t}\n\n\t\t/*\n\t\t * - Position constraining -\n\t\t * Constrain the position to a mix of grid, containment.\n\t\t */\n\n\t\tif(this.originalPosition) { //If we are not dragging yet, we won't check for options\n\n\t\t\tif(this.containment) {\n\t\t\t\tif(event.pageX - this.offset.click.left < this.containment[0]) {\n\t\t\t\t\tpageX = this.containment[0] + this.offset.click.left;\n\t\t\t\t}\n\t\t\t\tif(event.pageY - this.offset.click.top < this.containment[1]) {\n\t\t\t\t\tpageY = this.containment[1] + this.offset.click.top;\n\t\t\t\t}\n\t\t\t\tif(event.pageX - this.offset.click.left > this.containment[2]) {\n\t\t\t\t\tpageX = this.containment[2] + this.offset.click.left;\n\t\t\t\t}\n\t\t\t\tif(event.pageY - this.offset.click.top > this.containment[3]) {\n\t\t\t\t\tpageY = this.containment[3] + this.offset.click.top;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif(o.grid) {\n\t\t\t\ttop = this.originalPageY + Math.round((pageY - this.originalPageY) / o.grid[1]) * o.grid[1];\n\t\t\t\tpageY = this.containment ? ( (top - this.offset.click.top >= this.containment[1] && top - this.offset.click.top <= this.containment[3]) ? top : ((top - this.offset.click.top >= this.containment[1]) ? top - o.grid[1] : top + o.grid[1])) : top;\n\n\t\t\t\tleft = this.originalPageX + Math.round((pageX - this.originalPageX) / o.grid[0]) * o.grid[0];\n\t\t\t\tpageX = this.containment ? ( (left - this.offset.click.left >= this.containment[0] && left - this.offset.click.left <= this.containment[2]) ? left : ((left - this.offset.click.left >= this.containment[0]) ? left - o.grid[0] : left + o.grid[0])) : left;\n\t\t\t}\n\n\t\t}\n\n\t\treturn {\n\t\t\ttop: (\n\t\t\t\tpageY -\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t// The absolute mouse position\n\t\t\t\tthis.offset.click.top -\t\t\t\t\t\t\t\t\t\t\t\t\t// Click offset (relative to the element)\n\t\t\t\tthis.offset.relative.top\t-\t\t\t\t\t\t\t\t\t\t\t// Only for relative positioned nodes: Relative offset from element to offset parent\n\t\t\t\tthis.offset.parent.top +\t\t\t\t\t\t\t\t\t\t\t\t// The offsetParent's offset without borders (offset + border)\n\t\t\t\t( ( this.cssPosition === \"fixed\" ? -this.scrollParent.scrollTop() : ( scrollIsRootNode ? 0 : scroll.scrollTop() ) ))\n\t\t\t),\n\t\t\tleft: (\n\t\t\t\tpageX -\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t// The absolute mouse position\n\t\t\t\tthis.offset.click.left -\t\t\t\t\t\t\t\t\t\t\t\t// Click offset (relative to the element)\n\t\t\t\tthis.offset.relative.left\t-\t\t\t\t\t\t\t\t\t\t\t// Only for relative positioned nodes: Relative offset from element to offset parent\n\t\t\t\tthis.offset.parent.left +\t\t\t\t\t\t\t\t\t\t\t\t// The offsetParent's offset without borders (offset + border)\n\t\t\t\t( ( this.cssPosition === \"fixed\" ? -this.scrollParent.scrollLeft() : scrollIsRootNode ? 0 : scroll.scrollLeft() ))\n\t\t\t)\n\t\t};\n\n\t},\n\n\t_rearrange: function(event, i, a, hardRefresh) {\n\n\t\ta ? a[0].appendChild(this.placeholder[0]) : i.item[0].parentNode.insertBefore(this.placeholder[0], (this.direction === \"down\" ? i.item[0] : i.item[0].nextSibling));\n\n\t\t//Various things done here to improve the performance:\n\t\t// 1. we create a setTimeout, that calls refreshPositions\n\t\t// 2. on the instance, we have a counter variable, that get's higher after every append\n\t\t// 3. on the local scope, we copy the counter variable, and check in the timeout, if it's still the same\n\t\t// 4. this lets only the last addition to the timeout stack through\n\t\tthis.counter = this.counter ? ++this.counter : 1;\n\t\tvar counter = this.counter;\n\n\t\tthis._delay(function() {\n\t\t\tif(counter === this.counter) {\n\t\t\t\tthis.refreshPositions(!hardRefresh); //Precompute after each DOM insertion, NOT on mousemove\n\t\t\t}\n\t\t});\n\n\t},\n\n\t_clear: function(event, noPropagation) {\n\n\t\tthis.reverting = false;\n\t\t// We delay all events that have to be triggered to after the point where the placeholder has been removed and\n\t\t// everything else normalized again\n\t\tvar i,\n\t\t\tdelayedTriggers = [];\n\n\t\t// We first have to update the dom position of the actual currentItem\n\t\t// Note: don't do it if the current item is already removed (by a user), or it gets reappended (see #4088)\n\t\tif(!this._noFinalSort && this.currentItem.parent().length) {\n\t\t\tthis.placeholder.before(this.currentItem);\n\t\t}\n\t\tthis._noFinalSort = null;\n\n\t\tif(this.helper[0] === this.currentItem[0]) {\n\t\t\tfor(i in this._storedCSS) {\n\t\t\t\tif(this._storedCSS[i] === \"auto\" || this._storedCSS[i] === \"static\") {\n\t\t\t\t\tthis._storedCSS[i] = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t\tthis.currentItem.css(this._storedCSS).removeClass(\"ui-sortable-helper\");\n\t\t} else {\n\t\t\tthis.currentItem.show();\n\t\t}\n\n\t\tif(this.fromOutside && !noPropagation) {\n\t\t\tdelayedTriggers.push(function(event) { this._trigger(\"receive\", event, this._uiHash(this.fromOutside)); });\n\t\t}\n\t\tif((this.fromOutside || this.domPosition.prev !== this.currentItem.prev().not(\".ui-sortable-helper\")[0] || this.domPosition.parent !== this.currentItem.parent()[0]) && !noPropagation) {\n\t\t\tdelayedTriggers.push(function(event) { this._trigger(\"update\", event, this._uiHash()); }); //Trigger update callback if the DOM position has changed\n\t\t}\n\n\t\t// Check if the items Container has Changed and trigger appropriate\n\t\t// events.\n\t\tif (this !== this.currentContainer) {\n\t\t\tif(!noPropagation) {\n\t\t\t\tdelayedTriggers.push(function(event) { this._trigger(\"remove\", event, this._uiHash()); });\n\t\t\t\tdelayedTriggers.push((function(c) { return function(event) { c._trigger(\"receive\", event, this._uiHash(this)); }; }).call(this, this.currentContainer));\n\t\t\t\tdelayedTriggers.push((function(c) { return function(event) { c._trigger(\"update\", event, this._uiHash(this)); }; }).call(this, this.currentContainer));\n\t\t\t}\n\t\t}\n\n\n\t\t//Post events to containers\n\t\tfunction delayEvent( type, instance, container ) {\n\t\t\treturn function( event ) {\n\t\t\t\tcontainer._trigger( type, event, instance._uiHash( instance ) );\n\t\t\t};\n\t\t}\n\t\tfor (i = this.containers.length - 1; i >= 0; i--){\n\t\t\tif (!noPropagation) {\n\t\t\t\tdelayedTriggers.push( delayEvent( \"deactivate\", this, this.containers[ i ] ) );\n\t\t\t}\n\t\t\tif(this.containers[i].containerCache.over) {\n\t\t\t\tdelayedTriggers.push( delayEvent( \"out\", this, this.containers[ i ] ) );\n\t\t\t\tthis.containers[i].containerCache.over = 0;\n\t\t\t}\n\t\t}\n\n\t\t//Do what was originally in plugins\n\t\tif ( this.storedCursor ) {\n\t\t\tthis.document.find( \"body\" ).css( \"cursor\", this.storedCursor );\n\t\t\tthis.storedStylesheet.remove();\n\t\t}\n\t\tif(this._storedOpacity) {\n\t\t\tthis.helper.css(\"opacity\", this._storedOpacity);\n\t\t}\n\t\tif(this._storedZIndex) {\n\t\t\tthis.helper.css(\"zIndex\", this._storedZIndex === \"auto\" ? \"\" : this._storedZIndex);\n\t\t}\n\n\t\tthis.dragging = false;\n\t\tif(this.cancelHelperRemoval) {\n\t\t\tif(!noPropagation) {\n\t\t\t\tthis._trigger(\"beforeStop\", event, this._uiHash());\n\t\t\t\tfor (i=0; i < delayedTriggers.length; i++) {\n\t\t\t\t\tdelayedTriggers[i].call(this, event);\n\t\t\t\t} //Trigger all delayed events\n\t\t\t\tthis._trigger(\"stop\", event, this._uiHash());\n\t\t\t}\n\n\t\t\tthis.fromOutside = false;\n\t\t\treturn false;\n\t\t}\n\n\t\tif(!noPropagation) {\n\t\t\tthis._trigger(\"beforeStop\", event, this._uiHash());\n\t\t}\n\n\t\t//$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node!\n\t\tthis.placeholder[0].parentNode.removeChild(this.placeholder[0]);\n\n\t\tif(this.helper[0] !== this.currentItem[0]) {\n\t\t\tthis.helper.remove();\n\t\t}\n\t\tthis.helper = null;\n\n\t\tif(!noPropagation) {\n\t\t\tfor (i=0; i < delayedTriggers.length; i++) {\n\t\t\t\tdelayedTriggers[i].call(this, event);\n\t\t\t} //Trigger all delayed events\n\t\t\tthis._trigger(\"stop\", event, this._uiHash());\n\t\t}\n\n\t\tthis.fromOutside = false;\n\t\treturn true;\n\n\t},\n\n\t_trigger: function() {\n\t\tif ($.Widget.prototype._trigger.apply(this, arguments) === false) {\n\t\t\tthis.cancel();\n\t\t}\n\t},\n\n\t_uiHash: function(_inst) {\n\t\tvar inst = _inst || this;\n\t\treturn {\n\t\t\thelper: inst.helper,\n\t\t\tplaceholder: inst.placeholder || $([]),\n\t\t\tposition: inst.position,\n\t\t\toriginalPosition: inst.originalPosition,\n\t\t\toffset: inst.positionAbs,\n\t\t\titem: inst.currentItem,\n\t\t\tsender: _inst ? _inst.element : null\n\t\t};\n\t}\n\n});\n\n})(jQuery);\n","var jQuery = require('jquery');\n\n/*!\n * jQuery UI Widget 1.10.4\n * http://jqueryui.com\n *\n * Copyright 2014 jQuery Foundation and other contributors\n * Released under the MIT license.\n * http://jquery.org/license\n *\n * http://api.jqueryui.com/jQuery.widget/\n */\n(function( $, undefined ) {\n\nvar uuid = 0,\n\tslice = Array.prototype.slice,\n\t_cleanData = $.cleanData;\n$.cleanData = function( elems ) {\n\tfor ( var i = 0, elem; (elem = elems[i]) != null; i++ ) {\n\t\ttry {\n\t\t\t$( elem ).triggerHandler( \"remove\" );\n\t\t// http://bugs.jquery.com/ticket/8235\n\t\t} catch( e ) {}\n\t}\n\t_cleanData( elems );\n};\n\n$.widget = function( name, base, prototype ) {\n\tvar fullName, existingConstructor, constructor, basePrototype,\n\t\t// proxiedPrototype allows the provided prototype to remain unmodified\n\t\t// so that it can be used as a mixin for multiple widgets (#8876)\n\t\tproxiedPrototype = {},\n\t\tnamespace = name.split( \".\" )[ 0 ];\n\n\tname = name.split( \".\" )[ 1 ];\n\tfullName = namespace + \"-\" + name;\n\n\tif ( !prototype ) {\n\t\tprototype = base;\n\t\tbase = $.Widget;\n\t}\n\n\t// create selector for plugin\n\t$.expr[ \":\" ][ fullName.toLowerCase() ] = function( elem ) {\n\t\treturn !!$.data( elem, fullName );\n\t};\n\n\t$[ namespace ] = $[ namespace ] || {};\n\texistingConstructor = $[ namespace ][ name ];\n\tconstructor = $[ namespace ][ name ] = function( options, element ) {\n\t\t// allow instantiation without \"new\" keyword\n\t\tif ( !this._createWidget ) {\n\t\t\treturn new constructor( options, element );\n\t\t}\n\n\t\t// allow instantiation without initializing for simple inheritance\n\t\t// must use \"new\" keyword (the code above always passes args)\n\t\tif ( arguments.length ) {\n\t\t\tthis._createWidget( options, element );\n\t\t}\n\t};\n\t// extend with the existing constructor to carry over any static properties\n\t$.extend( constructor, existingConstructor, {\n\t\tversion: prototype.version,\n\t\t// copy the object used to create the prototype in case we need to\n\t\t// redefine the widget later\n\t\t_proto: $.extend( {}, prototype ),\n\t\t// track widgets that inherit from this widget in case this widget is\n\t\t// redefined after a widget inherits from it\n\t\t_childConstructors: []\n\t});\n\n\tbasePrototype = new base();\n\t// we need to make the options hash a property directly on the new instance\n\t// otherwise we'll modify the options hash on the prototype that we're\n\t// inheriting from\n\tbasePrototype.options = $.widget.extend( {}, basePrototype.options );\n\t$.each( prototype, function( prop, value ) {\n\t\tif ( !$.isFunction( value ) ) {\n\t\t\tproxiedPrototype[ prop ] = value;\n\t\t\treturn;\n\t\t}\n\t\tproxiedPrototype[ prop ] = (function() {\n\t\t\tvar _super = function() {\n\t\t\t\t\treturn base.prototype[ prop ].apply( this, arguments );\n\t\t\t\t},\n\t\t\t\t_superApply = function( args ) {\n\t\t\t\t\treturn base.prototype[ prop ].apply( this, args );\n\t\t\t\t};\n\t\t\treturn function() {\n\t\t\t\tvar __super = this._super,\n\t\t\t\t\t__superApply = this._superApply,\n\t\t\t\t\treturnValue;\n\n\t\t\t\tthis._super = _super;\n\t\t\t\tthis._superApply = _superApply;\n\n\t\t\t\treturnValue = value.apply( this, arguments );\n\n\t\t\t\tthis._super = __super;\n\t\t\t\tthis._superApply = __superApply;\n\n\t\t\t\treturn returnValue;\n\t\t\t};\n\t\t})();\n\t});\n\tconstructor.prototype = $.widget.extend( basePrototype, {\n\t\t// TODO: remove support for widgetEventPrefix\n\t\t// always use the name + a colon as the prefix, e.g., draggable:start\n\t\t// don't prefix for widgets that aren't DOM-based\n\t\twidgetEventPrefix: existingConstructor ? (basePrototype.widgetEventPrefix || name) : name\n\t}, proxiedPrototype, {\n\t\tconstructor: constructor,\n\t\tnamespace: namespace,\n\t\twidgetName: name,\n\t\twidgetFullName: fullName\n\t});\n\n\t// If this widget is being redefined then we need to find all widgets that\n\t// are inheriting from it and redefine all of them so that they inherit from\n\t// the new version of this widget. We're essentially trying to replace one\n\t// level in the prototype chain.\n\tif ( existingConstructor ) {\n\t\t$.each( existingConstructor._childConstructors, function( i, child ) {\n\t\t\tvar childPrototype = child.prototype;\n\n\t\t\t// redefine the child widget using the same prototype that was\n\t\t\t// originally used, but inherit from the new version of the base\n\t\t\t$.widget( childPrototype.namespace + \".\" + childPrototype.widgetName, constructor, child._proto );\n\t\t});\n\t\t// remove the list of existing child constructors from the old constructor\n\t\t// so the old child constructors can be garbage collected\n\t\tdelete existingConstructor._childConstructors;\n\t} else {\n\t\tbase._childConstructors.push( constructor );\n\t}\n\n\t$.widget.bridge( name, constructor );\n};\n\n$.widget.extend = function( target ) {\n\tvar input = slice.call( arguments, 1 ),\n\t\tinputIndex = 0,\n\t\tinputLength = input.length,\n\t\tkey,\n\t\tvalue;\n\tfor ( ; inputIndex < inputLength; inputIndex++ ) {\n\t\tfor ( key in input[ inputIndex ] ) {\n\t\t\tvalue = input[ inputIndex ][ key ];\n\t\t\tif ( input[ inputIndex ].hasOwnProperty( key ) && value !== undefined ) {\n\t\t\t\t// Clone objects\n\t\t\t\tif ( $.isPlainObject( value ) ) {\n\t\t\t\t\ttarget[ key ] = $.isPlainObject( target[ key ] ) ?\n\t\t\t\t\t\t$.widget.extend( {}, target[ key ], value ) :\n\t\t\t\t\t\t// Don't extend strings, arrays, etc. with objects\n\t\t\t\t\t\t$.widget.extend( {}, value );\n\t\t\t\t// Copy everything else by reference\n\t\t\t\t} else {\n\t\t\t\t\ttarget[ key ] = value;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\treturn target;\n};\n\n$.widget.bridge = function( name, object ) {\n\tvar fullName = object.prototype.widgetFullName || name;\n\t$.fn[ name ] = function( options ) {\n\t\tvar isMethodCall = typeof options === \"string\",\n\t\t\targs = slice.call( arguments, 1 ),\n\t\t\treturnValue = this;\n\n\t\t// allow multiple hashes to be passed on init\n\t\toptions = !isMethodCall && args.length ?\n\t\t\t$.widget.extend.apply( null, [ options ].concat(args) ) :\n\t\t\toptions;\n\n\t\tif ( isMethodCall ) {\n\t\t\tthis.each(function() {\n\t\t\t\tvar methodValue,\n\t\t\t\t\tinstance = $.data( this, fullName );\n\t\t\t\tif ( !instance ) {\n\t\t\t\t\treturn $.error( \"cannot call methods on \" + name + \" prior to initialization; \" +\n\t\t\t\t\t\t\"attempted to call method '\" + options + \"'\" );\n\t\t\t\t}\n\t\t\t\tif ( !$.isFunction( instance[options] ) || options.charAt( 0 ) === \"_\" ) {\n\t\t\t\t\treturn $.error( \"no such method '\" + options + \"' for \" + name + \" widget instance\" );\n\t\t\t\t}\n\t\t\t\tmethodValue = instance[ options ].apply( instance, args );\n\t\t\t\tif ( methodValue !== instance && methodValue !== undefined ) {\n\t\t\t\t\treturnValue = methodValue && methodValue.jquery ?\n\t\t\t\t\t\treturnValue.pushStack( methodValue.get() ) :\n\t\t\t\t\t\tmethodValue;\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tthis.each(function() {\n\t\t\t\tvar instance = $.data( this, fullName );\n\t\t\t\tif ( instance ) {\n\t\t\t\t\tinstance.option( options || {} )._init();\n\t\t\t\t} else {\n\t\t\t\t\t$.data( this, fullName, new object( options, this ) );\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\treturn returnValue;\n\t};\n};\n\n$.Widget = function( /* options, element */ ) {};\n$.Widget._childConstructors = [];\n\n$.Widget.prototype = {\n\twidgetName: \"widget\",\n\twidgetEventPrefix: \"\",\n\tdefaultElement: \"<div>\",\n\toptions: {\n\t\tdisabled: false,\n\n\t\t// callbacks\n\t\tcreate: null\n\t},\n\t_createWidget: function( options, element ) {\n\t\telement = $( element || this.defaultElement || this )[ 0 ];\n\t\tthis.element = $( element );\n\t\tthis.uuid = uuid++;\n\t\tthis.eventNamespace = \".\" + this.widgetName + this.uuid;\n\t\tthis.options = $.widget.extend( {},\n\t\t\tthis.options,\n\t\t\tthis._getCreateOptions(),\n\t\t\toptions );\n\n\t\tthis.bindings = $();\n\t\tthis.hoverable = $();\n\t\tthis.focusable = $();\n\n\t\tif ( element !== this ) {\n\t\t\t$.data( element, this.widgetFullName, this );\n\t\t\tthis._on( true, this.element, {\n\t\t\t\tremove: function( event ) {\n\t\t\t\t\tif ( event.target === element ) {\n\t\t\t\t\t\tthis.destroy();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t\tthis.document = $( element.style ?\n\t\t\t\t// element within the document\n\t\t\t\telement.ownerDocument :\n\t\t\t\t// element is window or document\n\t\t\t\telement.document || element );\n\t\t\tthis.window = $( this.document[0].defaultView || this.document[0].parentWindow );\n\t\t}\n\n\t\tthis._create();\n\t\tthis._trigger( \"create\", null, this._getCreateEventData() );\n\t\tthis._init();\n\t},\n\t_getCreateOptions: $.noop,\n\t_getCreateEventData: $.noop,\n\t_create: $.noop,\n\t_init: $.noop,\n\n\tdestroy: function() {\n\t\tthis._destroy();\n\t\t// we can probably remove the unbind calls in 2.0\n\t\t// all event bindings should go through this._on()\n\t\tthis.element\n\t\t\t.unbind( this.eventNamespace )\n\t\t\t// 1.9 BC for #7810\n\t\t\t// TODO remove dual storage\n\t\t\t.removeData( this.widgetName )\n\t\t\t.removeData( this.widgetFullName )\n\t\t\t// support: jquery <1.6.3\n\t\t\t// http://bugs.jquery.com/ticket/9413\n\t\t\t.removeData( $.camelCase( this.widgetFullName ) );\n\t\tthis.widget()\n\t\t\t.unbind( this.eventNamespace )\n\t\t\t.removeAttr( \"aria-disabled\" )\n\t\t\t.removeClass(\n\t\t\t\tthis.widgetFullName + \"-disabled \" +\n\t\t\t\t\"ui-state-disabled\" );\n\n\t\t// clean up events and states\n\t\tthis.bindings.unbind( this.eventNamespace );\n\t\tthis.hoverable.removeClass( \"ui-state-hover\" );\n\t\tthis.focusable.removeClass( \"ui-state-focus\" );\n\t},\n\t_destroy: $.noop,\n\n\twidget: function() {\n\t\treturn this.element;\n\t},\n\n\toption: function( key, value ) {\n\t\tvar options = key,\n\t\t\tparts,\n\t\t\tcurOption,\n\t\t\ti;\n\n\t\tif ( arguments.length === 0 ) {\n\t\t\t// don't return a reference to the internal hash\n\t\t\treturn $.widget.extend( {}, this.options );\n\t\t}\n\n\t\tif ( typeof key === \"string\" ) {\n\t\t\t// handle nested keys, e.g., \"foo.bar\" => { foo: { bar: ___ } }\n\t\t\toptions = {};\n\t\t\tparts = key.split( \".\" );\n\t\t\tkey = parts.shift();\n\t\t\tif ( parts.length ) {\n\t\t\t\tcurOption = options[ key ] = $.widget.extend( {}, this.options[ key ] );\n\t\t\t\tfor ( i = 0; i < parts.length - 1; i++ ) {\n\t\t\t\t\tcurOption[ parts[ i ] ] = curOption[ parts[ i ] ] || {};\n\t\t\t\t\tcurOption = curOption[ parts[ i ] ];\n\t\t\t\t}\n\t\t\t\tkey = parts.pop();\n\t\t\t\tif ( arguments.length === 1 ) {\n\t\t\t\t\treturn curOption[ key ] === undefined ? null : curOption[ key ];\n\t\t\t\t}\n\t\t\t\tcurOption[ key ] = value;\n\t\t\t} else {\n\t\t\t\tif ( arguments.length === 1 ) {\n\t\t\t\t\treturn this.options[ key ] === undefined ? null : this.options[ key ];\n\t\t\t\t}\n\t\t\t\toptions[ key ] = value;\n\t\t\t}\n\t\t}\n\n\t\tthis._setOptions( options );\n\n\t\treturn this;\n\t},\n\t_setOptions: function( options ) {\n\t\tvar key;\n\n\t\tfor ( key in options ) {\n\t\t\tthis._setOption( key, options[ key ] );\n\t\t}\n\n\t\treturn this;\n\t},\n\t_setOption: function( key, value ) {\n\t\tthis.options[ key ] = value;\n\n\t\tif ( key === \"disabled\" ) {\n\t\t\tthis.widget()\n\t\t\t\t.toggleClass( this.widgetFullName + \"-disabled ui-state-disabled\", !!value )\n\t\t\t\t.attr( \"aria-disabled\", value );\n\t\t\tthis.hoverable.removeClass( \"ui-state-hover\" );\n\t\t\tthis.focusable.removeClass( \"ui-state-focus\" );\n\t\t}\n\n\t\treturn this;\n\t},\n\n\tenable: function() {\n\t\treturn this._setOption( \"disabled\", false );\n\t},\n\tdisable: function() {\n\t\treturn this._setOption( \"disabled\", true );\n\t},\n\n\t_on: function( suppressDisabledCheck, element, handlers ) {\n\t\tvar delegateElement,\n\t\t\tinstance = this;\n\n\t\t// no suppressDisabledCheck flag, shuffle arguments\n\t\tif ( typeof suppressDisabledCheck !== \"boolean\" ) {\n\t\t\thandlers = element;\n\t\t\telement = suppressDisabledCheck;\n\t\t\tsuppressDisabledCheck = false;\n\t\t}\n\n\t\t// no element argument, shuffle and use this.element\n\t\tif ( !handlers ) {\n\t\t\thandlers = element;\n\t\t\telement = this.element;\n\t\t\tdelegateElement = this.widget();\n\t\t} else {\n\t\t\t// accept selectors, DOM elements\n\t\t\telement = delegateElement = $( element );\n\t\t\tthis.bindings = this.bindings.add( element );\n\t\t}\n\n\t\t$.each( handlers, function( event, handler ) {\n\t\t\tfunction handlerProxy() {\n\t\t\t\t// allow widgets to customize the disabled handling\n\t\t\t\t// - disabled as an array instead of boolean\n\t\t\t\t// - disabled class as method for disabling individual parts\n\t\t\t\tif ( !suppressDisabledCheck &&\n\t\t\t\t\t\t( instance.options.disabled === true ||\n\t\t\t\t\t\t\t$( this ).hasClass( \"ui-state-disabled\" ) ) ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\treturn ( typeof handler === \"string\" ? instance[ handler ] : handler )\n\t\t\t\t\t.apply( instance, arguments );\n\t\t\t}\n\n\t\t\t// copy the guid so direct unbinding works\n\t\t\tif ( typeof handler !== \"string\" ) {\n\t\t\t\thandlerProxy.guid = handler.guid =\n\t\t\t\t\thandler.guid || handlerProxy.guid || $.guid++;\n\t\t\t}\n\n\t\t\tvar match = event.match( /^(\\w+)\\s*(.*)$/ ),\n\t\t\t\teventName = match[1] + instance.eventNamespace,\n\t\t\t\tselector = match[2];\n\t\t\tif ( selector ) {\n\t\t\t\tdelegateElement.delegate( selector, eventName, handlerProxy );\n\t\t\t} else {\n\t\t\t\telement.bind( eventName, handlerProxy );\n\t\t\t}\n\t\t});\n\t},\n\n\t_off: function( element, eventName ) {\n\t\teventName = (eventName || \"\").split( \" \" ).join( this.eventNamespace + \" \" ) + this.eventNamespace;\n\t\telement.unbind( eventName ).undelegate( eventName );\n\t},\n\n\t_delay: function( handler, delay ) {\n\t\tfunction handlerProxy() {\n\t\t\treturn ( typeof handler === \"string\" ? instance[ handler ] : handler )\n\t\t\t\t.apply( instance, arguments );\n\t\t}\n\t\tvar instance = this;\n\t\treturn setTimeout( handlerProxy, delay || 0 );\n\t},\n\n\t_hoverable: function( element ) {\n\t\tthis.hoverable = this.hoverable.add( element );\n\t\tthis._on( element, {\n\t\t\tmouseenter: function( event ) {\n\t\t\t\t$( event.currentTarget ).addClass( \"ui-state-hover\" );\n\t\t\t},\n\t\t\tmouseleave: function( event ) {\n\t\t\t\t$( event.currentTarget ).removeClass( \"ui-state-hover\" );\n\t\t\t}\n\t\t});\n\t},\n\n\t_focusable: function( element ) {\n\t\tthis.focusable = this.focusable.add( element );\n\t\tthis._on( element, {\n\t\t\tfocusin: function( event ) {\n\t\t\t\t$( event.currentTarget ).addClass( \"ui-state-focus\" );\n\t\t\t},\n\t\t\tfocusout: function( event ) {\n\t\t\t\t$( event.currentTarget ).removeClass( \"ui-state-focus\" );\n\t\t\t}\n\t\t});\n\t},\n\n\t_trigger: function( type, event, data ) {\n\t\tvar prop, orig,\n\t\t\tcallback = this.options[ type ];\n\n\t\tdata = data || {};\n\t\tevent = $.Event( event );\n\t\tevent.type = ( type === this.widgetEventPrefix ?\n\t\t\ttype :\n\t\t\tthis.widgetEventPrefix + type ).toLowerCase();\n\t\t// the original event may come from any element\n\t\t// so we need to reset the target on the new event\n\t\tevent.target = this.element[ 0 ];\n\n\t\t// copy original event properties over to the new event\n\t\torig = event.originalEvent;\n\t\tif ( orig ) {\n\t\t\tfor ( prop in orig ) {\n\t\t\t\tif ( !( prop in event ) ) {\n\t\t\t\t\tevent[ prop ] = orig[ prop ];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.element.trigger( event, data );\n\t\treturn !( $.isFunction( callback ) &&\n\t\t\tcallback.apply( this.element[0], [ event ].concat( data ) ) === false ||\n\t\t\tevent.isDefaultPrevented() );\n\t}\n};\n\n$.each( { show: \"fadeIn\", hide: \"fadeOut\" }, function( method, defaultEffect ) {\n\t$.Widget.prototype[ \"_\" + method ] = function( element, options, callback ) {\n\t\tif ( typeof options === \"string\" ) {\n\t\t\toptions = { effect: options };\n\t\t}\n\t\tvar hasOptions,\n\t\t\teffectName = !options ?\n\t\t\t\tmethod :\n\t\t\t\toptions === true || typeof options === \"number\" ?\n\t\t\t\t\tdefaultEffect :\n\t\t\t\t\toptions.effect || defaultEffect;\n\t\toptions = options || {};\n\t\tif ( typeof options === \"number\" ) {\n\t\t\toptions = { duration: options };\n\t\t}\n\t\thasOptions = !$.isEmptyObject( options );\n\t\toptions.complete = callback;\n\t\tif ( options.delay ) {\n\t\t\telement.delay( options.delay );\n\t\t}\n\t\tif ( hasOptions && $.effects && $.effects.effect[ effectName ] ) {\n\t\t\telement[ method ]( options );\n\t\t} else if ( effectName !== method && element[ effectName ] ) {\n\t\t\telement[ effectName ]( options.duration, options.easing, callback );\n\t\t} else {\n\t\t\telement.queue(function( next ) {\n\t\t\t\t$( this )[ method ]();\n\t\t\t\tif ( callback ) {\n\t\t\t\t\tcallback.call( element[ 0 ] );\n\t\t\t\t}\n\t\t\t\tnext();\n\t\t\t});\n\t\t}\n\t};\n});\n\n})( jQuery );\n","/*!\n * jQuery JavaScript Library v2.2.4\n * http://jquery.com/\n *\n * Includes Sizzle.js\n * http://sizzlejs.com/\n *\n * Copyright jQuery Foundation and other contributors\n * Released under the MIT license\n * http://jquery.org/license\n *\n * Date: 2016-05-20T17:23Z\n */\n\n(function( global, factory ) {\n\n\tif ( typeof module === \"object\" && typeof module.exports === \"object\" ) {\n\t\t// For CommonJS and CommonJS-like environments where a proper `window`\n\t\t// is present, execute the factory and get jQuery.\n\t\t// For environments that do not have a `window` with a `document`\n\t\t// (such as Node.js), expose a factory as module.exports.\n\t\t// This accentuates the need for the creation of a real `window`.\n\t\t// e.g. var jQuery = require(\"jquery\")(window);\n\t\t// See ticket #14549 for more info.\n\t\tmodule.exports = global.document ?\n\t\t\tfactory( global, true ) :\n\t\t\tfunction( w ) {\n\t\t\t\tif ( !w.document ) {\n\t\t\t\t\tthrow new Error( \"jQuery requires a window with a document\" );\n\t\t\t\t}\n\t\t\t\treturn factory( w );\n\t\t\t};\n\t} else {\n\t\tfactory( global );\n\t}\n\n// Pass this if window is not defined yet\n}(typeof window !== \"undefined\" ? window : this, function( window, noGlobal ) {\n\n// Support: Firefox 18+\n// Can't be in strict mode, several libs including ASP.NET trace\n// the stack via arguments.caller.callee and Firefox dies if\n// you try to trace through \"use strict\" call chains. (#13335)\n//\"use strict\";\nvar arr = [];\n\nvar document = window.document;\n\nvar slice = arr.slice;\n\nvar concat = arr.concat;\n\nvar push = arr.push;\n\nvar indexOf = arr.indexOf;\n\nvar class2type = {};\n\nvar toString = class2type.toString;\n\nvar hasOwn = class2type.hasOwnProperty;\n\nvar support = {};\n\n\n\nvar\n\tversion = \"2.2.4\",\n\n\t// Define a local copy of jQuery\n\tjQuery = function( selector, context ) {\n\n\t\t// The jQuery object is actually just the init constructor 'enhanced'\n\t\t// Need init if jQuery is called (just allow error to be thrown if not included)\n\t\treturn new jQuery.fn.init( selector, context );\n\t},\n\n\t// Support: Android<4.1\n\t// Make sure we trim BOM and NBSP\n\trtrim = /^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g,\n\n\t// Matches dashed string for camelizing\n\trmsPrefix = /^-ms-/,\n\trdashAlpha = /-([\\da-z])/gi,\n\n\t// Used by jQuery.camelCase as callback to replace()\n\tfcamelCase = function( all, letter ) {\n\t\treturn letter.toUpperCase();\n\t};\n\njQuery.fn = jQuery.prototype = {\n\n\t// The current version of jQuery being used\n\tjquery: version,\n\n\tconstructor: jQuery,\n\n\t// Start with an empty selector\n\tselector: \"\",\n\n\t// The default length of a jQuery object is 0\n\tlength: 0,\n\n\ttoArray: function() {\n\t\treturn slice.call( this );\n\t},\n\n\t// Get the Nth element in the matched element set OR\n\t// Get the whole matched element set as a clean array\n\tget: function( num ) {\n\t\treturn num != null ?\n\n\t\t\t// Return just the one element from the set\n\t\t\t( num < 0 ? this[ num + this.length ] : this[ num ] ) :\n\n\t\t\t// Return all the elements in a clean array\n\t\t\tslice.call( this );\n\t},\n\n\t// Take an array of elements and push it onto the stack\n\t// (returning the new matched element set)\n\tpushStack: function( elems ) {\n\n\t\t// Build a new jQuery matched element set\n\t\tvar ret = jQuery.merge( this.constructor(), elems );\n\n\t\t// Add the old object onto the stack (as a reference)\n\t\tret.prevObject = this;\n\t\tret.context = this.context;\n\n\t\t// Return the newly-formed element set\n\t\treturn ret;\n\t},\n\n\t// Execute a callback for every element in the matched set.\n\teach: function( callback ) {\n\t\treturn jQuery.each( this, callback );\n\t},\n\n\tmap: function( callback ) {\n\t\treturn this.pushStack( jQuery.map( this, function( elem, i ) {\n\t\t\treturn callback.call( elem, i, elem );\n\t\t} ) );\n\t},\n\n\tslice: function() {\n\t\treturn this.pushStack( slice.apply( this, arguments ) );\n\t},\n\n\tfirst: function() {\n\t\treturn this.eq( 0 );\n\t},\n\n\tlast: function() {\n\t\treturn this.eq( -1 );\n\t},\n\n\teq: function( i ) {\n\t\tvar len = this.length,\n\t\t\tj = +i + ( i < 0 ? len : 0 );\n\t\treturn this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] );\n\t},\n\n\tend: function() {\n\t\treturn this.prevObject || this.constructor();\n\t},\n\n\t// For internal use only.\n\t// Behaves like an Array's method, not like a jQuery method.\n\tpush: push,\n\tsort: arr.sort,\n\tsplice: arr.splice\n};\n\njQuery.extend = jQuery.fn.extend = function() {\n\tvar options, name, src, copy, copyIsArray, clone,\n\t\ttarget = arguments[ 0 ] || {},\n\t\ti = 1,\n\t\tlength = arguments.length,\n\t\tdeep = false;\n\n\t// Handle a deep copy situation\n\tif ( typeof target === \"boolean\" ) {\n\t\tdeep = target;\n\n\t\t// Skip the boolean and the target\n\t\ttarget = arguments[ i ] || {};\n\t\ti++;\n\t}\n\n\t// Handle case when target is a string or something (possible in deep copy)\n\tif ( typeof target !== \"object\" && !jQuery.isFunction( target ) ) {\n\t\ttarget = {};\n\t}\n\n\t// Extend jQuery itself if only one argument is passed\n\tif ( i === length ) {\n\t\ttarget = this;\n\t\ti--;\n\t}\n\n\tfor ( ; i < length; i++ ) {\n\n\t\t// Only deal with non-null/undefined values\n\t\tif ( ( options = arguments[ i ] ) != null ) {\n\n\t\t\t// Extend the base object\n\t\t\tfor ( name in options ) {\n\t\t\t\tsrc = target[ name ];\n\t\t\t\tcopy = options[ name ];\n\n\t\t\t\t// Prevent never-ending loop\n\t\t\t\tif ( target === copy ) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Recurse if we're merging plain objects or arrays\n\t\t\t\tif ( deep && copy && ( jQuery.isPlainObject( copy ) ||\n\t\t\t\t\t( copyIsArray = jQuery.isArray( copy ) ) ) ) {\n\n\t\t\t\t\tif ( copyIsArray ) {\n\t\t\t\t\t\tcopyIsArray = false;\n\t\t\t\t\t\tclone = src && jQuery.isArray( src ) ? src : [];\n\n\t\t\t\t\t} else {\n\t\t\t\t\t\tclone = src && jQuery.isPlainObject( src ) ? src : {};\n\t\t\t\t\t}\n\n\t\t\t\t\t// Never move original objects, clone them\n\t\t\t\t\ttarget[ name ] = jQuery.extend( deep, clone, copy );\n\n\t\t\t\t// Don't bring in undefined values\n\t\t\t\t} else if ( copy !== undefined ) {\n\t\t\t\t\ttarget[ name ] = copy;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Return the modified object\n\treturn target;\n};\n\njQuery.extend( {\n\n\t// Unique for each copy of jQuery on the page\n\texpando: \"jQuery\" + ( version + Math.random() ).replace( /\\D/g, \"\" ),\n\n\t// Assume jQuery is ready without the ready module\n\tisReady: true,\n\n\terror: function( msg ) {\n\t\tthrow new Error( msg );\n\t},\n\n\tnoop: function() {},\n\n\tisFunction: function( obj ) {\n\t\treturn jQuery.type( obj ) === \"function\";\n\t},\n\n\tisArray: Array.isArray,\n\n\tisWindow: function( obj ) {\n\t\treturn obj != null && obj === obj.window;\n\t},\n\n\tisNumeric: function( obj ) {\n\n\t\t// parseFloat NaNs numeric-cast false positives (null|true|false|\"\")\n\t\t// ...but misinterprets leading-number strings, particularly hex literals (\"0x...\")\n\t\t// subtraction forces infinities to NaN\n\t\t// adding 1 corrects loss of precision from parseFloat (#15100)\n\t\tvar realStringObj = obj && obj.toString();\n\t\treturn !jQuery.isArray( obj ) && ( realStringObj - parseFloat( realStringObj ) + 1 ) >= 0;\n\t},\n\n\tisPlainObject: function( obj ) {\n\t\tvar key;\n\n\t\t// Not plain objects:\n\t\t// - Any object or value whose internal [[Class]] property is not \"[object Object]\"\n\t\t// - DOM nodes\n\t\t// - window\n\t\tif ( jQuery.type( obj ) !== \"object\" || obj.nodeType || jQuery.isWindow( obj ) ) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Not own constructor property must be Object\n\t\tif ( obj.constructor &&\n\t\t\t\t!hasOwn.call( obj, \"constructor\" ) &&\n\t\t\t\t!hasOwn.call( obj.constructor.prototype || {}, \"isPrototypeOf\" ) ) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Own properties are enumerated firstly, so to speed up,\n\t\t// if last one is own, then all properties are own\n\t\tfor ( key in obj ) {}\n\n\t\treturn key === undefined || hasOwn.call( obj, key );\n\t},\n\n\tisEmptyObject: function( obj ) {\n\t\tvar name;\n\t\tfor ( name in obj ) {\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t},\n\n\ttype: function( obj ) {\n\t\tif ( obj == null ) {\n\t\t\treturn obj + \"\";\n\t\t}\n\n\t\t// Support: Android<4.0, iOS<6 (functionish RegExp)\n\t\treturn typeof obj === \"object\" || typeof obj === \"function\" ?\n\t\t\tclass2type[ toString.call( obj ) ] || \"object\" :\n\t\t\ttypeof obj;\n\t},\n\n\t// Evaluates a script in a global context\n\tglobalEval: function( code ) {\n\t\tvar script,\n\t\t\tindirect = eval;\n\n\t\tcode = jQuery.trim( code );\n\n\t\tif ( code ) {\n\n\t\t\t// If the code includes a valid, prologue position\n\t\t\t// strict mode pragma, execute code by injecting a\n\t\t\t// script tag into the document.\n\t\t\tif ( code.indexOf( \"use strict\" ) === 1 ) {\n\t\t\t\tscript = document.createElement( \"script\" );\n\t\t\t\tscript.text = code;\n\t\t\t\tdocument.head.appendChild( script ).parentNode.removeChild( script );\n\t\t\t} else {\n\n\t\t\t\t// Otherwise, avoid the DOM node creation, insertion\n\t\t\t\t// and removal by using an indirect global eval\n\n\t\t\t\tindirect( code );\n\t\t\t}\n\t\t}\n\t},\n\n\t// Convert dashed to camelCase; used by the css and data modules\n\t// Support: IE9-11+\n\t// Microsoft forgot to hump their vendor prefix (#9572)\n\tcamelCase: function( string ) {\n\t\treturn string.replace( rmsPrefix, \"ms-\" ).replace( rdashAlpha, fcamelCase );\n\t},\n\n\tnodeName: function( elem, name ) {\n\t\treturn elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase();\n\t},\n\n\teach: function( obj, callback ) {\n\t\tvar length, i = 0;\n\n\t\tif ( isArrayLike( obj ) ) {\n\t\t\tlength = obj.length;\n\t\t\tfor ( ; i < length; i++ ) {\n\t\t\t\tif ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tfor ( i in obj ) {\n\t\t\t\tif ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn obj;\n\t},\n\n\t// Support: Android<4.1\n\ttrim: function( text ) {\n\t\treturn text == null ?\n\t\t\t\"\" :\n\t\t\t( text + \"\" ).replace( rtrim, \"\" );\n\t},\n\n\t// results is for internal usage only\n\tmakeArray: function( arr, results ) {\n\t\tvar ret = results || [];\n\n\t\tif ( arr != null ) {\n\t\t\tif ( isArrayLike( Object( arr ) ) ) {\n\t\t\t\tjQuery.merge( ret,\n\t\t\t\t\ttypeof arr === \"string\" ?\n\t\t\t\t\t[ arr ] : arr\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tpush.call( ret, arr );\n\t\t\t}\n\t\t}\n\n\t\treturn ret;\n\t},\n\n\tinArray: function( elem, arr, i ) {\n\t\treturn arr == null ? -1 : indexOf.call( arr, elem, i );\n\t},\n\n\tmerge: function( first, second ) {\n\t\tvar len = +second.length,\n\t\t\tj = 0,\n\t\t\ti = first.length;\n\n\t\tfor ( ; j < len; j++ ) {\n\t\t\tfirst[ i++ ] = second[ j ];\n\t\t}\n\n\t\tfirst.length = i;\n\n\t\treturn first;\n\t},\n\n\tgrep: function( elems, callback, invert ) {\n\t\tvar callbackInverse,\n\t\t\tmatches = [],\n\t\t\ti = 0,\n\t\t\tlength = elems.length,\n\t\t\tcallbackExpect = !invert;\n\n\t\t// Go through the array, only saving the items\n\t\t// that pass the validator function\n\t\tfor ( ; i < length; i++ ) {\n\t\t\tcallbackInverse = !callback( elems[ i ], i );\n\t\t\tif ( callbackInverse !== callbackExpect ) {\n\t\t\t\tmatches.push( elems[ i ] );\n\t\t\t}\n\t\t}\n\n\t\treturn matches;\n\t},\n\n\t// arg is for internal usage only\n\tmap: function( elems, callback, arg ) {\n\t\tvar length, value,\n\t\t\ti = 0,\n\t\t\tret = [];\n\n\t\t// Go through the array, translating each of the items to their new values\n\t\tif ( isArrayLike( elems ) ) {\n\t\t\tlength = elems.length;\n\t\t\tfor ( ; i < length; i++ ) {\n\t\t\t\tvalue = callback( elems[ i ], i, arg );\n\n\t\t\t\tif ( value != null ) {\n\t\t\t\t\tret.push( value );\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Go through every key on the object,\n\t\t} else {\n\t\t\tfor ( i in elems ) {\n\t\t\t\tvalue = callback( elems[ i ], i, arg );\n\n\t\t\t\tif ( value != null ) {\n\t\t\t\t\tret.push( value );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Flatten any nested arrays\n\t\treturn concat.apply( [], ret );\n\t},\n\n\t// A global GUID counter for objects\n\tguid: 1,\n\n\t// Bind a function to a context, optionally partially applying any\n\t// arguments.\n\tproxy: function( fn, context ) {\n\t\tvar tmp, args, proxy;\n\n\t\tif ( typeof context === \"string\" ) {\n\t\t\ttmp = fn[ context ];\n\t\t\tcontext = fn;\n\t\t\tfn = tmp;\n\t\t}\n\n\t\t// Quick check to determine if target is callable, in the spec\n\t\t// this throws a TypeError, but we will just return undefined.\n\t\tif ( !jQuery.isFunction( fn ) ) {\n\t\t\treturn undefined;\n\t\t}\n\n\t\t// Simulated bind\n\t\targs = slice.call( arguments, 2 );\n\t\tproxy = function() {\n\t\t\treturn fn.apply( context || this, args.concat( slice.call( arguments ) ) );\n\t\t};\n\n\t\t// Set the guid of unique handler to the same of original handler, so it can be removed\n\t\tproxy.guid = fn.guid = fn.guid || jQuery.guid++;\n\n\t\treturn proxy;\n\t},\n\n\tnow: Date.now,\n\n\t// jQuery.support is not used in Core but other projects attach their\n\t// properties to it so it needs to exist.\n\tsupport: support\n} );\n\n// JSHint would error on this code due to the Symbol not being defined in ES5.\n// Defining this global in .jshintrc would create a danger of using the global\n// unguarded in another place, it seems safer to just disable JSHint for these\n// three lines.\n/* jshint ignore: start */\nif ( typeof Symbol === \"function\" ) {\n\tjQuery.fn[ Symbol.iterator ] = arr[ Symbol.iterator ];\n}\n/* jshint ignore: end */\n\n// Populate the class2type map\njQuery.each( \"Boolean Number String Function Array Date RegExp Object Error Symbol\".split( \" \" ),\nfunction( i, name ) {\n\tclass2type[ \"[object \" + name + \"]\" ] = name.toLowerCase();\n} );\n\nfunction isArrayLike( obj ) {\n\n\t// Support: iOS 8.2 (not reproducible in simulator)\n\t// `in` check used to prevent JIT error (gh-2145)\n\t// hasOwn isn't used here due to false negatives\n\t// regarding Nodelist length in IE\n\tvar length = !!obj && \"length\" in obj && obj.length,\n\t\ttype = jQuery.type( obj );\n\n\tif ( type === \"function\" || jQuery.isWindow( obj ) ) {\n\t\treturn false;\n\t}\n\n\treturn type === \"array\" || length === 0 ||\n\t\ttypeof length === \"number\" && length > 0 && ( length - 1 ) in obj;\n}\nvar Sizzle =\n/*!\n * Sizzle CSS Selector Engine v2.2.1\n * http://sizzlejs.com/\n *\n * Copyright jQuery Foundation and other contributors\n * Released under the MIT license\n * http://jquery.org/license\n *\n * Date: 2015-10-17\n */\n(function( window ) {\n\nvar i,\n\tsupport,\n\tExpr,\n\tgetText,\n\tisXML,\n\ttokenize,\n\tcompile,\n\tselect,\n\toutermostContext,\n\tsortInput,\n\thasDuplicate,\n\n\t// Local document vars\n\tsetDocument,\n\tdocument,\n\tdocElem,\n\tdocumentIsHTML,\n\trbuggyQSA,\n\trbuggyMatches,\n\tmatches,\n\tcontains,\n\n\t// Instance-specific data\n\texpando = \"sizzle\" + 1 * new Date(),\n\tpreferredDoc = window.document,\n\tdirruns = 0,\n\tdone = 0,\n\tclassCache = createCache(),\n\ttokenCache = createCache(),\n\tcompilerCache = createCache(),\n\tsortOrder = function( a, b ) {\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t}\n\t\treturn 0;\n\t},\n\n\t// General-purpose constants\n\tMAX_NEGATIVE = 1 << 31,\n\n\t// Instance methods\n\thasOwn = ({}).hasOwnProperty,\n\tarr = [],\n\tpop = arr.pop,\n\tpush_native = arr.push,\n\tpush = arr.push,\n\tslice = arr.slice,\n\t// Use a stripped-down indexOf as it's faster than native\n\t// http://jsperf.com/thor-indexof-vs-for/5\n\tindexOf = function( list, elem ) {\n\t\tvar i = 0,\n\t\t\tlen = list.length;\n\t\tfor ( ; i < len; i++ ) {\n\t\t\tif ( list[i] === elem ) {\n\t\t\t\treturn i;\n\t\t\t}\n\t\t}\n\t\treturn -1;\n\t},\n\n\tbooleans = \"checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped\",\n\n\t// Regular expressions\n\n\t// http://www.w3.org/TR/css3-selectors/#whitespace\n\twhitespace = \"[\\\\x20\\\\t\\\\r\\\\n\\\\f]\",\n\n\t// http://www.w3.org/TR/CSS21/syndata.html#value-def-identifier\n\tidentifier = \"(?:\\\\\\\\.|[\\\\w-]|[^\\\\x00-\\\\xa0])+\",\n\n\t// Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors\n\tattributes = \"\\\\[\" + whitespace + \"*(\" + identifier + \")(?:\" + whitespace +\n\t\t// Operator (capture 2)\n\t\t\"*([*^$|!~]?=)\" + whitespace +\n\t\t// \"Attribute values must be CSS identifiers [capture 5] or strings [capture 3 or capture 4]\"\n\t\t\"*(?:'((?:\\\\\\\\.|[^\\\\\\\\'])*)'|\\\"((?:\\\\\\\\.|[^\\\\\\\\\\\"])*)\\\"|(\" + identifier + \"))|)\" + whitespace +\n\t\t\"*\\\\]\",\n\n\tpseudos = \":(\" + identifier + \")(?:\\\\((\" +\n\t\t// To reduce the number of selectors needing tokenize in the preFilter, prefer arguments:\n\t\t// 1. quoted (capture 3; capture 4 or capture 5)\n\t\t\"('((?:\\\\\\\\.|[^\\\\\\\\'])*)'|\\\"((?:\\\\\\\\.|[^\\\\\\\\\\\"])*)\\\")|\" +\n\t\t// 2. simple (capture 6)\n\t\t\"((?:\\\\\\\\.|[^\\\\\\\\()[\\\\]]|\" + attributes + \")*)|\" +\n\t\t// 3. anything else (capture 2)\n\t\t\".*\" +\n\t\t\")\\\\)|)\",\n\n\t// Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter\n\trwhitespace = new RegExp( whitespace + \"+\", \"g\" ),\n\trtrim = new RegExp( \"^\" + whitespace + \"+|((?:^|[^\\\\\\\\])(?:\\\\\\\\.)*)\" + whitespace + \"+$\", \"g\" ),\n\n\trcomma = new RegExp( \"^\" + whitespace + \"*,\" + whitespace + \"*\" ),\n\trcombinators = new RegExp( \"^\" + whitespace + \"*([>+~]|\" + whitespace + \")\" + whitespace + \"*\" ),\n\n\trattributeQuotes = new RegExp( \"=\" + whitespace + \"*([^\\\\]'\\\"]*?)\" + whitespace + \"*\\\\]\", \"g\" ),\n\n\trpseudo = new RegExp( pseudos ),\n\tridentifier = new RegExp( \"^\" + identifier + \"$\" ),\n\n\tmatchExpr = {\n\t\t\"ID\": new RegExp( \"^#(\" + identifier + \")\" ),\n\t\t\"CLASS\": new RegExp( \"^\\\\.(\" + identifier + \")\" ),\n\t\t\"TAG\": new RegExp( \"^(\" + identifier + \"|[*])\" ),\n\t\t\"ATTR\": new RegExp( \"^\" + attributes ),\n\t\t\"PSEUDO\": new RegExp( \"^\" + pseudos ),\n\t\t\"CHILD\": new RegExp( \"^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\\\(\" + whitespace +\n\t\t\t\"*(even|odd|(([+-]|)(\\\\d*)n|)\" + whitespace + \"*(?:([+-]|)\" + whitespace +\n\t\t\t\"*(\\\\d+)|))\" + whitespace + \"*\\\\)|)\", \"i\" ),\n\t\t\"bool\": new RegExp( \"^(?:\" + booleans + \")$\", \"i\" ),\n\t\t// For use in libraries implementing .is()\n\t\t// We use this for POS matching in `select`\n\t\t\"needsContext\": new RegExp( \"^\" + whitespace + \"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\\\(\" +\n\t\t\twhitespace + \"*((?:-\\\\d)?\\\\d*)\" + whitespace + \"*\\\\)|)(?=[^-]|$)\", \"i\" )\n\t},\n\n\trinputs = /^(?:input|select|textarea|button)$/i,\n\trheader = /^h\\d$/i,\n\n\trnative = /^[^{]+\\{\\s*\\[native \\w/,\n\n\t// Easily-parseable/retrievable ID or TAG or CLASS selectors\n\trquickExpr = /^(?:#([\\w-]+)|(\\w+)|\\.([\\w-]+))$/,\n\n\trsibling = /[+~]/,\n\trescape = /'|\\\\/g,\n\n\t// CSS escapes http://www.w3.org/TR/CSS21/syndata.html#escaped-characters\n\trunescape = new RegExp( \"\\\\\\\\([\\\\da-f]{1,6}\" + whitespace + \"?|(\" + whitespace + \")|.)\", \"ig\" ),\n\tfunescape = function( _, escaped, escapedWhitespace ) {\n\t\tvar high = \"0x\" + escaped - 0x10000;\n\t\t// NaN means non-codepoint\n\t\t// Support: Firefox<24\n\t\t// Workaround erroneous numeric interpretation of +\"0x\"\n\t\treturn high !== high || escapedWhitespace ?\n\t\t\tescaped :\n\t\t\thigh < 0 ?\n\t\t\t\t// BMP codepoint\n\t\t\t\tString.fromCharCode( high + 0x10000 ) :\n\t\t\t\t// Supplemental Plane codepoint (surrogate pair)\n\t\t\t\tString.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 );\n\t},\n\n\t// Used for iframes\n\t// See setDocument()\n\t// Removing the function wrapper causes a \"Permission Denied\"\n\t// error in IE\n\tunloadHandler = function() {\n\t\tsetDocument();\n\t};\n\n// Optimize for push.apply( _, NodeList )\ntry {\n\tpush.apply(\n\t\t(arr = slice.call( preferredDoc.childNodes )),\n\t\tpreferredDoc.childNodes\n\t);\n\t// Support: Android<4.0\n\t// Detect silently failing push.apply\n\tarr[ preferredDoc.childNodes.length ].nodeType;\n} catch ( e ) {\n\tpush = { apply: arr.length ?\n\n\t\t// Leverage slice if possible\n\t\tfunction( target, els ) {\n\t\t\tpush_native.apply( target, slice.call(els) );\n\t\t} :\n\n\t\t// Support: IE<9\n\t\t// Otherwise append directly\n\t\tfunction( target, els ) {\n\t\t\tvar j = target.length,\n\t\t\t\ti = 0;\n\t\t\t// Can't trust NodeList.length\n\t\t\twhile ( (target[j++] = els[i++]) ) {}\n\t\t\ttarget.length = j - 1;\n\t\t}\n\t};\n}\n\nfunction Sizzle( selector, context, results, seed ) {\n\tvar m, i, elem, nid, nidselect, match, groups, newSelector,\n\t\tnewContext = context && context.ownerDocument,\n\n\t\t// nodeType defaults to 9, since context defaults to document\n\t\tnodeType = context ? context.nodeType : 9;\n\n\tresults = results || [];\n\n\t// Return early from calls with invalid selector or context\n\tif ( typeof selector !== \"string\" || !selector ||\n\t\tnodeType !== 1 && nodeType !== 9 && nodeType !== 11 ) {\n\n\t\treturn results;\n\t}\n\n\t// Try to shortcut find operations (as opposed to filters) in HTML documents\n\tif ( !seed ) {\n\n\t\tif ( ( context ? context.ownerDocument || context : preferredDoc ) !== document ) {\n\t\t\tsetDocument( context );\n\t\t}\n\t\tcontext = context || document;\n\n\t\tif ( documentIsHTML ) {\n\n\t\t\t// If the selector is sufficiently simple, try using a \"get*By*\" DOM method\n\t\t\t// (excepting DocumentFragment context, where the methods don't exist)\n\t\t\tif ( nodeType !== 11 && (match = rquickExpr.exec( selector )) ) {\n\n\t\t\t\t// ID selector\n\t\t\t\tif ( (m = match[1]) ) {\n\n\t\t\t\t\t// Document context\n\t\t\t\t\tif ( nodeType === 9 ) {\n\t\t\t\t\t\tif ( (elem = context.getElementById( m )) ) {\n\n\t\t\t\t\t\t\t// Support: IE, Opera, Webkit\n\t\t\t\t\t\t\t// TODO: identify versions\n\t\t\t\t\t\t\t// getElementById can match elements by name instead of ID\n\t\t\t\t\t\t\tif ( elem.id === m ) {\n\t\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t// Element context\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// Support: IE, Opera, Webkit\n\t\t\t\t\t\t// TODO: identify versions\n\t\t\t\t\t\t// getElementById can match elements by name instead of ID\n\t\t\t\t\t\tif ( newContext && (elem = newContext.getElementById( m )) &&\n\t\t\t\t\t\t\tcontains( context, elem ) &&\n\t\t\t\t\t\t\telem.id === m ) {\n\n\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t// Type selector\n\t\t\t\t} else if ( match[2] ) {\n\t\t\t\t\tpush.apply( results, context.getElementsByTagName( selector ) );\n\t\t\t\t\treturn results;\n\n\t\t\t\t// Class selector\n\t\t\t\t} else if ( (m = match[3]) && support.getElementsByClassName &&\n\t\t\t\t\tcontext.getElementsByClassName ) {\n\n\t\t\t\t\tpush.apply( results, context.getElementsByClassName( m ) );\n\t\t\t\t\treturn results;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Take advantage of querySelectorAll\n\t\t\tif ( support.qsa &&\n\t\t\t\t!compilerCache[ selector + \" \" ] &&\n\t\t\t\t(!rbuggyQSA || !rbuggyQSA.test( selector )) ) {\n\n\t\t\t\tif ( nodeType !== 1 ) {\n\t\t\t\t\tnewContext = context;\n\t\t\t\t\tnewSelector = selector;\n\n\t\t\t\t// qSA looks outside Element context, which is not what we want\n\t\t\t\t// Thanks to Andrew Dupont for this workaround technique\n\t\t\t\t// Support: IE <=8\n\t\t\t\t// Exclude object elements\n\t\t\t\t} else if ( context.nodeName.toLowerCase() !== \"object\" ) {\n\n\t\t\t\t\t// Capture the context ID, setting it first if necessary\n\t\t\t\t\tif ( (nid = context.getAttribute( \"id\" )) ) {\n\t\t\t\t\t\tnid = nid.replace( rescape, \"\\\\$&\" );\n\t\t\t\t\t} else {\n\t\t\t\t\t\tcontext.setAttribute( \"id\", (nid = expando) );\n\t\t\t\t\t}\n\n\t\t\t\t\t// Prefix every selector in the list\n\t\t\t\t\tgroups = tokenize( selector );\n\t\t\t\t\ti = groups.length;\n\t\t\t\t\tnidselect = ridentifier.test( nid ) ? \"#\" + nid : \"[id='\" + nid + \"']\";\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tgroups[i] = nidselect + \" \" + toSelector( groups[i] );\n\t\t\t\t\t}\n\t\t\t\t\tnewSelector = groups.join( \",\" );\n\n\t\t\t\t\t// Expand context for sibling selectors\n\t\t\t\t\tnewContext = rsibling.test( selector ) && testContext( context.parentNode ) ||\n\t\t\t\t\t\tcontext;\n\t\t\t\t}\n\n\t\t\t\tif ( newSelector ) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tpush.apply( results,\n\t\t\t\t\t\t\tnewContext.querySelectorAll( newSelector )\n\t\t\t\t\t\t);\n\t\t\t\t\t\treturn results;\n\t\t\t\t\t} catch ( qsaError ) {\n\t\t\t\t\t} finally {\n\t\t\t\t\t\tif ( nid === expando ) {\n\t\t\t\t\t\t\tcontext.removeAttribute( \"id\" );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// All others\n\treturn select( selector.replace( rtrim, \"$1\" ), context, results, seed );\n}\n\n/**\n * Create key-value caches of limited size\n * @returns {function(string, object)} Returns the Object data after storing it on itself with\n *\tproperty name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength)\n *\tdeleting the oldest entry\n */\nfunction createCache() {\n\tvar keys = [];\n\n\tfunction cache( key, value ) {\n\t\t// Use (key + \" \") to avoid collision with native prototype properties (see Issue #157)\n\t\tif ( keys.push( key + \" \" ) > Expr.cacheLength ) {\n\t\t\t// Only keep the most recent entries\n\t\t\tdelete cache[ keys.shift() ];\n\t\t}\n\t\treturn (cache[ key + \" \" ] = value);\n\t}\n\treturn cache;\n}\n\n/**\n * Mark a function for special use by Sizzle\n * @param {Function} fn The function to mark\n */\nfunction markFunction( fn ) {\n\tfn[ expando ] = true;\n\treturn fn;\n}\n\n/**\n * Support testing using an element\n * @param {Function} fn Passed the created div and expects a boolean result\n */\nfunction assert( fn ) {\n\tvar div = document.createElement(\"div\");\n\n\ttry {\n\t\treturn !!fn( div );\n\t} catch (e) {\n\t\treturn false;\n\t} finally {\n\t\t// Remove from its parent by default\n\t\tif ( div.parentNode ) {\n\t\t\tdiv.parentNode.removeChild( div );\n\t\t}\n\t\t// release memory in IE\n\t\tdiv = null;\n\t}\n}\n\n/**\n * Adds the same handler for all of the specified attrs\n * @param {String} attrs Pipe-separated list of attributes\n * @param {Function} handler The method that will be applied\n */\nfunction addHandle( attrs, handler ) {\n\tvar arr = attrs.split(\"|\"),\n\t\ti = arr.length;\n\n\twhile ( i-- ) {\n\t\tExpr.attrHandle[ arr[i] ] = handler;\n\t}\n}\n\n/**\n * Checks document order of two siblings\n * @param {Element} a\n * @param {Element} b\n * @returns {Number} Returns less than 0 if a precedes b, greater than 0 if a follows b\n */\nfunction siblingCheck( a, b ) {\n\tvar cur = b && a,\n\t\tdiff = cur && a.nodeType === 1 && b.nodeType === 1 &&\n\t\t\t( ~b.sourceIndex || MAX_NEGATIVE ) -\n\t\t\t( ~a.sourceIndex || MAX_NEGATIVE );\n\n\t// Use IE sourceIndex if available on both nodes\n\tif ( diff ) {\n\t\treturn diff;\n\t}\n\n\t// Check if b follows a\n\tif ( cur ) {\n\t\twhile ( (cur = cur.nextSibling) ) {\n\t\t\tif ( cur === b ) {\n\t\t\t\treturn -1;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn a ? 1 : -1;\n}\n\n/**\n * Returns a function to use in pseudos for input types\n * @param {String} type\n */\nfunction createInputPseudo( type ) {\n\treturn function( elem ) {\n\t\tvar name = elem.nodeName.toLowerCase();\n\t\treturn name === \"input\" && elem.type === type;\n\t};\n}\n\n/**\n * Returns a function to use in pseudos for buttons\n * @param {String} type\n */\nfunction createButtonPseudo( type ) {\n\treturn function( elem ) {\n\t\tvar name = elem.nodeName.toLowerCase();\n\t\treturn (name === \"input\" || name === \"button\") && elem.type === type;\n\t};\n}\n\n/**\n * Returns a function to use in pseudos for positionals\n * @param {Function} fn\n */\nfunction createPositionalPseudo( fn ) {\n\treturn markFunction(function( argument ) {\n\t\targument = +argument;\n\t\treturn markFunction(function( seed, matches ) {\n\t\t\tvar j,\n\t\t\t\tmatchIndexes = fn( [], seed.length, argument ),\n\t\t\t\ti = matchIndexes.length;\n\n\t\t\t// Match elements found at the specified indexes\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( seed[ (j = matchIndexes[i]) ] ) {\n\t\t\t\t\tseed[j] = !(matches[j] = seed[j]);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t});\n}\n\n/**\n * Checks a node for validity as a Sizzle context\n * @param {Element|Object=} context\n * @returns {Element|Object|Boolean} The input node if acceptable, otherwise a falsy value\n */\nfunction testContext( context ) {\n\treturn context && typeof context.getElementsByTagName !== \"undefined\" && context;\n}\n\n// Expose support vars for convenience\nsupport = Sizzle.support = {};\n\n/**\n * Detects XML nodes\n * @param {Element|Object} elem An element or a document\n * @returns {Boolean} True iff elem is a non-HTML XML node\n */\nisXML = Sizzle.isXML = function( elem ) {\n\t// documentElement is verified for cases where it doesn't yet exist\n\t// (such as loading iframes in IE - #4833)\n\tvar documentElement = elem && (elem.ownerDocument || elem).documentElement;\n\treturn documentElement ? documentElement.nodeName !== \"HTML\" : false;\n};\n\n/**\n * Sets document-related variables once based on the current document\n * @param {Element|Object} [doc] An element or document object to use to set the document\n * @returns {Object} Returns the current document\n */\nsetDocument = Sizzle.setDocument = function( node ) {\n\tvar hasCompare, parent,\n\t\tdoc = node ? node.ownerDocument || node : preferredDoc;\n\n\t// Return early if doc is invalid or already selected\n\tif ( doc === document || doc.nodeType !== 9 || !doc.documentElement ) {\n\t\treturn document;\n\t}\n\n\t// Update global variables\n\tdocument = doc;\n\tdocElem = document.documentElement;\n\tdocumentIsHTML = !isXML( document );\n\n\t// Support: IE 9-11, Edge\n\t// Accessing iframe documents after unload throws \"permission denied\" errors (jQuery #13936)\n\tif ( (parent = document.defaultView) && parent.top !== parent ) {\n\t\t// Support: IE 11\n\t\tif ( parent.addEventListener ) {\n\t\t\tparent.addEventListener( \"unload\", unloadHandler, false );\n\n\t\t// Support: IE 9 - 10 only\n\t\t} else if ( parent.attachEvent ) {\n\t\t\tparent.attachEvent( \"onunload\", unloadHandler );\n\t\t}\n\t}\n\n\t/* Attributes\n\t---------------------------------------------------------------------- */\n\n\t// Support: IE<8\n\t// Verify that getAttribute really returns attributes and not properties\n\t// (excepting IE8 booleans)\n\tsupport.attributes = assert(function( div ) {\n\t\tdiv.className = \"i\";\n\t\treturn !div.getAttribute(\"className\");\n\t});\n\n\t/* getElement(s)By*\n\t---------------------------------------------------------------------- */\n\n\t// Check if getElementsByTagName(\"*\") returns only elements\n\tsupport.getElementsByTagName = assert(function( div ) {\n\t\tdiv.appendChild( document.createComment(\"\") );\n\t\treturn !div.getElementsByTagName(\"*\").length;\n\t});\n\n\t// Support: IE<9\n\tsupport.getElementsByClassName = rnative.test( document.getElementsByClassName );\n\n\t// Support: IE<10\n\t// Check if getElementById returns elements by name\n\t// The broken getElementById methods don't pick up programatically-set names,\n\t// so use a roundabout getElementsByName test\n\tsupport.getById = assert(function( div ) {\n\t\tdocElem.appendChild( div ).id = expando;\n\t\treturn !document.getElementsByName || !document.getElementsByName( expando ).length;\n\t});\n\n\t// ID find and filter\n\tif ( support.getById ) {\n\t\tExpr.find[\"ID\"] = function( id, context ) {\n\t\t\tif ( typeof context.getElementById !== \"undefined\" && documentIsHTML ) {\n\t\t\t\tvar m = context.getElementById( id );\n\t\t\t\treturn m ? [ m ] : [];\n\t\t\t}\n\t\t};\n\t\tExpr.filter[\"ID\"] = function( id ) {\n\t\t\tvar attrId = id.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\treturn elem.getAttribute(\"id\") === attrId;\n\t\t\t};\n\t\t};\n\t} else {\n\t\t// Support: IE6/7\n\t\t// getElementById is not reliable as a find shortcut\n\t\tdelete Expr.find[\"ID\"];\n\n\t\tExpr.filter[\"ID\"] = function( id ) {\n\t\t\tvar attrId = id.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\tvar node = typeof elem.getAttributeNode !== \"undefined\" &&\n\t\t\t\t\telem.getAttributeNode(\"id\");\n\t\t\t\treturn node && node.value === attrId;\n\t\t\t};\n\t\t};\n\t}\n\n\t// Tag\n\tExpr.find[\"TAG\"] = support.getElementsByTagName ?\n\t\tfunction( tag, context ) {\n\t\t\tif ( typeof context.getElementsByTagName !== \"undefined\" ) {\n\t\t\t\treturn context.getElementsByTagName( tag );\n\n\t\t\t// DocumentFragment nodes don't have gEBTN\n\t\t\t} else if ( support.qsa ) {\n\t\t\t\treturn context.querySelectorAll( tag );\n\t\t\t}\n\t\t} :\n\n\t\tfunction( tag, context ) {\n\t\t\tvar elem,\n\t\t\t\ttmp = [],\n\t\t\t\ti = 0,\n\t\t\t\t// By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too\n\t\t\t\tresults = context.getElementsByTagName( tag );\n\n\t\t\t// Filter out possible comments\n\t\t\tif ( tag === \"*\" ) {\n\t\t\t\twhile ( (elem = results[i++]) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 ) {\n\t\t\t\t\t\ttmp.push( elem );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn tmp;\n\t\t\t}\n\t\t\treturn results;\n\t\t};\n\n\t// Class\n\tExpr.find[\"CLASS\"] = support.getElementsByClassName && function( className, context ) {\n\t\tif ( typeof context.getElementsByClassName !== \"undefined\" && documentIsHTML ) {\n\t\t\treturn context.getElementsByClassName( className );\n\t\t}\n\t};\n\n\t/* QSA/matchesSelector\n\t---------------------------------------------------------------------- */\n\n\t// QSA and matchesSelector support\n\n\t// matchesSelector(:active) reports false when true (IE9/Opera 11.5)\n\trbuggyMatches = [];\n\n\t// qSa(:focus) reports false when true (Chrome 21)\n\t// We allow this because of a bug in IE8/9 that throws an error\n\t// whenever `document.activeElement` is accessed on an iframe\n\t// So, we allow :focus to pass through QSA all the time to avoid the IE error\n\t// See http://bugs.jquery.com/ticket/13378\n\trbuggyQSA = [];\n\n\tif ( (support.qsa = rnative.test( document.querySelectorAll )) ) {\n\t\t// Build QSA regex\n\t\t// Regex strategy adopted from Diego Perini\n\t\tassert(function( div ) {\n\t\t\t// Select is set to empty string on purpose\n\t\t\t// This is to test IE's treatment of not explicitly\n\t\t\t// setting a boolean content attribute,\n\t\t\t// since its presence should be enough\n\t\t\t// http://bugs.jquery.com/ticket/12359\n\t\t\tdocElem.appendChild( div ).innerHTML = \"<a id='\" + expando + \"'></a>\" +\n\t\t\t\t\"<select id='\" + expando + \"-\\r\\\\' msallowcapture=''>\" +\n\t\t\t\t\"<option selected=''></option></select>\";\n\n\t\t\t// Support: IE8, Opera 11-12.16\n\t\t\t// Nothing should be selected when empty strings follow ^= or $= or *=\n\t\t\t// The test attribute must be unknown in Opera but \"safe\" for WinRT\n\t\t\t// http://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section\n\t\t\tif ( div.querySelectorAll(\"[msallowcapture^='']\").length ) {\n\t\t\t\trbuggyQSA.push( \"[*^$]=\" + whitespace + \"*(?:''|\\\"\\\")\" );\n\t\t\t}\n\n\t\t\t// Support: IE8\n\t\t\t// Boolean attributes and \"value\" are not treated correctly\n\t\t\tif ( !div.querySelectorAll(\"[selected]\").length ) {\n\t\t\t\trbuggyQSA.push( \"\\\\[\" + whitespace + \"*(?:value|\" + booleans + \")\" );\n\t\t\t}\n\n\t\t\t// Support: Chrome<29, Android<4.4, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.8+\n\t\t\tif ( !div.querySelectorAll( \"[id~=\" + expando + \"-]\" ).length ) {\n\t\t\t\trbuggyQSA.push(\"~=\");\n\t\t\t}\n\n\t\t\t// Webkit/Opera - :checked should return selected option elements\n\t\t\t// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked\n\t\t\t// IE8 throws error here and will not see later tests\n\t\t\tif ( !div.querySelectorAll(\":checked\").length ) {\n\t\t\t\trbuggyQSA.push(\":checked\");\n\t\t\t}\n\n\t\t\t// Support: Safari 8+, iOS 8+\n\t\t\t// https://bugs.webkit.org/show_bug.cgi?id=136851\n\t\t\t// In-page `selector#id sibing-combinator selector` fails\n\t\t\tif ( !div.querySelectorAll( \"a#\" + expando + \"+*\" ).length ) {\n\t\t\t\trbuggyQSA.push(\".#.+[+~]\");\n\t\t\t}\n\t\t});\n\n\t\tassert(function( div ) {\n\t\t\t// Support: Windows 8 Native Apps\n\t\t\t// The type and name attributes are restricted during .innerHTML assignment\n\t\t\tvar input = document.createElement(\"input\");\n\t\t\tinput.setAttribute( \"type\", \"hidden\" );\n\t\t\tdiv.appendChild( input ).setAttribute( \"name\", \"D\" );\n\n\t\t\t// Support: IE8\n\t\t\t// Enforce case-sensitivity of name attribute\n\t\t\tif ( div.querySelectorAll(\"[name=d]\").length ) {\n\t\t\t\trbuggyQSA.push( \"name\" + whitespace + \"*[*^$|!~]?=\" );\n\t\t\t}\n\n\t\t\t// FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled)\n\t\t\t// IE8 throws error here and will not see later tests\n\t\t\tif ( !div.querySelectorAll(\":enabled\").length ) {\n\t\t\t\trbuggyQSA.push( \":enabled\", \":disabled\" );\n\t\t\t}\n\n\t\t\t// Opera 10-11 does not throw on post-comma invalid pseudos\n\t\t\tdiv.querySelectorAll(\"*,:x\");\n\t\t\trbuggyQSA.push(\",.*:\");\n\t\t});\n\t}\n\n\tif ( (support.matchesSelector = rnative.test( (matches = docElem.matches ||\n\t\tdocElem.webkitMatchesSelector ||\n\t\tdocElem.mozMatchesSelector ||\n\t\tdocElem.oMatchesSelector ||\n\t\tdocElem.msMatchesSelector) )) ) {\n\n\t\tassert(function( div ) {\n\t\t\t// Check to see if it's possible to do matchesSelector\n\t\t\t// on a disconnected node (IE 9)\n\t\t\tsupport.disconnectedMatch = matches.call( div, \"div\" );\n\n\t\t\t// This should fail with an exception\n\t\t\t// Gecko does not error, returns false instead\n\t\t\tmatches.call( div, \"[s!='']:x\" );\n\t\t\trbuggyMatches.push( \"!=\", pseudos );\n\t\t});\n\t}\n\n\trbuggyQSA = rbuggyQSA.length && new RegExp( rbuggyQSA.join(\"|\") );\n\trbuggyMatches = rbuggyMatches.length && new RegExp( rbuggyMatches.join(\"|\") );\n\n\t/* Contains\n\t---------------------------------------------------------------------- */\n\thasCompare = rnative.test( docElem.compareDocumentPosition );\n\n\t// Element contains another\n\t// Purposefully self-exclusive\n\t// As in, an element does not contain itself\n\tcontains = hasCompare || rnative.test( docElem.contains ) ?\n\t\tfunction( a, b ) {\n\t\t\tvar adown = a.nodeType === 9 ? a.documentElement : a,\n\t\t\t\tbup = b && b.parentNode;\n\t\t\treturn a === bup || !!( bup && bup.nodeType === 1 && (\n\t\t\t\tadown.contains ?\n\t\t\t\t\tadown.contains( bup ) :\n\t\t\t\t\ta.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16\n\t\t\t));\n\t\t} :\n\t\tfunction( a, b ) {\n\t\t\tif ( b ) {\n\t\t\t\twhile ( (b = b.parentNode) ) {\n\t\t\t\t\tif ( b === a ) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n\n\t/* Sorting\n\t---------------------------------------------------------------------- */\n\n\t// Document order sorting\n\tsortOrder = hasCompare ?\n\tfunction( a, b ) {\n\n\t\t// Flag for duplicate removal\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t\treturn 0;\n\t\t}\n\n\t\t// Sort on method existence if only one input has compareDocumentPosition\n\t\tvar compare = !a.compareDocumentPosition - !b.compareDocumentPosition;\n\t\tif ( compare ) {\n\t\t\treturn compare;\n\t\t}\n\n\t\t// Calculate position if both inputs belong to the same document\n\t\tcompare = ( a.ownerDocument || a ) === ( b.ownerDocument || b ) ?\n\t\t\ta.compareDocumentPosition( b ) :\n\n\t\t\t// Otherwise we know they are disconnected\n\t\t\t1;\n\n\t\t// Disconnected nodes\n\t\tif ( compare & 1 ||\n\t\t\t(!support.sortDetached && b.compareDocumentPosition( a ) === compare) ) {\n\n\t\t\t// Choose the first element that is related to our preferred document\n\t\t\tif ( a === document || a.ownerDocument === preferredDoc && contains(preferredDoc, a) ) {\n\t\t\t\treturn -1;\n\t\t\t}\n\t\t\tif ( b === document || b.ownerDocument === preferredDoc && contains(preferredDoc, b) ) {\n\t\t\t\treturn 1;\n\t\t\t}\n\n\t\t\t// Maintain original order\n\t\t\treturn sortInput ?\n\t\t\t\t( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :\n\t\t\t\t0;\n\t\t}\n\n\t\treturn compare & 4 ? -1 : 1;\n\t} :\n\tfunction( a, b ) {\n\t\t// Exit early if the nodes are identical\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t\treturn 0;\n\t\t}\n\n\t\tvar cur,\n\t\t\ti = 0,\n\t\t\taup = a.parentNode,\n\t\t\tbup = b.parentNode,\n\t\t\tap = [ a ],\n\t\t\tbp = [ b ];\n\n\t\t// Parentless nodes are either documents or disconnected\n\t\tif ( !aup || !bup ) {\n\t\t\treturn a === document ? -1 :\n\t\t\t\tb === document ? 1 :\n\t\t\t\taup ? -1 :\n\t\t\t\tbup ? 1 :\n\t\t\t\tsortInput ?\n\t\t\t\t( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :\n\t\t\t\t0;\n\n\t\t// If the nodes are siblings, we can do a quick check\n\t\t} else if ( aup === bup ) {\n\t\t\treturn siblingCheck( a, b );\n\t\t}\n\n\t\t// Otherwise we need full lists of their ancestors for comparison\n\t\tcur = a;\n\t\twhile ( (cur = cur.parentNode) ) {\n\t\t\tap.unshift( cur );\n\t\t}\n\t\tcur = b;\n\t\twhile ( (cur = cur.parentNode) ) {\n\t\t\tbp.unshift( cur );\n\t\t}\n\n\t\t// Walk down the tree looking for a discrepancy\n\t\twhile ( ap[i] === bp[i] ) {\n\t\t\ti++;\n\t\t}\n\n\t\treturn i ?\n\t\t\t// Do a sibling check if the nodes have a common ancestor\n\t\t\tsiblingCheck( ap[i], bp[i] ) :\n\n\t\t\t// Otherwise nodes in our document sort first\n\t\t\tap[i] === preferredDoc ? -1 :\n\t\t\tbp[i] === preferredDoc ? 1 :\n\t\t\t0;\n\t};\n\n\treturn document;\n};\n\nSizzle.matches = function( expr, elements ) {\n\treturn Sizzle( expr, null, null, elements );\n};\n\nSizzle.matchesSelector = function( elem, expr ) {\n\t// Set document vars if needed\n\tif ( ( elem.ownerDocument || elem ) !== document ) {\n\t\tsetDocument( elem );\n\t}\n\n\t// Make sure that attribute selectors are quoted\n\texpr = expr.replace( rattributeQuotes, \"='$1']\" );\n\n\tif ( support.matchesSelector && documentIsHTML &&\n\t\t!compilerCache[ expr + \" \" ] &&\n\t\t( !rbuggyMatches || !rbuggyMatches.test( expr ) ) &&\n\t\t( !rbuggyQSA || !rbuggyQSA.test( expr ) ) ) {\n\n\t\ttry {\n\t\t\tvar ret = matches.call( elem, expr );\n\n\t\t\t// IE 9's matchesSelector returns false on disconnected nodes\n\t\t\tif ( ret || support.disconnectedMatch ||\n\t\t\t\t\t// As well, disconnected nodes are said to be in a document\n\t\t\t\t\t// fragment in IE 9\n\t\t\t\t\telem.document && elem.document.nodeType !== 11 ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\t\t} catch (e) {}\n\t}\n\n\treturn Sizzle( expr, document, null, [ elem ] ).length > 0;\n};\n\nSizzle.contains = function( context, elem ) {\n\t// Set document vars if needed\n\tif ( ( context.ownerDocument || context ) !== document ) {\n\t\tsetDocument( context );\n\t}\n\treturn contains( context, elem );\n};\n\nSizzle.attr = function( elem, name ) {\n\t// Set document vars if needed\n\tif ( ( elem.ownerDocument || elem ) !== document ) {\n\t\tsetDocument( elem );\n\t}\n\n\tvar fn = Expr.attrHandle[ name.toLowerCase() ],\n\t\t// Don't get fooled by Object.prototype properties (jQuery #13807)\n\t\tval = fn && hasOwn.call( Expr.attrHandle, name.toLowerCase() ) ?\n\t\t\tfn( elem, name, !documentIsHTML ) :\n\t\t\tundefined;\n\n\treturn val !== undefined ?\n\t\tval :\n\t\tsupport.attributes || !documentIsHTML ?\n\t\t\telem.getAttribute( name ) :\n\t\t\t(val = elem.getAttributeNode(name)) && val.specified ?\n\t\t\t\tval.value :\n\t\t\t\tnull;\n};\n\nSizzle.error = function( msg ) {\n\tthrow new Error( \"Syntax error, unrecognized expression: \" + msg );\n};\n\n/**\n * Document sorting and removing duplicates\n * @param {ArrayLike} results\n */\nSizzle.uniqueSort = function( results ) {\n\tvar elem,\n\t\tduplicates = [],\n\t\tj = 0,\n\t\ti = 0;\n\n\t// Unless we *know* we can detect duplicates, assume their presence\n\thasDuplicate = !support.detectDuplicates;\n\tsortInput = !support.sortStable && results.slice( 0 );\n\tresults.sort( sortOrder );\n\n\tif ( hasDuplicate ) {\n\t\twhile ( (elem = results[i++]) ) {\n\t\t\tif ( elem === results[ i ] ) {\n\t\t\t\tj = duplicates.push( i );\n\t\t\t}\n\t\t}\n\t\twhile ( j-- ) {\n\t\t\tresults.splice( duplicates[ j ], 1 );\n\t\t}\n\t}\n\n\t// Clear input after sorting to release objects\n\t// See https://github.com/jquery/sizzle/pull/225\n\tsortInput = null;\n\n\treturn results;\n};\n\n/**\n * Utility function for retrieving the text value of an array of DOM nodes\n * @param {Array|Element} elem\n */\ngetText = Sizzle.getText = function( elem ) {\n\tvar node,\n\t\tret = \"\",\n\t\ti = 0,\n\t\tnodeType = elem.nodeType;\n\n\tif ( !nodeType ) {\n\t\t// If no nodeType, this is expected to be an array\n\t\twhile ( (node = elem[i++]) ) {\n\t\t\t// Do not traverse comment nodes\n\t\t\tret += getText( node );\n\t\t}\n\t} else if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) {\n\t\t// Use textContent for elements\n\t\t// innerText usage removed for consistency of new lines (jQuery #11153)\n\t\tif ( typeof elem.textContent === \"string\" ) {\n\t\t\treturn elem.textContent;\n\t\t} else {\n\t\t\t// Traverse its children\n\t\t\tfor ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {\n\t\t\t\tret += getText( elem );\n\t\t\t}\n\t\t}\n\t} else if ( nodeType === 3 || nodeType === 4 ) {\n\t\treturn elem.nodeValue;\n\t}\n\t// Do not include comment or processing instruction nodes\n\n\treturn ret;\n};\n\nExpr = Sizzle.selectors = {\n\n\t// Can be adjusted by the user\n\tcacheLength: 50,\n\n\tcreatePseudo: markFunction,\n\n\tmatch: matchExpr,\n\n\tattrHandle: {},\n\n\tfind: {},\n\n\trelative: {\n\t\t\">\": { dir: \"parentNode\", first: true },\n\t\t\" \": { dir: \"parentNode\" },\n\t\t\"+\": { dir: \"previousSibling\", first: true },\n\t\t\"~\": { dir: \"previousSibling\" }\n\t},\n\n\tpreFilter: {\n\t\t\"ATTR\": function( match ) {\n\t\t\tmatch[1] = match[1].replace( runescape, funescape );\n\n\t\t\t// Move the given value to match[3] whether quoted or unquoted\n\t\t\tmatch[3] = ( match[3] || match[4] || match[5] || \"\" ).replace( runescape, funescape );\n\n\t\t\tif ( match[2] === \"~=\" ) {\n\t\t\t\tmatch[3] = \" \" + match[3] + \" \";\n\t\t\t}\n\n\t\t\treturn match.slice( 0, 4 );\n\t\t},\n\n\t\t\"CHILD\": function( match ) {\n\t\t\t/* matches from matchExpr[\"CHILD\"]\n\t\t\t\t1 type (only|nth|...)\n\t\t\t\t2 what (child|of-type)\n\t\t\t\t3 argument (even|odd|\\d*|\\d*n([+-]\\d+)?|...)\n\t\t\t\t4 xn-component of xn+y argument ([+-]?\\d*n|)\n\t\t\t\t5 sign of xn-component\n\t\t\t\t6 x of xn-component\n\t\t\t\t7 sign of y-component\n\t\t\t\t8 y of y-component\n\t\t\t*/\n\t\t\tmatch[1] = match[1].toLowerCase();\n\n\t\t\tif ( match[1].slice( 0, 3 ) === \"nth\" ) {\n\t\t\t\t// nth-* requires argument\n\t\t\t\tif ( !match[3] ) {\n\t\t\t\t\tSizzle.error( match[0] );\n\t\t\t\t}\n\n\t\t\t\t// numeric x and y parameters for Expr.filter.CHILD\n\t\t\t\t// remember that false/true cast respectively to 0/1\n\t\t\t\tmatch[4] = +( match[4] ? match[5] + (match[6] || 1) : 2 * ( match[3] === \"even\" || match[3] === \"odd\" ) );\n\t\t\t\tmatch[5] = +( ( match[7] + match[8] ) || match[3] === \"odd\" );\n\n\t\t\t// other types prohibit arguments\n\t\t\t} else if ( match[3] ) {\n\t\t\t\tSizzle.error( match[0] );\n\t\t\t}\n\n\t\t\treturn match;\n\t\t},\n\n\t\t\"PSEUDO\": function( match ) {\n\t\t\tvar excess,\n\t\t\t\tunquoted = !match[6] && match[2];\n\n\t\t\tif ( matchExpr[\"CHILD\"].test( match[0] ) ) {\n\t\t\t\treturn null;\n\t\t\t}\n\n\t\t\t// Accept quoted arguments as-is\n\t\t\tif ( match[3] ) {\n\t\t\t\tmatch[2] = match[4] || match[5] || \"\";\n\n\t\t\t// Strip excess characters from unquoted arguments\n\t\t\t} else if ( unquoted && rpseudo.test( unquoted ) &&\n\t\t\t\t// Get excess from tokenize (recursively)\n\t\t\t\t(excess = tokenize( unquoted, true )) &&\n\t\t\t\t// advance to the next closing parenthesis\n\t\t\t\t(excess = unquoted.indexOf( \")\", unquoted.length - excess ) - unquoted.length) ) {\n\n\t\t\t\t// excess is a negative index\n\t\t\t\tmatch[0] = match[0].slice( 0, excess );\n\t\t\t\tmatch[2] = unquoted.slice( 0, excess );\n\t\t\t}\n\n\t\t\t// Return only captures needed by the pseudo filter method (type and argument)\n\t\t\treturn match.slice( 0, 3 );\n\t\t}\n\t},\n\n\tfilter: {\n\n\t\t\"TAG\": function( nodeNameSelector ) {\n\t\t\tvar nodeName = nodeNameSelector.replace( runescape, funescape ).toLowerCase();\n\t\t\treturn nodeNameSelector === \"*\" ?\n\t\t\t\tfunction() { return true; } :\n\t\t\t\tfunction( elem ) {\n\t\t\t\t\treturn elem.nodeName && elem.nodeName.toLowerCase() === nodeName;\n\t\t\t\t};\n\t\t},\n\n\t\t\"CLASS\": function( className ) {\n\t\t\tvar pattern = classCache[ className + \" \" ];\n\n\t\t\treturn pattern ||\n\t\t\t\t(pattern = new RegExp( \"(^|\" + whitespace + \")\" + className + \"(\" + whitespace + \"|$)\" )) &&\n\t\t\t\tclassCache( className, function( elem ) {\n\t\t\t\t\treturn pattern.test( typeof elem.className === \"string\" && elem.className || typeof elem.getAttribute !== \"undefined\" && elem.getAttribute(\"class\") || \"\" );\n\t\t\t\t});\n\t\t},\n\n\t\t\"ATTR\": function( name, operator, check ) {\n\t\t\treturn function( elem ) {\n\t\t\t\tvar result = Sizzle.attr( elem, name );\n\n\t\t\t\tif ( result == null ) {\n\t\t\t\t\treturn operator === \"!=\";\n\t\t\t\t}\n\t\t\t\tif ( !operator ) {\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\n\t\t\t\tresult += \"\";\n\n\t\t\t\treturn operator === \"=\" ? result === check :\n\t\t\t\t\toperator === \"!=\" ? result !== check :\n\t\t\t\t\toperator === \"^=\" ? check && result.indexOf( check ) === 0 :\n\t\t\t\t\toperator === \"*=\" ? check && result.indexOf( check ) > -1 :\n\t\t\t\t\toperator === \"$=\" ? check && result.slice( -check.length ) === check :\n\t\t\t\t\toperator === \"~=\" ? ( \" \" + result.replace( rwhitespace, \" \" ) + \" \" ).indexOf( check ) > -1 :\n\t\t\t\t\toperator === \"|=\" ? result === check || result.slice( 0, check.length + 1 ) === check + \"-\" :\n\t\t\t\t\tfalse;\n\t\t\t};\n\t\t},\n\n\t\t\"CHILD\": function( type, what, argument, first, last ) {\n\t\t\tvar simple = type.slice( 0, 3 ) !== \"nth\",\n\t\t\t\tforward = type.slice( -4 ) !== \"last\",\n\t\t\t\tofType = what === \"of-type\";\n\n\t\t\treturn first === 1 && last === 0 ?\n\n\t\t\t\t// Shortcut for :nth-*(n)\n\t\t\t\tfunction( elem ) {\n\t\t\t\t\treturn !!elem.parentNode;\n\t\t\t\t} :\n\n\t\t\t\tfunction( elem, context, xml ) {\n\t\t\t\t\tvar cache, uniqueCache, outerCache, node, nodeIndex, start,\n\t\t\t\t\t\tdir = simple !== forward ? \"nextSibling\" : \"previousSibling\",\n\t\t\t\t\t\tparent = elem.parentNode,\n\t\t\t\t\t\tname = ofType && elem.nodeName.toLowerCase(),\n\t\t\t\t\t\tuseCache = !xml && !ofType,\n\t\t\t\t\t\tdiff = false;\n\n\t\t\t\t\tif ( parent ) {\n\n\t\t\t\t\t\t// :(first|last|only)-(child|of-type)\n\t\t\t\t\t\tif ( simple ) {\n\t\t\t\t\t\t\twhile ( dir ) {\n\t\t\t\t\t\t\t\tnode = elem;\n\t\t\t\t\t\t\t\twhile ( (node = node[ dir ]) ) {\n\t\t\t\t\t\t\t\t\tif ( ofType ?\n\t\t\t\t\t\t\t\t\t\tnode.nodeName.toLowerCase() === name :\n\t\t\t\t\t\t\t\t\t\tnode.nodeType === 1 ) {\n\n\t\t\t\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t// Reverse direction for :only-* (if we haven't yet done so)\n\t\t\t\t\t\t\t\tstart = dir = type === \"only\" && !start && \"nextSibling\";\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tstart = [ forward ? parent.firstChild : parent.lastChild ];\n\n\t\t\t\t\t\t// non-xml :nth-child(...) stores cache data on `parent`\n\t\t\t\t\t\tif ( forward && useCache ) {\n\n\t\t\t\t\t\t\t// Seek `elem` from a previously-cached index\n\n\t\t\t\t\t\t\t// ...in a gzip-friendly way\n\t\t\t\t\t\t\tnode = parent;\n\t\t\t\t\t\t\touterCache = node[ expando ] || (node[ expando ] = {});\n\n\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t(outerCache[ node.uniqueID ] = {});\n\n\t\t\t\t\t\t\tcache = uniqueCache[ type ] || [];\n\t\t\t\t\t\t\tnodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];\n\t\t\t\t\t\t\tdiff = nodeIndex && cache[ 2 ];\n\t\t\t\t\t\t\tnode = nodeIndex && parent.childNodes[ nodeIndex ];\n\n\t\t\t\t\t\t\twhile ( (node = ++nodeIndex && node && node[ dir ] ||\n\n\t\t\t\t\t\t\t\t// Fallback to seeking `elem` from the start\n\t\t\t\t\t\t\t\t(diff = nodeIndex = 0) || start.pop()) ) {\n\n\t\t\t\t\t\t\t\t// When found, cache indexes on `parent` and break\n\t\t\t\t\t\t\t\tif ( node.nodeType === 1 && ++diff && node === elem ) {\n\t\t\t\t\t\t\t\t\tuniqueCache[ type ] = [ dirruns, nodeIndex, diff ];\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// Use previously-cached element index if available\n\t\t\t\t\t\t\tif ( useCache ) {\n\t\t\t\t\t\t\t\t// ...in a gzip-friendly way\n\t\t\t\t\t\t\t\tnode = elem;\n\t\t\t\t\t\t\t\touterCache = node[ expando ] || (node[ expando ] = {});\n\n\t\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t\t(outerCache[ node.uniqueID ] = {});\n\n\t\t\t\t\t\t\t\tcache = uniqueCache[ type ] || [];\n\t\t\t\t\t\t\t\tnodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];\n\t\t\t\t\t\t\t\tdiff = nodeIndex;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// xml :nth-child(...)\n\t\t\t\t\t\t\t// or :nth-last-child(...) or :nth(-last)?-of-type(...)\n\t\t\t\t\t\t\tif ( diff === false ) {\n\t\t\t\t\t\t\t\t// Use the same loop as above to seek `elem` from the start\n\t\t\t\t\t\t\t\twhile ( (node = ++nodeIndex && node && node[ dir ] ||\n\t\t\t\t\t\t\t\t\t(diff = nodeIndex = 0) || start.pop()) ) {\n\n\t\t\t\t\t\t\t\t\tif ( ( ofType ?\n\t\t\t\t\t\t\t\t\t\tnode.nodeName.toLowerCase() === name :\n\t\t\t\t\t\t\t\t\t\tnode.nodeType === 1 ) &&\n\t\t\t\t\t\t\t\t\t\t++diff ) {\n\n\t\t\t\t\t\t\t\t\t\t// Cache the index of each encountered element\n\t\t\t\t\t\t\t\t\t\tif ( useCache ) {\n\t\t\t\t\t\t\t\t\t\t\touterCache = node[ expando ] || (node[ expando ] = {});\n\n\t\t\t\t\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t\t\t\t\t(outerCache[ node.uniqueID ] = {});\n\n\t\t\t\t\t\t\t\t\t\t\tuniqueCache[ type ] = [ dirruns, diff ];\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tif ( node === elem ) {\n\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Incorporate the offset, then check against cycle size\n\t\t\t\t\t\tdiff -= last;\n\t\t\t\t\t\treturn diff === first || ( diff % first === 0 && diff / first >= 0 );\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t},\n\n\t\t\"PSEUDO\": function( pseudo, argument ) {\n\t\t\t// pseudo-class names are case-insensitive\n\t\t\t// http://www.w3.org/TR/selectors/#pseudo-classes\n\t\t\t// Prioritize by case sensitivity in case custom pseudos are added with uppercase letters\n\t\t\t// Remember that setFilters inherits from pseudos\n\t\t\tvar args,\n\t\t\t\tfn = Expr.pseudos[ pseudo ] || Expr.setFilters[ pseudo.toLowerCase() ] ||\n\t\t\t\t\tSizzle.error( \"unsupported pseudo: \" + pseudo );\n\n\t\t\t// The user may use createPseudo to indicate that\n\t\t\t// arguments are needed to create the filter function\n\t\t\t// just as Sizzle does\n\t\t\tif ( fn[ expando ] ) {\n\t\t\t\treturn fn( argument );\n\t\t\t}\n\n\t\t\t// But maintain support for old signatures\n\t\t\tif ( fn.length > 1 ) {\n\t\t\t\targs = [ pseudo, pseudo, \"\", argument ];\n\t\t\t\treturn Expr.setFilters.hasOwnProperty( pseudo.toLowerCase() ) ?\n\t\t\t\t\tmarkFunction(function( seed, matches ) {\n\t\t\t\t\t\tvar idx,\n\t\t\t\t\t\t\tmatched = fn( seed, argument ),\n\t\t\t\t\t\t\ti = matched.length;\n\t\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\t\tidx = indexOf( seed, matched[i] );\n\t\t\t\t\t\t\tseed[ idx ] = !( matches[ idx ] = matched[i] );\n\t\t\t\t\t\t}\n\t\t\t\t\t}) :\n\t\t\t\t\tfunction( elem ) {\n\t\t\t\t\t\treturn fn( elem, 0, args );\n\t\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn fn;\n\t\t}\n\t},\n\n\tpseudos: {\n\t\t// Potentially complex pseudos\n\t\t\"not\": markFunction(function( selector ) {\n\t\t\t// Trim the selector passed to compile\n\t\t\t// to avoid treating leading and trailing\n\t\t\t// spaces as combinators\n\t\t\tvar input = [],\n\t\t\t\tresults = [],\n\t\t\t\tmatcher = compile( selector.replace( rtrim, \"$1\" ) );\n\n\t\t\treturn matcher[ expando ] ?\n\t\t\t\tmarkFunction(function( seed, matches, context, xml ) {\n\t\t\t\t\tvar elem,\n\t\t\t\t\t\tunmatched = matcher( seed, null, xml, [] ),\n\t\t\t\t\t\ti = seed.length;\n\n\t\t\t\t\t// Match elements unmatched by `matcher`\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tif ( (elem = unmatched[i]) ) {\n\t\t\t\t\t\t\tseed[i] = !(matches[i] = elem);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}) :\n\t\t\t\tfunction( elem, context, xml ) {\n\t\t\t\t\tinput[0] = elem;\n\t\t\t\t\tmatcher( input, null, xml, results );\n\t\t\t\t\t// Don't keep the element (issue #299)\n\t\t\t\t\tinput[0] = null;\n\t\t\t\t\treturn !results.pop();\n\t\t\t\t};\n\t\t}),\n\n\t\t\"has\": markFunction(function( selector ) {\n\t\t\treturn function( elem ) {\n\t\t\t\treturn Sizzle( selector, elem ).length > 0;\n\t\t\t};\n\t\t}),\n\n\t\t\"contains\": markFunction(function( text ) {\n\t\t\ttext = text.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\treturn ( elem.textContent || elem.innerText || getText( elem ) ).indexOf( text ) > -1;\n\t\t\t};\n\t\t}),\n\n\t\t// \"Whether an element is represented by a :lang() selector\n\t\t// is based solely on the element's language value\n\t\t// being equal to the identifier C,\n\t\t// or beginning with the identifier C immediately followed by \"-\".\n\t\t// The matching of C against the element's language value is performed case-insensitively.\n\t\t// The identifier C does not have to be a valid language name.\"\n\t\t// http://www.w3.org/TR/selectors/#lang-pseudo\n\t\t\"lang\": markFunction( function( lang ) {\n\t\t\t// lang value must be a valid identifier\n\t\t\tif ( !ridentifier.test(lang || \"\") ) {\n\t\t\t\tSizzle.error( \"unsupported lang: \" + lang );\n\t\t\t}\n\t\t\tlang = lang.replace( runescape, funescape ).toLowerCase();\n\t\t\treturn function( elem ) {\n\t\t\t\tvar elemLang;\n\t\t\t\tdo {\n\t\t\t\t\tif ( (elemLang = documentIsHTML ?\n\t\t\t\t\t\telem.lang :\n\t\t\t\t\t\telem.getAttribute(\"xml:lang\") || elem.getAttribute(\"lang\")) ) {\n\n\t\t\t\t\t\telemLang = elemLang.toLowerCase();\n\t\t\t\t\t\treturn elemLang === lang || elemLang.indexOf( lang + \"-\" ) === 0;\n\t\t\t\t\t}\n\t\t\t\t} while ( (elem = elem.parentNode) && elem.nodeType === 1 );\n\t\t\t\treturn false;\n\t\t\t};\n\t\t}),\n\n\t\t// Miscellaneous\n\t\t\"target\": function( elem ) {\n\t\t\tvar hash = window.location && window.location.hash;\n\t\t\treturn hash && hash.slice( 1 ) === elem.id;\n\t\t},\n\n\t\t\"root\": function( elem ) {\n\t\t\treturn elem === docElem;\n\t\t},\n\n\t\t\"focus\": function( elem ) {\n\t\t\treturn elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex);\n\t\t},\n\n\t\t// Boolean properties\n\t\t\"enabled\": function( elem ) {\n\t\t\treturn elem.disabled === false;\n\t\t},\n\n\t\t\"disabled\": function( elem ) {\n\t\t\treturn elem.disabled === true;\n\t\t},\n\n\t\t\"checked\": function( elem ) {\n\t\t\t// In CSS3, :checked should return both checked and selected elements\n\t\t\t// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked\n\t\t\tvar nodeName = elem.nodeName.toLowerCase();\n\t\t\treturn (nodeName === \"input\" && !!elem.checked) || (nodeName === \"option\" && !!elem.selected);\n\t\t},\n\n\t\t\"selected\": function( elem ) {\n\t\t\t// Accessing this property makes selected-by-default\n\t\t\t// options in Safari work properly\n\t\t\tif ( elem.parentNode ) {\n\t\t\t\telem.parentNode.selectedIndex;\n\t\t\t}\n\n\t\t\treturn elem.selected === true;\n\t\t},\n\n\t\t// Contents\n\t\t\"empty\": function( elem ) {\n\t\t\t// http://www.w3.org/TR/selectors/#empty-pseudo\n\t\t\t// :empty is negated by element (1) or content nodes (text: 3; cdata: 4; entity ref: 5),\n\t\t\t// but not by others (comment: 8; processing instruction: 7; etc.)\n\t\t\t// nodeType < 6 works because attributes (2) do not appear as children\n\t\t\tfor ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {\n\t\t\t\tif ( elem.nodeType < 6 ) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t},\n\n\t\t\"parent\": function( elem ) {\n\t\t\treturn !Expr.pseudos[\"empty\"]( elem );\n\t\t},\n\n\t\t// Element/input types\n\t\t\"header\": function( elem ) {\n\t\t\treturn rheader.test( elem.nodeName );\n\t\t},\n\n\t\t\"input\": function( elem ) {\n\t\t\treturn rinputs.test( elem.nodeName );\n\t\t},\n\n\t\t\"button\": function( elem ) {\n\t\t\tvar name = elem.nodeName.toLowerCase();\n\t\t\treturn name === \"input\" && elem.type === \"button\" || name === \"button\";\n\t\t},\n\n\t\t\"text\": function( elem ) {\n\t\t\tvar attr;\n\t\t\treturn elem.nodeName.toLowerCase() === \"input\" &&\n\t\t\t\telem.type === \"text\" &&\n\n\t\t\t\t// Support: IE<8\n\t\t\t\t// New HTML5 attribute values (e.g., \"search\") appear with elem.type === \"text\"\n\t\t\t\t( (attr = elem.getAttribute(\"type\")) == null || attr.toLowerCase() === \"text\" );\n\t\t},\n\n\t\t// Position-in-collection\n\t\t\"first\": createPositionalPseudo(function() {\n\t\t\treturn [ 0 ];\n\t\t}),\n\n\t\t\"last\": createPositionalPseudo(function( matchIndexes, length ) {\n\t\t\treturn [ length - 1 ];\n\t\t}),\n\n\t\t\"eq\": createPositionalPseudo(function( matchIndexes, length, argument ) {\n\t\t\treturn [ argument < 0 ? argument + length : argument ];\n\t\t}),\n\n\t\t\"even\": createPositionalPseudo(function( matchIndexes, length ) {\n\t\t\tvar i = 0;\n\t\t\tfor ( ; i < length; i += 2 ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t}),\n\n\t\t\"odd\": createPositionalPseudo(function( matchIndexes, length ) {\n\t\t\tvar i = 1;\n\t\t\tfor ( ; i < length; i += 2 ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t}),\n\n\t\t\"lt\": createPositionalPseudo(function( matchIndexes, length, argument ) {\n\t\t\tvar i = argument < 0 ? argument + length : argument;\n\t\t\tfor ( ; --i >= 0; ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t}),\n\n\t\t\"gt\": createPositionalPseudo(function( matchIndexes, length, argument ) {\n\t\t\tvar i = argument < 0 ? argument + length : argument;\n\t\t\tfor ( ; ++i < length; ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t})\n\t}\n};\n\nExpr.pseudos[\"nth\"] = Expr.pseudos[\"eq\"];\n\n// Add button/input type pseudos\nfor ( i in { radio: true, checkbox: true, file: true, password: true, image: true } ) {\n\tExpr.pseudos[ i ] = createInputPseudo( i );\n}\nfor ( i in { submit: true, reset: true } ) {\n\tExpr.pseudos[ i ] = createButtonPseudo( i );\n}\n\n// Easy API for creating new setFilters\nfunction setFilters() {}\nsetFilters.prototype = Expr.filters = Expr.pseudos;\nExpr.setFilters = new setFilters();\n\ntokenize = Sizzle.tokenize = function( selector, parseOnly ) {\n\tvar matched, match, tokens, type,\n\t\tsoFar, groups, preFilters,\n\t\tcached = tokenCache[ selector + \" \" ];\n\n\tif ( cached ) {\n\t\treturn parseOnly ? 0 : cached.slice( 0 );\n\t}\n\n\tsoFar = selector;\n\tgroups = [];\n\tpreFilters = Expr.preFilter;\n\n\twhile ( soFar ) {\n\n\t\t// Comma and first run\n\t\tif ( !matched || (match = rcomma.exec( soFar )) ) {\n\t\t\tif ( match ) {\n\t\t\t\t// Don't consume trailing commas as valid\n\t\t\t\tsoFar = soFar.slice( match[0].length ) || soFar;\n\t\t\t}\n\t\t\tgroups.push( (tokens = []) );\n\t\t}\n\n\t\tmatched = false;\n\n\t\t// Combinators\n\t\tif ( (match = rcombinators.exec( soFar )) ) {\n\t\t\tmatched = match.shift();\n\t\t\ttokens.push({\n\t\t\t\tvalue: matched,\n\t\t\t\t// Cast descendant combinators to space\n\t\t\t\ttype: match[0].replace( rtrim, \" \" )\n\t\t\t});\n\t\t\tsoFar = soFar.slice( matched.length );\n\t\t}\n\n\t\t// Filters\n\t\tfor ( type in Expr.filter ) {\n\t\t\tif ( (match = matchExpr[ type ].exec( soFar )) && (!preFilters[ type ] ||\n\t\t\t\t(match = preFilters[ type ]( match ))) ) {\n\t\t\t\tmatched = match.shift();\n\t\t\t\ttokens.push({\n\t\t\t\t\tvalue: matched,\n\t\t\t\t\ttype: type,\n\t\t\t\t\tmatches: match\n\t\t\t\t});\n\t\t\t\tsoFar = soFar.slice( matched.length );\n\t\t\t}\n\t\t}\n\n\t\tif ( !matched ) {\n\t\t\tbreak;\n\t\t}\n\t}\n\n\t// Return the length of the invalid excess\n\t// if we're just parsing\n\t// Otherwise, throw an error or return tokens\n\treturn parseOnly ?\n\t\tsoFar.length :\n\t\tsoFar ?\n\t\t\tSizzle.error( selector ) :\n\t\t\t// Cache the tokens\n\t\t\ttokenCache( selector, groups ).slice( 0 );\n};\n\nfunction toSelector( tokens ) {\n\tvar i = 0,\n\t\tlen = tokens.length,\n\t\tselector = \"\";\n\tfor ( ; i < len; i++ ) {\n\t\tselector += tokens[i].value;\n\t}\n\treturn selector;\n}\n\nfunction addCombinator( matcher, combinator, base ) {\n\tvar dir = combinator.dir,\n\t\tcheckNonElements = base && dir === \"parentNode\",\n\t\tdoneName = done++;\n\n\treturn combinator.first ?\n\t\t// Check against closest ancestor/preceding element\n\t\tfunction( elem, context, xml ) {\n\t\t\twhile ( (elem = elem[ dir ]) ) {\n\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\treturn matcher( elem, context, xml );\n\t\t\t\t}\n\t\t\t}\n\t\t} :\n\n\t\t// Check against all ancestor/preceding elements\n\t\tfunction( elem, context, xml ) {\n\t\t\tvar oldCache, uniqueCache, outerCache,\n\t\t\t\tnewCache = [ dirruns, doneName ];\n\n\t\t\t// We can't set arbitrary data on XML nodes, so they don't benefit from combinator caching\n\t\t\tif ( xml ) {\n\t\t\t\twhile ( (elem = elem[ dir ]) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\t\tif ( matcher( elem, context, xml ) ) {\n\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\twhile ( (elem = elem[ dir ]) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\t\touterCache = elem[ expando ] || (elem[ expando ] = {});\n\n\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\tuniqueCache = outerCache[ elem.uniqueID ] || (outerCache[ elem.uniqueID ] = {});\n\n\t\t\t\t\t\tif ( (oldCache = uniqueCache[ dir ]) &&\n\t\t\t\t\t\t\toldCache[ 0 ] === dirruns && oldCache[ 1 ] === doneName ) {\n\n\t\t\t\t\t\t\t// Assign to newCache so results back-propagate to previous elements\n\t\t\t\t\t\t\treturn (newCache[ 2 ] = oldCache[ 2 ]);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// Reuse newcache so results back-propagate to previous elements\n\t\t\t\t\t\t\tuniqueCache[ dir ] = newCache;\n\n\t\t\t\t\t\t\t// A match means we're done; a fail means we have to keep checking\n\t\t\t\t\t\t\tif ( (newCache[ 2 ] = matcher( elem, context, xml )) ) {\n\t\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n}\n\nfunction elementMatcher( matchers ) {\n\treturn matchers.length > 1 ?\n\t\tfunction( elem, context, xml ) {\n\t\t\tvar i = matchers.length;\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( !matchers[i]( elem, context, xml ) ) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t} :\n\t\tmatchers[0];\n}\n\nfunction multipleContexts( selector, contexts, results ) {\n\tvar i = 0,\n\t\tlen = contexts.length;\n\tfor ( ; i < len; i++ ) {\n\t\tSizzle( selector, contexts[i], results );\n\t}\n\treturn results;\n}\n\nfunction condense( unmatched, map, filter, context, xml ) {\n\tvar elem,\n\t\tnewUnmatched = [],\n\t\ti = 0,\n\t\tlen = unmatched.length,\n\t\tmapped = map != null;\n\n\tfor ( ; i < len; i++ ) {\n\t\tif ( (elem = unmatched[i]) ) {\n\t\t\tif ( !filter || filter( elem, context, xml ) ) {\n\t\t\t\tnewUnmatched.push( elem );\n\t\t\t\tif ( mapped ) {\n\t\t\t\t\tmap.push( i );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn newUnmatched;\n}\n\nfunction setMatcher( preFilter, selector, matcher, postFilter, postFinder, postSelector ) {\n\tif ( postFilter && !postFilter[ expando ] ) {\n\t\tpostFilter = setMatcher( postFilter );\n\t}\n\tif ( postFinder && !postFinder[ expando ] ) {\n\t\tpostFinder = setMatcher( postFinder, postSelector );\n\t}\n\treturn markFunction(function( seed, results, context, xml ) {\n\t\tvar temp, i, elem,\n\t\t\tpreMap = [],\n\t\t\tpostMap = [],\n\t\t\tpreexisting = results.length,\n\n\t\t\t// Get initial elements from seed or context\n\t\t\telems = seed || multipleContexts( selector || \"*\", context.nodeType ? [ context ] : context, [] ),\n\n\t\t\t// Prefilter to get matcher input, preserving a map for seed-results synchronization\n\t\t\tmatcherIn = preFilter && ( seed || !selector ) ?\n\t\t\t\tcondense( elems, preMap, preFilter, context, xml ) :\n\t\t\t\telems,\n\n\t\t\tmatcherOut = matcher ?\n\t\t\t\t// If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results,\n\t\t\t\tpostFinder || ( seed ? preFilter : preexisting || postFilter ) ?\n\n\t\t\t\t\t// ...intermediate processing is necessary\n\t\t\t\t\t[] :\n\n\t\t\t\t\t// ...otherwise use results directly\n\t\t\t\t\tresults :\n\t\t\t\tmatcherIn;\n\n\t\t// Find primary matches\n\t\tif ( matcher ) {\n\t\t\tmatcher( matcherIn, matcherOut, context, xml );\n\t\t}\n\n\t\t// Apply postFilter\n\t\tif ( postFilter ) {\n\t\t\ttemp = condense( matcherOut, postMap );\n\t\t\tpostFilter( temp, [], context, xml );\n\n\t\t\t// Un-match failing elements by moving them back to matcherIn\n\t\t\ti = temp.length;\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( (elem = temp[i]) ) {\n\t\t\t\t\tmatcherOut[ postMap[i] ] = !(matcherIn[ postMap[i] ] = elem);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif ( seed ) {\n\t\t\tif ( postFinder || preFilter ) {\n\t\t\t\tif ( postFinder ) {\n\t\t\t\t\t// Get the final matcherOut by condensing this intermediate into postFinder contexts\n\t\t\t\t\ttemp = [];\n\t\t\t\t\ti = matcherOut.length;\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tif ( (elem = matcherOut[i]) ) {\n\t\t\t\t\t\t\t// Restore matcherIn since elem is not yet a final match\n\t\t\t\t\t\t\ttemp.push( (matcherIn[i] = elem) );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tpostFinder( null, (matcherOut = []), temp, xml );\n\t\t\t\t}\n\n\t\t\t\t// Move matched elements from seed to results to keep them synchronized\n\t\t\t\ti = matcherOut.length;\n\t\t\t\twhile ( i-- ) {\n\t\t\t\t\tif ( (elem = matcherOut[i]) &&\n\t\t\t\t\t\t(temp = postFinder ? indexOf( seed, elem ) : preMap[i]) > -1 ) {\n\n\t\t\t\t\t\tseed[temp] = !(results[temp] = elem);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Add elements to results, through postFinder if defined\n\t\t} else {\n\t\t\tmatcherOut = condense(\n\t\t\t\tmatcherOut === results ?\n\t\t\t\t\tmatcherOut.splice( preexisting, matcherOut.length ) :\n\t\t\t\t\tmatcherOut\n\t\t\t);\n\t\t\tif ( postFinder ) {\n\t\t\t\tpostFinder( null, results, matcherOut, xml );\n\t\t\t} else {\n\t\t\t\tpush.apply( results, matcherOut );\n\t\t\t}\n\t\t}\n\t});\n}\n\nfunction matcherFromTokens( tokens ) {\n\tvar checkContext, matcher, j,\n\t\tlen = tokens.length,\n\t\tleadingRelative = Expr.relative[ tokens[0].type ],\n\t\timplicitRelative = leadingRelative || Expr.relative[\" \"],\n\t\ti = leadingRelative ? 1 : 0,\n\n\t\t// The foundational matcher ensures that elements are reachable from top-level context(s)\n\t\tmatchContext = addCombinator( function( elem ) {\n\t\t\treturn elem === checkContext;\n\t\t}, implicitRelative, true ),\n\t\tmatchAnyContext = addCombinator( function( elem ) {\n\t\t\treturn indexOf( checkContext, elem ) > -1;\n\t\t}, implicitRelative, true ),\n\t\tmatchers = [ function( elem, context, xml ) {\n\t\t\tvar ret = ( !leadingRelative && ( xml || context !== outermostContext ) ) || (\n\t\t\t\t(checkContext = context).nodeType ?\n\t\t\t\t\tmatchContext( elem, context, xml ) :\n\t\t\t\t\tmatchAnyContext( elem, context, xml ) );\n\t\t\t// Avoid hanging onto element (issue #299)\n\t\t\tcheckContext = null;\n\t\t\treturn ret;\n\t\t} ];\n\n\tfor ( ; i < len; i++ ) {\n\t\tif ( (matcher = Expr.relative[ tokens[i].type ]) ) {\n\t\t\tmatchers = [ addCombinator(elementMatcher( matchers ), matcher) ];\n\t\t} else {\n\t\t\tmatcher = Expr.filter[ tokens[i].type ].apply( null, tokens[i].matches );\n\n\t\t\t// Return special upon seeing a positional matcher\n\t\t\tif ( matcher[ expando ] ) {\n\t\t\t\t// Find the next relative operator (if any) for proper handling\n\t\t\t\tj = ++i;\n\t\t\t\tfor ( ; j < len; j++ ) {\n\t\t\t\t\tif ( Expr.relative[ tokens[j].type ] ) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn setMatcher(\n\t\t\t\t\ti > 1 && elementMatcher( matchers ),\n\t\t\t\t\ti > 1 && toSelector(\n\t\t\t\t\t\t// If the preceding token was a descendant combinator, insert an implicit any-element `*`\n\t\t\t\t\t\ttokens.slice( 0, i - 1 ).concat({ value: tokens[ i - 2 ].type === \" \" ? \"*\" : \"\" })\n\t\t\t\t\t).replace( rtrim, \"$1\" ),\n\t\t\t\t\tmatcher,\n\t\t\t\t\ti < j && matcherFromTokens( tokens.slice( i, j ) ),\n\t\t\t\t\tj < len && matcherFromTokens( (tokens = tokens.slice( j )) ),\n\t\t\t\t\tj < len && toSelector( tokens )\n\t\t\t\t);\n\t\t\t}\n\t\t\tmatchers.push( matcher );\n\t\t}\n\t}\n\n\treturn elementMatcher( matchers );\n}\n\nfunction matcherFromGroupMatchers( elementMatchers, setMatchers ) {\n\tvar bySet = setMatchers.length > 0,\n\t\tbyElement = elementMatchers.length > 0,\n\t\tsuperMatcher = function( seed, context, xml, results, outermost ) {\n\t\t\tvar elem, j, matcher,\n\t\t\t\tmatchedCount = 0,\n\t\t\t\ti = \"0\",\n\t\t\t\tunmatched = seed && [],\n\t\t\t\tsetMatched = [],\n\t\t\t\tcontextBackup = outermostContext,\n\t\t\t\t// We must always have either seed elements or outermost context\n\t\t\t\telems = seed || byElement && Expr.find[\"TAG\"]( \"*\", outermost ),\n\t\t\t\t// Use integer dirruns iff this is the outermost matcher\n\t\t\t\tdirrunsUnique = (dirruns += contextBackup == null ? 1 : Math.random() || 0.1),\n\t\t\t\tlen = elems.length;\n\n\t\t\tif ( outermost ) {\n\t\t\t\toutermostContext = context === document || context || outermost;\n\t\t\t}\n\n\t\t\t// Add elements passing elementMatchers directly to results\n\t\t\t// Support: IE<9, Safari\n\t\t\t// Tolerate NodeList properties (IE: \"length\"; Safari: <number>) matching elements by id\n\t\t\tfor ( ; i !== len && (elem = elems[i]) != null; i++ ) {\n\t\t\t\tif ( byElement && elem ) {\n\t\t\t\t\tj = 0;\n\t\t\t\t\tif ( !context && elem.ownerDocument !== document ) {\n\t\t\t\t\t\tsetDocument( elem );\n\t\t\t\t\t\txml = !documentIsHTML;\n\t\t\t\t\t}\n\t\t\t\t\twhile ( (matcher = elementMatchers[j++]) ) {\n\t\t\t\t\t\tif ( matcher( elem, context || document, xml) ) {\n\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif ( outermost ) {\n\t\t\t\t\t\tdirruns = dirrunsUnique;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Track unmatched elements for set filters\n\t\t\t\tif ( bySet ) {\n\t\t\t\t\t// They will have gone through all possible matchers\n\t\t\t\t\tif ( (elem = !matcher && elem) ) {\n\t\t\t\t\t\tmatchedCount--;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Lengthen the array for every element, matched or not\n\t\t\t\t\tif ( seed ) {\n\t\t\t\t\t\tunmatched.push( elem );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// `i` is now the count of elements visited above, and adding it to `matchedCount`\n\t\t\t// makes the latter nonnegative.\n\t\t\tmatchedCount += i;\n\n\t\t\t// Apply set filters to unmatched elements\n\t\t\t// NOTE: This can be skipped if there are no unmatched elements (i.e., `matchedCount`\n\t\t\t// equals `i`), unless we didn't visit _any_ elements in the above loop because we have\n\t\t\t// no element matchers and no seed.\n\t\t\t// Incrementing an initially-string \"0\" `i` allows `i` to remain a string only in that\n\t\t\t// case, which will result in a \"00\" `matchedCount` that differs from `i` but is also\n\t\t\t// numerically zero.\n\t\t\tif ( bySet && i !== matchedCount ) {\n\t\t\t\tj = 0;\n\t\t\t\twhile ( (matcher = setMatchers[j++]) ) {\n\t\t\t\t\tmatcher( unmatched, setMatched, context, xml );\n\t\t\t\t}\n\n\t\t\t\tif ( seed ) {\n\t\t\t\t\t// Reintegrate element matches to eliminate the need for sorting\n\t\t\t\t\tif ( matchedCount > 0 ) {\n\t\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\t\tif ( !(unmatched[i] || setMatched[i]) ) {\n\t\t\t\t\t\t\t\tsetMatched[i] = pop.call( results );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Discard index placeholder values to get only actual matches\n\t\t\t\t\tsetMatched = condense( setMatched );\n\t\t\t\t}\n\n\t\t\t\t// Add matches to results\n\t\t\t\tpush.apply( results, setMatched );\n\n\t\t\t\t// Seedless set matches succeeding multiple successful matchers stipulate sorting\n\t\t\t\tif ( outermost && !seed && setMatched.length > 0 &&\n\t\t\t\t\t( matchedCount + setMatchers.length ) > 1 ) {\n\n\t\t\t\t\tSizzle.uniqueSort( results );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Override manipulation of globals by nested matchers\n\t\t\tif ( outermost ) {\n\t\t\t\tdirruns = dirrunsUnique;\n\t\t\t\toutermostContext = contextBackup;\n\t\t\t}\n\n\t\t\treturn unmatched;\n\t\t};\n\n\treturn bySet ?\n\t\tmarkFunction( superMatcher ) :\n\t\tsuperMatcher;\n}\n\ncompile = Sizzle.compile = function( selector, match /* Internal Use Only */ ) {\n\tvar i,\n\t\tsetMatchers = [],\n\t\telementMatchers = [],\n\t\tcached = compilerCache[ selector + \" \" ];\n\n\tif ( !cached ) {\n\t\t// Generate a function of recursive functions that can be used to check each element\n\t\tif ( !match ) {\n\t\t\tmatch = tokenize( selector );\n\t\t}\n\t\ti = match.length;\n\t\twhile ( i-- ) {\n\t\t\tcached = matcherFromTokens( match[i] );\n\t\t\tif ( cached[ expando ] ) {\n\t\t\t\tsetMatchers.push( cached );\n\t\t\t} else {\n\t\t\t\telementMatchers.push( cached );\n\t\t\t}\n\t\t}\n\n\t\t// Cache the compiled function\n\t\tcached = compilerCache( selector, matcherFromGroupMatchers( elementMatchers, setMatchers ) );\n\n\t\t// Save selector and tokenization\n\t\tcached.selector = selector;\n\t}\n\treturn cached;\n};\n\n/**\n * A low-level selection function that works with Sizzle's compiled\n * selector functions\n * @param {String|Function} selector A selector or a pre-compiled\n * selector function built with Sizzle.compile\n * @param {Element} context\n * @param {Array} [results]\n * @param {Array} [seed] A set of elements to match against\n */\nselect = Sizzle.select = function( selector, context, results, seed ) {\n\tvar i, tokens, token, type, find,\n\t\tcompiled = typeof selector === \"function\" && selector,\n\t\tmatch = !seed && tokenize( (selector = compiled.selector || selector) );\n\n\tresults = results || [];\n\n\t// Try to minimize operations if there is only one selector in the list and no seed\n\t// (the latter of which guarantees us context)\n\tif ( match.length === 1 ) {\n\n\t\t// Reduce context if the leading compound selector is an ID\n\t\ttokens = match[0] = match[0].slice( 0 );\n\t\tif ( tokens.length > 2 && (token = tokens[0]).type === \"ID\" &&\n\t\t\t\tsupport.getById && context.nodeType === 9 && documentIsHTML &&\n\t\t\t\tExpr.relative[ tokens[1].type ] ) {\n\n\t\t\tcontext = ( Expr.find[\"ID\"]( token.matches[0].replace(runescape, funescape), context ) || [] )[0];\n\t\t\tif ( !context ) {\n\t\t\t\treturn results;\n\n\t\t\t// Precompiled matchers will still verify ancestry, so step up a level\n\t\t\t} else if ( compiled ) {\n\t\t\t\tcontext = context.parentNode;\n\t\t\t}\n\n\t\t\tselector = selector.slice( tokens.shift().value.length );\n\t\t}\n\n\t\t// Fetch a seed set for right-to-left matching\n\t\ti = matchExpr[\"needsContext\"].test( selector ) ? 0 : tokens.length;\n\t\twhile ( i-- ) {\n\t\t\ttoken = tokens[i];\n\n\t\t\t// Abort if we hit a combinator\n\t\t\tif ( Expr.relative[ (type = token.type) ] ) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif ( (find = Expr.find[ type ]) ) {\n\t\t\t\t// Search, expanding context for leading sibling combinators\n\t\t\t\tif ( (seed = find(\n\t\t\t\t\ttoken.matches[0].replace( runescape, funescape ),\n\t\t\t\t\trsibling.test( tokens[0].type ) && testContext( context.parentNode ) || context\n\t\t\t\t)) ) {\n\n\t\t\t\t\t// If seed is empty or no tokens remain, we can return early\n\t\t\t\t\ttokens.splice( i, 1 );\n\t\t\t\t\tselector = seed.length && toSelector( tokens );\n\t\t\t\t\tif ( !selector ) {\n\t\t\t\t\t\tpush.apply( results, seed );\n\t\t\t\t\t\treturn results;\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Compile and execute a filtering function if one is not provided\n\t// Provide `match` to avoid retokenization if we modified the selector above\n\t( compiled || compile( selector, match ) )(\n\t\tseed,\n\t\tcontext,\n\t\t!documentIsHTML,\n\t\tresults,\n\t\t!context || rsibling.test( selector ) && testContext( context.parentNode ) || context\n\t);\n\treturn results;\n};\n\n// One-time assignments\n\n// Sort stability\nsupport.sortStable = expando.split(\"\").sort( sortOrder ).join(\"\") === expando;\n\n// Support: Chrome 14-35+\n// Always assume duplicates if they aren't passed to the comparison function\nsupport.detectDuplicates = !!hasDuplicate;\n\n// Initialize against the default document\nsetDocument();\n\n// Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27)\n// Detached nodes confoundingly follow *each other*\nsupport.sortDetached = assert(function( div1 ) {\n\t// Should return 1, but returns 4 (following)\n\treturn div1.compareDocumentPosition( document.createElement(\"div\") ) & 1;\n});\n\n// Support: IE<8\n// Prevent attribute/property \"interpolation\"\n// http://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx\nif ( !assert(function( div ) {\n\tdiv.innerHTML = \"<a href='#'></a>\";\n\treturn div.firstChild.getAttribute(\"href\") === \"#\" ;\n}) ) {\n\taddHandle( \"type|href|height|width\", function( elem, name, isXML ) {\n\t\tif ( !isXML ) {\n\t\t\treturn elem.getAttribute( name, name.toLowerCase() === \"type\" ? 1 : 2 );\n\t\t}\n\t});\n}\n\n// Support: IE<9\n// Use defaultValue in place of getAttribute(\"value\")\nif ( !support.attributes || !assert(function( div ) {\n\tdiv.innerHTML = \"<input/>\";\n\tdiv.firstChild.setAttribute( \"value\", \"\" );\n\treturn div.firstChild.getAttribute( \"value\" ) === \"\";\n}) ) {\n\taddHandle( \"value\", function( elem, name, isXML ) {\n\t\tif ( !isXML && elem.nodeName.toLowerCase() === \"input\" ) {\n\t\t\treturn elem.defaultValue;\n\t\t}\n\t});\n}\n\n// Support: IE<9\n// Use getAttributeNode to fetch booleans when getAttribute lies\nif ( !assert(function( div ) {\n\treturn div.getAttribute(\"disabled\") == null;\n}) ) {\n\taddHandle( booleans, function( elem, name, isXML ) {\n\t\tvar val;\n\t\tif ( !isXML ) {\n\t\t\treturn elem[ name ] === true ? name.toLowerCase() :\n\t\t\t\t\t(val = elem.getAttributeNode( name )) && val.specified ?\n\t\t\t\t\tval.value :\n\t\t\t\tnull;\n\t\t}\n\t});\n}\n\nreturn Sizzle;\n\n})( window );\n\n\n\njQuery.find = Sizzle;\njQuery.expr = Sizzle.selectors;\njQuery.expr[ \":\" ] = jQuery.expr.pseudos;\njQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort;\njQuery.text = Sizzle.getText;\njQuery.isXMLDoc = Sizzle.isXML;\njQuery.contains = Sizzle.contains;\n\n\n\nvar dir = function( elem, dir, until ) {\n\tvar matched = [],\n\t\ttruncate = until !== undefined;\n\n\twhile ( ( elem = elem[ dir ] ) && elem.nodeType !== 9 ) {\n\t\tif ( elem.nodeType === 1 ) {\n\t\t\tif ( truncate && jQuery( elem ).is( until ) ) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tmatched.push( elem );\n\t\t}\n\t}\n\treturn matched;\n};\n\n\nvar siblings = function( n, elem ) {\n\tvar matched = [];\n\n\tfor ( ; n; n = n.nextSibling ) {\n\t\tif ( n.nodeType === 1 && n !== elem ) {\n\t\t\tmatched.push( n );\n\t\t}\n\t}\n\n\treturn matched;\n};\n\n\nvar rneedsContext = jQuery.expr.match.needsContext;\n\nvar rsingleTag = ( /^<([\\w-]+)\\s*\\/?>(?:<\\/\\1>|)$/ );\n\n\n\nvar risSimple = /^.[^:#\\[\\.,]*$/;\n\n// Implement the identical functionality for filter and not\nfunction winnow( elements, qualifier, not ) {\n\tif ( jQuery.isFunction( qualifier ) ) {\n\t\treturn jQuery.grep( elements, function( elem, i ) {\n\t\t\t/* jshint -W018 */\n\t\t\treturn !!qualifier.call( elem, i, elem ) !== not;\n\t\t} );\n\n\t}\n\n\tif ( qualifier.nodeType ) {\n\t\treturn jQuery.grep( elements, function( elem ) {\n\t\t\treturn ( elem === qualifier ) !== not;\n\t\t} );\n\n\t}\n\n\tif ( typeof qualifier === \"string\" ) {\n\t\tif ( risSimple.test( qualifier ) ) {\n\t\t\treturn jQuery.filter( qualifier, elements, not );\n\t\t}\n\n\t\tqualifier = jQuery.filter( qualifier, elements );\n\t}\n\n\treturn jQuery.grep( elements, function( elem ) {\n\t\treturn ( indexOf.call( qualifier, elem ) > -1 ) !== not;\n\t} );\n}\n\njQuery.filter = function( expr, elems, not ) {\n\tvar elem = elems[ 0 ];\n\n\tif ( not ) {\n\t\texpr = \":not(\" + expr + \")\";\n\t}\n\n\treturn elems.length === 1 && elem.nodeType === 1 ?\n\t\tjQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [] :\n\t\tjQuery.find.matches( expr, jQuery.grep( elems, function( elem ) {\n\t\t\treturn elem.nodeType === 1;\n\t\t} ) );\n};\n\njQuery.fn.extend( {\n\tfind: function( selector ) {\n\t\tvar i,\n\t\t\tlen = this.length,\n\t\t\tret = [],\n\t\t\tself = this;\n\n\t\tif ( typeof selector !== \"string\" ) {\n\t\t\treturn this.pushStack( jQuery( selector ).filter( function() {\n\t\t\t\tfor ( i = 0; i < len; i++ ) {\n\t\t\t\t\tif ( jQuery.contains( self[ i ], this ) ) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} ) );\n\t\t}\n\n\t\tfor ( i = 0; i < len; i++ ) {\n\t\t\tjQuery.find( selector, self[ i ], ret );\n\t\t}\n\n\t\t// Needed because $( selector, context ) becomes $( context ).find( selector )\n\t\tret = this.pushStack( len > 1 ? jQuery.unique( ret ) : ret );\n\t\tret.selector = this.selector ? this.selector + \" \" + selector : selector;\n\t\treturn ret;\n\t},\n\tfilter: function( selector ) {\n\t\treturn this.pushStack( winnow( this, selector || [], false ) );\n\t},\n\tnot: function( selector ) {\n\t\treturn this.pushStack( winnow( this, selector || [], true ) );\n\t},\n\tis: function( selector ) {\n\t\treturn !!winnow(\n\t\t\tthis,\n\n\t\t\t// If this is a positional/relative selector, check membership in the returned set\n\t\t\t// so $(\"p:first\").is(\"p:last\") won't return true for a doc with two \"p\".\n\t\t\ttypeof selector === \"string\" && rneedsContext.test( selector ) ?\n\t\t\t\tjQuery( selector ) :\n\t\t\t\tselector || [],\n\t\t\tfalse\n\t\t).length;\n\t}\n} );\n\n\n// Initialize a jQuery object\n\n\n// A central reference to the root jQuery(document)\nvar rootjQuery,\n\n\t// A simple way to check for HTML strings\n\t// Prioritize #id over <tag> to avoid XSS via location.hash (#9521)\n\t// Strict HTML recognition (#11290: must start with <)\n\trquickExpr = /^(?:\\s*(<[\\w\\W]+>)[^>]*|#([\\w-]*))$/,\n\n\tinit = jQuery.fn.init = function( selector, context, root ) {\n\t\tvar match, elem;\n\n\t\t// HANDLE: $(\"\"), $(null), $(undefined), $(false)\n\t\tif ( !selector ) {\n\t\t\treturn this;\n\t\t}\n\n\t\t// Method init() accepts an alternate rootjQuery\n\t\t// so migrate can support jQuery.sub (gh-2101)\n\t\troot = root || rootjQuery;\n\n\t\t// Handle HTML strings\n\t\tif ( typeof selector === \"string\" ) {\n\t\t\tif ( selector[ 0 ] === \"<\" &&\n\t\t\t\tselector[ selector.length - 1 ] === \">\" &&\n\t\t\t\tselector.length >= 3 ) {\n\n\t\t\t\t// Assume that strings that start and end with <> are HTML and skip the regex check\n\t\t\t\tmatch = [ null, selector, null ];\n\n\t\t\t} else {\n\t\t\t\tmatch = rquickExpr.exec( selector );\n\t\t\t}\n\n\t\t\t// Match html or make sure no context is specified for #id\n\t\t\tif ( match && ( match[ 1 ] || !context ) ) {\n\n\t\t\t\t// HANDLE: $(html) -> $(array)\n\t\t\t\tif ( match[ 1 ] ) {\n\t\t\t\t\tcontext = context instanceof jQuery ? context[ 0 ] : context;\n\n\t\t\t\t\t// Option to run scripts is true for back-compat\n\t\t\t\t\t// Intentionally let the error be thrown if parseHTML is not present\n\t\t\t\t\tjQuery.merge( this, jQuery.parseHTML(\n\t\t\t\t\t\tmatch[ 1 ],\n\t\t\t\t\t\tcontext && context.nodeType ? context.ownerDocument || context : document,\n\t\t\t\t\t\ttrue\n\t\t\t\t\t) );\n\n\t\t\t\t\t// HANDLE: $(html, props)\n\t\t\t\t\tif ( rsingleTag.test( match[ 1 ] ) && jQuery.isPlainObject( context ) ) {\n\t\t\t\t\t\tfor ( match in context ) {\n\n\t\t\t\t\t\t\t// Properties of context are called as methods if possible\n\t\t\t\t\t\t\tif ( jQuery.isFunction( this[ match ] ) ) {\n\t\t\t\t\t\t\t\tthis[ match ]( context[ match ] );\n\n\t\t\t\t\t\t\t// ...and otherwise set as attributes\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tthis.attr( match, context[ match ] );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\treturn this;\n\n\t\t\t\t// HANDLE: $(#id)\n\t\t\t\t} else {\n\t\t\t\t\telem = document.getElementById( match[ 2 ] );\n\n\t\t\t\t\t// Support: Blackberry 4.6\n\t\t\t\t\t// gEBID returns nodes no longer in the document (#6963)\n\t\t\t\t\tif ( elem && elem.parentNode ) {\n\n\t\t\t\t\t\t// Inject the element directly into the jQuery object\n\t\t\t\t\t\tthis.length = 1;\n\t\t\t\t\t\tthis[ 0 ] = elem;\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.context = document;\n\t\t\t\t\tthis.selector = selector;\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\n\t\t\t// HANDLE: $(expr, $(...))\n\t\t\t} else if ( !context || context.jquery ) {\n\t\t\t\treturn ( context || root ).find( selector );\n\n\t\t\t// HANDLE: $(expr, context)\n\t\t\t// (which is just equivalent to: $(context).find(expr)\n\t\t\t} else {\n\t\t\t\treturn this.constructor( context ).find( selector );\n\t\t\t}\n\n\t\t// HANDLE: $(DOMElement)\n\t\t} else if ( selector.nodeType ) {\n\t\t\tthis.context = this[ 0 ] = selector;\n\t\t\tthis.length = 1;\n\t\t\treturn this;\n\n\t\t// HANDLE: $(function)\n\t\t// Shortcut for document ready\n\t\t} else if ( jQuery.isFunction( selector ) ) {\n\t\t\treturn root.ready !== undefined ?\n\t\t\t\troot.ready( selector ) :\n\n\t\t\t\t// Execute immediately if ready is not present\n\t\t\t\tselector( jQuery );\n\t\t}\n\n\t\tif ( selector.selector !== undefined ) {\n\t\t\tthis.selector = selector.selector;\n\t\t\tthis.context = selector.context;\n\t\t}\n\n\t\treturn jQuery.makeArray( selector, this );\n\t};\n\n// Give the init function the jQuery prototype for later instantiation\ninit.prototype = jQuery.fn;\n\n// Initialize central reference\nrootjQuery = jQuery( document );\n\n\nvar rparentsprev = /^(?:parents|prev(?:Until|All))/,\n\n\t// Methods guaranteed to produce a unique set when starting from a unique set\n\tguaranteedUnique = {\n\t\tchildren: true,\n\t\tcontents: true,\n\t\tnext: true,\n\t\tprev: true\n\t};\n\njQuery.fn.extend( {\n\thas: function( target ) {\n\t\tvar targets = jQuery( target, this ),\n\t\t\tl = targets.length;\n\n\t\treturn this.filter( function() {\n\t\t\tvar i = 0;\n\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\tif ( jQuery.contains( this, targets[ i ] ) ) {\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t},\n\n\tclosest: function( selectors, context ) {\n\t\tvar cur,\n\t\t\ti = 0,\n\t\t\tl = this.length,\n\t\t\tmatched = [],\n\t\t\tpos = rneedsContext.test( selectors ) || typeof selectors !== \"string\" ?\n\t\t\t\tjQuery( selectors, context || this.context ) :\n\t\t\t\t0;\n\n\t\tfor ( ; i < l; i++ ) {\n\t\t\tfor ( cur = this[ i ]; cur && cur !== context; cur = cur.parentNode ) {\n\n\t\t\t\t// Always skip document fragments\n\t\t\t\tif ( cur.nodeType < 11 && ( pos ?\n\t\t\t\t\tpos.index( cur ) > -1 :\n\n\t\t\t\t\t// Don't pass non-elements to Sizzle\n\t\t\t\t\tcur.nodeType === 1 &&\n\t\t\t\t\t\tjQuery.find.matchesSelector( cur, selectors ) ) ) {\n\n\t\t\t\t\tmatched.push( cur );\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this.pushStack( matched.length > 1 ? jQuery.uniqueSort( matched ) : matched );\n\t},\n\n\t// Determine the position of an element within the set\n\tindex: function( elem ) {\n\n\t\t// No argument, return index in parent\n\t\tif ( !elem ) {\n\t\t\treturn ( this[ 0 ] && this[ 0 ].parentNode ) ? this.first().prevAll().length : -1;\n\t\t}\n\n\t\t// Index in selector\n\t\tif ( typeof elem === \"string\" ) {\n\t\t\treturn indexOf.call( jQuery( elem ), this[ 0 ] );\n\t\t}\n\n\t\t// Locate the position of the desired element\n\t\treturn indexOf.call( this,\n\n\t\t\t// If it receives a jQuery object, the first element is used\n\t\t\telem.jquery ? elem[ 0 ] : elem\n\t\t);\n\t},\n\n\tadd: function( selector, context ) {\n\t\treturn this.pushStack(\n\t\t\tjQuery.uniqueSort(\n\t\t\t\tjQuery.merge( this.get(), jQuery( selector, context ) )\n\t\t\t)\n\t\t);\n\t},\n\n\taddBack: function( selector ) {\n\t\treturn this.add( selector == null ?\n\t\t\tthis.prevObject : this.prevObject.filter( selector )\n\t\t);\n\t}\n} );\n\nfunction sibling( cur, dir ) {\n\twhile ( ( cur = cur[ dir ] ) && cur.nodeType !== 1 ) {}\n\treturn cur;\n}\n\njQuery.each( {\n\tparent: function( elem ) {\n\t\tvar parent = elem.parentNode;\n\t\treturn parent && parent.nodeType !== 11 ? parent : null;\n\t},\n\tparents: function( elem ) {\n\t\treturn dir( elem, \"parentNode\" );\n\t},\n\tparentsUntil: function( elem, i, until ) {\n\t\treturn dir( elem, \"parentNode\", until );\n\t},\n\tnext: function( elem ) {\n\t\treturn sibling( elem, \"nextSibling\" );\n\t},\n\tprev: function( elem ) {\n\t\treturn sibling( elem, \"previousSibling\" );\n\t},\n\tnextAll: function( elem ) {\n\t\treturn dir( elem, \"nextSibling\" );\n\t},\n\tprevAll: function( elem ) {\n\t\treturn dir( elem, \"previousSibling\" );\n\t},\n\tnextUntil: function( elem, i, until ) {\n\t\treturn dir( elem, \"nextSibling\", until );\n\t},\n\tprevUntil: function( elem, i, until ) {\n\t\treturn dir( elem, \"previousSibling\", until );\n\t},\n\tsiblings: function( elem ) {\n\t\treturn siblings( ( elem.parentNode || {} ).firstChild, elem );\n\t},\n\tchildren: function( elem ) {\n\t\treturn siblings( elem.firstChild );\n\t},\n\tcontents: function( elem ) {\n\t\treturn elem.contentDocument || jQuery.merge( [], elem.childNodes );\n\t}\n}, function( name, fn ) {\n\tjQuery.fn[ name ] = function( until, selector ) {\n\t\tvar matched = jQuery.map( this, fn, until );\n\n\t\tif ( name.slice( -5 ) !== \"Until\" ) {\n\t\t\tselector = until;\n\t\t}\n\n\t\tif ( selector && typeof selector === \"string\" ) {\n\t\t\tmatched = jQuery.filter( selector, matched );\n\t\t}\n\n\t\tif ( this.length > 1 ) {\n\n\t\t\t// Remove duplicates\n\t\t\tif ( !guaranteedUnique[ name ] ) {\n\t\t\t\tjQuery.uniqueSort( matched );\n\t\t\t}\n\n\t\t\t// Reverse order for parents* and prev-derivatives\n\t\t\tif ( rparentsprev.test( name ) ) {\n\t\t\t\tmatched.reverse();\n\t\t\t}\n\t\t}\n\n\t\treturn this.pushStack( matched );\n\t};\n} );\nvar rnotwhite = ( /\\S+/g );\n\n\n\n// Convert String-formatted options into Object-formatted ones\nfunction createOptions( options ) {\n\tvar object = {};\n\tjQuery.each( options.match( rnotwhite ) || [], function( _, flag ) {\n\t\tobject[ flag ] = true;\n\t} );\n\treturn object;\n}\n\n/*\n * Create a callback list using the following parameters:\n *\n *\toptions: an optional list of space-separated options that will change how\n *\t\t\tthe callback list behaves or a more traditional option object\n *\n * By default a callback list will act like an event callback list and can be\n * \"fired\" multiple times.\n *\n * Possible options:\n *\n *\tonce:\t\t\twill ensure the callback list can only be fired once (like a Deferred)\n *\n *\tmemory:\t\t\twill keep track of previous values and will call any callback added\n *\t\t\t\t\tafter the list has been fired right away with the latest \"memorized\"\n *\t\t\t\t\tvalues (like a Deferred)\n *\n *\tunique:\t\t\twill ensure a callback can only be added once (no duplicate in the list)\n *\n *\tstopOnFalse:\tinterrupt callings when a callback returns false\n *\n */\njQuery.Callbacks = function( options ) {\n\n\t// Convert options from String-formatted to Object-formatted if needed\n\t// (we check in cache first)\n\toptions = typeof options === \"string\" ?\n\t\tcreateOptions( options ) :\n\t\tjQuery.extend( {}, options );\n\n\tvar // Flag to know if list is currently firing\n\t\tfiring,\n\n\t\t// Last fire value for non-forgettable lists\n\t\tmemory,\n\n\t\t// Flag to know if list was already fired\n\t\tfired,\n\n\t\t// Flag to prevent firing\n\t\tlocked,\n\n\t\t// Actual callback list\n\t\tlist = [],\n\n\t\t// Queue of execution data for repeatable lists\n\t\tqueue = [],\n\n\t\t// Index of currently firing callback (modified by add/remove as needed)\n\t\tfiringIndex = -1,\n\n\t\t// Fire callbacks\n\t\tfire = function() {\n\n\t\t\t// Enforce single-firing\n\t\t\tlocked = options.once;\n\n\t\t\t// Execute callbacks for all pending executions,\n\t\t\t// respecting firingIndex overrides and runtime changes\n\t\t\tfired = firing = true;\n\t\t\tfor ( ; queue.length; firingIndex = -1 ) {\n\t\t\t\tmemory = queue.shift();\n\t\t\t\twhile ( ++firingIndex < list.length ) {\n\n\t\t\t\t\t// Run callback and check for early termination\n\t\t\t\t\tif ( list[ firingIndex ].apply( memory[ 0 ], memory[ 1 ] ) === false &&\n\t\t\t\t\t\toptions.stopOnFalse ) {\n\n\t\t\t\t\t\t// Jump to end and forget the data so .add doesn't re-fire\n\t\t\t\t\t\tfiringIndex = list.length;\n\t\t\t\t\t\tmemory = false;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Forget the data if we're done with it\n\t\t\tif ( !options.memory ) {\n\t\t\t\tmemory = false;\n\t\t\t}\n\n\t\t\tfiring = false;\n\n\t\t\t// Clean up if we're done firing for good\n\t\t\tif ( locked ) {\n\n\t\t\t\t// Keep an empty list if we have data for future add calls\n\t\t\t\tif ( memory ) {\n\t\t\t\t\tlist = [];\n\n\t\t\t\t// Otherwise, this object is spent\n\t\t\t\t} else {\n\t\t\t\t\tlist = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\t// Actual Callbacks object\n\t\tself = {\n\n\t\t\t// Add a callback or a collection of callbacks to the list\n\t\t\tadd: function() {\n\t\t\t\tif ( list ) {\n\n\t\t\t\t\t// If we have memory from a past run, we should fire after adding\n\t\t\t\t\tif ( memory && !firing ) {\n\t\t\t\t\t\tfiringIndex = list.length - 1;\n\t\t\t\t\t\tqueue.push( memory );\n\t\t\t\t\t}\n\n\t\t\t\t\t( function add( args ) {\n\t\t\t\t\t\tjQuery.each( args, function( _, arg ) {\n\t\t\t\t\t\t\tif ( jQuery.isFunction( arg ) ) {\n\t\t\t\t\t\t\t\tif ( !options.unique || !self.has( arg ) ) {\n\t\t\t\t\t\t\t\t\tlist.push( arg );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if ( arg && arg.length && jQuery.type( arg ) !== \"string\" ) {\n\n\t\t\t\t\t\t\t\t// Inspect recursively\n\t\t\t\t\t\t\t\tadd( arg );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} );\n\t\t\t\t\t} )( arguments );\n\n\t\t\t\t\tif ( memory && !firing ) {\n\t\t\t\t\t\tfire();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Remove a callback from the list\n\t\t\tremove: function() {\n\t\t\t\tjQuery.each( arguments, function( _, arg ) {\n\t\t\t\t\tvar index;\n\t\t\t\t\twhile ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) {\n\t\t\t\t\t\tlist.splice( index, 1 );\n\n\t\t\t\t\t\t// Handle firing indexes\n\t\t\t\t\t\tif ( index <= firingIndex ) {\n\t\t\t\t\t\t\tfiringIndex--;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Check if a given callback is in the list.\n\t\t\t// If no argument is given, return whether or not list has callbacks attached.\n\t\t\thas: function( fn ) {\n\t\t\t\treturn fn ?\n\t\t\t\t\tjQuery.inArray( fn, list ) > -1 :\n\t\t\t\t\tlist.length > 0;\n\t\t\t},\n\n\t\t\t// Remove all callbacks from the list\n\t\t\tempty: function() {\n\t\t\t\tif ( list ) {\n\t\t\t\t\tlist = [];\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Disable .fire and .add\n\t\t\t// Abort any current/pending executions\n\t\t\t// Clear all callbacks and values\n\t\t\tdisable: function() {\n\t\t\t\tlocked = queue = [];\n\t\t\t\tlist = memory = \"\";\n\t\t\t\treturn this;\n\t\t\t},\n\t\t\tdisabled: function() {\n\t\t\t\treturn !list;\n\t\t\t},\n\n\t\t\t// Disable .fire\n\t\t\t// Also disable .add unless we have memory (since it would have no effect)\n\t\t\t// Abort any pending executions\n\t\t\tlock: function() {\n\t\t\t\tlocked = queue = [];\n\t\t\t\tif ( !memory ) {\n\t\t\t\t\tlist = memory = \"\";\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\t\t\tlocked: function() {\n\t\t\t\treturn !!locked;\n\t\t\t},\n\n\t\t\t// Call all callbacks with the given context and arguments\n\t\t\tfireWith: function( context, args ) {\n\t\t\t\tif ( !locked ) {\n\t\t\t\t\targs = args || [];\n\t\t\t\t\targs = [ context, args.slice ? args.slice() : args ];\n\t\t\t\t\tqueue.push( args );\n\t\t\t\t\tif ( !firing ) {\n\t\t\t\t\t\tfire();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Call all the callbacks with the given arguments\n\t\t\tfire: function() {\n\t\t\t\tself.fireWith( this, arguments );\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// To know if the callbacks have already been called at least once\n\t\t\tfired: function() {\n\t\t\t\treturn !!fired;\n\t\t\t}\n\t\t};\n\n\treturn self;\n};\n\n\njQuery.extend( {\n\n\tDeferred: function( func ) {\n\t\tvar tuples = [\n\n\t\t\t\t// action, add listener, listener list, final state\n\t\t\t\t[ \"resolve\", \"done\", jQuery.Callbacks( \"once memory\" ), \"resolved\" ],\n\t\t\t\t[ \"reject\", \"fail\", jQuery.Callbacks( \"once memory\" ), \"rejected\" ],\n\t\t\t\t[ \"notify\", \"progress\", jQuery.Callbacks( \"memory\" ) ]\n\t\t\t],\n\t\t\tstate = \"pending\",\n\t\t\tpromise = {\n\t\t\t\tstate: function() {\n\t\t\t\t\treturn state;\n\t\t\t\t},\n\t\t\t\talways: function() {\n\t\t\t\t\tdeferred.done( arguments ).fail( arguments );\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\t\t\t\tthen: function( /* fnDone, fnFail, fnProgress */ ) {\n\t\t\t\t\tvar fns = arguments;\n\t\t\t\t\treturn jQuery.Deferred( function( newDefer ) {\n\t\t\t\t\t\tjQuery.each( tuples, function( i, tuple ) {\n\t\t\t\t\t\t\tvar fn = jQuery.isFunction( fns[ i ] ) && fns[ i ];\n\n\t\t\t\t\t\t\t// deferred[ done | fail | progress ] for forwarding actions to newDefer\n\t\t\t\t\t\t\tdeferred[ tuple[ 1 ] ]( function() {\n\t\t\t\t\t\t\t\tvar returned = fn && fn.apply( this, arguments );\n\t\t\t\t\t\t\t\tif ( returned && jQuery.isFunction( returned.promise ) ) {\n\t\t\t\t\t\t\t\t\treturned.promise()\n\t\t\t\t\t\t\t\t\t\t.progress( newDefer.notify )\n\t\t\t\t\t\t\t\t\t\t.done( newDefer.resolve )\n\t\t\t\t\t\t\t\t\t\t.fail( newDefer.reject );\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tnewDefer[ tuple[ 0 ] + \"With\" ](\n\t\t\t\t\t\t\t\t\t\tthis === promise ? newDefer.promise() : this,\n\t\t\t\t\t\t\t\t\t\tfn ? [ returned ] : arguments\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t} );\n\t\t\t\t\t\tfns = null;\n\t\t\t\t\t} ).promise();\n\t\t\t\t},\n\n\t\t\t\t// Get a promise for this deferred\n\t\t\t\t// If obj is provided, the promise aspect is added to the object\n\t\t\t\tpromise: function( obj ) {\n\t\t\t\t\treturn obj != null ? jQuery.extend( obj, promise ) : promise;\n\t\t\t\t}\n\t\t\t},\n\t\t\tdeferred = {};\n\n\t\t// Keep pipe for back-compat\n\t\tpromise.pipe = promise.then;\n\n\t\t// Add list-specific methods\n\t\tjQuery.each( tuples, function( i, tuple ) {\n\t\t\tvar list = tuple[ 2 ],\n\t\t\t\tstateString = tuple[ 3 ];\n\n\t\t\t// promise[ done | fail | progress ] = list.add\n\t\t\tpromise[ tuple[ 1 ] ] = list.add;\n\n\t\t\t// Handle state\n\t\t\tif ( stateString ) {\n\t\t\t\tlist.add( function() {\n\n\t\t\t\t\t// state = [ resolved | rejected ]\n\t\t\t\t\tstate = stateString;\n\n\t\t\t\t// [ reject_list | resolve_list ].disable; progress_list.lock\n\t\t\t\t}, tuples[ i ^ 1 ][ 2 ].disable, tuples[ 2 ][ 2 ].lock );\n\t\t\t}\n\n\t\t\t// deferred[ resolve | reject | notify ]\n\t\t\tdeferred[ tuple[ 0 ] ] = function() {\n\t\t\t\tdeferred[ tuple[ 0 ] + \"With\" ]( this === deferred ? promise : this, arguments );\n\t\t\t\treturn this;\n\t\t\t};\n\t\t\tdeferred[ tuple[ 0 ] + \"With\" ] = list.fireWith;\n\t\t} );\n\n\t\t// Make the deferred a promise\n\t\tpromise.promise( deferred );\n\n\t\t// Call given func if any\n\t\tif ( func ) {\n\t\t\tfunc.call( deferred, deferred );\n\t\t}\n\n\t\t// All done!\n\t\treturn deferred;\n\t},\n\n\t// Deferred helper\n\twhen: function( subordinate /* , ..., subordinateN */ ) {\n\t\tvar i = 0,\n\t\t\tresolveValues = slice.call( arguments ),\n\t\t\tlength = resolveValues.length,\n\n\t\t\t// the count of uncompleted subordinates\n\t\t\tremaining = length !== 1 ||\n\t\t\t\t( subordinate && jQuery.isFunction( subordinate.promise ) ) ? length : 0,\n\n\t\t\t// the master Deferred.\n\t\t\t// If resolveValues consist of only a single Deferred, just use that.\n\t\t\tdeferred = remaining === 1 ? subordinate : jQuery.Deferred(),\n\n\t\t\t// Update function for both resolve and progress values\n\t\t\tupdateFunc = function( i, contexts, values ) {\n\t\t\t\treturn function( value ) {\n\t\t\t\t\tcontexts[ i ] = this;\n\t\t\t\t\tvalues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value;\n\t\t\t\t\tif ( values === progressValues ) {\n\t\t\t\t\t\tdeferred.notifyWith( contexts, values );\n\t\t\t\t\t} else if ( !( --remaining ) ) {\n\t\t\t\t\t\tdeferred.resolveWith( contexts, values );\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t},\n\n\t\t\tprogressValues, progressContexts, resolveContexts;\n\n\t\t// Add listeners to Deferred subordinates; treat others as resolved\n\t\tif ( length > 1 ) {\n\t\t\tprogressValues = new Array( length );\n\t\t\tprogressContexts = new Array( length );\n\t\t\tresolveContexts = new Array( length );\n\t\t\tfor ( ; i < length; i++ ) {\n\t\t\t\tif ( resolveValues[ i ] && jQuery.isFunction( resolveValues[ i ].promise ) ) {\n\t\t\t\t\tresolveValues[ i ].promise()\n\t\t\t\t\t\t.progress( updateFunc( i, progressContexts, progressValues ) )\n\t\t\t\t\t\t.done( updateFunc( i, resolveContexts, resolveValues ) )\n\t\t\t\t\t\t.fail( deferred.reject );\n\t\t\t\t} else {\n\t\t\t\t\t--remaining;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// If we're not waiting on anything, resolve the master\n\t\tif ( !remaining ) {\n\t\t\tdeferred.resolveWith( resolveContexts, resolveValues );\n\t\t}\n\n\t\treturn deferred.promise();\n\t}\n} );\n\n\n// The deferred used on DOM ready\nvar readyList;\n\njQuery.fn.ready = function( fn ) {\n\n\t// Add the callback\n\tjQuery.ready.promise().done( fn );\n\n\treturn this;\n};\n\njQuery.extend( {\n\n\t// Is the DOM ready to be used? Set to true once it occurs.\n\tisReady: false,\n\n\t// A counter to track how many items to wait for before\n\t// the ready event fires. See #6781\n\treadyWait: 1,\n\n\t// Hold (or release) the ready event\n\tholdReady: function( hold ) {\n\t\tif ( hold ) {\n\t\t\tjQuery.readyWait++;\n\t\t} else {\n\t\t\tjQuery.ready( true );\n\t\t}\n\t},\n\n\t// Handle when the DOM is ready\n\tready: function( wait ) {\n\n\t\t// Abort if there are pending holds or we're already ready\n\t\tif ( wait === true ? --jQuery.readyWait : jQuery.isReady ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Remember that the DOM is ready\n\t\tjQuery.isReady = true;\n\n\t\t// If a normal DOM Ready event fired, decrement, and wait if need be\n\t\tif ( wait !== true && --jQuery.readyWait > 0 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// If there are functions bound, to execute\n\t\treadyList.resolveWith( document, [ jQuery ] );\n\n\t\t// Trigger any bound ready events\n\t\tif ( jQuery.fn.triggerHandler ) {\n\t\t\tjQuery( document ).triggerHandler( \"ready\" );\n\t\t\tjQuery( document ).off( \"ready\" );\n\t\t}\n\t}\n} );\n\n/**\n * The ready event handler and self cleanup method\n */\nfunction completed() {\n\tdocument.removeEventListener( \"DOMContentLoaded\", completed );\n\twindow.removeEventListener( \"load\", completed );\n\tjQuery.ready();\n}\n\njQuery.ready.promise = function( obj ) {\n\tif ( !readyList ) {\n\n\t\treadyList = jQuery.Deferred();\n\n\t\t// Catch cases where $(document).ready() is called\n\t\t// after the browser event has already occurred.\n\t\t// Support: IE9-10 only\n\t\t// Older IE sometimes signals \"interactive\" too soon\n\t\tif ( document.readyState === \"complete\" ||\n\t\t\t( document.readyState !== \"loading\" && !document.documentElement.doScroll ) ) {\n\n\t\t\t// Handle it asynchronously to allow scripts the opportunity to delay ready\n\t\t\twindow.setTimeout( jQuery.ready );\n\n\t\t} else {\n\n\t\t\t// Use the handy event callback\n\t\t\tdocument.addEventListener( \"DOMContentLoaded\", completed );\n\n\t\t\t// A fallback to window.onload, that will always work\n\t\t\twindow.addEventListener( \"load\", completed );\n\t\t}\n\t}\n\treturn readyList.promise( obj );\n};\n\n// Kick off the DOM ready check even if the user does not\njQuery.ready.promise();\n\n\n\n\n// Multifunctional method to get and set values of a collection\n// The value/s can optionally be executed if it's a function\nvar access = function( elems, fn, key, value, chainable, emptyGet, raw ) {\n\tvar i = 0,\n\t\tlen = elems.length,\n\t\tbulk = key == null;\n\n\t// Sets many values\n\tif ( jQuery.type( key ) === \"object\" ) {\n\t\tchainable = true;\n\t\tfor ( i in key ) {\n\t\t\taccess( elems, fn, i, key[ i ], true, emptyGet, raw );\n\t\t}\n\n\t// Sets one value\n\t} else if ( value !== undefined ) {\n\t\tchainable = true;\n\n\t\tif ( !jQuery.isFunction( value ) ) {\n\t\t\traw = true;\n\t\t}\n\n\t\tif ( bulk ) {\n\n\t\t\t// Bulk operations run against the entire set\n\t\t\tif ( raw ) {\n\t\t\t\tfn.call( elems, value );\n\t\t\t\tfn = null;\n\n\t\t\t// ...except when executing function values\n\t\t\t} else {\n\t\t\t\tbulk = fn;\n\t\t\t\tfn = function( elem, key, value ) {\n\t\t\t\t\treturn bulk.call( jQuery( elem ), value );\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\n\t\tif ( fn ) {\n\t\t\tfor ( ; i < len; i++ ) {\n\t\t\t\tfn(\n\t\t\t\t\telems[ i ], key, raw ?\n\t\t\t\t\tvalue :\n\t\t\t\t\tvalue.call( elems[ i ], i, fn( elems[ i ], key ) )\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn chainable ?\n\t\telems :\n\n\t\t// Gets\n\t\tbulk ?\n\t\t\tfn.call( elems ) :\n\t\t\tlen ? fn( elems[ 0 ], key ) : emptyGet;\n};\nvar acceptData = function( owner ) {\n\n\t// Accepts only:\n\t// - Node\n\t// - Node.ELEMENT_NODE\n\t// - Node.DOCUMENT_NODE\n\t// - Object\n\t// - Any\n\t/* jshint -W018 */\n\treturn owner.nodeType === 1 || owner.nodeType === 9 || !( +owner.nodeType );\n};\n\n\n\n\nfunction Data() {\n\tthis.expando = jQuery.expando + Data.uid++;\n}\n\nData.uid = 1;\n\nData.prototype = {\n\n\tregister: function( owner, initial ) {\n\t\tvar value = initial || {};\n\n\t\t// If it is a node unlikely to be stringify-ed or looped over\n\t\t// use plain assignment\n\t\tif ( owner.nodeType ) {\n\t\t\towner[ this.expando ] = value;\n\n\t\t// Otherwise secure it in a non-enumerable, non-writable property\n\t\t// configurability must be true to allow the property to be\n\t\t// deleted with the delete operator\n\t\t} else {\n\t\t\tObject.defineProperty( owner, this.expando, {\n\t\t\t\tvalue: value,\n\t\t\t\twritable: true,\n\t\t\t\tconfigurable: true\n\t\t\t} );\n\t\t}\n\t\treturn owner[ this.expando ];\n\t},\n\tcache: function( owner ) {\n\n\t\t// We can accept data for non-element nodes in modern browsers,\n\t\t// but we should not, see #8335.\n\t\t// Always return an empty object.\n\t\tif ( !acceptData( owner ) ) {\n\t\t\treturn {};\n\t\t}\n\n\t\t// Check if the owner object already has a cache\n\t\tvar value = owner[ this.expando ];\n\n\t\t// If not, create one\n\t\tif ( !value ) {\n\t\t\tvalue = {};\n\n\t\t\t// We can accept data for non-element nodes in modern browsers,\n\t\t\t// but we should not, see #8335.\n\t\t\t// Always return an empty object.\n\t\t\tif ( acceptData( owner ) ) {\n\n\t\t\t\t// If it is a node unlikely to be stringify-ed or looped over\n\t\t\t\t// use plain assignment\n\t\t\t\tif ( owner.nodeType ) {\n\t\t\t\t\towner[ this.expando ] = value;\n\n\t\t\t\t// Otherwise secure it in a non-enumerable property\n\t\t\t\t// configurable must be true to allow the property to be\n\t\t\t\t// deleted when data is removed\n\t\t\t\t} else {\n\t\t\t\t\tObject.defineProperty( owner, this.expando, {\n\t\t\t\t\t\tvalue: value,\n\t\t\t\t\t\tconfigurable: true\n\t\t\t\t\t} );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn value;\n\t},\n\tset: function( owner, data, value ) {\n\t\tvar prop,\n\t\t\tcache = this.cache( owner );\n\n\t\t// Handle: [ owner, key, value ] args\n\t\tif ( typeof data === \"string\" ) {\n\t\t\tcache[ data ] = value;\n\n\t\t// Handle: [ owner, { properties } ] args\n\t\t} else {\n\n\t\t\t// Copy the properties one-by-one to the cache object\n\t\t\tfor ( prop in data ) {\n\t\t\t\tcache[ prop ] = data[ prop ];\n\t\t\t}\n\t\t}\n\t\treturn cache;\n\t},\n\tget: function( owner, key ) {\n\t\treturn key === undefined ?\n\t\t\tthis.cache( owner ) :\n\t\t\towner[ this.expando ] && owner[ this.expando ][ key ];\n\t},\n\taccess: function( owner, key, value ) {\n\t\tvar stored;\n\n\t\t// In cases where either:\n\t\t//\n\t\t// 1. No key was specified\n\t\t// 2. A string key was specified, but no value provided\n\t\t//\n\t\t// Take the \"read\" path and allow the get method to determine\n\t\t// which value to return, respectively either:\n\t\t//\n\t\t// 1. The entire cache object\n\t\t// 2. The data stored at the key\n\t\t//\n\t\tif ( key === undefined ||\n\t\t\t\t( ( key && typeof key === \"string\" ) && value === undefined ) ) {\n\n\t\t\tstored = this.get( owner, key );\n\n\t\t\treturn stored !== undefined ?\n\t\t\t\tstored : this.get( owner, jQuery.camelCase( key ) );\n\t\t}\n\n\t\t// When the key is not a string, or both a key and value\n\t\t// are specified, set or extend (existing objects) with either:\n\t\t//\n\t\t// 1. An object of properties\n\t\t// 2. A key and value\n\t\t//\n\t\tthis.set( owner, key, value );\n\n\t\t// Since the \"set\" path can have two possible entry points\n\t\t// return the expected data based on which path was taken[*]\n\t\treturn value !== undefined ? value : key;\n\t},\n\tremove: function( owner, key ) {\n\t\tvar i, name, camel,\n\t\t\tcache = owner[ this.expando ];\n\n\t\tif ( cache === undefined ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( key === undefined ) {\n\t\t\tthis.register( owner );\n\n\t\t} else {\n\n\t\t\t// Support array or space separated string of keys\n\t\t\tif ( jQuery.isArray( key ) ) {\n\n\t\t\t\t// If \"name\" is an array of keys...\n\t\t\t\t// When data is initially created, via (\"key\", \"val\") signature,\n\t\t\t\t// keys will be converted to camelCase.\n\t\t\t\t// Since there is no way to tell _how_ a key was added, remove\n\t\t\t\t// both plain key and camelCase key. #12786\n\t\t\t\t// This will only penalize the array argument path.\n\t\t\t\tname = key.concat( key.map( jQuery.camelCase ) );\n\t\t\t} else {\n\t\t\t\tcamel = jQuery.camelCase( key );\n\n\t\t\t\t// Try the string as a key before any manipulation\n\t\t\t\tif ( key in cache ) {\n\t\t\t\t\tname = [ key, camel ];\n\t\t\t\t} else {\n\n\t\t\t\t\t// If a key with the spaces exists, use it.\n\t\t\t\t\t// Otherwise, create an array by matching non-whitespace\n\t\t\t\t\tname = camel;\n\t\t\t\t\tname = name in cache ?\n\t\t\t\t\t\t[ name ] : ( name.match( rnotwhite ) || [] );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\ti = name.length;\n\n\t\t\twhile ( i-- ) {\n\t\t\t\tdelete cache[ name[ i ] ];\n\t\t\t}\n\t\t}\n\n\t\t// Remove the expando if there's no more data\n\t\tif ( key === undefined || jQuery.isEmptyObject( cache ) ) {\n\n\t\t\t// Support: Chrome <= 35-45+\n\t\t\t// Webkit & Blink performance suffers when deleting properties\n\t\t\t// from DOM nodes, so set to undefined instead\n\t\t\t// https://code.google.com/p/chromium/issues/detail?id=378607\n\t\t\tif ( owner.nodeType ) {\n\t\t\t\towner[ this.expando ] = undefined;\n\t\t\t} else {\n\t\t\t\tdelete owner[ this.expando ];\n\t\t\t}\n\t\t}\n\t},\n\thasData: function( owner ) {\n\t\tvar cache = owner[ this.expando ];\n\t\treturn cache !== undefined && !jQuery.isEmptyObject( cache );\n\t}\n};\nvar dataPriv = new Data();\n\nvar dataUser = new Data();\n\n\n\n//\tImplementation Summary\n//\n//\t1. Enforce API surface and semantic compatibility with 1.9.x branch\n//\t2. Improve the module's maintainability by reducing the storage\n//\t\tpaths to a single mechanism.\n//\t3. Use the same single mechanism to support \"private\" and \"user\" data.\n//\t4. _Never_ expose \"private\" data to user code (TODO: Drop _data, _removeData)\n//\t5. Avoid exposing implementation details on user objects (eg. expando properties)\n//\t6. Provide a clear path for implementation upgrade to WeakMap in 2014\n\nvar rbrace = /^(?:\\{[\\w\\W]*\\}|\\[[\\w\\W]*\\])$/,\n\trmultiDash = /[A-Z]/g;\n\nfunction dataAttr( elem, key, data ) {\n\tvar name;\n\n\t// If nothing was found internally, try to fetch any\n\t// data from the HTML5 data-* attribute\n\tif ( data === undefined && elem.nodeType === 1 ) {\n\t\tname = \"data-\" + key.replace( rmultiDash, \"-$&\" ).toLowerCase();\n\t\tdata = elem.getAttribute( name );\n\n\t\tif ( typeof data === \"string\" ) {\n\t\t\ttry {\n\t\t\t\tdata = data === \"true\" ? true :\n\t\t\t\t\tdata === \"false\" ? false :\n\t\t\t\t\tdata === \"null\" ? null :\n\n\t\t\t\t\t// Only convert to a number if it doesn't change the string\n\t\t\t\t\t+data + \"\" === data ? +data :\n\t\t\t\t\trbrace.test( data ) ? jQuery.parseJSON( data ) :\n\t\t\t\t\tdata;\n\t\t\t} catch ( e ) {}\n\n\t\t\t// Make sure we set the data so it isn't changed later\n\t\t\tdataUser.set( elem, key, data );\n\t\t} else {\n\t\t\tdata = undefined;\n\t\t}\n\t}\n\treturn data;\n}\n\njQuery.extend( {\n\thasData: function( elem ) {\n\t\treturn dataUser.hasData( elem ) || dataPriv.hasData( elem );\n\t},\n\n\tdata: function( elem, name, data ) {\n\t\treturn dataUser.access( elem, name, data );\n\t},\n\n\tremoveData: function( elem, name ) {\n\t\tdataUser.remove( elem, name );\n\t},\n\n\t// TODO: Now that all calls to _data and _removeData have been replaced\n\t// with direct calls to dataPriv methods, these can be deprecated.\n\t_data: function( elem, name, data ) {\n\t\treturn dataPriv.access( elem, name, data );\n\t},\n\n\t_removeData: function( elem, name ) {\n\t\tdataPriv.remove( elem, name );\n\t}\n} );\n\njQuery.fn.extend( {\n\tdata: function( key, value ) {\n\t\tvar i, name, data,\n\t\t\telem = this[ 0 ],\n\t\t\tattrs = elem && elem.attributes;\n\n\t\t// Gets all values\n\t\tif ( key === undefined ) {\n\t\t\tif ( this.length ) {\n\t\t\t\tdata = dataUser.get( elem );\n\n\t\t\t\tif ( elem.nodeType === 1 && !dataPriv.get( elem, \"hasDataAttrs\" ) ) {\n\t\t\t\t\ti = attrs.length;\n\t\t\t\t\twhile ( i-- ) {\n\n\t\t\t\t\t\t// Support: IE11+\n\t\t\t\t\t\t// The attrs elements can be null (#14894)\n\t\t\t\t\t\tif ( attrs[ i ] ) {\n\t\t\t\t\t\t\tname = attrs[ i ].name;\n\t\t\t\t\t\t\tif ( name.indexOf( \"data-\" ) === 0 ) {\n\t\t\t\t\t\t\t\tname = jQuery.camelCase( name.slice( 5 ) );\n\t\t\t\t\t\t\t\tdataAttr( elem, name, data[ name ] );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tdataPriv.set( elem, \"hasDataAttrs\", true );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn data;\n\t\t}\n\n\t\t// Sets multiple values\n\t\tif ( typeof key === \"object\" ) {\n\t\t\treturn this.each( function() {\n\t\t\t\tdataUser.set( this, key );\n\t\t\t} );\n\t\t}\n\n\t\treturn access( this, function( value ) {\n\t\t\tvar data, camelKey;\n\n\t\t\t// The calling jQuery object (element matches) is not empty\n\t\t\t// (and therefore has an element appears at this[ 0 ]) and the\n\t\t\t// `value` parameter was not undefined. An empty jQuery object\n\t\t\t// will result in `undefined` for elem = this[ 0 ] which will\n\t\t\t// throw an exception if an attempt to read a data cache is made.\n\t\t\tif ( elem && value === undefined ) {\n\n\t\t\t\t// Attempt to get data from the cache\n\t\t\t\t// with the key as-is\n\t\t\t\tdata = dataUser.get( elem, key ) ||\n\n\t\t\t\t\t// Try to find dashed key if it exists (gh-2779)\n\t\t\t\t\t// This is for 2.2.x only\n\t\t\t\t\tdataUser.get( elem, key.replace( rmultiDash, \"-$&\" ).toLowerCase() );\n\n\t\t\t\tif ( data !== undefined ) {\n\t\t\t\t\treturn data;\n\t\t\t\t}\n\n\t\t\t\tcamelKey = jQuery.camelCase( key );\n\n\t\t\t\t// Attempt to get data from the cache\n\t\t\t\t// with the key camelized\n\t\t\t\tdata = dataUser.get( elem, camelKey );\n\t\t\t\tif ( data !== undefined ) {\n\t\t\t\t\treturn data;\n\t\t\t\t}\n\n\t\t\t\t// Attempt to \"discover\" the data in\n\t\t\t\t// HTML5 custom data-* attrs\n\t\t\t\tdata = dataAttr( elem, camelKey, undefined );\n\t\t\t\tif ( data !== undefined ) {\n\t\t\t\t\treturn data;\n\t\t\t\t}\n\n\t\t\t\t// We tried really hard, but the data doesn't exist.\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Set the data...\n\t\t\tcamelKey = jQuery.camelCase( key );\n\t\t\tthis.each( function() {\n\n\t\t\t\t// First, attempt to store a copy or reference of any\n\t\t\t\t// data that might've been store with a camelCased key.\n\t\t\t\tvar data = dataUser.get( this, camelKey );\n\n\t\t\t\t// For HTML5 data-* attribute interop, we have to\n\t\t\t\t// store property names with dashes in a camelCase form.\n\t\t\t\t// This might not apply to all properties...*\n\t\t\t\tdataUser.set( this, camelKey, value );\n\n\t\t\t\t// *... In the case of properties that might _actually_\n\t\t\t\t// have dashes, we need to also store a copy of that\n\t\t\t\t// unchanged property.\n\t\t\t\tif ( key.indexOf( \"-\" ) > -1 && data !== undefined ) {\n\t\t\t\t\tdataUser.set( this, key, value );\n\t\t\t\t}\n\t\t\t} );\n\t\t}, null, value, arguments.length > 1, null, true );\n\t},\n\n\tremoveData: function( key ) {\n\t\treturn this.each( function() {\n\t\t\tdataUser.remove( this, key );\n\t\t} );\n\t}\n} );\n\n\njQuery.extend( {\n\tqueue: function( elem, type, data ) {\n\t\tvar queue;\n\n\t\tif ( elem ) {\n\t\t\ttype = ( type || \"fx\" ) + \"queue\";\n\t\t\tqueue = dataPriv.get( elem, type );\n\n\t\t\t// Speed up dequeue by getting out quickly if this is just a lookup\n\t\t\tif ( data ) {\n\t\t\t\tif ( !queue || jQuery.isArray( data ) ) {\n\t\t\t\t\tqueue = dataPriv.access( elem, type, jQuery.makeArray( data ) );\n\t\t\t\t} else {\n\t\t\t\t\tqueue.push( data );\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn queue || [];\n\t\t}\n\t},\n\n\tdequeue: function( elem, type ) {\n\t\ttype = type || \"fx\";\n\n\t\tvar queue = jQuery.queue( elem, type ),\n\t\t\tstartLength = queue.length,\n\t\t\tfn = queue.shift(),\n\t\t\thooks = jQuery._queueHooks( elem, type ),\n\t\t\tnext = function() {\n\t\t\t\tjQuery.dequeue( elem, type );\n\t\t\t};\n\n\t\t// If the fx queue is dequeued, always remove the progress sentinel\n\t\tif ( fn === \"inprogress\" ) {\n\t\t\tfn = queue.shift();\n\t\t\tstartLength--;\n\t\t}\n\n\t\tif ( fn ) {\n\n\t\t\t// Add a progress sentinel to prevent the fx queue from being\n\t\t\t// automatically dequeued\n\t\t\tif ( type === \"fx\" ) {\n\t\t\t\tqueue.unshift( \"inprogress\" );\n\t\t\t}\n\n\t\t\t// Clear up the last queue stop function\n\t\t\tdelete hooks.stop;\n\t\t\tfn.call( elem, next, hooks );\n\t\t}\n\n\t\tif ( !startLength && hooks ) {\n\t\t\thooks.empty.fire();\n\t\t}\n\t},\n\n\t// Not public - generate a queueHooks object, or return the current one\n\t_queueHooks: function( elem, type ) {\n\t\tvar key = type + \"queueHooks\";\n\t\treturn dataPriv.get( elem, key ) || dataPriv.access( elem, key, {\n\t\t\tempty: jQuery.Callbacks( \"once memory\" ).add( function() {\n\t\t\t\tdataPriv.remove( elem, [ type + \"queue\", key ] );\n\t\t\t} )\n\t\t} );\n\t}\n} );\n\njQuery.fn.extend( {\n\tqueue: function( type, data ) {\n\t\tvar setter = 2;\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tdata = type;\n\t\t\ttype = \"fx\";\n\t\t\tsetter--;\n\t\t}\n\n\t\tif ( arguments.length < setter ) {\n\t\t\treturn jQuery.queue( this[ 0 ], type );\n\t\t}\n\n\t\treturn data === undefined ?\n\t\t\tthis :\n\t\t\tthis.each( function() {\n\t\t\t\tvar queue = jQuery.queue( this, type, data );\n\n\t\t\t\t// Ensure a hooks for this queue\n\t\t\t\tjQuery._queueHooks( this, type );\n\n\t\t\t\tif ( type === \"fx\" && queue[ 0 ] !== \"inprogress\" ) {\n\t\t\t\t\tjQuery.dequeue( this, type );\n\t\t\t\t}\n\t\t\t} );\n\t},\n\tdequeue: function( type ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.dequeue( this, type );\n\t\t} );\n\t},\n\tclearQueue: function( type ) {\n\t\treturn this.queue( type || \"fx\", [] );\n\t},\n\n\t// Get a promise resolved when queues of a certain type\n\t// are emptied (fx is the type by default)\n\tpromise: function( type, obj ) {\n\t\tvar tmp,\n\t\t\tcount = 1,\n\t\t\tdefer = jQuery.Deferred(),\n\t\t\telements = this,\n\t\t\ti = this.length,\n\t\t\tresolve = function() {\n\t\t\t\tif ( !( --count ) ) {\n\t\t\t\t\tdefer.resolveWith( elements, [ elements ] );\n\t\t\t\t}\n\t\t\t};\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tobj = type;\n\t\t\ttype = undefined;\n\t\t}\n\t\ttype = type || \"fx\";\n\n\t\twhile ( i-- ) {\n\t\t\ttmp = dataPriv.get( elements[ i ], type + \"queueHooks\" );\n\t\t\tif ( tmp && tmp.empty ) {\n\t\t\t\tcount++;\n\t\t\t\ttmp.empty.add( resolve );\n\t\t\t}\n\t\t}\n\t\tresolve();\n\t\treturn defer.promise( obj );\n\t}\n} );\nvar pnum = ( /[+-]?(?:\\d*\\.|)\\d+(?:[eE][+-]?\\d+|)/ ).source;\n\nvar rcssNum = new RegExp( \"^(?:([+-])=|)(\" + pnum + \")([a-z%]*)$\", \"i\" );\n\n\nvar cssExpand = [ \"Top\", \"Right\", \"Bottom\", \"Left\" ];\n\nvar isHidden = function( elem, el ) {\n\n\t\t// isHidden might be called from jQuery#filter function;\n\t\t// in that case, element will be second argument\n\t\telem = el || elem;\n\t\treturn jQuery.css( elem, \"display\" ) === \"none\" ||\n\t\t\t!jQuery.contains( elem.ownerDocument, elem );\n\t};\n\n\n\nfunction adjustCSS( elem, prop, valueParts, tween ) {\n\tvar adjusted,\n\t\tscale = 1,\n\t\tmaxIterations = 20,\n\t\tcurrentValue = tween ?\n\t\t\tfunction() { return tween.cur(); } :\n\t\t\tfunction() { return jQuery.css( elem, prop, \"\" ); },\n\t\tinitial = currentValue(),\n\t\tunit = valueParts && valueParts[ 3 ] || ( jQuery.cssNumber[ prop ] ? \"\" : \"px\" ),\n\n\t\t// Starting value computation is required for potential unit mismatches\n\t\tinitialInUnit = ( jQuery.cssNumber[ prop ] || unit !== \"px\" && +initial ) &&\n\t\t\trcssNum.exec( jQuery.css( elem, prop ) );\n\n\tif ( initialInUnit && initialInUnit[ 3 ] !== unit ) {\n\n\t\t// Trust units reported by jQuery.css\n\t\tunit = unit || initialInUnit[ 3 ];\n\n\t\t// Make sure we update the tween properties later on\n\t\tvalueParts = valueParts || [];\n\n\t\t// Iteratively approximate from a nonzero starting point\n\t\tinitialInUnit = +initial || 1;\n\n\t\tdo {\n\n\t\t\t// If previous iteration zeroed out, double until we get *something*.\n\t\t\t// Use string for doubling so we don't accidentally see scale as unchanged below\n\t\t\tscale = scale || \".5\";\n\n\t\t\t// Adjust and apply\n\t\t\tinitialInUnit = initialInUnit / scale;\n\t\t\tjQuery.style( elem, prop, initialInUnit + unit );\n\n\t\t// Update scale, tolerating zero or NaN from tween.cur()\n\t\t// Break the loop if scale is unchanged or perfect, or if we've just had enough.\n\t\t} while (\n\t\t\tscale !== ( scale = currentValue() / initial ) && scale !== 1 && --maxIterations\n\t\t);\n\t}\n\n\tif ( valueParts ) {\n\t\tinitialInUnit = +initialInUnit || +initial || 0;\n\n\t\t// Apply relative offset (+=/-=) if specified\n\t\tadjusted = valueParts[ 1 ] ?\n\t\t\tinitialInUnit + ( valueParts[ 1 ] + 1 ) * valueParts[ 2 ] :\n\t\t\t+valueParts[ 2 ];\n\t\tif ( tween ) {\n\t\t\ttween.unit = unit;\n\t\t\ttween.start = initialInUnit;\n\t\t\ttween.end = adjusted;\n\t\t}\n\t}\n\treturn adjusted;\n}\nvar rcheckableType = ( /^(?:checkbox|radio)$/i );\n\nvar rtagName = ( /<([\\w:-]+)/ );\n\nvar rscriptType = ( /^$|\\/(?:java|ecma)script/i );\n\n\n\n// We have to close these tags to support XHTML (#13200)\nvar wrapMap = {\n\n\t// Support: IE9\n\toption: [ 1, \"<select multiple='multiple'>\", \"</select>\" ],\n\n\t// XHTML parsers do not magically insert elements in the\n\t// same way that tag soup parsers do. So we cannot shorten\n\t// this by omitting <tbody> or other required elements.\n\tthead: [ 1, \"<table>\", \"</table>\" ],\n\tcol: [ 2, \"<table><colgroup>\", \"</colgroup></table>\" ],\n\ttr: [ 2, \"<table><tbody>\", \"</tbody></table>\" ],\n\ttd: [ 3, \"<table><tbody><tr>\", \"</tr></tbody></table>\" ],\n\n\t_default: [ 0, \"\", \"\" ]\n};\n\n// Support: IE9\nwrapMap.optgroup = wrapMap.option;\n\nwrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead;\nwrapMap.th = wrapMap.td;\n\n\nfunction getAll( context, tag ) {\n\n\t// Support: IE9-11+\n\t// Use typeof to avoid zero-argument method invocation on host objects (#15151)\n\tvar ret = typeof context.getElementsByTagName !== \"undefined\" ?\n\t\t\tcontext.getElementsByTagName( tag || \"*\" ) :\n\t\t\ttypeof context.querySelectorAll !== \"undefined\" ?\n\t\t\t\tcontext.querySelectorAll( tag || \"*\" ) :\n\t\t\t[];\n\n\treturn tag === undefined || tag && jQuery.nodeName( context, tag ) ?\n\t\tjQuery.merge( [ context ], ret ) :\n\t\tret;\n}\n\n\n// Mark scripts as having already been evaluated\nfunction setGlobalEval( elems, refElements ) {\n\tvar i = 0,\n\t\tl = elems.length;\n\n\tfor ( ; i < l; i++ ) {\n\t\tdataPriv.set(\n\t\t\telems[ i ],\n\t\t\t\"globalEval\",\n\t\t\t!refElements || dataPriv.get( refElements[ i ], \"globalEval\" )\n\t\t);\n\t}\n}\n\n\nvar rhtml = /<|&#?\\w+;/;\n\nfunction buildFragment( elems, context, scripts, selection, ignored ) {\n\tvar elem, tmp, tag, wrap, contains, j,\n\t\tfragment = context.createDocumentFragment(),\n\t\tnodes = [],\n\t\ti = 0,\n\t\tl = elems.length;\n\n\tfor ( ; i < l; i++ ) {\n\t\telem = elems[ i ];\n\n\t\tif ( elem || elem === 0 ) {\n\n\t\t\t// Add nodes directly\n\t\t\tif ( jQuery.type( elem ) === \"object\" ) {\n\n\t\t\t\t// Support: Android<4.1, PhantomJS<2\n\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\tjQuery.merge( nodes, elem.nodeType ? [ elem ] : elem );\n\n\t\t\t// Convert non-html into a text node\n\t\t\t} else if ( !rhtml.test( elem ) ) {\n\t\t\t\tnodes.push( context.createTextNode( elem ) );\n\n\t\t\t// Convert html into DOM nodes\n\t\t\t} else {\n\t\t\t\ttmp = tmp || fragment.appendChild( context.createElement( \"div\" ) );\n\n\t\t\t\t// Deserialize a standard representation\n\t\t\t\ttag = ( rtagName.exec( elem ) || [ \"\", \"\" ] )[ 1 ].toLowerCase();\n\t\t\t\twrap = wrapMap[ tag ] || wrapMap._default;\n\t\t\t\ttmp.innerHTML = wrap[ 1 ] + jQuery.htmlPrefilter( elem ) + wrap[ 2 ];\n\n\t\t\t\t// Descend through wrappers to the right content\n\t\t\t\tj = wrap[ 0 ];\n\t\t\t\twhile ( j-- ) {\n\t\t\t\t\ttmp = tmp.lastChild;\n\t\t\t\t}\n\n\t\t\t\t// Support: Android<4.1, PhantomJS<2\n\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\tjQuery.merge( nodes, tmp.childNodes );\n\n\t\t\t\t// Remember the top-level container\n\t\t\t\ttmp = fragment.firstChild;\n\n\t\t\t\t// Ensure the created nodes are orphaned (#12392)\n\t\t\t\ttmp.textContent = \"\";\n\t\t\t}\n\t\t}\n\t}\n\n\t// Remove wrapper from fragment\n\tfragment.textContent = \"\";\n\n\ti = 0;\n\twhile ( ( elem = nodes[ i++ ] ) ) {\n\n\t\t// Skip elements already in the context collection (trac-4087)\n\t\tif ( selection && jQuery.inArray( elem, selection ) > -1 ) {\n\t\t\tif ( ignored ) {\n\t\t\t\tignored.push( elem );\n\t\t\t}\n\t\t\tcontinue;\n\t\t}\n\n\t\tcontains = jQuery.contains( elem.ownerDocument, elem );\n\n\t\t// Append to fragment\n\t\ttmp = getAll( fragment.appendChild( elem ), \"script\" );\n\n\t\t// Preserve script evaluation history\n\t\tif ( contains ) {\n\t\t\tsetGlobalEval( tmp );\n\t\t}\n\n\t\t// Capture executables\n\t\tif ( scripts ) {\n\t\t\tj = 0;\n\t\t\twhile ( ( elem = tmp[ j++ ] ) ) {\n\t\t\t\tif ( rscriptType.test( elem.type || \"\" ) ) {\n\t\t\t\t\tscripts.push( elem );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn fragment;\n}\n\n\n( function() {\n\tvar fragment = document.createDocumentFragment(),\n\t\tdiv = fragment.appendChild( document.createElement( \"div\" ) ),\n\t\tinput = document.createElement( \"input\" );\n\n\t// Support: Android 4.0-4.3, Safari<=5.1\n\t// Check state lost if the name is set (#11217)\n\t// Support: Windows Web Apps (WWA)\n\t// `name` and `type` must use .setAttribute for WWA (#14901)\n\tinput.setAttribute( \"type\", \"radio\" );\n\tinput.setAttribute( \"checked\", \"checked\" );\n\tinput.setAttribute( \"name\", \"t\" );\n\n\tdiv.appendChild( input );\n\n\t// Support: Safari<=5.1, Android<4.2\n\t// Older WebKit doesn't clone checked state correctly in fragments\n\tsupport.checkClone = div.cloneNode( true ).cloneNode( true ).lastChild.checked;\n\n\t// Support: IE<=11+\n\t// Make sure textarea (and checkbox) defaultValue is properly cloned\n\tdiv.innerHTML = \"<textarea>x</textarea>\";\n\tsupport.noCloneChecked = !!div.cloneNode( true ).lastChild.defaultValue;\n} )();\n\n\nvar\n\trkeyEvent = /^key/,\n\trmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/,\n\trtypenamespace = /^([^.]*)(?:\\.(.+)|)/;\n\nfunction returnTrue() {\n\treturn true;\n}\n\nfunction returnFalse() {\n\treturn false;\n}\n\n// Support: IE9\n// See #13393 for more info\nfunction safeActiveElement() {\n\ttry {\n\t\treturn document.activeElement;\n\t} catch ( err ) { }\n}\n\nfunction on( elem, types, selector, data, fn, one ) {\n\tvar origFn, type;\n\n\t// Types can be a map of types/handlers\n\tif ( typeof types === \"object\" ) {\n\n\t\t// ( types-Object, selector, data )\n\t\tif ( typeof selector !== \"string\" ) {\n\n\t\t\t// ( types-Object, data )\n\t\t\tdata = data || selector;\n\t\t\tselector = undefined;\n\t\t}\n\t\tfor ( type in types ) {\n\t\t\ton( elem, type, selector, data, types[ type ], one );\n\t\t}\n\t\treturn elem;\n\t}\n\n\tif ( data == null && fn == null ) {\n\n\t\t// ( types, fn )\n\t\tfn = selector;\n\t\tdata = selector = undefined;\n\t} else if ( fn == null ) {\n\t\tif ( typeof selector === \"string\" ) {\n\n\t\t\t// ( types, selector, fn )\n\t\t\tfn = data;\n\t\t\tdata = undefined;\n\t\t} else {\n\n\t\t\t// ( types, data, fn )\n\t\t\tfn = data;\n\t\t\tdata = selector;\n\t\t\tselector = undefined;\n\t\t}\n\t}\n\tif ( fn === false ) {\n\t\tfn = returnFalse;\n\t} else if ( !fn ) {\n\t\treturn elem;\n\t}\n\n\tif ( one === 1 ) {\n\t\torigFn = fn;\n\t\tfn = function( event ) {\n\n\t\t\t// Can use an empty set, since event contains the info\n\t\t\tjQuery().off( event );\n\t\t\treturn origFn.apply( this, arguments );\n\t\t};\n\n\t\t// Use same guid so caller can remove using origFn\n\t\tfn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ );\n\t}\n\treturn elem.each( function() {\n\t\tjQuery.event.add( this, types, fn, data, selector );\n\t} );\n}\n\n/*\n * Helper functions for managing events -- not part of the public interface.\n * Props to Dean Edwards' addEvent library for many of the ideas.\n */\njQuery.event = {\n\n\tglobal: {},\n\n\tadd: function( elem, types, handler, data, selector ) {\n\n\t\tvar handleObjIn, eventHandle, tmp,\n\t\t\tevents, t, handleObj,\n\t\t\tspecial, handlers, type, namespaces, origType,\n\t\t\telemData = dataPriv.get( elem );\n\n\t\t// Don't attach events to noData or text/comment nodes (but allow plain objects)\n\t\tif ( !elemData ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Caller can pass in an object of custom data in lieu of the handler\n\t\tif ( handler.handler ) {\n\t\t\thandleObjIn = handler;\n\t\t\thandler = handleObjIn.handler;\n\t\t\tselector = handleObjIn.selector;\n\t\t}\n\n\t\t// Make sure that the handler has a unique ID, used to find/remove it later\n\t\tif ( !handler.guid ) {\n\t\t\thandler.guid = jQuery.guid++;\n\t\t}\n\n\t\t// Init the element's event structure and main handler, if this is the first\n\t\tif ( !( events = elemData.events ) ) {\n\t\t\tevents = elemData.events = {};\n\t\t}\n\t\tif ( !( eventHandle = elemData.handle ) ) {\n\t\t\teventHandle = elemData.handle = function( e ) {\n\n\t\t\t\t// Discard the second event of a jQuery.event.trigger() and\n\t\t\t\t// when an event is called after a page has unloaded\n\t\t\t\treturn typeof jQuery !== \"undefined\" && jQuery.event.triggered !== e.type ?\n\t\t\t\t\tjQuery.event.dispatch.apply( elem, arguments ) : undefined;\n\t\t\t};\n\t\t}\n\n\t\t// Handle multiple events separated by a space\n\t\ttypes = ( types || \"\" ).match( rnotwhite ) || [ \"\" ];\n\t\tt = types.length;\n\t\twhile ( t-- ) {\n\t\t\ttmp = rtypenamespace.exec( types[ t ] ) || [];\n\t\t\ttype = origType = tmp[ 1 ];\n\t\t\tnamespaces = ( tmp[ 2 ] || \"\" ).split( \".\" ).sort();\n\n\t\t\t// There *must* be a type, no attaching namespace-only handlers\n\t\t\tif ( !type ) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// If event changes its type, use the special event handlers for the changed type\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\n\t\t\t// If selector defined, determine special event api type, otherwise given type\n\t\t\ttype = ( selector ? special.delegateType : special.bindType ) || type;\n\n\t\t\t// Update special based on newly reset type\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\n\t\t\t// handleObj is passed to all event handlers\n\t\t\thandleObj = jQuery.extend( {\n\t\t\t\ttype: type,\n\t\t\t\torigType: origType,\n\t\t\t\tdata: data,\n\t\t\t\thandler: handler,\n\t\t\t\tguid: handler.guid,\n\t\t\t\tselector: selector,\n\t\t\t\tneedsContext: selector && jQuery.expr.match.needsContext.test( selector ),\n\t\t\t\tnamespace: namespaces.join( \".\" )\n\t\t\t}, handleObjIn );\n\n\t\t\t// Init the event handler queue if we're the first\n\t\t\tif ( !( handlers = events[ type ] ) ) {\n\t\t\t\thandlers = events[ type ] = [];\n\t\t\t\thandlers.delegateCount = 0;\n\n\t\t\t\t// Only use addEventListener if the special events handler returns false\n\t\t\t\tif ( !special.setup ||\n\t\t\t\t\tspecial.setup.call( elem, data, namespaces, eventHandle ) === false ) {\n\n\t\t\t\t\tif ( elem.addEventListener ) {\n\t\t\t\t\t\telem.addEventListener( type, eventHandle );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif ( special.add ) {\n\t\t\t\tspecial.add.call( elem, handleObj );\n\n\t\t\t\tif ( !handleObj.handler.guid ) {\n\t\t\t\t\thandleObj.handler.guid = handler.guid;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add to the element's handler list, delegates in front\n\t\t\tif ( selector ) {\n\t\t\t\thandlers.splice( handlers.delegateCount++, 0, handleObj );\n\t\t\t} else {\n\t\t\t\thandlers.push( handleObj );\n\t\t\t}\n\n\t\t\t// Keep track of which events have ever been used, for event optimization\n\t\t\tjQuery.event.global[ type ] = true;\n\t\t}\n\n\t},\n\n\t// Detach an event or set of events from an element\n\tremove: function( elem, types, handler, selector, mappedTypes ) {\n\n\t\tvar j, origCount, tmp,\n\t\t\tevents, t, handleObj,\n\t\t\tspecial, handlers, type, namespaces, origType,\n\t\t\telemData = dataPriv.hasData( elem ) && dataPriv.get( elem );\n\n\t\tif ( !elemData || !( events = elemData.events ) ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Once for each type.namespace in types; type may be omitted\n\t\ttypes = ( types || \"\" ).match( rnotwhite ) || [ \"\" ];\n\t\tt = types.length;\n\t\twhile ( t-- ) {\n\t\t\ttmp = rtypenamespace.exec( types[ t ] ) || [];\n\t\t\ttype = origType = tmp[ 1 ];\n\t\t\tnamespaces = ( tmp[ 2 ] || \"\" ).split( \".\" ).sort();\n\n\t\t\t// Unbind all events (on this namespace, if provided) for the element\n\t\t\tif ( !type ) {\n\t\t\t\tfor ( type in events ) {\n\t\t\t\t\tjQuery.event.remove( elem, type + types[ t ], handler, selector, true );\n\t\t\t\t}\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\t\t\ttype = ( selector ? special.delegateType : special.bindType ) || type;\n\t\t\thandlers = events[ type ] || [];\n\t\t\ttmp = tmp[ 2 ] &&\n\t\t\t\tnew RegExp( \"(^|\\\\.)\" + namespaces.join( \"\\\\.(?:.*\\\\.|)\" ) + \"(\\\\.|$)\" );\n\n\t\t\t// Remove matching events\n\t\t\torigCount = j = handlers.length;\n\t\t\twhile ( j-- ) {\n\t\t\t\thandleObj = handlers[ j ];\n\n\t\t\t\tif ( ( mappedTypes || origType === handleObj.origType ) &&\n\t\t\t\t\t( !handler || handler.guid === handleObj.guid ) &&\n\t\t\t\t\t( !tmp || tmp.test( handleObj.namespace ) ) &&\n\t\t\t\t\t( !selector || selector === handleObj.selector ||\n\t\t\t\t\t\tselector === \"**\" && handleObj.selector ) ) {\n\t\t\t\t\thandlers.splice( j, 1 );\n\n\t\t\t\t\tif ( handleObj.selector ) {\n\t\t\t\t\t\thandlers.delegateCount--;\n\t\t\t\t\t}\n\t\t\t\t\tif ( special.remove ) {\n\t\t\t\t\t\tspecial.remove.call( elem, handleObj );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Remove generic event handler if we removed something and no more handlers exist\n\t\t\t// (avoids potential for endless recursion during removal of special event handlers)\n\t\t\tif ( origCount && !handlers.length ) {\n\t\t\t\tif ( !special.teardown ||\n\t\t\t\t\tspecial.teardown.call( elem, namespaces, elemData.handle ) === false ) {\n\n\t\t\t\t\tjQuery.removeEvent( elem, type, elemData.handle );\n\t\t\t\t}\n\n\t\t\t\tdelete events[ type ];\n\t\t\t}\n\t\t}\n\n\t\t// Remove data and the expando if it's no longer used\n\t\tif ( jQuery.isEmptyObject( events ) ) {\n\t\t\tdataPriv.remove( elem, \"handle events\" );\n\t\t}\n\t},\n\n\tdispatch: function( event ) {\n\n\t\t// Make a writable jQuery.Event from the native event object\n\t\tevent = jQuery.event.fix( event );\n\n\t\tvar i, j, ret, matched, handleObj,\n\t\t\thandlerQueue = [],\n\t\t\targs = slice.call( arguments ),\n\t\t\thandlers = ( dataPriv.get( this, \"events\" ) || {} )[ event.type ] || [],\n\t\t\tspecial = jQuery.event.special[ event.type ] || {};\n\n\t\t// Use the fix-ed jQuery.Event rather than the (read-only) native event\n\t\targs[ 0 ] = event;\n\t\tevent.delegateTarget = this;\n\n\t\t// Call the preDispatch hook for the mapped type, and let it bail if desired\n\t\tif ( special.preDispatch && special.preDispatch.call( this, event ) === false ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Determine handlers\n\t\thandlerQueue = jQuery.event.handlers.call( this, event, handlers );\n\n\t\t// Run delegates first; they may want to stop propagation beneath us\n\t\ti = 0;\n\t\twhile ( ( matched = handlerQueue[ i++ ] ) && !event.isPropagationStopped() ) {\n\t\t\tevent.currentTarget = matched.elem;\n\n\t\t\tj = 0;\n\t\t\twhile ( ( handleObj = matched.handlers[ j++ ] ) &&\n\t\t\t\t!event.isImmediatePropagationStopped() ) {\n\n\t\t\t\t// Triggered event must either 1) have no namespace, or 2) have namespace(s)\n\t\t\t\t// a subset or equal to those in the bound event (both can have no namespace).\n\t\t\t\tif ( !event.rnamespace || event.rnamespace.test( handleObj.namespace ) ) {\n\n\t\t\t\t\tevent.handleObj = handleObj;\n\t\t\t\t\tevent.data = handleObj.data;\n\n\t\t\t\t\tret = ( ( jQuery.event.special[ handleObj.origType ] || {} ).handle ||\n\t\t\t\t\t\thandleObj.handler ).apply( matched.elem, args );\n\n\t\t\t\t\tif ( ret !== undefined ) {\n\t\t\t\t\t\tif ( ( event.result = ret ) === false ) {\n\t\t\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Call the postDispatch hook for the mapped type\n\t\tif ( special.postDispatch ) {\n\t\t\tspecial.postDispatch.call( this, event );\n\t\t}\n\n\t\treturn event.result;\n\t},\n\n\thandlers: function( event, handlers ) {\n\t\tvar i, matches, sel, handleObj,\n\t\t\thandlerQueue = [],\n\t\t\tdelegateCount = handlers.delegateCount,\n\t\t\tcur = event.target;\n\n\t\t// Support (at least): Chrome, IE9\n\t\t// Find delegate handlers\n\t\t// Black-hole SVG <use> instance trees (#13180)\n\t\t//\n\t\t// Support: Firefox<=42+\n\t\t// Avoid non-left-click in FF but don't block IE radio events (#3861, gh-2343)\n\t\tif ( delegateCount && cur.nodeType &&\n\t\t\t( event.type !== \"click\" || isNaN( event.button ) || event.button < 1 ) ) {\n\n\t\t\tfor ( ; cur !== this; cur = cur.parentNode || this ) {\n\n\t\t\t\t// Don't check non-elements (#13208)\n\t\t\t\t// Don't process clicks on disabled elements (#6911, #8165, #11382, #11764)\n\t\t\t\tif ( cur.nodeType === 1 && ( cur.disabled !== true || event.type !== \"click\" ) ) {\n\t\t\t\t\tmatches = [];\n\t\t\t\t\tfor ( i = 0; i < delegateCount; i++ ) {\n\t\t\t\t\t\thandleObj = handlers[ i ];\n\n\t\t\t\t\t\t// Don't conflict with Object.prototype properties (#13203)\n\t\t\t\t\t\tsel = handleObj.selector + \" \";\n\n\t\t\t\t\t\tif ( matches[ sel ] === undefined ) {\n\t\t\t\t\t\t\tmatches[ sel ] = handleObj.needsContext ?\n\t\t\t\t\t\t\t\tjQuery( sel, this ).index( cur ) > -1 :\n\t\t\t\t\t\t\t\tjQuery.find( sel, this, null, [ cur ] ).length;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif ( matches[ sel ] ) {\n\t\t\t\t\t\t\tmatches.push( handleObj );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif ( matches.length ) {\n\t\t\t\t\t\thandlerQueue.push( { elem: cur, handlers: matches } );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Add the remaining (directly-bound) handlers\n\t\tif ( delegateCount < handlers.length ) {\n\t\t\thandlerQueue.push( { elem: this, handlers: handlers.slice( delegateCount ) } );\n\t\t}\n\n\t\treturn handlerQueue;\n\t},\n\n\t// Includes some event props shared by KeyEvent and MouseEvent\n\tprops: ( \"altKey bubbles cancelable ctrlKey currentTarget detail eventPhase \" +\n\t\t\"metaKey relatedTarget shiftKey target timeStamp view which\" ).split( \" \" ),\n\n\tfixHooks: {},\n\n\tkeyHooks: {\n\t\tprops: \"char charCode key keyCode\".split( \" \" ),\n\t\tfilter: function( event, original ) {\n\n\t\t\t// Add which for key events\n\t\t\tif ( event.which == null ) {\n\t\t\t\tevent.which = original.charCode != null ? original.charCode : original.keyCode;\n\t\t\t}\n\n\t\t\treturn event;\n\t\t}\n\t},\n\n\tmouseHooks: {\n\t\tprops: ( \"button buttons clientX clientY offsetX offsetY pageX pageY \" +\n\t\t\t\"screenX screenY toElement\" ).split( \" \" ),\n\t\tfilter: function( event, original ) {\n\t\t\tvar eventDoc, doc, body,\n\t\t\t\tbutton = original.button;\n\n\t\t\t// Calculate pageX/Y if missing and clientX/Y available\n\t\t\tif ( event.pageX == null && original.clientX != null ) {\n\t\t\t\teventDoc = event.target.ownerDocument || document;\n\t\t\t\tdoc = eventDoc.documentElement;\n\t\t\t\tbody = eventDoc.body;\n\n\t\t\t\tevent.pageX = original.clientX +\n\t\t\t\t\t( doc && doc.scrollLeft || body && body.scrollLeft || 0 ) -\n\t\t\t\t\t( doc && doc.clientLeft || body && body.clientLeft || 0 );\n\t\t\t\tevent.pageY = original.clientY +\n\t\t\t\t\t( doc && doc.scrollTop || body && body.scrollTop || 0 ) -\n\t\t\t\t\t( doc && doc.clientTop || body && body.clientTop || 0 );\n\t\t\t}\n\n\t\t\t// Add which for click: 1 === left; 2 === middle; 3 === right\n\t\t\t// Note: button is not normalized, so don't use it\n\t\t\tif ( !event.which && button !== undefined ) {\n\t\t\t\tevent.which = ( button & 1 ? 1 : ( button & 2 ? 3 : ( button & 4 ? 2 : 0 ) ) );\n\t\t\t}\n\n\t\t\treturn event;\n\t\t}\n\t},\n\n\tfix: function( event ) {\n\t\tif ( event[ jQuery.expando ] ) {\n\t\t\treturn event;\n\t\t}\n\n\t\t// Create a writable copy of the event object and normalize some properties\n\t\tvar i, prop, copy,\n\t\t\ttype = event.type,\n\t\t\toriginalEvent = event,\n\t\t\tfixHook = this.fixHooks[ type ];\n\n\t\tif ( !fixHook ) {\n\t\t\tthis.fixHooks[ type ] = fixHook =\n\t\t\t\trmouseEvent.test( type ) ? this.mouseHooks :\n\t\t\t\trkeyEvent.test( type ) ? this.keyHooks :\n\t\t\t\t{};\n\t\t}\n\t\tcopy = fixHook.props ? this.props.concat( fixHook.props ) : this.props;\n\n\t\tevent = new jQuery.Event( originalEvent );\n\n\t\ti = copy.length;\n\t\twhile ( i-- ) {\n\t\t\tprop = copy[ i ];\n\t\t\tevent[ prop ] = originalEvent[ prop ];\n\t\t}\n\n\t\t// Support: Cordova 2.5 (WebKit) (#13255)\n\t\t// All events should have a target; Cordova deviceready doesn't\n\t\tif ( !event.target ) {\n\t\t\tevent.target = document;\n\t\t}\n\n\t\t// Support: Safari 6.0+, Chrome<28\n\t\t// Target should not be a text node (#504, #13143)\n\t\tif ( event.target.nodeType === 3 ) {\n\t\t\tevent.target = event.target.parentNode;\n\t\t}\n\n\t\treturn fixHook.filter ? fixHook.filter( event, originalEvent ) : event;\n\t},\n\n\tspecial: {\n\t\tload: {\n\n\t\t\t// Prevent triggered image.load events from bubbling to window.load\n\t\t\tnoBubble: true\n\t\t},\n\t\tfocus: {\n\n\t\t\t// Fire native event if possible so blur/focus sequence is correct\n\t\t\ttrigger: function() {\n\t\t\t\tif ( this !== safeActiveElement() && this.focus ) {\n\t\t\t\t\tthis.focus();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t},\n\t\t\tdelegateType: \"focusin\"\n\t\t},\n\t\tblur: {\n\t\t\ttrigger: function() {\n\t\t\t\tif ( this === safeActiveElement() && this.blur ) {\n\t\t\t\t\tthis.blur();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t},\n\t\t\tdelegateType: \"focusout\"\n\t\t},\n\t\tclick: {\n\n\t\t\t// For checkbox, fire native event so checked state will be right\n\t\t\ttrigger: function() {\n\t\t\t\tif ( this.type === \"checkbox\" && this.click && jQuery.nodeName( this, \"input\" ) ) {\n\t\t\t\t\tthis.click();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t},\n\n\t\t\t// For cross-browser consistency, don't fire native .click() on links\n\t\t\t_default: function( event ) {\n\t\t\t\treturn jQuery.nodeName( event.target, \"a\" );\n\t\t\t}\n\t\t},\n\n\t\tbeforeunload: {\n\t\t\tpostDispatch: function( event ) {\n\n\t\t\t\t// Support: Firefox 20+\n\t\t\t\t// Firefox doesn't alert if the returnValue field is not set.\n\t\t\t\tif ( event.result !== undefined && event.originalEvent ) {\n\t\t\t\t\tevent.originalEvent.returnValue = event.result;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n};\n\njQuery.removeEvent = function( elem, type, handle ) {\n\n\t// This \"if\" is needed for plain objects\n\tif ( elem.removeEventListener ) {\n\t\telem.removeEventListener( type, handle );\n\t}\n};\n\njQuery.Event = function( src, props ) {\n\n\t// Allow instantiation without the 'new' keyword\n\tif ( !( this instanceof jQuery.Event ) ) {\n\t\treturn new jQuery.Event( src, props );\n\t}\n\n\t// Event object\n\tif ( src && src.type ) {\n\t\tthis.originalEvent = src;\n\t\tthis.type = src.type;\n\n\t\t// Events bubbling up the document may have been marked as prevented\n\t\t// by a handler lower down the tree; reflect the correct value.\n\t\tthis.isDefaultPrevented = src.defaultPrevented ||\n\t\t\t\tsrc.defaultPrevented === undefined &&\n\n\t\t\t\t// Support: Android<4.0\n\t\t\t\tsrc.returnValue === false ?\n\t\t\treturnTrue :\n\t\t\treturnFalse;\n\n\t// Event type\n\t} else {\n\t\tthis.type = src;\n\t}\n\n\t// Put explicitly provided properties onto the event object\n\tif ( props ) {\n\t\tjQuery.extend( this, props );\n\t}\n\n\t// Create a timestamp if incoming event doesn't have one\n\tthis.timeStamp = src && src.timeStamp || jQuery.now();\n\n\t// Mark it as fixed\n\tthis[ jQuery.expando ] = true;\n};\n\n// jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding\n// http://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html\njQuery.Event.prototype = {\n\tconstructor: jQuery.Event,\n\tisDefaultPrevented: returnFalse,\n\tisPropagationStopped: returnFalse,\n\tisImmediatePropagationStopped: returnFalse,\n\tisSimulated: false,\n\n\tpreventDefault: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isDefaultPrevented = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.preventDefault();\n\t\t}\n\t},\n\tstopPropagation: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isPropagationStopped = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.stopPropagation();\n\t\t}\n\t},\n\tstopImmediatePropagation: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isImmediatePropagationStopped = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.stopImmediatePropagation();\n\t\t}\n\n\t\tthis.stopPropagation();\n\t}\n};\n\n// Create mouseenter/leave events using mouseover/out and event-time checks\n// so that event delegation works in jQuery.\n// Do the same for pointerenter/pointerleave and pointerover/pointerout\n//\n// Support: Safari 7 only\n// Safari sends mouseenter too often; see:\n// https://code.google.com/p/chromium/issues/detail?id=470258\n// for the description of the bug (it existed in older Chrome versions as well).\njQuery.each( {\n\tmouseenter: \"mouseover\",\n\tmouseleave: \"mouseout\",\n\tpointerenter: \"pointerover\",\n\tpointerleave: \"pointerout\"\n}, function( orig, fix ) {\n\tjQuery.event.special[ orig ] = {\n\t\tdelegateType: fix,\n\t\tbindType: fix,\n\n\t\thandle: function( event ) {\n\t\t\tvar ret,\n\t\t\t\ttarget = this,\n\t\t\t\trelated = event.relatedTarget,\n\t\t\t\thandleObj = event.handleObj;\n\n\t\t\t// For mouseenter/leave call the handler if related is outside the target.\n\t\t\t// NB: No relatedTarget if the mouse left/entered the browser window\n\t\t\tif ( !related || ( related !== target && !jQuery.contains( target, related ) ) ) {\n\t\t\t\tevent.type = handleObj.origType;\n\t\t\t\tret = handleObj.handler.apply( this, arguments );\n\t\t\t\tevent.type = fix;\n\t\t\t}\n\t\t\treturn ret;\n\t\t}\n\t};\n} );\n\njQuery.fn.extend( {\n\ton: function( types, selector, data, fn ) {\n\t\treturn on( this, types, selector, data, fn );\n\t},\n\tone: function( types, selector, data, fn ) {\n\t\treturn on( this, types, selector, data, fn, 1 );\n\t},\n\toff: function( types, selector, fn ) {\n\t\tvar handleObj, type;\n\t\tif ( types && types.preventDefault && types.handleObj ) {\n\n\t\t\t// ( event ) dispatched jQuery.Event\n\t\t\thandleObj = types.handleObj;\n\t\t\tjQuery( types.delegateTarget ).off(\n\t\t\t\thandleObj.namespace ?\n\t\t\t\t\thandleObj.origType + \".\" + handleObj.namespace :\n\t\t\t\t\thandleObj.origType,\n\t\t\t\thandleObj.selector,\n\t\t\t\thandleObj.handler\n\t\t\t);\n\t\t\treturn this;\n\t\t}\n\t\tif ( typeof types === \"object\" ) {\n\n\t\t\t// ( types-object [, selector] )\n\t\t\tfor ( type in types ) {\n\t\t\t\tthis.off( type, selector, types[ type ] );\n\t\t\t}\n\t\t\treturn this;\n\t\t}\n\t\tif ( selector === false || typeof selector === \"function\" ) {\n\n\t\t\t// ( types [, fn] )\n\t\t\tfn = selector;\n\t\t\tselector = undefined;\n\t\t}\n\t\tif ( fn === false ) {\n\t\t\tfn = returnFalse;\n\t\t}\n\t\treturn this.each( function() {\n\t\t\tjQuery.event.remove( this, types, fn, selector );\n\t\t} );\n\t}\n} );\n\n\nvar\n\trxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\\w:-]+)[^>]*)\\/>/gi,\n\n\t// Support: IE 10-11, Edge 10240+\n\t// In IE/Edge using regex groups here causes severe slowdowns.\n\t// See https://connect.microsoft.com/IE/feedback/details/1736512/\n\trnoInnerhtml = /<script|<style|<link/i,\n\n\t// checked=\"checked\" or checked\n\trchecked = /checked\\s*(?:[^=]|=\\s*.checked.)/i,\n\trscriptTypeMasked = /^true\\/(.*)/,\n\trcleanScript = /^\\s*<!(?:\\[CDATA\\[|--)|(?:\\]\\]|--)>\\s*$/g;\n\n// Manipulating tables requires a tbody\nfunction manipulationTarget( elem, content ) {\n\treturn jQuery.nodeName( elem, \"table\" ) &&\n\t\tjQuery.nodeName( content.nodeType !== 11 ? content : content.firstChild, \"tr\" ) ?\n\n\t\telem.getElementsByTagName( \"tbody\" )[ 0 ] ||\n\t\t\telem.appendChild( elem.ownerDocument.createElement( \"tbody\" ) ) :\n\t\telem;\n}\n\n// Replace/restore the type attribute of script elements for safe DOM manipulation\nfunction disableScript( elem ) {\n\telem.type = ( elem.getAttribute( \"type\" ) !== null ) + \"/\" + elem.type;\n\treturn elem;\n}\nfunction restoreScript( elem ) {\n\tvar match = rscriptTypeMasked.exec( elem.type );\n\n\tif ( match ) {\n\t\telem.type = match[ 1 ];\n\t} else {\n\t\telem.removeAttribute( \"type\" );\n\t}\n\n\treturn elem;\n}\n\nfunction cloneCopyEvent( src, dest ) {\n\tvar i, l, type, pdataOld, pdataCur, udataOld, udataCur, events;\n\n\tif ( dest.nodeType !== 1 ) {\n\t\treturn;\n\t}\n\n\t// 1. Copy private data: events, handlers, etc.\n\tif ( dataPriv.hasData( src ) ) {\n\t\tpdataOld = dataPriv.access( src );\n\t\tpdataCur = dataPriv.set( dest, pdataOld );\n\t\tevents = pdataOld.events;\n\n\t\tif ( events ) {\n\t\t\tdelete pdataCur.handle;\n\t\t\tpdataCur.events = {};\n\n\t\t\tfor ( type in events ) {\n\t\t\t\tfor ( i = 0, l = events[ type ].length; i < l; i++ ) {\n\t\t\t\t\tjQuery.event.add( dest, type, events[ type ][ i ] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// 2. Copy user data\n\tif ( dataUser.hasData( src ) ) {\n\t\tudataOld = dataUser.access( src );\n\t\tudataCur = jQuery.extend( {}, udataOld );\n\n\t\tdataUser.set( dest, udataCur );\n\t}\n}\n\n// Fix IE bugs, see support tests\nfunction fixInput( src, dest ) {\n\tvar nodeName = dest.nodeName.toLowerCase();\n\n\t// Fails to persist the checked state of a cloned checkbox or radio button.\n\tif ( nodeName === \"input\" && rcheckableType.test( src.type ) ) {\n\t\tdest.checked = src.checked;\n\n\t// Fails to return the selected option to the default selected state when cloning options\n\t} else if ( nodeName === \"input\" || nodeName === \"textarea\" ) {\n\t\tdest.defaultValue = src.defaultValue;\n\t}\n}\n\nfunction domManip( collection, args, callback, ignored ) {\n\n\t// Flatten any nested arrays\n\targs = concat.apply( [], args );\n\n\tvar fragment, first, scripts, hasScripts, node, doc,\n\t\ti = 0,\n\t\tl = collection.length,\n\t\tiNoClone = l - 1,\n\t\tvalue = args[ 0 ],\n\t\tisFunction = jQuery.isFunction( value );\n\n\t// We can't cloneNode fragments that contain checked, in WebKit\n\tif ( isFunction ||\n\t\t\t( l > 1 && typeof value === \"string\" &&\n\t\t\t\t!support.checkClone && rchecked.test( value ) ) ) {\n\t\treturn collection.each( function( index ) {\n\t\t\tvar self = collection.eq( index );\n\t\t\tif ( isFunction ) {\n\t\t\t\targs[ 0 ] = value.call( this, index, self.html() );\n\t\t\t}\n\t\t\tdomManip( self, args, callback, ignored );\n\t\t} );\n\t}\n\n\tif ( l ) {\n\t\tfragment = buildFragment( args, collection[ 0 ].ownerDocument, false, collection, ignored );\n\t\tfirst = fragment.firstChild;\n\n\t\tif ( fragment.childNodes.length === 1 ) {\n\t\t\tfragment = first;\n\t\t}\n\n\t\t// Require either new content or an interest in ignored elements to invoke the callback\n\t\tif ( first || ignored ) {\n\t\t\tscripts = jQuery.map( getAll( fragment, \"script\" ), disableScript );\n\t\t\thasScripts = scripts.length;\n\n\t\t\t// Use the original fragment for the last item\n\t\t\t// instead of the first because it can end up\n\t\t\t// being emptied incorrectly in certain situations (#8070).\n\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\tnode = fragment;\n\n\t\t\t\tif ( i !== iNoClone ) {\n\t\t\t\t\tnode = jQuery.clone( node, true, true );\n\n\t\t\t\t\t// Keep references to cloned scripts for later restoration\n\t\t\t\t\tif ( hasScripts ) {\n\n\t\t\t\t\t\t// Support: Android<4.1, PhantomJS<2\n\t\t\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\t\t\tjQuery.merge( scripts, getAll( node, \"script\" ) );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tcallback.call( collection[ i ], node, i );\n\t\t\t}\n\n\t\t\tif ( hasScripts ) {\n\t\t\t\tdoc = scripts[ scripts.length - 1 ].ownerDocument;\n\n\t\t\t\t// Reenable scripts\n\t\t\t\tjQuery.map( scripts, restoreScript );\n\n\t\t\t\t// Evaluate executable scripts on first document insertion\n\t\t\t\tfor ( i = 0; i < hasScripts; i++ ) {\n\t\t\t\t\tnode = scripts[ i ];\n\t\t\t\t\tif ( rscriptType.test( node.type || \"\" ) &&\n\t\t\t\t\t\t!dataPriv.access( node, \"globalEval\" ) &&\n\t\t\t\t\t\tjQuery.contains( doc, node ) ) {\n\n\t\t\t\t\t\tif ( node.src ) {\n\n\t\t\t\t\t\t\t// Optional AJAX dependency, but won't run scripts if not present\n\t\t\t\t\t\t\tif ( jQuery._evalUrl ) {\n\t\t\t\t\t\t\t\tjQuery._evalUrl( node.src );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tjQuery.globalEval( node.textContent.replace( rcleanScript, \"\" ) );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn collection;\n}\n\nfunction remove( elem, selector, keepData ) {\n\tvar node,\n\t\tnodes = selector ? jQuery.filter( selector, elem ) : elem,\n\t\ti = 0;\n\n\tfor ( ; ( node = nodes[ i ] ) != null; i++ ) {\n\t\tif ( !keepData && node.nodeType === 1 ) {\n\t\t\tjQuery.cleanData( getAll( node ) );\n\t\t}\n\n\t\tif ( node.parentNode ) {\n\t\t\tif ( keepData && jQuery.contains( node.ownerDocument, node ) ) {\n\t\t\t\tsetGlobalEval( getAll( node, \"script\" ) );\n\t\t\t}\n\t\t\tnode.parentNode.removeChild( node );\n\t\t}\n\t}\n\n\treturn elem;\n}\n\njQuery.extend( {\n\thtmlPrefilter: function( html ) {\n\t\treturn html.replace( rxhtmlTag, \"<$1></$2>\" );\n\t},\n\n\tclone: function( elem, dataAndEvents, deepDataAndEvents ) {\n\t\tvar i, l, srcElements, destElements,\n\t\t\tclone = elem.cloneNode( true ),\n\t\t\tinPage = jQuery.contains( elem.ownerDocument, elem );\n\n\t\t// Fix IE cloning issues\n\t\tif ( !support.noCloneChecked && ( elem.nodeType === 1 || elem.nodeType === 11 ) &&\n\t\t\t\t!jQuery.isXMLDoc( elem ) ) {\n\n\t\t\t// We eschew Sizzle here for performance reasons: http://jsperf.com/getall-vs-sizzle/2\n\t\t\tdestElements = getAll( clone );\n\t\t\tsrcElements = getAll( elem );\n\n\t\t\tfor ( i = 0, l = srcElements.length; i < l; i++ ) {\n\t\t\t\tfixInput( srcElements[ i ], destElements[ i ] );\n\t\t\t}\n\t\t}\n\n\t\t// Copy the events from the original to the clone\n\t\tif ( dataAndEvents ) {\n\t\t\tif ( deepDataAndEvents ) {\n\t\t\t\tsrcElements = srcElements || getAll( elem );\n\t\t\t\tdestElements = destElements || getAll( clone );\n\n\t\t\t\tfor ( i = 0, l = srcElements.length; i < l; i++ ) {\n\t\t\t\t\tcloneCopyEvent( srcElements[ i ], destElements[ i ] );\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tcloneCopyEvent( elem, clone );\n\t\t\t}\n\t\t}\n\n\t\t// Preserve script evaluation history\n\t\tdestElements = getAll( clone, \"script\" );\n\t\tif ( destElements.length > 0 ) {\n\t\t\tsetGlobalEval( destElements, !inPage && getAll( elem, \"script\" ) );\n\t\t}\n\n\t\t// Return the cloned set\n\t\treturn clone;\n\t},\n\n\tcleanData: function( elems ) {\n\t\tvar data, elem, type,\n\t\t\tspecial = jQuery.event.special,\n\t\t\ti = 0;\n\n\t\tfor ( ; ( elem = elems[ i ] ) !== undefined; i++ ) {\n\t\t\tif ( acceptData( elem ) ) {\n\t\t\t\tif ( ( data = elem[ dataPriv.expando ] ) ) {\n\t\t\t\t\tif ( data.events ) {\n\t\t\t\t\t\tfor ( type in data.events ) {\n\t\t\t\t\t\t\tif ( special[ type ] ) {\n\t\t\t\t\t\t\t\tjQuery.event.remove( elem, type );\n\n\t\t\t\t\t\t\t// This is a shortcut to avoid jQuery.event.remove's overhead\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tjQuery.removeEvent( elem, type, data.handle );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Support: Chrome <= 35-45+\n\t\t\t\t\t// Assign undefined instead of using delete, see Data#remove\n\t\t\t\t\telem[ dataPriv.expando ] = undefined;\n\t\t\t\t}\n\t\t\t\tif ( elem[ dataUser.expando ] ) {\n\n\t\t\t\t\t// Support: Chrome <= 35-45+\n\t\t\t\t\t// Assign undefined instead of using delete, see Data#remove\n\t\t\t\t\telem[ dataUser.expando ] = undefined;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n} );\n\njQuery.fn.extend( {\n\n\t// Keep domManip exposed until 3.0 (gh-2225)\n\tdomManip: domManip,\n\n\tdetach: function( selector ) {\n\t\treturn remove( this, selector, true );\n\t},\n\n\tremove: function( selector ) {\n\t\treturn remove( this, selector );\n\t},\n\n\ttext: function( value ) {\n\t\treturn access( this, function( value ) {\n\t\t\treturn value === undefined ?\n\t\t\t\tjQuery.text( this ) :\n\t\t\t\tthis.empty().each( function() {\n\t\t\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\t\t\tthis.textContent = value;\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t}, null, value, arguments.length );\n\t},\n\n\tappend: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\tvar target = manipulationTarget( this, elem );\n\t\t\t\ttarget.appendChild( elem );\n\t\t\t}\n\t\t} );\n\t},\n\n\tprepend: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\tvar target = manipulationTarget( this, elem );\n\t\t\t\ttarget.insertBefore( elem, target.firstChild );\n\t\t\t}\n\t\t} );\n\t},\n\n\tbefore: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.parentNode ) {\n\t\t\t\tthis.parentNode.insertBefore( elem, this );\n\t\t\t}\n\t\t} );\n\t},\n\n\tafter: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.parentNode ) {\n\t\t\t\tthis.parentNode.insertBefore( elem, this.nextSibling );\n\t\t\t}\n\t\t} );\n\t},\n\n\tempty: function() {\n\t\tvar elem,\n\t\t\ti = 0;\n\n\t\tfor ( ; ( elem = this[ i ] ) != null; i++ ) {\n\t\t\tif ( elem.nodeType === 1 ) {\n\n\t\t\t\t// Prevent memory leaks\n\t\t\t\tjQuery.cleanData( getAll( elem, false ) );\n\n\t\t\t\t// Remove any remaining nodes\n\t\t\t\telem.textContent = \"\";\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\tclone: function( dataAndEvents, deepDataAndEvents ) {\n\t\tdataAndEvents = dataAndEvents == null ? false : dataAndEvents;\n\t\tdeepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents;\n\n\t\treturn this.map( function() {\n\t\t\treturn jQuery.clone( this, dataAndEvents, deepDataAndEvents );\n\t\t} );\n\t},\n\n\thtml: function( value ) {\n\t\treturn access( this, function( value ) {\n\t\t\tvar elem = this[ 0 ] || {},\n\t\t\t\ti = 0,\n\t\t\t\tl = this.length;\n\n\t\t\tif ( value === undefined && elem.nodeType === 1 ) {\n\t\t\t\treturn elem.innerHTML;\n\t\t\t}\n\n\t\t\t// See if we can take a shortcut and just use innerHTML\n\t\t\tif ( typeof value === \"string\" && !rnoInnerhtml.test( value ) &&\n\t\t\t\t!wrapMap[ ( rtagName.exec( value ) || [ \"\", \"\" ] )[ 1 ].toLowerCase() ] ) {\n\n\t\t\t\tvalue = jQuery.htmlPrefilter( value );\n\n\t\t\t\ttry {\n\t\t\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\t\t\telem = this[ i ] || {};\n\n\t\t\t\t\t\t// Remove element nodes and prevent memory leaks\n\t\t\t\t\t\tif ( elem.nodeType === 1 ) {\n\t\t\t\t\t\t\tjQuery.cleanData( getAll( elem, false ) );\n\t\t\t\t\t\t\telem.innerHTML = value;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\telem = 0;\n\n\t\t\t\t// If using innerHTML throws an exception, use the fallback method\n\t\t\t\t} catch ( e ) {}\n\t\t\t}\n\n\t\t\tif ( elem ) {\n\t\t\t\tthis.empty().append( value );\n\t\t\t}\n\t\t}, null, value, arguments.length );\n\t},\n\n\treplaceWith: function() {\n\t\tvar ignored = [];\n\n\t\t// Make the changes, replacing each non-ignored context element with the new content\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tvar parent = this.parentNode;\n\n\t\t\tif ( jQuery.inArray( this, ignored ) < 0 ) {\n\t\t\t\tjQuery.cleanData( getAll( this ) );\n\t\t\t\tif ( parent ) {\n\t\t\t\t\tparent.replaceChild( elem, this );\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Force callback invocation\n\t\t}, ignored );\n\t}\n} );\n\njQuery.each( {\n\tappendTo: \"append\",\n\tprependTo: \"prepend\",\n\tinsertBefore: \"before\",\n\tinsertAfter: \"after\",\n\treplaceAll: \"replaceWith\"\n}, function( name, original ) {\n\tjQuery.fn[ name ] = function( selector ) {\n\t\tvar elems,\n\t\t\tret = [],\n\t\t\tinsert = jQuery( selector ),\n\t\t\tlast = insert.length - 1,\n\t\t\ti = 0;\n\n\t\tfor ( ; i <= last; i++ ) {\n\t\t\telems = i === last ? this : this.clone( true );\n\t\t\tjQuery( insert[ i ] )[ original ]( elems );\n\n\t\t\t// Support: QtWebKit\n\t\t\t// .get() because push.apply(_, arraylike) throws\n\t\t\tpush.apply( ret, elems.get() );\n\t\t}\n\n\t\treturn this.pushStack( ret );\n\t};\n} );\n\n\nvar iframe,\n\telemdisplay = {\n\n\t\t// Support: Firefox\n\t\t// We have to pre-define these values for FF (#10227)\n\t\tHTML: \"block\",\n\t\tBODY: \"block\"\n\t};\n\n/**\n * Retrieve the actual display of a element\n * @param {String} name nodeName of the element\n * @param {Object} doc Document object\n */\n\n// Called only from within defaultDisplay\nfunction actualDisplay( name, doc ) {\n\tvar elem = jQuery( doc.createElement( name ) ).appendTo( doc.body ),\n\n\t\tdisplay = jQuery.css( elem[ 0 ], \"display\" );\n\n\t// We don't have any data stored on the element,\n\t// so use \"detach\" method as fast way to get rid of the element\n\telem.detach();\n\n\treturn display;\n}\n\n/**\n * Try to determine the default display value of an element\n * @param {String} nodeName\n */\nfunction defaultDisplay( nodeName ) {\n\tvar doc = document,\n\t\tdisplay = elemdisplay[ nodeName ];\n\n\tif ( !display ) {\n\t\tdisplay = actualDisplay( nodeName, doc );\n\n\t\t// If the simple way fails, read from inside an iframe\n\t\tif ( display === \"none\" || !display ) {\n\n\t\t\t// Use the already-created iframe if possible\n\t\t\tiframe = ( iframe || jQuery( \"<iframe frameborder='0' width='0' height='0'/>\" ) )\n\t\t\t\t.appendTo( doc.documentElement );\n\n\t\t\t// Always write a new HTML skeleton so Webkit and Firefox don't choke on reuse\n\t\t\tdoc = iframe[ 0 ].contentDocument;\n\n\t\t\t// Support: IE\n\t\t\tdoc.write();\n\t\t\tdoc.close();\n\n\t\t\tdisplay = actualDisplay( nodeName, doc );\n\t\t\tiframe.detach();\n\t\t}\n\n\t\t// Store the correct default display\n\t\telemdisplay[ nodeName ] = display;\n\t}\n\n\treturn display;\n}\nvar rmargin = ( /^margin/ );\n\nvar rnumnonpx = new RegExp( \"^(\" + pnum + \")(?!px)[a-z%]+$\", \"i\" );\n\nvar getStyles = function( elem ) {\n\n\t\t// Support: IE<=11+, Firefox<=30+ (#15098, #14150)\n\t\t// IE throws on elements created in popups\n\t\t// FF meanwhile throws on frame elements through \"defaultView.getComputedStyle\"\n\t\tvar view = elem.ownerDocument.defaultView;\n\n\t\tif ( !view || !view.opener ) {\n\t\t\tview = window;\n\t\t}\n\n\t\treturn view.getComputedStyle( elem );\n\t};\n\nvar swap = function( elem, options, callback, args ) {\n\tvar ret, name,\n\t\told = {};\n\n\t// Remember the old values, and insert the new ones\n\tfor ( name in options ) {\n\t\told[ name ] = elem.style[ name ];\n\t\telem.style[ name ] = options[ name ];\n\t}\n\n\tret = callback.apply( elem, args || [] );\n\n\t// Revert the old values\n\tfor ( name in options ) {\n\t\telem.style[ name ] = old[ name ];\n\t}\n\n\treturn ret;\n};\n\n\nvar documentElement = document.documentElement;\n\n\n\n( function() {\n\tvar pixelPositionVal, boxSizingReliableVal, pixelMarginRightVal, reliableMarginLeftVal,\n\t\tcontainer = document.createElement( \"div\" ),\n\t\tdiv = document.createElement( \"div\" );\n\n\t// Finish early in limited (non-browser) environments\n\tif ( !div.style ) {\n\t\treturn;\n\t}\n\n\t// Support: IE9-11+\n\t// Style of cloned element affects source element cloned (#8908)\n\tdiv.style.backgroundClip = \"content-box\";\n\tdiv.cloneNode( true ).style.backgroundClip = \"\";\n\tsupport.clearCloneStyle = div.style.backgroundClip === \"content-box\";\n\n\tcontainer.style.cssText = \"border:0;width:8px;height:0;top:0;left:-9999px;\" +\n\t\t\"padding:0;margin-top:1px;position:absolute\";\n\tcontainer.appendChild( div );\n\n\t// Executing both pixelPosition & boxSizingReliable tests require only one layout\n\t// so they're executed at the same time to save the second computation.\n\tfunction computeStyleTests() {\n\t\tdiv.style.cssText =\n\n\t\t\t// Support: Firefox<29, Android 2.3\n\t\t\t// Vendor-prefix box-sizing\n\t\t\t\"-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;\" +\n\t\t\t\"position:relative;display:block;\" +\n\t\t\t\"margin:auto;border:1px;padding:1px;\" +\n\t\t\t\"top:1%;width:50%\";\n\t\tdiv.innerHTML = \"\";\n\t\tdocumentElement.appendChild( container );\n\n\t\tvar divStyle = window.getComputedStyle( div );\n\t\tpixelPositionVal = divStyle.top !== \"1%\";\n\t\treliableMarginLeftVal = divStyle.marginLeft === \"2px\";\n\t\tboxSizingReliableVal = divStyle.width === \"4px\";\n\n\t\t// Support: Android 4.0 - 4.3 only\n\t\t// Some styles come back with percentage values, even though they shouldn't\n\t\tdiv.style.marginRight = \"50%\";\n\t\tpixelMarginRightVal = divStyle.marginRight === \"4px\";\n\n\t\tdocumentElement.removeChild( container );\n\t}\n\n\tjQuery.extend( support, {\n\t\tpixelPosition: function() {\n\n\t\t\t// This test is executed only once but we still do memoizing\n\t\t\t// since we can use the boxSizingReliable pre-computing.\n\t\t\t// No need to check if the test was already performed, though.\n\t\t\tcomputeStyleTests();\n\t\t\treturn pixelPositionVal;\n\t\t},\n\t\tboxSizingReliable: function() {\n\t\t\tif ( boxSizingReliableVal == null ) {\n\t\t\t\tcomputeStyleTests();\n\t\t\t}\n\t\t\treturn boxSizingReliableVal;\n\t\t},\n\t\tpixelMarginRight: function() {\n\n\t\t\t// Support: Android 4.0-4.3\n\t\t\t// We're checking for boxSizingReliableVal here instead of pixelMarginRightVal\n\t\t\t// since that compresses better and they're computed together anyway.\n\t\t\tif ( boxSizingReliableVal == null ) {\n\t\t\t\tcomputeStyleTests();\n\t\t\t}\n\t\t\treturn pixelMarginRightVal;\n\t\t},\n\t\treliableMarginLeft: function() {\n\n\t\t\t// Support: IE <=8 only, Android 4.0 - 4.3 only, Firefox <=3 - 37\n\t\t\tif ( boxSizingReliableVal == null ) {\n\t\t\t\tcomputeStyleTests();\n\t\t\t}\n\t\t\treturn reliableMarginLeftVal;\n\t\t},\n\t\treliableMarginRight: function() {\n\n\t\t\t// Support: Android 2.3\n\t\t\t// Check if div with explicit width and no margin-right incorrectly\n\t\t\t// gets computed margin-right based on width of container. (#3333)\n\t\t\t// WebKit Bug 13343 - getComputedStyle returns wrong value for margin-right\n\t\t\t// This support function is only executed once so no memoizing is needed.\n\t\t\tvar ret,\n\t\t\t\tmarginDiv = div.appendChild( document.createElement( \"div\" ) );\n\n\t\t\t// Reset CSS: box-sizing; display; margin; border; padding\n\t\t\tmarginDiv.style.cssText = div.style.cssText =\n\n\t\t\t\t// Support: Android 2.3\n\t\t\t\t// Vendor-prefix box-sizing\n\t\t\t\t\"-webkit-box-sizing:content-box;box-sizing:content-box;\" +\n\t\t\t\t\"display:block;margin:0;border:0;padding:0\";\n\t\t\tmarginDiv.style.marginRight = marginDiv.style.width = \"0\";\n\t\t\tdiv.style.width = \"1px\";\n\t\t\tdocumentElement.appendChild( container );\n\n\t\t\tret = !parseFloat( window.getComputedStyle( marginDiv ).marginRight );\n\n\t\t\tdocumentElement.removeChild( container );\n\t\t\tdiv.removeChild( marginDiv );\n\n\t\t\treturn ret;\n\t\t}\n\t} );\n} )();\n\n\nfunction curCSS( elem, name, computed ) {\n\tvar width, minWidth, maxWidth, ret,\n\t\tstyle = elem.style;\n\n\tcomputed = computed || getStyles( elem );\n\tret = computed ? computed.getPropertyValue( name ) || computed[ name ] : undefined;\n\n\t// Support: Opera 12.1x only\n\t// Fall back to style even without computed\n\t// computed is undefined for elems on document fragments\n\tif ( ( ret === \"\" || ret === undefined ) && !jQuery.contains( elem.ownerDocument, elem ) ) {\n\t\tret = jQuery.style( elem, name );\n\t}\n\n\t// Support: IE9\n\t// getPropertyValue is only needed for .css('filter') (#12537)\n\tif ( computed ) {\n\n\t\t// A tribute to the \"awesome hack by Dean Edwards\"\n\t\t// Android Browser returns percentage for some values,\n\t\t// but width seems to be reliably pixels.\n\t\t// This is against the CSSOM draft spec:\n\t\t// http://dev.w3.org/csswg/cssom/#resolved-values\n\t\tif ( !support.pixelMarginRight() && rnumnonpx.test( ret ) && rmargin.test( name ) ) {\n\n\t\t\t// Remember the original values\n\t\t\twidth = style.width;\n\t\t\tminWidth = style.minWidth;\n\t\t\tmaxWidth = style.maxWidth;\n\n\t\t\t// Put in the new values to get a computed value out\n\t\t\tstyle.minWidth = style.maxWidth = style.width = ret;\n\t\t\tret = computed.width;\n\n\t\t\t// Revert the changed values\n\t\t\tstyle.width = width;\n\t\t\tstyle.minWidth = minWidth;\n\t\t\tstyle.maxWidth = maxWidth;\n\t\t}\n\t}\n\n\treturn ret !== undefined ?\n\n\t\t// Support: IE9-11+\n\t\t// IE returns zIndex value as an integer.\n\t\tret + \"\" :\n\t\tret;\n}\n\n\nfunction addGetHookIf( conditionFn, hookFn ) {\n\n\t// Define the hook, we'll check on the first run if it's really needed.\n\treturn {\n\t\tget: function() {\n\t\t\tif ( conditionFn() ) {\n\n\t\t\t\t// Hook not needed (or it's not possible to use it due\n\t\t\t\t// to missing dependency), remove it.\n\t\t\t\tdelete this.get;\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Hook needed; redefine it so that the support test is not executed again.\n\t\t\treturn ( this.get = hookFn ).apply( this, arguments );\n\t\t}\n\t};\n}\n\n\nvar\n\n\t// Swappable if display is none or starts with table\n\t// except \"table\", \"table-cell\", or \"table-caption\"\n\t// See here for display values: https://developer.mozilla.org/en-US/docs/CSS/display\n\trdisplayswap = /^(none|table(?!-c[ea]).+)/,\n\n\tcssShow = { position: \"absolute\", visibility: \"hidden\", display: \"block\" },\n\tcssNormalTransform = {\n\t\tletterSpacing: \"0\",\n\t\tfontWeight: \"400\"\n\t},\n\n\tcssPrefixes = [ \"Webkit\", \"O\", \"Moz\", \"ms\" ],\n\temptyStyle = document.createElement( \"div\" ).style;\n\n// Return a css property mapped to a potentially vendor prefixed property\nfunction vendorPropName( name ) {\n\n\t// Shortcut for names that are not vendor prefixed\n\tif ( name in emptyStyle ) {\n\t\treturn name;\n\t}\n\n\t// Check for vendor prefixed names\n\tvar capName = name[ 0 ].toUpperCase() + name.slice( 1 ),\n\t\ti = cssPrefixes.length;\n\n\twhile ( i-- ) {\n\t\tname = cssPrefixes[ i ] + capName;\n\t\tif ( name in emptyStyle ) {\n\t\t\treturn name;\n\t\t}\n\t}\n}\n\nfunction setPositiveNumber( elem, value, subtract ) {\n\n\t// Any relative (+/-) values have already been\n\t// normalized at this point\n\tvar matches = rcssNum.exec( value );\n\treturn matches ?\n\n\t\t// Guard against undefined \"subtract\", e.g., when used as in cssHooks\n\t\tMath.max( 0, matches[ 2 ] - ( subtract || 0 ) ) + ( matches[ 3 ] || \"px\" ) :\n\t\tvalue;\n}\n\nfunction augmentWidthOrHeight( elem, name, extra, isBorderBox, styles ) {\n\tvar i = extra === ( isBorderBox ? \"border\" : \"content\" ) ?\n\n\t\t// If we already have the right measurement, avoid augmentation\n\t\t4 :\n\n\t\t// Otherwise initialize for horizontal or vertical properties\n\t\tname === \"width\" ? 1 : 0,\n\n\t\tval = 0;\n\n\tfor ( ; i < 4; i += 2 ) {\n\n\t\t// Both box models exclude margin, so add it if we want it\n\t\tif ( extra === \"margin\" ) {\n\t\t\tval += jQuery.css( elem, extra + cssExpand[ i ], true, styles );\n\t\t}\n\n\t\tif ( isBorderBox ) {\n\n\t\t\t// border-box includes padding, so remove it if we want content\n\t\t\tif ( extra === \"content\" ) {\n\t\t\t\tval -= jQuery.css( elem, \"padding\" + cssExpand[ i ], true, styles );\n\t\t\t}\n\n\t\t\t// At this point, extra isn't border nor margin, so remove border\n\t\t\tif ( extra !== \"margin\" ) {\n\t\t\t\tval -= jQuery.css( elem, \"border\" + cssExpand[ i ] + \"Width\", true, styles );\n\t\t\t}\n\t\t} else {\n\n\t\t\t// At this point, extra isn't content, so add padding\n\t\t\tval += jQuery.css( elem, \"padding\" + cssExpand[ i ], true, styles );\n\n\t\t\t// At this point, extra isn't content nor padding, so add border\n\t\t\tif ( extra !== \"padding\" ) {\n\t\t\t\tval += jQuery.css( elem, \"border\" + cssExpand[ i ] + \"Width\", true, styles );\n\t\t\t}\n\t\t}\n\t}\n\n\treturn val;\n}\n\nfunction getWidthOrHeight( elem, name, extra ) {\n\n\t// Start with offset property, which is equivalent to the border-box value\n\tvar valueIsBorderBox = true,\n\t\tval = name === \"width\" ? elem.offsetWidth : elem.offsetHeight,\n\t\tstyles = getStyles( elem ),\n\t\tisBorderBox = jQuery.css( elem, \"boxSizing\", false, styles ) === \"border-box\";\n\n\t// Some non-html elements return undefined for offsetWidth, so check for null/undefined\n\t// svg - https://bugzilla.mozilla.org/show_bug.cgi?id=649285\n\t// MathML - https://bugzilla.mozilla.org/show_bug.cgi?id=491668\n\tif ( val <= 0 || val == null ) {\n\n\t\t// Fall back to computed then uncomputed css if necessary\n\t\tval = curCSS( elem, name, styles );\n\t\tif ( val < 0 || val == null ) {\n\t\t\tval = elem.style[ name ];\n\t\t}\n\n\t\t// Computed unit is not pixels. Stop here and return.\n\t\tif ( rnumnonpx.test( val ) ) {\n\t\t\treturn val;\n\t\t}\n\n\t\t// Check for style in case a browser which returns unreliable values\n\t\t// for getComputedStyle silently falls back to the reliable elem.style\n\t\tvalueIsBorderBox = isBorderBox &&\n\t\t\t( support.boxSizingReliable() || val === elem.style[ name ] );\n\n\t\t// Normalize \"\", auto, and prepare for extra\n\t\tval = parseFloat( val ) || 0;\n\t}\n\n\t// Use the active box-sizing model to add/subtract irrelevant styles\n\treturn ( val +\n\t\taugmentWidthOrHeight(\n\t\t\telem,\n\t\t\tname,\n\t\t\textra || ( isBorderBox ? \"border\" : \"content\" ),\n\t\t\tvalueIsBorderBox,\n\t\t\tstyles\n\t\t)\n\t) + \"px\";\n}\n\nfunction showHide( elements, show ) {\n\tvar display, elem, hidden,\n\t\tvalues = [],\n\t\tindex = 0,\n\t\tlength = elements.length;\n\n\tfor ( ; index < length; index++ ) {\n\t\telem = elements[ index ];\n\t\tif ( !elem.style ) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tvalues[ index ] = dataPriv.get( elem, \"olddisplay\" );\n\t\tdisplay = elem.style.display;\n\t\tif ( show ) {\n\n\t\t\t// Reset the inline display of this element to learn if it is\n\t\t\t// being hidden by cascaded rules or not\n\t\t\tif ( !values[ index ] && display === \"none\" ) {\n\t\t\t\telem.style.display = \"\";\n\t\t\t}\n\n\t\t\t// Set elements which have been overridden with display: none\n\t\t\t// in a stylesheet to whatever the default browser style is\n\t\t\t// for such an element\n\t\t\tif ( elem.style.display === \"\" && isHidden( elem ) ) {\n\t\t\t\tvalues[ index ] = dataPriv.access(\n\t\t\t\t\telem,\n\t\t\t\t\t\"olddisplay\",\n\t\t\t\t\tdefaultDisplay( elem.nodeName )\n\t\t\t\t);\n\t\t\t}\n\t\t} else {\n\t\t\thidden = isHidden( elem );\n\n\t\t\tif ( display !== \"none\" || !hidden ) {\n\t\t\t\tdataPriv.set(\n\t\t\t\t\telem,\n\t\t\t\t\t\"olddisplay\",\n\t\t\t\t\thidden ? display : jQuery.css( elem, \"display\" )\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\n\t// Set the display of most of the elements in a second loop\n\t// to avoid the constant reflow\n\tfor ( index = 0; index < length; index++ ) {\n\t\telem = elements[ index ];\n\t\tif ( !elem.style ) {\n\t\t\tcontinue;\n\t\t}\n\t\tif ( !show || elem.style.display === \"none\" || elem.style.display === \"\" ) {\n\t\t\telem.style.display = show ? values[ index ] || \"\" : \"none\";\n\t\t}\n\t}\n\n\treturn elements;\n}\n\njQuery.extend( {\n\n\t// Add in style property hooks for overriding the default\n\t// behavior of getting and setting a style property\n\tcssHooks: {\n\t\topacity: {\n\t\t\tget: function( elem, computed ) {\n\t\t\t\tif ( computed ) {\n\n\t\t\t\t\t// We should always get a number back from opacity\n\t\t\t\t\tvar ret = curCSS( elem, \"opacity\" );\n\t\t\t\t\treturn ret === \"\" ? \"1\" : ret;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\t// Don't automatically add \"px\" to these possibly-unitless properties\n\tcssNumber: {\n\t\t\"animationIterationCount\": true,\n\t\t\"columnCount\": true,\n\t\t\"fillOpacity\": true,\n\t\t\"flexGrow\": true,\n\t\t\"flexShrink\": true,\n\t\t\"fontWeight\": true,\n\t\t\"lineHeight\": true,\n\t\t\"opacity\": true,\n\t\t\"order\": true,\n\t\t\"orphans\": true,\n\t\t\"widows\": true,\n\t\t\"zIndex\": true,\n\t\t\"zoom\": true\n\t},\n\n\t// Add in properties whose names you wish to fix before\n\t// setting or getting the value\n\tcssProps: {\n\t\t\"float\": \"cssFloat\"\n\t},\n\n\t// Get and set the style property on a DOM Node\n\tstyle: function( elem, name, value, extra ) {\n\n\t\t// Don't set styles on text and comment nodes\n\t\tif ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Make sure that we're working with the right name\n\t\tvar ret, type, hooks,\n\t\t\torigName = jQuery.camelCase( name ),\n\t\t\tstyle = elem.style;\n\n\t\tname = jQuery.cssProps[ origName ] ||\n\t\t\t( jQuery.cssProps[ origName ] = vendorPropName( origName ) || origName );\n\n\t\t// Gets hook for the prefixed version, then unprefixed version\n\t\thooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];\n\n\t\t// Check if we're setting a value\n\t\tif ( value !== undefined ) {\n\t\t\ttype = typeof value;\n\n\t\t\t// Convert \"+=\" or \"-=\" to relative numbers (#7345)\n\t\t\tif ( type === \"string\" && ( ret = rcssNum.exec( value ) ) && ret[ 1 ] ) {\n\t\t\t\tvalue = adjustCSS( elem, name, ret );\n\n\t\t\t\t// Fixes bug #9237\n\t\t\t\ttype = \"number\";\n\t\t\t}\n\n\t\t\t// Make sure that null and NaN values aren't set (#7116)\n\t\t\tif ( value == null || value !== value ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// If a number was passed in, add the unit (except for certain CSS properties)\n\t\t\tif ( type === \"number\" ) {\n\t\t\t\tvalue += ret && ret[ 3 ] || ( jQuery.cssNumber[ origName ] ? \"\" : \"px\" );\n\t\t\t}\n\n\t\t\t// Support: IE9-11+\n\t\t\t// background-* props affect original clone's values\n\t\t\tif ( !support.clearCloneStyle && value === \"\" && name.indexOf( \"background\" ) === 0 ) {\n\t\t\t\tstyle[ name ] = \"inherit\";\n\t\t\t}\n\n\t\t\t// If a hook was provided, use that value, otherwise just set the specified value\n\t\t\tif ( !hooks || !( \"set\" in hooks ) ||\n\t\t\t\t( value = hooks.set( elem, value, extra ) ) !== undefined ) {\n\n\t\t\t\tstyle[ name ] = value;\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t// If a hook was provided get the non-computed value from there\n\t\t\tif ( hooks && \"get\" in hooks &&\n\t\t\t\t( ret = hooks.get( elem, false, extra ) ) !== undefined ) {\n\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\t// Otherwise just get the value from the style object\n\t\t\treturn style[ name ];\n\t\t}\n\t},\n\n\tcss: function( elem, name, extra, styles ) {\n\t\tvar val, num, hooks,\n\t\t\torigName = jQuery.camelCase( name );\n\n\t\t// Make sure that we're working with the right name\n\t\tname = jQuery.cssProps[ origName ] ||\n\t\t\t( jQuery.cssProps[ origName ] = vendorPropName( origName ) || origName );\n\n\t\t// Try prefixed name followed by the unprefixed name\n\t\thooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];\n\n\t\t// If a hook was provided get the computed value from there\n\t\tif ( hooks && \"get\" in hooks ) {\n\t\t\tval = hooks.get( elem, true, extra );\n\t\t}\n\n\t\t// Otherwise, if a way to get the computed value exists, use that\n\t\tif ( val === undefined ) {\n\t\t\tval = curCSS( elem, name, styles );\n\t\t}\n\n\t\t// Convert \"normal\" to computed value\n\t\tif ( val === \"normal\" && name in cssNormalTransform ) {\n\t\t\tval = cssNormalTransform[ name ];\n\t\t}\n\n\t\t// Make numeric if forced or a qualifier was provided and val looks numeric\n\t\tif ( extra === \"\" || extra ) {\n\t\t\tnum = parseFloat( val );\n\t\t\treturn extra === true || isFinite( num ) ? num || 0 : val;\n\t\t}\n\t\treturn val;\n\t}\n} );\n\njQuery.each( [ \"height\", \"width\" ], function( i, name ) {\n\tjQuery.cssHooks[ name ] = {\n\t\tget: function( elem, computed, extra ) {\n\t\t\tif ( computed ) {\n\n\t\t\t\t// Certain elements can have dimension info if we invisibly show them\n\t\t\t\t// but it must have a current display style that would benefit\n\t\t\t\treturn rdisplayswap.test( jQuery.css( elem, \"display\" ) ) &&\n\t\t\t\t\telem.offsetWidth === 0 ?\n\t\t\t\t\t\tswap( elem, cssShow, function() {\n\t\t\t\t\t\t\treturn getWidthOrHeight( elem, name, extra );\n\t\t\t\t\t\t} ) :\n\t\t\t\t\t\tgetWidthOrHeight( elem, name, extra );\n\t\t\t}\n\t\t},\n\n\t\tset: function( elem, value, extra ) {\n\t\t\tvar matches,\n\t\t\t\tstyles = extra && getStyles( elem ),\n\t\t\t\tsubtract = extra && augmentWidthOrHeight(\n\t\t\t\t\telem,\n\t\t\t\t\tname,\n\t\t\t\t\textra,\n\t\t\t\t\tjQuery.css( elem, \"boxSizing\", false, styles ) === \"border-box\",\n\t\t\t\t\tstyles\n\t\t\t\t);\n\n\t\t\t// Convert to pixels if value adjustment is needed\n\t\t\tif ( subtract && ( matches = rcssNum.exec( value ) ) &&\n\t\t\t\t( matches[ 3 ] || \"px\" ) !== \"px\" ) {\n\n\t\t\t\telem.style[ name ] = value;\n\t\t\t\tvalue = jQuery.css( elem, name );\n\t\t\t}\n\n\t\t\treturn setPositiveNumber( elem, value, subtract );\n\t\t}\n\t};\n} );\n\njQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft,\n\tfunction( elem, computed ) {\n\t\tif ( computed ) {\n\t\t\treturn ( parseFloat( curCSS( elem, \"marginLeft\" ) ) ||\n\t\t\t\telem.getBoundingClientRect().left -\n\t\t\t\t\tswap( elem, { marginLeft: 0 }, function() {\n\t\t\t\t\t\treturn elem.getBoundingClientRect().left;\n\t\t\t\t\t} )\n\t\t\t\t) + \"px\";\n\t\t}\n\t}\n);\n\n// Support: Android 2.3\njQuery.cssHooks.marginRight = addGetHookIf( support.reliableMarginRight,\n\tfunction( elem, computed ) {\n\t\tif ( computed ) {\n\t\t\treturn swap( elem, { \"display\": \"inline-block\" },\n\t\t\t\tcurCSS, [ elem, \"marginRight\" ] );\n\t\t}\n\t}\n);\n\n// These hooks are used by animate to expand properties\njQuery.each( {\n\tmargin: \"\",\n\tpadding: \"\",\n\tborder: \"Width\"\n}, function( prefix, suffix ) {\n\tjQuery.cssHooks[ prefix + suffix ] = {\n\t\texpand: function( value ) {\n\t\t\tvar i = 0,\n\t\t\t\texpanded = {},\n\n\t\t\t\t// Assumes a single number if not a string\n\t\t\t\tparts = typeof value === \"string\" ? value.split( \" \" ) : [ value ];\n\n\t\t\tfor ( ; i < 4; i++ ) {\n\t\t\t\texpanded[ prefix + cssExpand[ i ] + suffix ] =\n\t\t\t\t\tparts[ i ] || parts[ i - 2 ] || parts[ 0 ];\n\t\t\t}\n\n\t\t\treturn expanded;\n\t\t}\n\t};\n\n\tif ( !rmargin.test( prefix ) ) {\n\t\tjQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber;\n\t}\n} );\n\njQuery.fn.extend( {\n\tcss: function( name, value ) {\n\t\treturn access( this, function( elem, name, value ) {\n\t\t\tvar styles, len,\n\t\t\t\tmap = {},\n\t\t\t\ti = 0;\n\n\t\t\tif ( jQuery.isArray( name ) ) {\n\t\t\t\tstyles = getStyles( elem );\n\t\t\t\tlen = name.length;\n\n\t\t\t\tfor ( ; i < len; i++ ) {\n\t\t\t\t\tmap[ name[ i ] ] = jQuery.css( elem, name[ i ], false, styles );\n\t\t\t\t}\n\n\t\t\t\treturn map;\n\t\t\t}\n\n\t\t\treturn value !== undefined ?\n\t\t\t\tjQuery.style( elem, name, value ) :\n\t\t\t\tjQuery.css( elem, name );\n\t\t}, name, value, arguments.length > 1 );\n\t},\n\tshow: function() {\n\t\treturn showHide( this, true );\n\t},\n\thide: function() {\n\t\treturn showHide( this );\n\t},\n\ttoggle: function( state ) {\n\t\tif ( typeof state === \"boolean\" ) {\n\t\t\treturn state ? this.show() : this.hide();\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tif ( isHidden( this ) ) {\n\t\t\t\tjQuery( this ).show();\n\t\t\t} else {\n\t\t\t\tjQuery( this ).hide();\n\t\t\t}\n\t\t} );\n\t}\n} );\n\n\nfunction Tween( elem, options, prop, end, easing ) {\n\treturn new Tween.prototype.init( elem, options, prop, end, easing );\n}\njQuery.Tween = Tween;\n\nTween.prototype = {\n\tconstructor: Tween,\n\tinit: function( elem, options, prop, end, easing, unit ) {\n\t\tthis.elem = elem;\n\t\tthis.prop = prop;\n\t\tthis.easing = easing || jQuery.easing._default;\n\t\tthis.options = options;\n\t\tthis.start = this.now = this.cur();\n\t\tthis.end = end;\n\t\tthis.unit = unit || ( jQuery.cssNumber[ prop ] ? \"\" : \"px\" );\n\t},\n\tcur: function() {\n\t\tvar hooks = Tween.propHooks[ this.prop ];\n\n\t\treturn hooks && hooks.get ?\n\t\t\thooks.get( this ) :\n\t\t\tTween.propHooks._default.get( this );\n\t},\n\trun: function( percent ) {\n\t\tvar eased,\n\t\t\thooks = Tween.propHooks[ this.prop ];\n\n\t\tif ( this.options.duration ) {\n\t\t\tthis.pos = eased = jQuery.easing[ this.easing ](\n\t\t\t\tpercent, this.options.duration * percent, 0, 1, this.options.duration\n\t\t\t);\n\t\t} else {\n\t\t\tthis.pos = eased = percent;\n\t\t}\n\t\tthis.now = ( this.end - this.start ) * eased + this.start;\n\n\t\tif ( this.options.step ) {\n\t\t\tthis.options.step.call( this.elem, this.now, this );\n\t\t}\n\n\t\tif ( hooks && hooks.set ) {\n\t\t\thooks.set( this );\n\t\t} else {\n\t\t\tTween.propHooks._default.set( this );\n\t\t}\n\t\treturn this;\n\t}\n};\n\nTween.prototype.init.prototype = Tween.prototype;\n\nTween.propHooks = {\n\t_default: {\n\t\tget: function( tween ) {\n\t\t\tvar result;\n\n\t\t\t// Use a property on the element directly when it is not a DOM element,\n\t\t\t// or when there is no matching style property that exists.\n\t\t\tif ( tween.elem.nodeType !== 1 ||\n\t\t\t\ttween.elem[ tween.prop ] != null && tween.elem.style[ tween.prop ] == null ) {\n\t\t\t\treturn tween.elem[ tween.prop ];\n\t\t\t}\n\n\t\t\t// Passing an empty string as a 3rd parameter to .css will automatically\n\t\t\t// attempt a parseFloat and fallback to a string if the parse fails.\n\t\t\t// Simple values such as \"10px\" are parsed to Float;\n\t\t\t// complex values such as \"rotate(1rad)\" are returned as-is.\n\t\t\tresult = jQuery.css( tween.elem, tween.prop, \"\" );\n\n\t\t\t// Empty strings, null, undefined and \"auto\" are converted to 0.\n\t\t\treturn !result || result === \"auto\" ? 0 : result;\n\t\t},\n\t\tset: function( tween ) {\n\n\t\t\t// Use step hook for back compat.\n\t\t\t// Use cssHook if its there.\n\t\t\t// Use .style if available and use plain properties where available.\n\t\t\tif ( jQuery.fx.step[ tween.prop ] ) {\n\t\t\t\tjQuery.fx.step[ tween.prop ]( tween );\n\t\t\t} else if ( tween.elem.nodeType === 1 &&\n\t\t\t\t( tween.elem.style[ jQuery.cssProps[ tween.prop ] ] != null ||\n\t\t\t\t\tjQuery.cssHooks[ tween.prop ] ) ) {\n\t\t\t\tjQuery.style( tween.elem, tween.prop, tween.now + tween.unit );\n\t\t\t} else {\n\t\t\t\ttween.elem[ tween.prop ] = tween.now;\n\t\t\t}\n\t\t}\n\t}\n};\n\n// Support: IE9\n// Panic based approach to setting things on disconnected nodes\nTween.propHooks.scrollTop = Tween.propHooks.scrollLeft = {\n\tset: function( tween ) {\n\t\tif ( tween.elem.nodeType && tween.elem.parentNode ) {\n\t\t\ttween.elem[ tween.prop ] = tween.now;\n\t\t}\n\t}\n};\n\njQuery.easing = {\n\tlinear: function( p ) {\n\t\treturn p;\n\t},\n\tswing: function( p ) {\n\t\treturn 0.5 - Math.cos( p * Math.PI ) / 2;\n\t},\n\t_default: \"swing\"\n};\n\njQuery.fx = Tween.prototype.init;\n\n// Back Compat <1.8 extension point\njQuery.fx.step = {};\n\n\n\n\nvar\n\tfxNow, timerId,\n\trfxtypes = /^(?:toggle|show|hide)$/,\n\trrun = /queueHooks$/;\n\n// Animations created synchronously will run synchronously\nfunction createFxNow() {\n\twindow.setTimeout( function() {\n\t\tfxNow = undefined;\n\t} );\n\treturn ( fxNow = jQuery.now() );\n}\n\n// Generate parameters to create a standard animation\nfunction genFx( type, includeWidth ) {\n\tvar which,\n\t\ti = 0,\n\t\tattrs = { height: type };\n\n\t// If we include width, step value is 1 to do all cssExpand values,\n\t// otherwise step value is 2 to skip over Left and Right\n\tincludeWidth = includeWidth ? 1 : 0;\n\tfor ( ; i < 4 ; i += 2 - includeWidth ) {\n\t\twhich = cssExpand[ i ];\n\t\tattrs[ \"margin\" + which ] = attrs[ \"padding\" + which ] = type;\n\t}\n\n\tif ( includeWidth ) {\n\t\tattrs.opacity = attrs.width = type;\n\t}\n\n\treturn attrs;\n}\n\nfunction createTween( value, prop, animation ) {\n\tvar tween,\n\t\tcollection = ( Animation.tweeners[ prop ] || [] ).concat( Animation.tweeners[ \"*\" ] ),\n\t\tindex = 0,\n\t\tlength = collection.length;\n\tfor ( ; index < length; index++ ) {\n\t\tif ( ( tween = collection[ index ].call( animation, prop, value ) ) ) {\n\n\t\t\t// We're done with this property\n\t\t\treturn tween;\n\t\t}\n\t}\n}\n\nfunction defaultPrefilter( elem, props, opts ) {\n\t/* jshint validthis: true */\n\tvar prop, value, toggle, tween, hooks, oldfire, display, checkDisplay,\n\t\tanim = this,\n\t\torig = {},\n\t\tstyle = elem.style,\n\t\thidden = elem.nodeType && isHidden( elem ),\n\t\tdataShow = dataPriv.get( elem, \"fxshow\" );\n\n\t// Handle queue: false promises\n\tif ( !opts.queue ) {\n\t\thooks = jQuery._queueHooks( elem, \"fx\" );\n\t\tif ( hooks.unqueued == null ) {\n\t\t\thooks.unqueued = 0;\n\t\t\toldfire = hooks.empty.fire;\n\t\t\thooks.empty.fire = function() {\n\t\t\t\tif ( !hooks.unqueued ) {\n\t\t\t\t\toldfire();\n\t\t\t\t}\n\t\t\t};\n\t\t}\n\t\thooks.unqueued++;\n\n\t\tanim.always( function() {\n\n\t\t\t// Ensure the complete handler is called before this completes\n\t\t\tanim.always( function() {\n\t\t\t\thooks.unqueued--;\n\t\t\t\tif ( !jQuery.queue( elem, \"fx\" ).length ) {\n\t\t\t\t\thooks.empty.fire();\n\t\t\t\t}\n\t\t\t} );\n\t\t} );\n\t}\n\n\t// Height/width overflow pass\n\tif ( elem.nodeType === 1 && ( \"height\" in props || \"width\" in props ) ) {\n\n\t\t// Make sure that nothing sneaks out\n\t\t// Record all 3 overflow attributes because IE9-10 do not\n\t\t// change the overflow attribute when overflowX and\n\t\t// overflowY are set to the same value\n\t\topts.overflow = [ style.overflow, style.overflowX, style.overflowY ];\n\n\t\t// Set display property to inline-block for height/width\n\t\t// animations on inline elements that are having width/height animated\n\t\tdisplay = jQuery.css( elem, \"display\" );\n\n\t\t// Test default display if display is currently \"none\"\n\t\tcheckDisplay = display === \"none\" ?\n\t\t\tdataPriv.get( elem, \"olddisplay\" ) || defaultDisplay( elem.nodeName ) : display;\n\n\t\tif ( checkDisplay === \"inline\" && jQuery.css( elem, \"float\" ) === \"none\" ) {\n\t\t\tstyle.display = \"inline-block\";\n\t\t}\n\t}\n\n\tif ( opts.overflow ) {\n\t\tstyle.overflow = \"hidden\";\n\t\tanim.always( function() {\n\t\t\tstyle.overflow = opts.overflow[ 0 ];\n\t\t\tstyle.overflowX = opts.overflow[ 1 ];\n\t\t\tstyle.overflowY = opts.overflow[ 2 ];\n\t\t} );\n\t}\n\n\t// show/hide pass\n\tfor ( prop in props ) {\n\t\tvalue = props[ prop ];\n\t\tif ( rfxtypes.exec( value ) ) {\n\t\t\tdelete props[ prop ];\n\t\t\ttoggle = toggle || value === \"toggle\";\n\t\t\tif ( value === ( hidden ? \"hide\" : \"show\" ) ) {\n\n\t\t\t\t// If there is dataShow left over from a stopped hide or show\n\t\t\t\t// and we are going to proceed with show, we should pretend to be hidden\n\t\t\t\tif ( value === \"show\" && dataShow && dataShow[ prop ] !== undefined ) {\n\t\t\t\t\thidden = true;\n\t\t\t\t} else {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t}\n\t\t\torig[ prop ] = dataShow && dataShow[ prop ] || jQuery.style( elem, prop );\n\n\t\t// Any non-fx value stops us from restoring the original display value\n\t\t} else {\n\t\t\tdisplay = undefined;\n\t\t}\n\t}\n\n\tif ( !jQuery.isEmptyObject( orig ) ) {\n\t\tif ( dataShow ) {\n\t\t\tif ( \"hidden\" in dataShow ) {\n\t\t\t\thidden = dataShow.hidden;\n\t\t\t}\n\t\t} else {\n\t\t\tdataShow = dataPriv.access( elem, \"fxshow\", {} );\n\t\t}\n\n\t\t// Store state if its toggle - enables .stop().toggle() to \"reverse\"\n\t\tif ( toggle ) {\n\t\t\tdataShow.hidden = !hidden;\n\t\t}\n\t\tif ( hidden ) {\n\t\t\tjQuery( elem ).show();\n\t\t} else {\n\t\t\tanim.done( function() {\n\t\t\t\tjQuery( elem ).hide();\n\t\t\t} );\n\t\t}\n\t\tanim.done( function() {\n\t\t\tvar prop;\n\n\t\t\tdataPriv.remove( elem, \"fxshow\" );\n\t\t\tfor ( prop in orig ) {\n\t\t\t\tjQuery.style( elem, prop, orig[ prop ] );\n\t\t\t}\n\t\t} );\n\t\tfor ( prop in orig ) {\n\t\t\ttween = createTween( hidden ? dataShow[ prop ] : 0, prop, anim );\n\n\t\t\tif ( !( prop in dataShow ) ) {\n\t\t\t\tdataShow[ prop ] = tween.start;\n\t\t\t\tif ( hidden ) {\n\t\t\t\t\ttween.end = tween.start;\n\t\t\t\t\ttween.start = prop === \"width\" || prop === \"height\" ? 1 : 0;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t// If this is a noop like .hide().hide(), restore an overwritten display value\n\t} else if ( ( display === \"none\" ? defaultDisplay( elem.nodeName ) : display ) === \"inline\" ) {\n\t\tstyle.display = display;\n\t}\n}\n\nfunction propFilter( props, specialEasing ) {\n\tvar index, name, easing, value, hooks;\n\n\t// camelCase, specialEasing and expand cssHook pass\n\tfor ( index in props ) {\n\t\tname = jQuery.camelCase( index );\n\t\teasing = specialEasing[ name ];\n\t\tvalue = props[ index ];\n\t\tif ( jQuery.isArray( value ) ) {\n\t\t\teasing = value[ 1 ];\n\t\t\tvalue = props[ index ] = value[ 0 ];\n\t\t}\n\n\t\tif ( index !== name ) {\n\t\t\tprops[ name ] = value;\n\t\t\tdelete props[ index ];\n\t\t}\n\n\t\thooks = jQuery.cssHooks[ name ];\n\t\tif ( hooks && \"expand\" in hooks ) {\n\t\t\tvalue = hooks.expand( value );\n\t\t\tdelete props[ name ];\n\n\t\t\t// Not quite $.extend, this won't overwrite existing keys.\n\t\t\t// Reusing 'index' because we have the correct \"name\"\n\t\t\tfor ( index in value ) {\n\t\t\t\tif ( !( index in props ) ) {\n\t\t\t\t\tprops[ index ] = value[ index ];\n\t\t\t\t\tspecialEasing[ index ] = easing;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tspecialEasing[ name ] = easing;\n\t\t}\n\t}\n}\n\nfunction Animation( elem, properties, options ) {\n\tvar result,\n\t\tstopped,\n\t\tindex = 0,\n\t\tlength = Animation.prefilters.length,\n\t\tdeferred = jQuery.Deferred().always( function() {\n\n\t\t\t// Don't match elem in the :animated selector\n\t\t\tdelete tick.elem;\n\t\t} ),\n\t\ttick = function() {\n\t\t\tif ( stopped ) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tvar currentTime = fxNow || createFxNow(),\n\t\t\t\tremaining = Math.max( 0, animation.startTime + animation.duration - currentTime ),\n\n\t\t\t\t// Support: Android 2.3\n\t\t\t\t// Archaic crash bug won't allow us to use `1 - ( 0.5 || 0 )` (#12497)\n\t\t\t\ttemp = remaining / animation.duration || 0,\n\t\t\t\tpercent = 1 - temp,\n\t\t\t\tindex = 0,\n\t\t\t\tlength = animation.tweens.length;\n\n\t\t\tfor ( ; index < length ; index++ ) {\n\t\t\t\tanimation.tweens[ index ].run( percent );\n\t\t\t}\n\n\t\t\tdeferred.notifyWith( elem, [ animation, percent, remaining ] );\n\n\t\t\tif ( percent < 1 && length ) {\n\t\t\t\treturn remaining;\n\t\t\t} else {\n\t\t\t\tdeferred.resolveWith( elem, [ animation ] );\n\t\t\t\treturn false;\n\t\t\t}\n\t\t},\n\t\tanimation = deferred.promise( {\n\t\t\telem: elem,\n\t\t\tprops: jQuery.extend( {}, properties ),\n\t\t\topts: jQuery.extend( true, {\n\t\t\t\tspecialEasing: {},\n\t\t\t\teasing: jQuery.easing._default\n\t\t\t}, options ),\n\t\t\toriginalProperties: properties,\n\t\t\toriginalOptions: options,\n\t\t\tstartTime: fxNow || createFxNow(),\n\t\t\tduration: options.duration,\n\t\t\ttweens: [],\n\t\t\tcreateTween: function( prop, end ) {\n\t\t\t\tvar tween = jQuery.Tween( elem, animation.opts, prop, end,\n\t\t\t\t\t\tanimation.opts.specialEasing[ prop ] || animation.opts.easing );\n\t\t\t\tanimation.tweens.push( tween );\n\t\t\t\treturn tween;\n\t\t\t},\n\t\t\tstop: function( gotoEnd ) {\n\t\t\t\tvar index = 0,\n\n\t\t\t\t\t// If we are going to the end, we want to run all the tweens\n\t\t\t\t\t// otherwise we skip this part\n\t\t\t\t\tlength = gotoEnd ? animation.tweens.length : 0;\n\t\t\t\tif ( stopped ) {\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t\tstopped = true;\n\t\t\t\tfor ( ; index < length ; index++ ) {\n\t\t\t\t\tanimation.tweens[ index ].run( 1 );\n\t\t\t\t}\n\n\t\t\t\t// Resolve when we played the last frame; otherwise, reject\n\t\t\t\tif ( gotoEnd ) {\n\t\t\t\t\tdeferred.notifyWith( elem, [ animation, 1, 0 ] );\n\t\t\t\t\tdeferred.resolveWith( elem, [ animation, gotoEnd ] );\n\t\t\t\t} else {\n\t\t\t\t\tdeferred.rejectWith( elem, [ animation, gotoEnd ] );\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t}\n\t\t} ),\n\t\tprops = animation.props;\n\n\tpropFilter( props, animation.opts.specialEasing );\n\n\tfor ( ; index < length ; index++ ) {\n\t\tresult = Animation.prefilters[ index ].call( animation, elem, props, animation.opts );\n\t\tif ( result ) {\n\t\t\tif ( jQuery.isFunction( result.stop ) ) {\n\t\t\t\tjQuery._queueHooks( animation.elem, animation.opts.queue ).stop =\n\t\t\t\t\tjQuery.proxy( result.stop, result );\n\t\t\t}\n\t\t\treturn result;\n\t\t}\n\t}\n\n\tjQuery.map( props, createTween, animation );\n\n\tif ( jQuery.isFunction( animation.opts.start ) ) {\n\t\tanimation.opts.start.call( elem, animation );\n\t}\n\n\tjQuery.fx.timer(\n\t\tjQuery.extend( tick, {\n\t\t\telem: elem,\n\t\t\tanim: animation,\n\t\t\tqueue: animation.opts.queue\n\t\t} )\n\t);\n\n\t// attach callbacks from options\n\treturn animation.progress( animation.opts.progress )\n\t\t.done( animation.opts.done, animation.opts.complete )\n\t\t.fail( animation.opts.fail )\n\t\t.always( animation.opts.always );\n}\n\njQuery.Animation = jQuery.extend( Animation, {\n\ttweeners: {\n\t\t\"*\": [ function( prop, value ) {\n\t\t\tvar tween = this.createTween( prop, value );\n\t\t\tadjustCSS( tween.elem, prop, rcssNum.exec( value ), tween );\n\t\t\treturn tween;\n\t\t} ]\n\t},\n\n\ttweener: function( props, callback ) {\n\t\tif ( jQuery.isFunction( props ) ) {\n\t\t\tcallback = props;\n\t\t\tprops = [ \"*\" ];\n\t\t} else {\n\t\t\tprops = props.match( rnotwhite );\n\t\t}\n\n\t\tvar prop,\n\t\t\tindex = 0,\n\t\t\tlength = props.length;\n\n\t\tfor ( ; index < length ; index++ ) {\n\t\t\tprop = props[ index ];\n\t\t\tAnimation.tweeners[ prop ] = Animation.tweeners[ prop ] || [];\n\t\t\tAnimation.tweeners[ prop ].unshift( callback );\n\t\t}\n\t},\n\n\tprefilters: [ defaultPrefilter ],\n\n\tprefilter: function( callback, prepend ) {\n\t\tif ( prepend ) {\n\t\t\tAnimation.prefilters.unshift( callback );\n\t\t} else {\n\t\t\tAnimation.prefilters.push( callback );\n\t\t}\n\t}\n} );\n\njQuery.speed = function( speed, easing, fn ) {\n\tvar opt = speed && typeof speed === \"object\" ? jQuery.extend( {}, speed ) : {\n\t\tcomplete: fn || !fn && easing ||\n\t\t\tjQuery.isFunction( speed ) && speed,\n\t\tduration: speed,\n\t\teasing: fn && easing || easing && !jQuery.isFunction( easing ) && easing\n\t};\n\n\topt.duration = jQuery.fx.off ? 0 : typeof opt.duration === \"number\" ?\n\t\topt.duration : opt.duration in jQuery.fx.speeds ?\n\t\t\tjQuery.fx.speeds[ opt.duration ] : jQuery.fx.speeds._default;\n\n\t// Normalize opt.queue - true/undefined/null -> \"fx\"\n\tif ( opt.queue == null || opt.queue === true ) {\n\t\topt.queue = \"fx\";\n\t}\n\n\t// Queueing\n\topt.old = opt.complete;\n\n\topt.complete = function() {\n\t\tif ( jQuery.isFunction( opt.old ) ) {\n\t\t\topt.old.call( this );\n\t\t}\n\n\t\tif ( opt.queue ) {\n\t\t\tjQuery.dequeue( this, opt.queue );\n\t\t}\n\t};\n\n\treturn opt;\n};\n\njQuery.fn.extend( {\n\tfadeTo: function( speed, to, easing, callback ) {\n\n\t\t// Show any hidden elements after setting opacity to 0\n\t\treturn this.filter( isHidden ).css( \"opacity\", 0 ).show()\n\n\t\t\t// Animate to the value specified\n\t\t\t.end().animate( { opacity: to }, speed, easing, callback );\n\t},\n\tanimate: function( prop, speed, easing, callback ) {\n\t\tvar empty = jQuery.isEmptyObject( prop ),\n\t\t\toptall = jQuery.speed( speed, easing, callback ),\n\t\t\tdoAnimation = function() {\n\n\t\t\t\t// Operate on a copy of prop so per-property easing won't be lost\n\t\t\t\tvar anim = Animation( this, jQuery.extend( {}, prop ), optall );\n\n\t\t\t\t// Empty animations, or finishing resolves immediately\n\t\t\t\tif ( empty || dataPriv.get( this, \"finish\" ) ) {\n\t\t\t\t\tanim.stop( true );\n\t\t\t\t}\n\t\t\t};\n\t\t\tdoAnimation.finish = doAnimation;\n\n\t\treturn empty || optall.queue === false ?\n\t\t\tthis.each( doAnimation ) :\n\t\t\tthis.queue( optall.queue, doAnimation );\n\t},\n\tstop: function( type, clearQueue, gotoEnd ) {\n\t\tvar stopQueue = function( hooks ) {\n\t\t\tvar stop = hooks.stop;\n\t\t\tdelete hooks.stop;\n\t\t\tstop( gotoEnd );\n\t\t};\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tgotoEnd = clearQueue;\n\t\t\tclearQueue = type;\n\t\t\ttype = undefined;\n\t\t}\n\t\tif ( clearQueue && type !== false ) {\n\t\t\tthis.queue( type || \"fx\", [] );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar dequeue = true,\n\t\t\t\tindex = type != null && type + \"queueHooks\",\n\t\t\t\ttimers = jQuery.timers,\n\t\t\t\tdata = dataPriv.get( this );\n\n\t\t\tif ( index ) {\n\t\t\t\tif ( data[ index ] && data[ index ].stop ) {\n\t\t\t\t\tstopQueue( data[ index ] );\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tfor ( index in data ) {\n\t\t\t\t\tif ( data[ index ] && data[ index ].stop && rrun.test( index ) ) {\n\t\t\t\t\t\tstopQueue( data[ index ] );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfor ( index = timers.length; index--; ) {\n\t\t\t\tif ( timers[ index ].elem === this &&\n\t\t\t\t\t( type == null || timers[ index ].queue === type ) ) {\n\n\t\t\t\t\ttimers[ index ].anim.stop( gotoEnd );\n\t\t\t\t\tdequeue = false;\n\t\t\t\t\ttimers.splice( index, 1 );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Start the next in the queue if the last step wasn't forced.\n\t\t\t// Timers currently will call their complete callbacks, which\n\t\t\t// will dequeue but only if they were gotoEnd.\n\t\t\tif ( dequeue || !gotoEnd ) {\n\t\t\t\tjQuery.dequeue( this, type );\n\t\t\t}\n\t\t} );\n\t},\n\tfinish: function( type ) {\n\t\tif ( type !== false ) {\n\t\t\ttype = type || \"fx\";\n\t\t}\n\t\treturn this.each( function() {\n\t\t\tvar index,\n\t\t\t\tdata = dataPriv.get( this ),\n\t\t\t\tqueue = data[ type + \"queue\" ],\n\t\t\t\thooks = data[ type + \"queueHooks\" ],\n\t\t\t\ttimers = jQuery.timers,\n\t\t\t\tlength = queue ? queue.length : 0;\n\n\t\t\t// Enable finishing flag on private data\n\t\t\tdata.finish = true;\n\n\t\t\t// Empty the queue first\n\t\t\tjQuery.queue( this, type, [] );\n\n\t\t\tif ( hooks && hooks.stop ) {\n\t\t\t\thooks.stop.call( this, true );\n\t\t\t}\n\n\t\t\t// Look for any active animations, and finish them\n\t\t\tfor ( index = timers.length; index--; ) {\n\t\t\t\tif ( timers[ index ].elem === this && timers[ index ].queue === type ) {\n\t\t\t\t\ttimers[ index ].anim.stop( true );\n\t\t\t\t\ttimers.splice( index, 1 );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Look for any animations in the old queue and finish them\n\t\t\tfor ( index = 0; index < length; index++ ) {\n\t\t\t\tif ( queue[ index ] && queue[ index ].finish ) {\n\t\t\t\t\tqueue[ index ].finish.call( this );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Turn off finishing flag\n\t\t\tdelete data.finish;\n\t\t} );\n\t}\n} );\n\njQuery.each( [ \"toggle\", \"show\", \"hide\" ], function( i, name ) {\n\tvar cssFn = jQuery.fn[ name ];\n\tjQuery.fn[ name ] = function( speed, easing, callback ) {\n\t\treturn speed == null || typeof speed === \"boolean\" ?\n\t\t\tcssFn.apply( this, arguments ) :\n\t\t\tthis.animate( genFx( name, true ), speed, easing, callback );\n\t};\n} );\n\n// Generate shortcuts for custom animations\njQuery.each( {\n\tslideDown: genFx( \"show\" ),\n\tslideUp: genFx( \"hide\" ),\n\tslideToggle: genFx( \"toggle\" ),\n\tfadeIn: { opacity: \"show\" },\n\tfadeOut: { opacity: \"hide\" },\n\tfadeToggle: { opacity: \"toggle\" }\n}, function( name, props ) {\n\tjQuery.fn[ name ] = function( speed, easing, callback ) {\n\t\treturn this.animate( props, speed, easing, callback );\n\t};\n} );\n\njQuery.timers = [];\njQuery.fx.tick = function() {\n\tvar timer,\n\t\ti = 0,\n\t\ttimers = jQuery.timers;\n\n\tfxNow = jQuery.now();\n\n\tfor ( ; i < timers.length; i++ ) {\n\t\ttimer = timers[ i ];\n\n\t\t// Checks the timer has not already been removed\n\t\tif ( !timer() && timers[ i ] === timer ) {\n\t\t\ttimers.splice( i--, 1 );\n\t\t}\n\t}\n\n\tif ( !timers.length ) {\n\t\tjQuery.fx.stop();\n\t}\n\tfxNow = undefined;\n};\n\njQuery.fx.timer = function( timer ) {\n\tjQuery.timers.push( timer );\n\tif ( timer() ) {\n\t\tjQuery.fx.start();\n\t} else {\n\t\tjQuery.timers.pop();\n\t}\n};\n\njQuery.fx.interval = 13;\njQuery.fx.start = function() {\n\tif ( !timerId ) {\n\t\ttimerId = window.setInterval( jQuery.fx.tick, jQuery.fx.interval );\n\t}\n};\n\njQuery.fx.stop = function() {\n\twindow.clearInterval( timerId );\n\n\ttimerId = null;\n};\n\njQuery.fx.speeds = {\n\tslow: 600,\n\tfast: 200,\n\n\t// Default speed\n\t_default: 400\n};\n\n\n// Based off of the plugin by Clint Helfers, with permission.\n// http://web.archive.org/web/20100324014747/http://blindsignals.com/index.php/2009/07/jquery-delay/\njQuery.fn.delay = function( time, type ) {\n\ttime = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time;\n\ttype = type || \"fx\";\n\n\treturn this.queue( type, function( next, hooks ) {\n\t\tvar timeout = window.setTimeout( next, time );\n\t\thooks.stop = function() {\n\t\t\twindow.clearTimeout( timeout );\n\t\t};\n\t} );\n};\n\n\n( function() {\n\tvar input = document.createElement( \"input\" ),\n\t\tselect = document.createElement( \"select\" ),\n\t\topt = select.appendChild( document.createElement( \"option\" ) );\n\n\tinput.type = \"checkbox\";\n\n\t// Support: iOS<=5.1, Android<=4.2+\n\t// Default value for a checkbox should be \"on\"\n\tsupport.checkOn = input.value !== \"\";\n\n\t// Support: IE<=11+\n\t// Must access selectedIndex to make default options select\n\tsupport.optSelected = opt.selected;\n\n\t// Support: Android<=2.3\n\t// Options inside disabled selects are incorrectly marked as disabled\n\tselect.disabled = true;\n\tsupport.optDisabled = !opt.disabled;\n\n\t// Support: IE<=11+\n\t// An input loses its value after becoming a radio\n\tinput = document.createElement( \"input\" );\n\tinput.value = \"t\";\n\tinput.type = \"radio\";\n\tsupport.radioValue = input.value === \"t\";\n} )();\n\n\nvar boolHook,\n\tattrHandle = jQuery.expr.attrHandle;\n\njQuery.fn.extend( {\n\tattr: function( name, value ) {\n\t\treturn access( this, jQuery.attr, name, value, arguments.length > 1 );\n\t},\n\n\tremoveAttr: function( name ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.removeAttr( this, name );\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tattr: function( elem, name, value ) {\n\t\tvar ret, hooks,\n\t\t\tnType = elem.nodeType;\n\n\t\t// Don't get/set attributes on text, comment and attribute nodes\n\t\tif ( nType === 3 || nType === 8 || nType === 2 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Fallback to prop when attributes are not supported\n\t\tif ( typeof elem.getAttribute === \"undefined\" ) {\n\t\t\treturn jQuery.prop( elem, name, value );\n\t\t}\n\n\t\t// All attributes are lowercase\n\t\t// Grab necessary hook if one is defined\n\t\tif ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {\n\t\t\tname = name.toLowerCase();\n\t\t\thooks = jQuery.attrHooks[ name ] ||\n\t\t\t\t( jQuery.expr.match.bool.test( name ) ? boolHook : undefined );\n\t\t}\n\n\t\tif ( value !== undefined ) {\n\t\t\tif ( value === null ) {\n\t\t\t\tjQuery.removeAttr( elem, name );\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif ( hooks && \"set\" in hooks &&\n\t\t\t\t( ret = hooks.set( elem, value, name ) ) !== undefined ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\telem.setAttribute( name, value + \"\" );\n\t\t\treturn value;\n\t\t}\n\n\t\tif ( hooks && \"get\" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {\n\t\t\treturn ret;\n\t\t}\n\n\t\tret = jQuery.find.attr( elem, name );\n\n\t\t// Non-existent attributes return null, we normalize to undefined\n\t\treturn ret == null ? undefined : ret;\n\t},\n\n\tattrHooks: {\n\t\ttype: {\n\t\t\tset: function( elem, value ) {\n\t\t\t\tif ( !support.radioValue && value === \"radio\" &&\n\t\t\t\t\tjQuery.nodeName( elem, \"input\" ) ) {\n\t\t\t\t\tvar val = elem.value;\n\t\t\t\t\telem.setAttribute( \"type\", value );\n\t\t\t\t\tif ( val ) {\n\t\t\t\t\t\telem.value = val;\n\t\t\t\t\t}\n\t\t\t\t\treturn value;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\tremoveAttr: function( elem, value ) {\n\t\tvar name, propName,\n\t\t\ti = 0,\n\t\t\tattrNames = value && value.match( rnotwhite );\n\n\t\tif ( attrNames && elem.nodeType === 1 ) {\n\t\t\twhile ( ( name = attrNames[ i++ ] ) ) {\n\t\t\t\tpropName = jQuery.propFix[ name ] || name;\n\n\t\t\t\t// Boolean attributes get special treatment (#10870)\n\t\t\t\tif ( jQuery.expr.match.bool.test( name ) ) {\n\n\t\t\t\t\t// Set corresponding property to false\n\t\t\t\t\telem[ propName ] = false;\n\t\t\t\t}\n\n\t\t\t\telem.removeAttribute( name );\n\t\t\t}\n\t\t}\n\t}\n} );\n\n// Hooks for boolean attributes\nboolHook = {\n\tset: function( elem, value, name ) {\n\t\tif ( value === false ) {\n\n\t\t\t// Remove boolean attributes when set to false\n\t\t\tjQuery.removeAttr( elem, name );\n\t\t} else {\n\t\t\telem.setAttribute( name, name );\n\t\t}\n\t\treturn name;\n\t}\n};\njQuery.each( jQuery.expr.match.bool.source.match( /\\w+/g ), function( i, name ) {\n\tvar getter = attrHandle[ name ] || jQuery.find.attr;\n\n\tattrHandle[ name ] = function( elem, name, isXML ) {\n\t\tvar ret, handle;\n\t\tif ( !isXML ) {\n\n\t\t\t// Avoid an infinite loop by temporarily removing this function from the getter\n\t\t\thandle = attrHandle[ name ];\n\t\t\tattrHandle[ name ] = ret;\n\t\t\tret = getter( elem, name, isXML ) != null ?\n\t\t\t\tname.toLowerCase() :\n\t\t\t\tnull;\n\t\t\tattrHandle[ name ] = handle;\n\t\t}\n\t\treturn ret;\n\t};\n} );\n\n\n\n\nvar rfocusable = /^(?:input|select|textarea|button)$/i,\n\trclickable = /^(?:a|area)$/i;\n\njQuery.fn.extend( {\n\tprop: function( name, value ) {\n\t\treturn access( this, jQuery.prop, name, value, arguments.length > 1 );\n\t},\n\n\tremoveProp: function( name ) {\n\t\treturn this.each( function() {\n\t\t\tdelete this[ jQuery.propFix[ name ] || name ];\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tprop: function( elem, name, value ) {\n\t\tvar ret, hooks,\n\t\t\tnType = elem.nodeType;\n\n\t\t// Don't get/set properties on text, comment and attribute nodes\n\t\tif ( nType === 3 || nType === 8 || nType === 2 ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {\n\n\t\t\t// Fix name and attach hooks\n\t\t\tname = jQuery.propFix[ name ] || name;\n\t\t\thooks = jQuery.propHooks[ name ];\n\t\t}\n\n\t\tif ( value !== undefined ) {\n\t\t\tif ( hooks && \"set\" in hooks &&\n\t\t\t\t( ret = hooks.set( elem, value, name ) ) !== undefined ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\treturn ( elem[ name ] = value );\n\t\t}\n\n\t\tif ( hooks && \"get\" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {\n\t\t\treturn ret;\n\t\t}\n\n\t\treturn elem[ name ];\n\t},\n\n\tpropHooks: {\n\t\ttabIndex: {\n\t\t\tget: function( elem ) {\n\n\t\t\t\t// elem.tabIndex doesn't always return the\n\t\t\t\t// correct value when it hasn't been explicitly set\n\t\t\t\t// http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/\n\t\t\t\t// Use proper attribute retrieval(#12072)\n\t\t\t\tvar tabindex = jQuery.find.attr( elem, \"tabindex\" );\n\n\t\t\t\treturn tabindex ?\n\t\t\t\t\tparseInt( tabindex, 10 ) :\n\t\t\t\t\trfocusable.test( elem.nodeName ) ||\n\t\t\t\t\t\trclickable.test( elem.nodeName ) && elem.href ?\n\t\t\t\t\t\t\t0 :\n\t\t\t\t\t\t\t-1;\n\t\t\t}\n\t\t}\n\t},\n\n\tpropFix: {\n\t\t\"for\": \"htmlFor\",\n\t\t\"class\": \"className\"\n\t}\n} );\n\n// Support: IE <=11 only\n// Accessing the selectedIndex property\n// forces the browser to respect setting selected\n// on the option\n// The getter ensures a default option is selected\n// when in an optgroup\nif ( !support.optSelected ) {\n\tjQuery.propHooks.selected = {\n\t\tget: function( elem ) {\n\t\t\tvar parent = elem.parentNode;\n\t\t\tif ( parent && parent.parentNode ) {\n\t\t\t\tparent.parentNode.selectedIndex;\n\t\t\t}\n\t\t\treturn null;\n\t\t},\n\t\tset: function( elem ) {\n\t\t\tvar parent = elem.parentNode;\n\t\t\tif ( parent ) {\n\t\t\t\tparent.selectedIndex;\n\n\t\t\t\tif ( parent.parentNode ) {\n\t\t\t\t\tparent.parentNode.selectedIndex;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n}\n\njQuery.each( [\n\t\"tabIndex\",\n\t\"readOnly\",\n\t\"maxLength\",\n\t\"cellSpacing\",\n\t\"cellPadding\",\n\t\"rowSpan\",\n\t\"colSpan\",\n\t\"useMap\",\n\t\"frameBorder\",\n\t\"contentEditable\"\n], function() {\n\tjQuery.propFix[ this.toLowerCase() ] = this;\n} );\n\n\n\n\nvar rclass = /[\\t\\r\\n\\f]/g;\n\nfunction getClass( elem ) {\n\treturn elem.getAttribute && elem.getAttribute( \"class\" ) || \"\";\n}\n\njQuery.fn.extend( {\n\taddClass: function( value ) {\n\t\tvar classes, elem, cur, curValue, clazz, j, finalValue,\n\t\t\ti = 0;\n\n\t\tif ( jQuery.isFunction( value ) ) {\n\t\t\treturn this.each( function( j ) {\n\t\t\t\tjQuery( this ).addClass( value.call( this, j, getClass( this ) ) );\n\t\t\t} );\n\t\t}\n\n\t\tif ( typeof value === \"string\" && value ) {\n\t\t\tclasses = value.match( rnotwhite ) || [];\n\n\t\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\t\tcurValue = getClass( elem );\n\t\t\t\tcur = elem.nodeType === 1 &&\n\t\t\t\t\t( \" \" + curValue + \" \" ).replace( rclass, \" \" );\n\n\t\t\t\tif ( cur ) {\n\t\t\t\t\tj = 0;\n\t\t\t\t\twhile ( ( clazz = classes[ j++ ] ) ) {\n\t\t\t\t\t\tif ( cur.indexOf( \" \" + clazz + \" \" ) < 0 ) {\n\t\t\t\t\t\t\tcur += clazz + \" \";\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Only assign if different to avoid unneeded rendering.\n\t\t\t\t\tfinalValue = jQuery.trim( cur );\n\t\t\t\t\tif ( curValue !== finalValue ) {\n\t\t\t\t\t\telem.setAttribute( \"class\", finalValue );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\tremoveClass: function( value ) {\n\t\tvar classes, elem, cur, curValue, clazz, j, finalValue,\n\t\t\ti = 0;\n\n\t\tif ( jQuery.isFunction( value ) ) {\n\t\t\treturn this.each( function( j ) {\n\t\t\t\tjQuery( this ).removeClass( value.call( this, j, getClass( this ) ) );\n\t\t\t} );\n\t\t}\n\n\t\tif ( !arguments.length ) {\n\t\t\treturn this.attr( \"class\", \"\" );\n\t\t}\n\n\t\tif ( typeof value === \"string\" && value ) {\n\t\t\tclasses = value.match( rnotwhite ) || [];\n\n\t\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\t\tcurValue = getClass( elem );\n\n\t\t\t\t// This expression is here for better compressibility (see addClass)\n\t\t\t\tcur = elem.nodeType === 1 &&\n\t\t\t\t\t( \" \" + curValue + \" \" ).replace( rclass, \" \" );\n\n\t\t\t\tif ( cur ) {\n\t\t\t\t\tj = 0;\n\t\t\t\t\twhile ( ( clazz = classes[ j++ ] ) ) {\n\n\t\t\t\t\t\t// Remove *all* instances\n\t\t\t\t\t\twhile ( cur.indexOf( \" \" + clazz + \" \" ) > -1 ) {\n\t\t\t\t\t\t\tcur = cur.replace( \" \" + clazz + \" \", \" \" );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Only assign if different to avoid unneeded rendering.\n\t\t\t\t\tfinalValue = jQuery.trim( cur );\n\t\t\t\t\tif ( curValue !== finalValue ) {\n\t\t\t\t\t\telem.setAttribute( \"class\", finalValue );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\ttoggleClass: function( value, stateVal ) {\n\t\tvar type = typeof value;\n\n\t\tif ( typeof stateVal === \"boolean\" && type === \"string\" ) {\n\t\t\treturn stateVal ? this.addClass( value ) : this.removeClass( value );\n\t\t}\n\n\t\tif ( jQuery.isFunction( value ) ) {\n\t\t\treturn this.each( function( i ) {\n\t\t\t\tjQuery( this ).toggleClass(\n\t\t\t\t\tvalue.call( this, i, getClass( this ), stateVal ),\n\t\t\t\t\tstateVal\n\t\t\t\t);\n\t\t\t} );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar className, i, self, classNames;\n\n\t\t\tif ( type === \"string\" ) {\n\n\t\t\t\t// Toggle individual class names\n\t\t\t\ti = 0;\n\t\t\t\tself = jQuery( this );\n\t\t\t\tclassNames = value.match( rnotwhite ) || [];\n\n\t\t\t\twhile ( ( className = classNames[ i++ ] ) ) {\n\n\t\t\t\t\t// Check each className given, space separated list\n\t\t\t\t\tif ( self.hasClass( className ) ) {\n\t\t\t\t\t\tself.removeClass( className );\n\t\t\t\t\t} else {\n\t\t\t\t\t\tself.addClass( className );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t// Toggle whole class name\n\t\t\t} else if ( value === undefined || type === \"boolean\" ) {\n\t\t\t\tclassName = getClass( this );\n\t\t\t\tif ( className ) {\n\n\t\t\t\t\t// Store className if set\n\t\t\t\t\tdataPriv.set( this, \"__className__\", className );\n\t\t\t\t}\n\n\t\t\t\t// If the element has a class name or if we're passed `false`,\n\t\t\t\t// then remove the whole classname (if there was one, the above saved it).\n\t\t\t\t// Otherwise bring back whatever was previously saved (if anything),\n\t\t\t\t// falling back to the empty string if nothing was stored.\n\t\t\t\tif ( this.setAttribute ) {\n\t\t\t\t\tthis.setAttribute( \"class\",\n\t\t\t\t\t\tclassName || value === false ?\n\t\t\t\t\t\t\"\" :\n\t\t\t\t\t\tdataPriv.get( this, \"__className__\" ) || \"\"\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t},\n\n\thasClass: function( selector ) {\n\t\tvar className, elem,\n\t\t\ti = 0;\n\n\t\tclassName = \" \" + selector + \" \";\n\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\tif ( elem.nodeType === 1 &&\n\t\t\t\t( \" \" + getClass( elem ) + \" \" ).replace( rclass, \" \" )\n\t\t\t\t\t.indexOf( className ) > -1\n\t\t\t) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n} );\n\n\n\n\nvar rreturn = /\\r/g,\n\trspaces = /[\\x20\\t\\r\\n\\f]+/g;\n\njQuery.fn.extend( {\n\tval: function( value ) {\n\t\tvar hooks, ret, isFunction,\n\t\t\telem = this[ 0 ];\n\n\t\tif ( !arguments.length ) {\n\t\t\tif ( elem ) {\n\t\t\t\thooks = jQuery.valHooks[ elem.type ] ||\n\t\t\t\t\tjQuery.valHooks[ elem.nodeName.toLowerCase() ];\n\n\t\t\t\tif ( hooks &&\n\t\t\t\t\t\"get\" in hooks &&\n\t\t\t\t\t( ret = hooks.get( elem, \"value\" ) ) !== undefined\n\t\t\t\t) {\n\t\t\t\t\treturn ret;\n\t\t\t\t}\n\n\t\t\t\tret = elem.value;\n\n\t\t\t\treturn typeof ret === \"string\" ?\n\n\t\t\t\t\t// Handle most common string cases\n\t\t\t\t\tret.replace( rreturn, \"\" ) :\n\n\t\t\t\t\t// Handle cases where value is null/undef or number\n\t\t\t\t\tret == null ? \"\" : ret;\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tisFunction = jQuery.isFunction( value );\n\n\t\treturn this.each( function( i ) {\n\t\t\tvar val;\n\n\t\t\tif ( this.nodeType !== 1 ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif ( isFunction ) {\n\t\t\t\tval = value.call( this, i, jQuery( this ).val() );\n\t\t\t} else {\n\t\t\t\tval = value;\n\t\t\t}\n\n\t\t\t// Treat null/undefined as \"\"; convert numbers to string\n\t\t\tif ( val == null ) {\n\t\t\t\tval = \"\";\n\n\t\t\t} else if ( typeof val === \"number\" ) {\n\t\t\t\tval += \"\";\n\n\t\t\t} else if ( jQuery.isArray( val ) ) {\n\t\t\t\tval = jQuery.map( val, function( value ) {\n\t\t\t\t\treturn value == null ? \"\" : value + \"\";\n\t\t\t\t} );\n\t\t\t}\n\n\t\t\thooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ];\n\n\t\t\t// If set returns undefined, fall back to normal setting\n\t\t\tif ( !hooks || !( \"set\" in hooks ) || hooks.set( this, val, \"value\" ) === undefined ) {\n\t\t\t\tthis.value = val;\n\t\t\t}\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tvalHooks: {\n\t\toption: {\n\t\t\tget: function( elem ) {\n\n\t\t\t\tvar val = jQuery.find.attr( elem, \"value\" );\n\t\t\t\treturn val != null ?\n\t\t\t\t\tval :\n\n\t\t\t\t\t// Support: IE10-11+\n\t\t\t\t\t// option.text throws exceptions (#14686, #14858)\n\t\t\t\t\t// Strip and collapse whitespace\n\t\t\t\t\t// https://html.spec.whatwg.org/#strip-and-collapse-whitespace\n\t\t\t\t\tjQuery.trim( jQuery.text( elem ) ).replace( rspaces, \" \" );\n\t\t\t}\n\t\t},\n\t\tselect: {\n\t\t\tget: function( elem ) {\n\t\t\t\tvar value, option,\n\t\t\t\t\toptions = elem.options,\n\t\t\t\t\tindex = elem.selectedIndex,\n\t\t\t\t\tone = elem.type === \"select-one\" || index < 0,\n\t\t\t\t\tvalues = one ? null : [],\n\t\t\t\t\tmax = one ? index + 1 : options.length,\n\t\t\t\t\ti = index < 0 ?\n\t\t\t\t\t\tmax :\n\t\t\t\t\t\tone ? index : 0;\n\n\t\t\t\t// Loop through all the selected options\n\t\t\t\tfor ( ; i < max; i++ ) {\n\t\t\t\t\toption = options[ i ];\n\n\t\t\t\t\t// IE8-9 doesn't update selected after form reset (#2551)\n\t\t\t\t\tif ( ( option.selected || i === index ) &&\n\n\t\t\t\t\t\t\t// Don't return options that are disabled or in a disabled optgroup\n\t\t\t\t\t\t\t( support.optDisabled ?\n\t\t\t\t\t\t\t\t!option.disabled : option.getAttribute( \"disabled\" ) === null ) &&\n\t\t\t\t\t\t\t( !option.parentNode.disabled ||\n\t\t\t\t\t\t\t\t!jQuery.nodeName( option.parentNode, \"optgroup\" ) ) ) {\n\n\t\t\t\t\t\t// Get the specific value for the option\n\t\t\t\t\t\tvalue = jQuery( option ).val();\n\n\t\t\t\t\t\t// We don't need an array for one selects\n\t\t\t\t\t\tif ( one ) {\n\t\t\t\t\t\t\treturn value;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Multi-Selects return an array\n\t\t\t\t\t\tvalues.push( value );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn values;\n\t\t\t},\n\n\t\t\tset: function( elem, value ) {\n\t\t\t\tvar optionSet, option,\n\t\t\t\t\toptions = elem.options,\n\t\t\t\t\tvalues = jQuery.makeArray( value ),\n\t\t\t\t\ti = options.length;\n\n\t\t\t\twhile ( i-- ) {\n\t\t\t\t\toption = options[ i ];\n\t\t\t\t\tif ( option.selected =\n\t\t\t\t\t\tjQuery.inArray( jQuery.valHooks.option.get( option ), values ) > -1\n\t\t\t\t\t) {\n\t\t\t\t\t\toptionSet = true;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Force browsers to behave consistently when non-matching value is set\n\t\t\t\tif ( !optionSet ) {\n\t\t\t\t\telem.selectedIndex = -1;\n\t\t\t\t}\n\t\t\t\treturn values;\n\t\t\t}\n\t\t}\n\t}\n} );\n\n// Radios and checkboxes getter/setter\njQuery.each( [ \"radio\", \"checkbox\" ], function() {\n\tjQuery.valHooks[ this ] = {\n\t\tset: function( elem, value ) {\n\t\t\tif ( jQuery.isArray( value ) ) {\n\t\t\t\treturn ( elem.checked = jQuery.inArray( jQuery( elem ).val(), value ) > -1 );\n\t\t\t}\n\t\t}\n\t};\n\tif ( !support.checkOn ) {\n\t\tjQuery.valHooks[ this ].get = function( elem ) {\n\t\t\treturn elem.getAttribute( \"value\" ) === null ? \"on\" : elem.value;\n\t\t};\n\t}\n} );\n\n\n\n\n// Return jQuery for attributes-only inclusion\n\n\nvar rfocusMorph = /^(?:focusinfocus|focusoutblur)$/;\n\njQuery.extend( jQuery.event, {\n\n\ttrigger: function( event, data, elem, onlyHandlers ) {\n\n\t\tvar i, cur, tmp, bubbleType, ontype, handle, special,\n\t\t\teventPath = [ elem || document ],\n\t\t\ttype = hasOwn.call( event, \"type\" ) ? event.type : event,\n\t\t\tnamespaces = hasOwn.call( event, \"namespace\" ) ? event.namespace.split( \".\" ) : [];\n\n\t\tcur = tmp = elem = elem || document;\n\n\t\t// Don't do events on text and comment nodes\n\t\tif ( elem.nodeType === 3 || elem.nodeType === 8 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// focus/blur morphs to focusin/out; ensure we're not firing them right now\n\t\tif ( rfocusMorph.test( type + jQuery.event.triggered ) ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( type.indexOf( \".\" ) > -1 ) {\n\n\t\t\t// Namespaced trigger; create a regexp to match event type in handle()\n\t\t\tnamespaces = type.split( \".\" );\n\t\t\ttype = namespaces.shift();\n\t\t\tnamespaces.sort();\n\t\t}\n\t\tontype = type.indexOf( \":\" ) < 0 && \"on\" + type;\n\n\t\t// Caller can pass in a jQuery.Event object, Object, or just an event type string\n\t\tevent = event[ jQuery.expando ] ?\n\t\t\tevent :\n\t\t\tnew jQuery.Event( type, typeof event === \"object\" && event );\n\n\t\t// Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true)\n\t\tevent.isTrigger = onlyHandlers ? 2 : 3;\n\t\tevent.namespace = namespaces.join( \".\" );\n\t\tevent.rnamespace = event.namespace ?\n\t\t\tnew RegExp( \"(^|\\\\.)\" + namespaces.join( \"\\\\.(?:.*\\\\.|)\" ) + \"(\\\\.|$)\" ) :\n\t\t\tnull;\n\n\t\t// Clean up the event in case it is being reused\n\t\tevent.result = undefined;\n\t\tif ( !event.target ) {\n\t\t\tevent.target = elem;\n\t\t}\n\n\t\t// Clone any incoming data and prepend the event, creating the handler arg list\n\t\tdata = data == null ?\n\t\t\t[ event ] :\n\t\t\tjQuery.makeArray( data, [ event ] );\n\n\t\t// Allow special events to draw outside the lines\n\t\tspecial = jQuery.event.special[ type ] || {};\n\t\tif ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Determine event propagation path in advance, per W3C events spec (#9951)\n\t\t// Bubble up to document, then to window; watch for a global ownerDocument var (#9724)\n\t\tif ( !onlyHandlers && !special.noBubble && !jQuery.isWindow( elem ) ) {\n\n\t\t\tbubbleType = special.delegateType || type;\n\t\t\tif ( !rfocusMorph.test( bubbleType + type ) ) {\n\t\t\t\tcur = cur.parentNode;\n\t\t\t}\n\t\t\tfor ( ; cur; cur = cur.parentNode ) {\n\t\t\t\teventPath.push( cur );\n\t\t\t\ttmp = cur;\n\t\t\t}\n\n\t\t\t// Only add window if we got to document (e.g., not plain obj or detached DOM)\n\t\t\tif ( tmp === ( elem.ownerDocument || document ) ) {\n\t\t\t\teventPath.push( tmp.defaultView || tmp.parentWindow || window );\n\t\t\t}\n\t\t}\n\n\t\t// Fire handlers on the event path\n\t\ti = 0;\n\t\twhile ( ( cur = eventPath[ i++ ] ) && !event.isPropagationStopped() ) {\n\n\t\t\tevent.type = i > 1 ?\n\t\t\t\tbubbleType :\n\t\t\t\tspecial.bindType || type;\n\n\t\t\t// jQuery handler\n\t\t\thandle = ( dataPriv.get( cur, \"events\" ) || {} )[ event.type ] &&\n\t\t\t\tdataPriv.get( cur, \"handle\" );\n\t\t\tif ( handle ) {\n\t\t\t\thandle.apply( cur, data );\n\t\t\t}\n\n\t\t\t// Native handler\n\t\t\thandle = ontype && cur[ ontype ];\n\t\t\tif ( handle && handle.apply && acceptData( cur ) ) {\n\t\t\t\tevent.result = handle.apply( cur, data );\n\t\t\t\tif ( event.result === false ) {\n\t\t\t\t\tevent.preventDefault();\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tevent.type = type;\n\n\t\t// If nobody prevented the default action, do it now\n\t\tif ( !onlyHandlers && !event.isDefaultPrevented() ) {\n\n\t\t\tif ( ( !special._default ||\n\t\t\t\tspecial._default.apply( eventPath.pop(), data ) === false ) &&\n\t\t\t\tacceptData( elem ) ) {\n\n\t\t\t\t// Call a native DOM method on the target with the same name name as the event.\n\t\t\t\t// Don't do default actions on window, that's where global variables be (#6170)\n\t\t\t\tif ( ontype && jQuery.isFunction( elem[ type ] ) && !jQuery.isWindow( elem ) ) {\n\n\t\t\t\t\t// Don't re-trigger an onFOO event when we call its FOO() method\n\t\t\t\t\ttmp = elem[ ontype ];\n\n\t\t\t\t\tif ( tmp ) {\n\t\t\t\t\t\telem[ ontype ] = null;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Prevent re-triggering of the same event, since we already bubbled it above\n\t\t\t\t\tjQuery.event.triggered = type;\n\t\t\t\t\telem[ type ]();\n\t\t\t\t\tjQuery.event.triggered = undefined;\n\n\t\t\t\t\tif ( tmp ) {\n\t\t\t\t\t\telem[ ontype ] = tmp;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn event.result;\n\t},\n\n\t// Piggyback on a donor event to simulate a different one\n\t// Used only for `focus(in | out)` events\n\tsimulate: function( type, elem, event ) {\n\t\tvar e = jQuery.extend(\n\t\t\tnew jQuery.Event(),\n\t\t\tevent,\n\t\t\t{\n\t\t\t\ttype: type,\n\t\t\t\tisSimulated: true\n\t\t\t}\n\t\t);\n\n\t\tjQuery.event.trigger( e, null, elem );\n\t}\n\n} );\n\njQuery.fn.extend( {\n\n\ttrigger: function( type, data ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.event.trigger( type, data, this );\n\t\t} );\n\t},\n\ttriggerHandler: function( type, data ) {\n\t\tvar elem = this[ 0 ];\n\t\tif ( elem ) {\n\t\t\treturn jQuery.event.trigger( type, data, elem, true );\n\t\t}\n\t}\n} );\n\n\njQuery.each( ( \"blur focus focusin focusout load resize scroll unload click dblclick \" +\n\t\"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave \" +\n\t\"change select submit keydown keypress keyup error contextmenu\" ).split( \" \" ),\n\tfunction( i, name ) {\n\n\t// Handle event binding\n\tjQuery.fn[ name ] = function( data, fn ) {\n\t\treturn arguments.length > 0 ?\n\t\t\tthis.on( name, null, data, fn ) :\n\t\t\tthis.trigger( name );\n\t};\n} );\n\njQuery.fn.extend( {\n\thover: function( fnOver, fnOut ) {\n\t\treturn this.mouseenter( fnOver ).mouseleave( fnOut || fnOver );\n\t}\n} );\n\n\n\n\nsupport.focusin = \"onfocusin\" in window;\n\n\n// Support: Firefox\n// Firefox doesn't have focus(in | out) events\n// Related ticket - https://bugzilla.mozilla.org/show_bug.cgi?id=687787\n//\n// Support: Chrome, Safari\n// focus(in | out) events fire after focus & blur events,\n// which is spec violation - http://www.w3.org/TR/DOM-Level-3-Events/#events-focusevent-event-order\n// Related ticket - https://code.google.com/p/chromium/issues/detail?id=449857\nif ( !support.focusin ) {\n\tjQuery.each( { focus: \"focusin\", blur: \"focusout\" }, function( orig, fix ) {\n\n\t\t// Attach a single capturing handler on the document while someone wants focusin/focusout\n\t\tvar handler = function( event ) {\n\t\t\tjQuery.event.simulate( fix, event.target, jQuery.event.fix( event ) );\n\t\t};\n\n\t\tjQuery.event.special[ fix ] = {\n\t\t\tsetup: function() {\n\t\t\t\tvar doc = this.ownerDocument || this,\n\t\t\t\t\tattaches = dataPriv.access( doc, fix );\n\n\t\t\t\tif ( !attaches ) {\n\t\t\t\t\tdoc.addEventListener( orig, handler, true );\n\t\t\t\t}\n\t\t\t\tdataPriv.access( doc, fix, ( attaches || 0 ) + 1 );\n\t\t\t},\n\t\t\tteardown: function() {\n\t\t\t\tvar doc = this.ownerDocument || this,\n\t\t\t\t\tattaches = dataPriv.access( doc, fix ) - 1;\n\n\t\t\t\tif ( !attaches ) {\n\t\t\t\t\tdoc.removeEventListener( orig, handler, true );\n\t\t\t\t\tdataPriv.remove( doc, fix );\n\n\t\t\t\t} else {\n\t\t\t\t\tdataPriv.access( doc, fix, attaches );\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t} );\n}\nvar location = window.location;\n\nvar nonce = jQuery.now();\n\nvar rquery = ( /\\?/ );\n\n\n\n// Support: Android 2.3\n// Workaround failure to string-cast null input\njQuery.parseJSON = function( data ) {\n\treturn JSON.parse( data + \"\" );\n};\n\n\n// Cross-browser xml parsing\njQuery.parseXML = function( data ) {\n\tvar xml;\n\tif ( !data || typeof data !== \"string\" ) {\n\t\treturn null;\n\t}\n\n\t// Support: IE9\n\ttry {\n\t\txml = ( new window.DOMParser() ).parseFromString( data, \"text/xml\" );\n\t} catch ( e ) {\n\t\txml = undefined;\n\t}\n\n\tif ( !xml || xml.getElementsByTagName( \"parsererror\" ).length ) {\n\t\tjQuery.error( \"Invalid XML: \" + data );\n\t}\n\treturn xml;\n};\n\n\nvar\n\trhash = /#.*$/,\n\trts = /([?&])_=[^&]*/,\n\trheaders = /^(.*?):[ \\t]*([^\\r\\n]*)$/mg,\n\n\t// #7653, #8125, #8152: local protocol detection\n\trlocalProtocol = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/,\n\trnoContent = /^(?:GET|HEAD)$/,\n\trprotocol = /^\\/\\//,\n\n\t/* Prefilters\n\t * 1) They are useful to introduce custom dataTypes (see ajax/jsonp.js for an example)\n\t * 2) These are called:\n\t * - BEFORE asking for a transport\n\t * - AFTER param serialization (s.data is a string if s.processData is true)\n\t * 3) key is the dataType\n\t * 4) the catchall symbol \"*\" can be used\n\t * 5) execution will start with transport dataType and THEN continue down to \"*\" if needed\n\t */\n\tprefilters = {},\n\n\t/* Transports bindings\n\t * 1) key is the dataType\n\t * 2) the catchall symbol \"*\" can be used\n\t * 3) selection will start with transport dataType and THEN go to \"*\" if needed\n\t */\n\ttransports = {},\n\n\t// Avoid comment-prolog char sequence (#10098); must appease lint and evade compression\n\tallTypes = \"*/\".concat( \"*\" ),\n\n\t// Anchor tag for parsing the document origin\n\toriginAnchor = document.createElement( \"a\" );\n\toriginAnchor.href = location.href;\n\n// Base \"constructor\" for jQuery.ajaxPrefilter and jQuery.ajaxTransport\nfunction addToPrefiltersOrTransports( structure ) {\n\n\t// dataTypeExpression is optional and defaults to \"*\"\n\treturn function( dataTypeExpression, func ) {\n\n\t\tif ( typeof dataTypeExpression !== \"string\" ) {\n\t\t\tfunc = dataTypeExpression;\n\t\t\tdataTypeExpression = \"*\";\n\t\t}\n\n\t\tvar dataType,\n\t\t\ti = 0,\n\t\t\tdataTypes = dataTypeExpression.toLowerCase().match( rnotwhite ) || [];\n\n\t\tif ( jQuery.isFunction( func ) ) {\n\n\t\t\t// For each dataType in the dataTypeExpression\n\t\t\twhile ( ( dataType = dataTypes[ i++ ] ) ) {\n\n\t\t\t\t// Prepend if requested\n\t\t\t\tif ( dataType[ 0 ] === \"+\" ) {\n\t\t\t\t\tdataType = dataType.slice( 1 ) || \"*\";\n\t\t\t\t\t( structure[ dataType ] = structure[ dataType ] || [] ).unshift( func );\n\n\t\t\t\t// Otherwise append\n\t\t\t\t} else {\n\t\t\t\t\t( structure[ dataType ] = structure[ dataType ] || [] ).push( func );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n}\n\n// Base inspection function for prefilters and transports\nfunction inspectPrefiltersOrTransports( structure, options, originalOptions, jqXHR ) {\n\n\tvar inspected = {},\n\t\tseekingTransport = ( structure === transports );\n\n\tfunction inspect( dataType ) {\n\t\tvar selected;\n\t\tinspected[ dataType ] = true;\n\t\tjQuery.each( structure[ dataType ] || [], function( _, prefilterOrFactory ) {\n\t\t\tvar dataTypeOrTransport = prefilterOrFactory( options, originalOptions, jqXHR );\n\t\t\tif ( typeof dataTypeOrTransport === \"string\" &&\n\t\t\t\t!seekingTransport && !inspected[ dataTypeOrTransport ] ) {\n\n\t\t\t\toptions.dataTypes.unshift( dataTypeOrTransport );\n\t\t\t\tinspect( dataTypeOrTransport );\n\t\t\t\treturn false;\n\t\t\t} else if ( seekingTransport ) {\n\t\t\t\treturn !( selected = dataTypeOrTransport );\n\t\t\t}\n\t\t} );\n\t\treturn selected;\n\t}\n\n\treturn inspect( options.dataTypes[ 0 ] ) || !inspected[ \"*\" ] && inspect( \"*\" );\n}\n\n// A special extend for ajax options\n// that takes \"flat\" options (not to be deep extended)\n// Fixes #9887\nfunction ajaxExtend( target, src ) {\n\tvar key, deep,\n\t\tflatOptions = jQuery.ajaxSettings.flatOptions || {};\n\n\tfor ( key in src ) {\n\t\tif ( src[ key ] !== undefined ) {\n\t\t\t( flatOptions[ key ] ? target : ( deep || ( deep = {} ) ) )[ key ] = src[ key ];\n\t\t}\n\t}\n\tif ( deep ) {\n\t\tjQuery.extend( true, target, deep );\n\t}\n\n\treturn target;\n}\n\n/* Handles responses to an ajax request:\n * - finds the right dataType (mediates between content-type and expected dataType)\n * - returns the corresponding response\n */\nfunction ajaxHandleResponses( s, jqXHR, responses ) {\n\n\tvar ct, type, finalDataType, firstDataType,\n\t\tcontents = s.contents,\n\t\tdataTypes = s.dataTypes;\n\n\t// Remove auto dataType and get content-type in the process\n\twhile ( dataTypes[ 0 ] === \"*\" ) {\n\t\tdataTypes.shift();\n\t\tif ( ct === undefined ) {\n\t\t\tct = s.mimeType || jqXHR.getResponseHeader( \"Content-Type\" );\n\t\t}\n\t}\n\n\t// Check if we're dealing with a known content-type\n\tif ( ct ) {\n\t\tfor ( type in contents ) {\n\t\t\tif ( contents[ type ] && contents[ type ].test( ct ) ) {\n\t\t\t\tdataTypes.unshift( type );\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\t// Check to see if we have a response for the expected dataType\n\tif ( dataTypes[ 0 ] in responses ) {\n\t\tfinalDataType = dataTypes[ 0 ];\n\t} else {\n\n\t\t// Try convertible dataTypes\n\t\tfor ( type in responses ) {\n\t\t\tif ( !dataTypes[ 0 ] || s.converters[ type + \" \" + dataTypes[ 0 ] ] ) {\n\t\t\t\tfinalDataType = type;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif ( !firstDataType ) {\n\t\t\t\tfirstDataType = type;\n\t\t\t}\n\t\t}\n\n\t\t// Or just use first one\n\t\tfinalDataType = finalDataType || firstDataType;\n\t}\n\n\t// If we found a dataType\n\t// We add the dataType to the list if needed\n\t// and return the corresponding response\n\tif ( finalDataType ) {\n\t\tif ( finalDataType !== dataTypes[ 0 ] ) {\n\t\t\tdataTypes.unshift( finalDataType );\n\t\t}\n\t\treturn responses[ finalDataType ];\n\t}\n}\n\n/* Chain conversions given the request and the original response\n * Also sets the responseXXX fields on the jqXHR instance\n */\nfunction ajaxConvert( s, response, jqXHR, isSuccess ) {\n\tvar conv2, current, conv, tmp, prev,\n\t\tconverters = {},\n\n\t\t// Work with a copy of dataTypes in case we need to modify it for conversion\n\t\tdataTypes = s.dataTypes.slice();\n\n\t// Create converters map with lowercased keys\n\tif ( dataTypes[ 1 ] ) {\n\t\tfor ( conv in s.converters ) {\n\t\t\tconverters[ conv.toLowerCase() ] = s.converters[ conv ];\n\t\t}\n\t}\n\n\tcurrent = dataTypes.shift();\n\n\t// Convert to each sequential dataType\n\twhile ( current ) {\n\n\t\tif ( s.responseFields[ current ] ) {\n\t\t\tjqXHR[ s.responseFields[ current ] ] = response;\n\t\t}\n\n\t\t// Apply the dataFilter if provided\n\t\tif ( !prev && isSuccess && s.dataFilter ) {\n\t\t\tresponse = s.dataFilter( response, s.dataType );\n\t\t}\n\n\t\tprev = current;\n\t\tcurrent = dataTypes.shift();\n\n\t\tif ( current ) {\n\n\t\t// There's only work to do if current dataType is non-auto\n\t\t\tif ( current === \"*\" ) {\n\n\t\t\t\tcurrent = prev;\n\n\t\t\t// Convert response if prev dataType is non-auto and differs from current\n\t\t\t} else if ( prev !== \"*\" && prev !== current ) {\n\n\t\t\t\t// Seek a direct converter\n\t\t\t\tconv = converters[ prev + \" \" + current ] || converters[ \"* \" + current ];\n\n\t\t\t\t// If none found, seek a pair\n\t\t\t\tif ( !conv ) {\n\t\t\t\t\tfor ( conv2 in converters ) {\n\n\t\t\t\t\t\t// If conv2 outputs current\n\t\t\t\t\t\ttmp = conv2.split( \" \" );\n\t\t\t\t\t\tif ( tmp[ 1 ] === current ) {\n\n\t\t\t\t\t\t\t// If prev can be converted to accepted input\n\t\t\t\t\t\t\tconv = converters[ prev + \" \" + tmp[ 0 ] ] ||\n\t\t\t\t\t\t\t\tconverters[ \"* \" + tmp[ 0 ] ];\n\t\t\t\t\t\t\tif ( conv ) {\n\n\t\t\t\t\t\t\t\t// Condense equivalence converters\n\t\t\t\t\t\t\t\tif ( conv === true ) {\n\t\t\t\t\t\t\t\t\tconv = converters[ conv2 ];\n\n\t\t\t\t\t\t\t\t// Otherwise, insert the intermediate dataType\n\t\t\t\t\t\t\t\t} else if ( converters[ conv2 ] !== true ) {\n\t\t\t\t\t\t\t\t\tcurrent = tmp[ 0 ];\n\t\t\t\t\t\t\t\t\tdataTypes.unshift( tmp[ 1 ] );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Apply converter (if not an equivalence)\n\t\t\t\tif ( conv !== true ) {\n\n\t\t\t\t\t// Unless errors are allowed to bubble, catch and return them\n\t\t\t\t\tif ( conv && s.throws ) {\n\t\t\t\t\t\tresponse = conv( response );\n\t\t\t\t\t} else {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tresponse = conv( response );\n\t\t\t\t\t\t} catch ( e ) {\n\t\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\t\tstate: \"parsererror\",\n\t\t\t\t\t\t\t\terror: conv ? e : \"No conversion from \" + prev + \" to \" + current\n\t\t\t\t\t\t\t};\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn { state: \"success\", data: response };\n}\n\njQuery.extend( {\n\n\t// Counter for holding the number of active queries\n\tactive: 0,\n\n\t// Last-Modified header cache for next request\n\tlastModified: {},\n\tetag: {},\n\n\tajaxSettings: {\n\t\turl: location.href,\n\t\ttype: \"GET\",\n\t\tisLocal: rlocalProtocol.test( location.protocol ),\n\t\tglobal: true,\n\t\tprocessData: true,\n\t\tasync: true,\n\t\tcontentType: \"application/x-www-form-urlencoded; charset=UTF-8\",\n\t\t/*\n\t\ttimeout: 0,\n\t\tdata: null,\n\t\tdataType: null,\n\t\tusername: null,\n\t\tpassword: null,\n\t\tcache: null,\n\t\tthrows: false,\n\t\ttraditional: false,\n\t\theaders: {},\n\t\t*/\n\n\t\taccepts: {\n\t\t\t\"*\": allTypes,\n\t\t\ttext: \"text/plain\",\n\t\t\thtml: \"text/html\",\n\t\t\txml: \"application/xml, text/xml\",\n\t\t\tjson: \"application/json, text/javascript\"\n\t\t},\n\n\t\tcontents: {\n\t\t\txml: /\\bxml\\b/,\n\t\t\thtml: /\\bhtml/,\n\t\t\tjson: /\\bjson\\b/\n\t\t},\n\n\t\tresponseFields: {\n\t\t\txml: \"responseXML\",\n\t\t\ttext: \"responseText\",\n\t\t\tjson: \"responseJSON\"\n\t\t},\n\n\t\t// Data converters\n\t\t// Keys separate source (or catchall \"*\") and destination types with a single space\n\t\tconverters: {\n\n\t\t\t// Convert anything to text\n\t\t\t\"* text\": String,\n\n\t\t\t// Text to html (true = no transformation)\n\t\t\t\"text html\": true,\n\n\t\t\t// Evaluate text as a json expression\n\t\t\t\"text json\": jQuery.parseJSON,\n\n\t\t\t// Parse text as xml\n\t\t\t\"text xml\": jQuery.parseXML\n\t\t},\n\n\t\t// For options that shouldn't be deep extended:\n\t\t// you can add your own custom options here if\n\t\t// and when you create one that shouldn't be\n\t\t// deep extended (see ajaxExtend)\n\t\tflatOptions: {\n\t\t\turl: true,\n\t\t\tcontext: true\n\t\t}\n\t},\n\n\t// Creates a full fledged settings object into target\n\t// with both ajaxSettings and settings fields.\n\t// If target is omitted, writes into ajaxSettings.\n\tajaxSetup: function( target, settings ) {\n\t\treturn settings ?\n\n\t\t\t// Building a settings object\n\t\t\tajaxExtend( ajaxExtend( target, jQuery.ajaxSettings ), settings ) :\n\n\t\t\t// Extending ajaxSettings\n\t\t\tajaxExtend( jQuery.ajaxSettings, target );\n\t},\n\n\tajaxPrefilter: addToPrefiltersOrTransports( prefilters ),\n\tajaxTransport: addToPrefiltersOrTransports( transports ),\n\n\t// Main method\n\tajax: function( url, options ) {\n\n\t\t// If url is an object, simulate pre-1.5 signature\n\t\tif ( typeof url === \"object\" ) {\n\t\t\toptions = url;\n\t\t\turl = undefined;\n\t\t}\n\n\t\t// Force options to be an object\n\t\toptions = options || {};\n\n\t\tvar transport,\n\n\t\t\t// URL without anti-cache param\n\t\t\tcacheURL,\n\n\t\t\t// Response headers\n\t\t\tresponseHeadersString,\n\t\t\tresponseHeaders,\n\n\t\t\t// timeout handle\n\t\t\ttimeoutTimer,\n\n\t\t\t// Url cleanup var\n\t\t\turlAnchor,\n\n\t\t\t// To know if global events are to be dispatched\n\t\t\tfireGlobals,\n\n\t\t\t// Loop variable\n\t\t\ti,\n\n\t\t\t// Create the final options object\n\t\t\ts = jQuery.ajaxSetup( {}, options ),\n\n\t\t\t// Callbacks context\n\t\t\tcallbackContext = s.context || s,\n\n\t\t\t// Context for global events is callbackContext if it is a DOM node or jQuery collection\n\t\t\tglobalEventContext = s.context &&\n\t\t\t\t( callbackContext.nodeType || callbackContext.jquery ) ?\n\t\t\t\t\tjQuery( callbackContext ) :\n\t\t\t\t\tjQuery.event,\n\n\t\t\t// Deferreds\n\t\t\tdeferred = jQuery.Deferred(),\n\t\t\tcompleteDeferred = jQuery.Callbacks( \"once memory\" ),\n\n\t\t\t// Status-dependent callbacks\n\t\t\tstatusCode = s.statusCode || {},\n\n\t\t\t// Headers (they are sent all at once)\n\t\t\trequestHeaders = {},\n\t\t\trequestHeadersNames = {},\n\n\t\t\t// The jqXHR state\n\t\t\tstate = 0,\n\n\t\t\t// Default abort message\n\t\t\tstrAbort = \"canceled\",\n\n\t\t\t// Fake xhr\n\t\t\tjqXHR = {\n\t\t\t\treadyState: 0,\n\n\t\t\t\t// Builds headers hashtable if needed\n\t\t\t\tgetResponseHeader: function( key ) {\n\t\t\t\t\tvar match;\n\t\t\t\t\tif ( state === 2 ) {\n\t\t\t\t\t\tif ( !responseHeaders ) {\n\t\t\t\t\t\t\tresponseHeaders = {};\n\t\t\t\t\t\t\twhile ( ( match = rheaders.exec( responseHeadersString ) ) ) {\n\t\t\t\t\t\t\t\tresponseHeaders[ match[ 1 ].toLowerCase() ] = match[ 2 ];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tmatch = responseHeaders[ key.toLowerCase() ];\n\t\t\t\t\t}\n\t\t\t\t\treturn match == null ? null : match;\n\t\t\t\t},\n\n\t\t\t\t// Raw string\n\t\t\t\tgetAllResponseHeaders: function() {\n\t\t\t\t\treturn state === 2 ? responseHeadersString : null;\n\t\t\t\t},\n\n\t\t\t\t// Caches the header\n\t\t\t\tsetRequestHeader: function( name, value ) {\n\t\t\t\t\tvar lname = name.toLowerCase();\n\t\t\t\t\tif ( !state ) {\n\t\t\t\t\t\tname = requestHeadersNames[ lname ] = requestHeadersNames[ lname ] || name;\n\t\t\t\t\t\trequestHeaders[ name ] = value;\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Overrides response content-type header\n\t\t\t\toverrideMimeType: function( type ) {\n\t\t\t\t\tif ( !state ) {\n\t\t\t\t\t\ts.mimeType = type;\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Status-dependent callbacks\n\t\t\t\tstatusCode: function( map ) {\n\t\t\t\t\tvar code;\n\t\t\t\t\tif ( map ) {\n\t\t\t\t\t\tif ( state < 2 ) {\n\t\t\t\t\t\t\tfor ( code in map ) {\n\n\t\t\t\t\t\t\t\t// Lazy-add the new callback in a way that preserves old ones\n\t\t\t\t\t\t\t\tstatusCode[ code ] = [ statusCode[ code ], map[ code ] ];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t// Execute the appropriate callbacks\n\t\t\t\t\t\t\tjqXHR.always( map[ jqXHR.status ] );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Cancel the request\n\t\t\t\tabort: function( statusText ) {\n\t\t\t\t\tvar finalText = statusText || strAbort;\n\t\t\t\t\tif ( transport ) {\n\t\t\t\t\t\ttransport.abort( finalText );\n\t\t\t\t\t}\n\t\t\t\t\tdone( 0, finalText );\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t};\n\n\t\t// Attach deferreds\n\t\tdeferred.promise( jqXHR ).complete = completeDeferred.add;\n\t\tjqXHR.success = jqXHR.done;\n\t\tjqXHR.error = jqXHR.fail;\n\n\t\t// Remove hash character (#7531: and string promotion)\n\t\t// Add protocol if not provided (prefilters might expect it)\n\t\t// Handle falsy url in the settings object (#10093: consistency with old signature)\n\t\t// We also use the url parameter if available\n\t\ts.url = ( ( url || s.url || location.href ) + \"\" ).replace( rhash, \"\" )\n\t\t\t.replace( rprotocol, location.protocol + \"//\" );\n\n\t\t// Alias method option to type as per ticket #12004\n\t\ts.type = options.method || options.type || s.method || s.type;\n\n\t\t// Extract dataTypes list\n\t\ts.dataTypes = jQuery.trim( s.dataType || \"*\" ).toLowerCase().match( rnotwhite ) || [ \"\" ];\n\n\t\t// A cross-domain request is in order when the origin doesn't match the current origin.\n\t\tif ( s.crossDomain == null ) {\n\t\t\turlAnchor = document.createElement( \"a\" );\n\n\t\t\t// Support: IE8-11+\n\t\t\t// IE throws exception if url is malformed, e.g. http://example.com:80x/\n\t\t\ttry {\n\t\t\t\turlAnchor.href = s.url;\n\n\t\t\t\t// Support: IE8-11+\n\t\t\t\t// Anchor's host property isn't correctly set when s.url is relative\n\t\t\t\turlAnchor.href = urlAnchor.href;\n\t\t\t\ts.crossDomain = originAnchor.protocol + \"//\" + originAnchor.host !==\n\t\t\t\t\turlAnchor.protocol + \"//\" + urlAnchor.host;\n\t\t\t} catch ( e ) {\n\n\t\t\t\t// If there is an error parsing the URL, assume it is crossDomain,\n\t\t\t\t// it can be rejected by the transport if it is invalid\n\t\t\t\ts.crossDomain = true;\n\t\t\t}\n\t\t}\n\n\t\t// Convert data if not already a string\n\t\tif ( s.data && s.processData && typeof s.data !== \"string\" ) {\n\t\t\ts.data = jQuery.param( s.data, s.traditional );\n\t\t}\n\n\t\t// Apply prefilters\n\t\tinspectPrefiltersOrTransports( prefilters, s, options, jqXHR );\n\n\t\t// If request was aborted inside a prefilter, stop there\n\t\tif ( state === 2 ) {\n\t\t\treturn jqXHR;\n\t\t}\n\n\t\t// We can fire global events as of now if asked to\n\t\t// Don't fire events if jQuery.event is undefined in an AMD-usage scenario (#15118)\n\t\tfireGlobals = jQuery.event && s.global;\n\n\t\t// Watch for a new set of requests\n\t\tif ( fireGlobals && jQuery.active++ === 0 ) {\n\t\t\tjQuery.event.trigger( \"ajaxStart\" );\n\t\t}\n\n\t\t// Uppercase the type\n\t\ts.type = s.type.toUpperCase();\n\n\t\t// Determine if request has content\n\t\ts.hasContent = !rnoContent.test( s.type );\n\n\t\t// Save the URL in case we're toying with the If-Modified-Since\n\t\t// and/or If-None-Match header later on\n\t\tcacheURL = s.url;\n\n\t\t// More options handling for requests with no content\n\t\tif ( !s.hasContent ) {\n\n\t\t\t// If data is available, append data to url\n\t\t\tif ( s.data ) {\n\t\t\t\tcacheURL = ( s.url += ( rquery.test( cacheURL ) ? \"&\" : \"?\" ) + s.data );\n\n\t\t\t\t// #9682: remove data so that it's not used in an eventual retry\n\t\t\t\tdelete s.data;\n\t\t\t}\n\n\t\t\t// Add anti-cache in url if needed\n\t\t\tif ( s.cache === false ) {\n\t\t\t\ts.url = rts.test( cacheURL ) ?\n\n\t\t\t\t\t// If there is already a '_' parameter, set its value\n\t\t\t\t\tcacheURL.replace( rts, \"$1_=\" + nonce++ ) :\n\n\t\t\t\t\t// Otherwise add one to the end\n\t\t\t\t\tcacheURL + ( rquery.test( cacheURL ) ? \"&\" : \"?\" ) + \"_=\" + nonce++;\n\t\t\t}\n\t\t}\n\n\t\t// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.\n\t\tif ( s.ifModified ) {\n\t\t\tif ( jQuery.lastModified[ cacheURL ] ) {\n\t\t\t\tjqXHR.setRequestHeader( \"If-Modified-Since\", jQuery.lastModified[ cacheURL ] );\n\t\t\t}\n\t\t\tif ( jQuery.etag[ cacheURL ] ) {\n\t\t\t\tjqXHR.setRequestHeader( \"If-None-Match\", jQuery.etag[ cacheURL ] );\n\t\t\t}\n\t\t}\n\n\t\t// Set the correct header, if data is being sent\n\t\tif ( s.data && s.hasContent && s.contentType !== false || options.contentType ) {\n\t\t\tjqXHR.setRequestHeader( \"Content-Type\", s.contentType );\n\t\t}\n\n\t\t// Set the Accepts header for the server, depending on the dataType\n\t\tjqXHR.setRequestHeader(\n\t\t\t\"Accept\",\n\t\t\ts.dataTypes[ 0 ] && s.accepts[ s.dataTypes[ 0 ] ] ?\n\t\t\t\ts.accepts[ s.dataTypes[ 0 ] ] +\n\t\t\t\t\t( s.dataTypes[ 0 ] !== \"*\" ? \", \" + allTypes + \"; q=0.01\" : \"\" ) :\n\t\t\t\ts.accepts[ \"*\" ]\n\t\t);\n\n\t\t// Check for headers option\n\t\tfor ( i in s.headers ) {\n\t\t\tjqXHR.setRequestHeader( i, s.headers[ i ] );\n\t\t}\n\n\t\t// Allow custom headers/mimetypes and early abort\n\t\tif ( s.beforeSend &&\n\t\t\t( s.beforeSend.call( callbackContext, jqXHR, s ) === false || state === 2 ) ) {\n\n\t\t\t// Abort if not done already and return\n\t\t\treturn jqXHR.abort();\n\t\t}\n\n\t\t// Aborting is no longer a cancellation\n\t\tstrAbort = \"abort\";\n\n\t\t// Install callbacks on deferreds\n\t\tfor ( i in { success: 1, error: 1, complete: 1 } ) {\n\t\t\tjqXHR[ i ]( s[ i ] );\n\t\t}\n\n\t\t// Get transport\n\t\ttransport = inspectPrefiltersOrTransports( transports, s, options, jqXHR );\n\n\t\t// If no transport, we auto-abort\n\t\tif ( !transport ) {\n\t\t\tdone( -1, \"No Transport\" );\n\t\t} else {\n\t\t\tjqXHR.readyState = 1;\n\n\t\t\t// Send global event\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( \"ajaxSend\", [ jqXHR, s ] );\n\t\t\t}\n\n\t\t\t// If request was aborted inside ajaxSend, stop there\n\t\t\tif ( state === 2 ) {\n\t\t\t\treturn jqXHR;\n\t\t\t}\n\n\t\t\t// Timeout\n\t\t\tif ( s.async && s.timeout > 0 ) {\n\t\t\t\ttimeoutTimer = window.setTimeout( function() {\n\t\t\t\t\tjqXHR.abort( \"timeout\" );\n\t\t\t\t}, s.timeout );\n\t\t\t}\n\n\t\t\ttry {\n\t\t\t\tstate = 1;\n\t\t\t\ttransport.send( requestHeaders, done );\n\t\t\t} catch ( e ) {\n\n\t\t\t\t// Propagate exception as error if not done\n\t\t\t\tif ( state < 2 ) {\n\t\t\t\t\tdone( -1, e );\n\n\t\t\t\t// Simply rethrow otherwise\n\t\t\t\t} else {\n\t\t\t\t\tthrow e;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Callback for when everything is done\n\t\tfunction done( status, nativeStatusText, responses, headers ) {\n\t\t\tvar isSuccess, success, error, response, modified,\n\t\t\t\tstatusText = nativeStatusText;\n\n\t\t\t// Called once\n\t\t\tif ( state === 2 ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// State is \"done\" now\n\t\t\tstate = 2;\n\n\t\t\t// Clear timeout if it exists\n\t\t\tif ( timeoutTimer ) {\n\t\t\t\twindow.clearTimeout( timeoutTimer );\n\t\t\t}\n\n\t\t\t// Dereference transport for early garbage collection\n\t\t\t// (no matter how long the jqXHR object will be used)\n\t\t\ttransport = undefined;\n\n\t\t\t// Cache response headers\n\t\t\tresponseHeadersString = headers || \"\";\n\n\t\t\t// Set readyState\n\t\t\tjqXHR.readyState = status > 0 ? 4 : 0;\n\n\t\t\t// Determine if successful\n\t\t\tisSuccess = status >= 200 && status < 300 || status === 304;\n\n\t\t\t// Get response data\n\t\t\tif ( responses ) {\n\t\t\t\tresponse = ajaxHandleResponses( s, jqXHR, responses );\n\t\t\t}\n\n\t\t\t// Convert no matter what (that way responseXXX fields are always set)\n\t\t\tresponse = ajaxConvert( s, response, jqXHR, isSuccess );\n\n\t\t\t// If successful, handle type chaining\n\t\t\tif ( isSuccess ) {\n\n\t\t\t\t// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.\n\t\t\t\tif ( s.ifModified ) {\n\t\t\t\t\tmodified = jqXHR.getResponseHeader( \"Last-Modified\" );\n\t\t\t\t\tif ( modified ) {\n\t\t\t\t\t\tjQuery.lastModified[ cacheURL ] = modified;\n\t\t\t\t\t}\n\t\t\t\t\tmodified = jqXHR.getResponseHeader( \"etag\" );\n\t\t\t\t\tif ( modified ) {\n\t\t\t\t\t\tjQuery.etag[ cacheURL ] = modified;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// if no content\n\t\t\t\tif ( status === 204 || s.type === \"HEAD\" ) {\n\t\t\t\t\tstatusText = \"nocontent\";\n\n\t\t\t\t// if not modified\n\t\t\t\t} else if ( status === 304 ) {\n\t\t\t\t\tstatusText = \"notmodified\";\n\n\t\t\t\t// If we have data, let's convert it\n\t\t\t\t} else {\n\t\t\t\t\tstatusText = response.state;\n\t\t\t\t\tsuccess = response.data;\n\t\t\t\t\terror = response.error;\n\t\t\t\t\tisSuccess = !error;\n\t\t\t\t}\n\t\t\t} else {\n\n\t\t\t\t// Extract error from statusText and normalize for non-aborts\n\t\t\t\terror = statusText;\n\t\t\t\tif ( status || !statusText ) {\n\t\t\t\t\tstatusText = \"error\";\n\t\t\t\t\tif ( status < 0 ) {\n\t\t\t\t\t\tstatus = 0;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Set data for the fake xhr object\n\t\t\tjqXHR.status = status;\n\t\t\tjqXHR.statusText = ( nativeStatusText || statusText ) + \"\";\n\n\t\t\t// Success/Error\n\t\t\tif ( isSuccess ) {\n\t\t\t\tdeferred.resolveWith( callbackContext, [ success, statusText, jqXHR ] );\n\t\t\t} else {\n\t\t\t\tdeferred.rejectWith( callbackContext, [ jqXHR, statusText, error ] );\n\t\t\t}\n\n\t\t\t// Status-dependent callbacks\n\t\t\tjqXHR.statusCode( statusCode );\n\t\t\tstatusCode = undefined;\n\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( isSuccess ? \"ajaxSuccess\" : \"ajaxError\",\n\t\t\t\t\t[ jqXHR, s, isSuccess ? success : error ] );\n\t\t\t}\n\n\t\t\t// Complete\n\t\t\tcompleteDeferred.fireWith( callbackContext, [ jqXHR, statusText ] );\n\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( \"ajaxComplete\", [ jqXHR, s ] );\n\n\t\t\t\t// Handle the global AJAX counter\n\t\t\t\tif ( !( --jQuery.active ) ) {\n\t\t\t\t\tjQuery.event.trigger( \"ajaxStop\" );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn jqXHR;\n\t},\n\n\tgetJSON: function( url, data, callback ) {\n\t\treturn jQuery.get( url, data, callback, \"json\" );\n\t},\n\n\tgetScript: function( url, callback ) {\n\t\treturn jQuery.get( url, undefined, callback, \"script\" );\n\t}\n} );\n\njQuery.each( [ \"get\", \"post\" ], function( i, method ) {\n\tjQuery[ method ] = function( url, data, callback, type ) {\n\n\t\t// Shift arguments if data argument was omitted\n\t\tif ( jQuery.isFunction( data ) ) {\n\t\t\ttype = type || callback;\n\t\t\tcallback = data;\n\t\t\tdata = undefined;\n\t\t}\n\n\t\t// The url can be an options object (which then must have .url)\n\t\treturn jQuery.ajax( jQuery.extend( {\n\t\t\turl: url,\n\t\t\ttype: method,\n\t\t\tdataType: type,\n\t\t\tdata: data,\n\t\t\tsuccess: callback\n\t\t}, jQuery.isPlainObject( url ) && url ) );\n\t};\n} );\n\n\njQuery._evalUrl = function( url ) {\n\treturn jQuery.ajax( {\n\t\turl: url,\n\n\t\t// Make this explicit, since user can override this through ajaxSetup (#11264)\n\t\ttype: \"GET\",\n\t\tdataType: \"script\",\n\t\tasync: false,\n\t\tglobal: false,\n\t\t\"throws\": true\n\t} );\n};\n\n\njQuery.fn.extend( {\n\twrapAll: function( html ) {\n\t\tvar wrap;\n\n\t\tif ( jQuery.isFunction( html ) ) {\n\t\t\treturn this.each( function( i ) {\n\t\t\t\tjQuery( this ).wrapAll( html.call( this, i ) );\n\t\t\t} );\n\t\t}\n\n\t\tif ( this[ 0 ] ) {\n\n\t\t\t// The elements to wrap the target around\n\t\t\twrap = jQuery( html, this[ 0 ].ownerDocument ).eq( 0 ).clone( true );\n\n\t\t\tif ( this[ 0 ].parentNode ) {\n\t\t\t\twrap.insertBefore( this[ 0 ] );\n\t\t\t}\n\n\t\t\twrap.map( function() {\n\t\t\t\tvar elem = this;\n\n\t\t\t\twhile ( elem.firstElementChild ) {\n\t\t\t\t\telem = elem.firstElementChild;\n\t\t\t\t}\n\n\t\t\t\treturn elem;\n\t\t\t} ).append( this );\n\t\t}\n\n\t\treturn this;\n\t},\n\n\twrapInner: function( html ) {\n\t\tif ( jQuery.isFunction( html ) ) {\n\t\t\treturn this.each( function( i ) {\n\t\t\t\tjQuery( this ).wrapInner( html.call( this, i ) );\n\t\t\t} );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar self = jQuery( this ),\n\t\t\t\tcontents = self.contents();\n\n\t\t\tif ( contents.length ) {\n\t\t\t\tcontents.wrapAll( html );\n\n\t\t\t} else {\n\t\t\t\tself.append( html );\n\t\t\t}\n\t\t} );\n\t},\n\n\twrap: function( html ) {\n\t\tvar isFunction = jQuery.isFunction( html );\n\n\t\treturn this.each( function( i ) {\n\t\t\tjQuery( this ).wrapAll( isFunction ? html.call( this, i ) : html );\n\t\t} );\n\t},\n\n\tunwrap: function() {\n\t\treturn this.parent().each( function() {\n\t\t\tif ( !jQuery.nodeName( this, \"body\" ) ) {\n\t\t\t\tjQuery( this ).replaceWith( this.childNodes );\n\t\t\t}\n\t\t} ).end();\n\t}\n} );\n\n\njQuery.expr.filters.hidden = function( elem ) {\n\treturn !jQuery.expr.filters.visible( elem );\n};\njQuery.expr.filters.visible = function( elem ) {\n\n\t// Support: Opera <= 12.12\n\t// Opera reports offsetWidths and offsetHeights less than zero on some elements\n\t// Use OR instead of AND as the element is not visible if either is true\n\t// See tickets #10406 and #13132\n\treturn elem.offsetWidth > 0 || elem.offsetHeight > 0 || elem.getClientRects().length > 0;\n};\n\n\n\n\nvar r20 = /%20/g,\n\trbracket = /\\[\\]$/,\n\trCRLF = /\\r?\\n/g,\n\trsubmitterTypes = /^(?:submit|button|image|reset|file)$/i,\n\trsubmittable = /^(?:input|select|textarea|keygen)/i;\n\nfunction buildParams( prefix, obj, traditional, add ) {\n\tvar name;\n\n\tif ( jQuery.isArray( obj ) ) {\n\n\t\t// Serialize array item.\n\t\tjQuery.each( obj, function( i, v ) {\n\t\t\tif ( traditional || rbracket.test( prefix ) ) {\n\n\t\t\t\t// Treat each array item as a scalar.\n\t\t\t\tadd( prefix, v );\n\n\t\t\t} else {\n\n\t\t\t\t// Item is non-scalar (array or object), encode its numeric index.\n\t\t\t\tbuildParams(\n\t\t\t\t\tprefix + \"[\" + ( typeof v === \"object\" && v != null ? i : \"\" ) + \"]\",\n\t\t\t\t\tv,\n\t\t\t\t\ttraditional,\n\t\t\t\t\tadd\n\t\t\t\t);\n\t\t\t}\n\t\t} );\n\n\t} else if ( !traditional && jQuery.type( obj ) === \"object\" ) {\n\n\t\t// Serialize object item.\n\t\tfor ( name in obj ) {\n\t\t\tbuildParams( prefix + \"[\" + name + \"]\", obj[ name ], traditional, add );\n\t\t}\n\n\t} else {\n\n\t\t// Serialize scalar item.\n\t\tadd( prefix, obj );\n\t}\n}\n\n// Serialize an array of form elements or a set of\n// key/values into a query string\njQuery.param = function( a, traditional ) {\n\tvar prefix,\n\t\ts = [],\n\t\tadd = function( key, value ) {\n\n\t\t\t// If value is a function, invoke it and return its value\n\t\t\tvalue = jQuery.isFunction( value ) ? value() : ( value == null ? \"\" : value );\n\t\t\ts[ s.length ] = encodeURIComponent( key ) + \"=\" + encodeURIComponent( value );\n\t\t};\n\n\t// Set traditional to true for jQuery <= 1.3.2 behavior.\n\tif ( traditional === undefined ) {\n\t\ttraditional = jQuery.ajaxSettings && jQuery.ajaxSettings.traditional;\n\t}\n\n\t// If an array was passed in, assume that it is an array of form elements.\n\tif ( jQuery.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) {\n\n\t\t// Serialize the form elements\n\t\tjQuery.each( a, function() {\n\t\t\tadd( this.name, this.value );\n\t\t} );\n\n\t} else {\n\n\t\t// If traditional, encode the \"old\" way (the way 1.3.2 or older\n\t\t// did it), otherwise encode params recursively.\n\t\tfor ( prefix in a ) {\n\t\t\tbuildParams( prefix, a[ prefix ], traditional, add );\n\t\t}\n\t}\n\n\t// Return the resulting serialization\n\treturn s.join( \"&\" ).replace( r20, \"+\" );\n};\n\njQuery.fn.extend( {\n\tserialize: function() {\n\t\treturn jQuery.param( this.serializeArray() );\n\t},\n\tserializeArray: function() {\n\t\treturn this.map( function() {\n\n\t\t\t// Can add propHook for \"elements\" to filter or add form elements\n\t\t\tvar elements = jQuery.prop( this, \"elements\" );\n\t\t\treturn elements ? jQuery.makeArray( elements ) : this;\n\t\t} )\n\t\t.filter( function() {\n\t\t\tvar type = this.type;\n\n\t\t\t// Use .is( \":disabled\" ) so that fieldset[disabled] works\n\t\t\treturn this.name && !jQuery( this ).is( \":disabled\" ) &&\n\t\t\t\trsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) &&\n\t\t\t\t( this.checked || !rcheckableType.test( type ) );\n\t\t} )\n\t\t.map( function( i, elem ) {\n\t\t\tvar val = jQuery( this ).val();\n\n\t\t\treturn val == null ?\n\t\t\t\tnull :\n\t\t\t\tjQuery.isArray( val ) ?\n\t\t\t\t\tjQuery.map( val, function( val ) {\n\t\t\t\t\t\treturn { name: elem.name, value: val.replace( rCRLF, \"\\r\\n\" ) };\n\t\t\t\t\t} ) :\n\t\t\t\t\t{ name: elem.name, value: val.replace( rCRLF, \"\\r\\n\" ) };\n\t\t} ).get();\n\t}\n} );\n\n\njQuery.ajaxSettings.xhr = function() {\n\ttry {\n\t\treturn new window.XMLHttpRequest();\n\t} catch ( e ) {}\n};\n\nvar xhrSuccessStatus = {\n\n\t\t// File protocol always yields status code 0, assume 200\n\t\t0: 200,\n\n\t\t// Support: IE9\n\t\t// #1450: sometimes IE returns 1223 when it should be 204\n\t\t1223: 204\n\t},\n\txhrSupported = jQuery.ajaxSettings.xhr();\n\nsupport.cors = !!xhrSupported && ( \"withCredentials\" in xhrSupported );\nsupport.ajax = xhrSupported = !!xhrSupported;\n\njQuery.ajaxTransport( function( options ) {\n\tvar callback, errorCallback;\n\n\t// Cross domain only allowed if supported through XMLHttpRequest\n\tif ( support.cors || xhrSupported && !options.crossDomain ) {\n\t\treturn {\n\t\t\tsend: function( headers, complete ) {\n\t\t\t\tvar i,\n\t\t\t\t\txhr = options.xhr();\n\n\t\t\t\txhr.open(\n\t\t\t\t\toptions.type,\n\t\t\t\t\toptions.url,\n\t\t\t\t\toptions.async,\n\t\t\t\t\toptions.username,\n\t\t\t\t\toptions.password\n\t\t\t\t);\n\n\t\t\t\t// Apply custom fields if provided\n\t\t\t\tif ( options.xhrFields ) {\n\t\t\t\t\tfor ( i in options.xhrFields ) {\n\t\t\t\t\t\txhr[ i ] = options.xhrFields[ i ];\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Override mime type if needed\n\t\t\t\tif ( options.mimeType && xhr.overrideMimeType ) {\n\t\t\t\t\txhr.overrideMimeType( options.mimeType );\n\t\t\t\t}\n\n\t\t\t\t// X-Requested-With header\n\t\t\t\t// For cross-domain requests, seeing as conditions for a preflight are\n\t\t\t\t// akin to a jigsaw puzzle, we simply never set it to be sure.\n\t\t\t\t// (it can always be set on a per-request basis or even using ajaxSetup)\n\t\t\t\t// For same-domain requests, won't change header if already provided.\n\t\t\t\tif ( !options.crossDomain && !headers[ \"X-Requested-With\" ] ) {\n\t\t\t\t\theaders[ \"X-Requested-With\" ] = \"XMLHttpRequest\";\n\t\t\t\t}\n\n\t\t\t\t// Set headers\n\t\t\t\tfor ( i in headers ) {\n\t\t\t\t\txhr.setRequestHeader( i, headers[ i ] );\n\t\t\t\t}\n\n\t\t\t\t// Callback\n\t\t\t\tcallback = function( type ) {\n\t\t\t\t\treturn function() {\n\t\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\t\tcallback = errorCallback = xhr.onload =\n\t\t\t\t\t\t\t\txhr.onerror = xhr.onabort = xhr.onreadystatechange = null;\n\n\t\t\t\t\t\t\tif ( type === \"abort\" ) {\n\t\t\t\t\t\t\t\txhr.abort();\n\t\t\t\t\t\t\t} else if ( type === \"error\" ) {\n\n\t\t\t\t\t\t\t\t// Support: IE9\n\t\t\t\t\t\t\t\t// On a manual native abort, IE9 throws\n\t\t\t\t\t\t\t\t// errors on any property access that is not readyState\n\t\t\t\t\t\t\t\tif ( typeof xhr.status !== \"number\" ) {\n\t\t\t\t\t\t\t\t\tcomplete( 0, \"error\" );\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tcomplete(\n\n\t\t\t\t\t\t\t\t\t\t// File: protocol always yields status 0; see #8605, #14207\n\t\t\t\t\t\t\t\t\t\txhr.status,\n\t\t\t\t\t\t\t\t\t\txhr.statusText\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tcomplete(\n\t\t\t\t\t\t\t\t\txhrSuccessStatus[ xhr.status ] || xhr.status,\n\t\t\t\t\t\t\t\t\txhr.statusText,\n\n\t\t\t\t\t\t\t\t\t// Support: IE9 only\n\t\t\t\t\t\t\t\t\t// IE9 has no XHR2 but throws on binary (trac-11426)\n\t\t\t\t\t\t\t\t\t// For XHR2 non-text, let the caller handle it (gh-2498)\n\t\t\t\t\t\t\t\t\t( xhr.responseType || \"text\" ) !== \"text\" ||\n\t\t\t\t\t\t\t\t\ttypeof xhr.responseText !== \"string\" ?\n\t\t\t\t\t\t\t\t\t\t{ binary: xhr.response } :\n\t\t\t\t\t\t\t\t\t\t{ text: xhr.responseText },\n\t\t\t\t\t\t\t\t\txhr.getAllResponseHeaders()\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t};\n\n\t\t\t\t// Listen to events\n\t\t\t\txhr.onload = callback();\n\t\t\t\terrorCallback = xhr.onerror = callback( \"error\" );\n\n\t\t\t\t// Support: IE9\n\t\t\t\t// Use onreadystatechange to replace onabort\n\t\t\t\t// to handle uncaught aborts\n\t\t\t\tif ( xhr.onabort !== undefined ) {\n\t\t\t\t\txhr.onabort = errorCallback;\n\t\t\t\t} else {\n\t\t\t\t\txhr.onreadystatechange = function() {\n\n\t\t\t\t\t\t// Check readyState before timeout as it changes\n\t\t\t\t\t\tif ( xhr.readyState === 4 ) {\n\n\t\t\t\t\t\t\t// Allow onerror to be called first,\n\t\t\t\t\t\t\t// but that will not handle a native abort\n\t\t\t\t\t\t\t// Also, save errorCallback to a variable\n\t\t\t\t\t\t\t// as xhr.onerror cannot be accessed\n\t\t\t\t\t\t\twindow.setTimeout( function() {\n\t\t\t\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\t\t\t\terrorCallback();\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t}\n\n\t\t\t\t// Create the abort callback\n\t\t\t\tcallback = callback( \"abort\" );\n\n\t\t\t\ttry {\n\n\t\t\t\t\t// Do send the request (this may raise an exception)\n\t\t\t\t\txhr.send( options.hasContent && options.data || null );\n\t\t\t\t} catch ( e ) {\n\n\t\t\t\t\t// #14683: Only rethrow if this hasn't been notified as an error yet\n\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\tthrow e;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\n\t\t\tabort: function() {\n\t\t\t\tif ( callback ) {\n\t\t\t\t\tcallback();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n} );\n\n\n\n\n// Install script dataType\njQuery.ajaxSetup( {\n\taccepts: {\n\t\tscript: \"text/javascript, application/javascript, \" +\n\t\t\t\"application/ecmascript, application/x-ecmascript\"\n\t},\n\tcontents: {\n\t\tscript: /\\b(?:java|ecma)script\\b/\n\t},\n\tconverters: {\n\t\t\"text script\": function( text ) {\n\t\t\tjQuery.globalEval( text );\n\t\t\treturn text;\n\t\t}\n\t}\n} );\n\n// Handle cache's special case and crossDomain\njQuery.ajaxPrefilter( \"script\", function( s ) {\n\tif ( s.cache === undefined ) {\n\t\ts.cache = false;\n\t}\n\tif ( s.crossDomain ) {\n\t\ts.type = \"GET\";\n\t}\n} );\n\n// Bind script tag hack transport\njQuery.ajaxTransport( \"script\", function( s ) {\n\n\t// This transport only deals with cross domain requests\n\tif ( s.crossDomain ) {\n\t\tvar script, callback;\n\t\treturn {\n\t\t\tsend: function( _, complete ) {\n\t\t\t\tscript = jQuery( \"<script>\" ).prop( {\n\t\t\t\t\tcharset: s.scriptCharset,\n\t\t\t\t\tsrc: s.url\n\t\t\t\t} ).on(\n\t\t\t\t\t\"load error\",\n\t\t\t\t\tcallback = function( evt ) {\n\t\t\t\t\t\tscript.remove();\n\t\t\t\t\t\tcallback = null;\n\t\t\t\t\t\tif ( evt ) {\n\t\t\t\t\t\t\tcomplete( evt.type === \"error\" ? 404 : 200, evt.type );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t);\n\n\t\t\t\t// Use native DOM manipulation to avoid our domManip AJAX trickery\n\t\t\t\tdocument.head.appendChild( script[ 0 ] );\n\t\t\t},\n\t\t\tabort: function() {\n\t\t\t\tif ( callback ) {\n\t\t\t\t\tcallback();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n} );\n\n\n\n\nvar oldCallbacks = [],\n\trjsonp = /(=)\\?(?=&|$)|\\?\\?/;\n\n// Default jsonp settings\njQuery.ajaxSetup( {\n\tjsonp: \"callback\",\n\tjsonpCallback: function() {\n\t\tvar callback = oldCallbacks.pop() || ( jQuery.expando + \"_\" + ( nonce++ ) );\n\t\tthis[ callback ] = true;\n\t\treturn callback;\n\t}\n} );\n\n// Detect, normalize options and install callbacks for jsonp requests\njQuery.ajaxPrefilter( \"json jsonp\", function( s, originalSettings, jqXHR ) {\n\n\tvar callbackName, overwritten, responseContainer,\n\t\tjsonProp = s.jsonp !== false && ( rjsonp.test( s.url ) ?\n\t\t\t\"url\" :\n\t\t\ttypeof s.data === \"string\" &&\n\t\t\t\t( s.contentType || \"\" )\n\t\t\t\t\t.indexOf( \"application/x-www-form-urlencoded\" ) === 0 &&\n\t\t\t\trjsonp.test( s.data ) && \"data\"\n\t\t);\n\n\t// Handle iff the expected data type is \"jsonp\" or we have a parameter to set\n\tif ( jsonProp || s.dataTypes[ 0 ] === \"jsonp\" ) {\n\n\t\t// Get callback name, remembering preexisting value associated with it\n\t\tcallbackName = s.jsonpCallback = jQuery.isFunction( s.jsonpCallback ) ?\n\t\t\ts.jsonpCallback() :\n\t\t\ts.jsonpCallback;\n\n\t\t// Insert callback into url or form data\n\t\tif ( jsonProp ) {\n\t\t\ts[ jsonProp ] = s[ jsonProp ].replace( rjsonp, \"$1\" + callbackName );\n\t\t} else if ( s.jsonp !== false ) {\n\t\t\ts.url += ( rquery.test( s.url ) ? \"&\" : \"?\" ) + s.jsonp + \"=\" + callbackName;\n\t\t}\n\n\t\t// Use data converter to retrieve json after script execution\n\t\ts.converters[ \"script json\" ] = function() {\n\t\t\tif ( !responseContainer ) {\n\t\t\t\tjQuery.error( callbackName + \" was not called\" );\n\t\t\t}\n\t\t\treturn responseContainer[ 0 ];\n\t\t};\n\n\t\t// Force json dataType\n\t\ts.dataTypes[ 0 ] = \"json\";\n\n\t\t// Install callback\n\t\toverwritten = window[ callbackName ];\n\t\twindow[ callbackName ] = function() {\n\t\t\tresponseContainer = arguments;\n\t\t};\n\n\t\t// Clean-up function (fires after converters)\n\t\tjqXHR.always( function() {\n\n\t\t\t// If previous value didn't exist - remove it\n\t\t\tif ( overwritten === undefined ) {\n\t\t\t\tjQuery( window ).removeProp( callbackName );\n\n\t\t\t// Otherwise restore preexisting value\n\t\t\t} else {\n\t\t\t\twindow[ callbackName ] = overwritten;\n\t\t\t}\n\n\t\t\t// Save back as free\n\t\t\tif ( s[ callbackName ] ) {\n\n\t\t\t\t// Make sure that re-using the options doesn't screw things around\n\t\t\t\ts.jsonpCallback = originalSettings.jsonpCallback;\n\n\t\t\t\t// Save the callback name for future use\n\t\t\t\toldCallbacks.push( callbackName );\n\t\t\t}\n\n\t\t\t// Call if it was a function and we have a response\n\t\t\tif ( responseContainer && jQuery.isFunction( overwritten ) ) {\n\t\t\t\toverwritten( responseContainer[ 0 ] );\n\t\t\t}\n\n\t\t\tresponseContainer = overwritten = undefined;\n\t\t} );\n\n\t\t// Delegate to script\n\t\treturn \"script\";\n\t}\n} );\n\n\n\n\n// Argument \"data\" should be string of html\n// context (optional): If specified, the fragment will be created in this context,\n// defaults to document\n// keepScripts (optional): If true, will include scripts passed in the html string\njQuery.parseHTML = function( data, context, keepScripts ) {\n\tif ( !data || typeof data !== \"string\" ) {\n\t\treturn null;\n\t}\n\tif ( typeof context === \"boolean\" ) {\n\t\tkeepScripts = context;\n\t\tcontext = false;\n\t}\n\tcontext = context || document;\n\n\tvar parsed = rsingleTag.exec( data ),\n\t\tscripts = !keepScripts && [];\n\n\t// Single tag\n\tif ( parsed ) {\n\t\treturn [ context.createElement( parsed[ 1 ] ) ];\n\t}\n\n\tparsed = buildFragment( [ data ], context, scripts );\n\n\tif ( scripts && scripts.length ) {\n\t\tjQuery( scripts ).remove();\n\t}\n\n\treturn jQuery.merge( [], parsed.childNodes );\n};\n\n\n// Keep a copy of the old load method\nvar _load = jQuery.fn.load;\n\n/**\n * Load a url into a page\n */\njQuery.fn.load = function( url, params, callback ) {\n\tif ( typeof url !== \"string\" && _load ) {\n\t\treturn _load.apply( this, arguments );\n\t}\n\n\tvar selector, type, response,\n\t\tself = this,\n\t\toff = url.indexOf( \" \" );\n\n\tif ( off > -1 ) {\n\t\tselector = jQuery.trim( url.slice( off ) );\n\t\turl = url.slice( 0, off );\n\t}\n\n\t// If it's a function\n\tif ( jQuery.isFunction( params ) ) {\n\n\t\t// We assume that it's the callback\n\t\tcallback = params;\n\t\tparams = undefined;\n\n\t// Otherwise, build a param string\n\t} else if ( params && typeof params === \"object\" ) {\n\t\ttype = \"POST\";\n\t}\n\n\t// If we have elements to modify, make the request\n\tif ( self.length > 0 ) {\n\t\tjQuery.ajax( {\n\t\t\turl: url,\n\n\t\t\t// If \"type\" variable is undefined, then \"GET\" method will be used.\n\t\t\t// Make value of this field explicit since\n\t\t\t// user can override it through ajaxSetup method\n\t\t\ttype: type || \"GET\",\n\t\t\tdataType: \"html\",\n\t\t\tdata: params\n\t\t} ).done( function( responseText ) {\n\n\t\t\t// Save response for use in complete callback\n\t\t\tresponse = arguments;\n\n\t\t\tself.html( selector ?\n\n\t\t\t\t// If a selector was specified, locate the right elements in a dummy div\n\t\t\t\t// Exclude scripts to avoid IE 'Permission Denied' errors\n\t\t\t\tjQuery( \"<div>\" ).append( jQuery.parseHTML( responseText ) ).find( selector ) :\n\n\t\t\t\t// Otherwise use the full result\n\t\t\t\tresponseText );\n\n\t\t// If the request succeeds, this function gets \"data\", \"status\", \"jqXHR\"\n\t\t// but they are ignored because response was set above.\n\t\t// If it fails, this function gets \"jqXHR\", \"status\", \"error\"\n\t\t} ).always( callback && function( jqXHR, status ) {\n\t\t\tself.each( function() {\n\t\t\t\tcallback.apply( this, response || [ jqXHR.responseText, status, jqXHR ] );\n\t\t\t} );\n\t\t} );\n\t}\n\n\treturn this;\n};\n\n\n\n\n// Attach a bunch of functions for handling common AJAX events\njQuery.each( [\n\t\"ajaxStart\",\n\t\"ajaxStop\",\n\t\"ajaxComplete\",\n\t\"ajaxError\",\n\t\"ajaxSuccess\",\n\t\"ajaxSend\"\n], function( i, type ) {\n\tjQuery.fn[ type ] = function( fn ) {\n\t\treturn this.on( type, fn );\n\t};\n} );\n\n\n\n\njQuery.expr.filters.animated = function( elem ) {\n\treturn jQuery.grep( jQuery.timers, function( fn ) {\n\t\treturn elem === fn.elem;\n\t} ).length;\n};\n\n\n\n\n/**\n * Gets a window from an element\n */\nfunction getWindow( elem ) {\n\treturn jQuery.isWindow( elem ) ? elem : elem.nodeType === 9 && elem.defaultView;\n}\n\njQuery.offset = {\n\tsetOffset: function( elem, options, i ) {\n\t\tvar curPosition, curLeft, curCSSTop, curTop, curOffset, curCSSLeft, calculatePosition,\n\t\t\tposition = jQuery.css( elem, \"position\" ),\n\t\t\tcurElem = jQuery( elem ),\n\t\t\tprops = {};\n\n\t\t// Set position first, in-case top/left are set even on static elem\n\t\tif ( position === \"static\" ) {\n\t\t\telem.style.position = \"relative\";\n\t\t}\n\n\t\tcurOffset = curElem.offset();\n\t\tcurCSSTop = jQuery.css( elem, \"top\" );\n\t\tcurCSSLeft = jQuery.css( elem, \"left\" );\n\t\tcalculatePosition = ( position === \"absolute\" || position === \"fixed\" ) &&\n\t\t\t( curCSSTop + curCSSLeft ).indexOf( \"auto\" ) > -1;\n\n\t\t// Need to be able to calculate position if either\n\t\t// top or left is auto and position is either absolute or fixed\n\t\tif ( calculatePosition ) {\n\t\t\tcurPosition = curElem.position();\n\t\t\tcurTop = curPosition.top;\n\t\t\tcurLeft = curPosition.left;\n\n\t\t} else {\n\t\t\tcurTop = parseFloat( curCSSTop ) || 0;\n\t\t\tcurLeft = parseFloat( curCSSLeft ) || 0;\n\t\t}\n\n\t\tif ( jQuery.isFunction( options ) ) {\n\n\t\t\t// Use jQuery.extend here to allow modification of coordinates argument (gh-1848)\n\t\t\toptions = options.call( elem, i, jQuery.extend( {}, curOffset ) );\n\t\t}\n\n\t\tif ( options.top != null ) {\n\t\t\tprops.top = ( options.top - curOffset.top ) + curTop;\n\t\t}\n\t\tif ( options.left != null ) {\n\t\t\tprops.left = ( options.left - curOffset.left ) + curLeft;\n\t\t}\n\n\t\tif ( \"using\" in options ) {\n\t\t\toptions.using.call( elem, props );\n\n\t\t} else {\n\t\t\tcurElem.css( props );\n\t\t}\n\t}\n};\n\njQuery.fn.extend( {\n\toffset: function( options ) {\n\t\tif ( arguments.length ) {\n\t\t\treturn options === undefined ?\n\t\t\t\tthis :\n\t\t\t\tthis.each( function( i ) {\n\t\t\t\t\tjQuery.offset.setOffset( this, options, i );\n\t\t\t\t} );\n\t\t}\n\n\t\tvar docElem, win,\n\t\t\telem = this[ 0 ],\n\t\t\tbox = { top: 0, left: 0 },\n\t\t\tdoc = elem && elem.ownerDocument;\n\n\t\tif ( !doc ) {\n\t\t\treturn;\n\t\t}\n\n\t\tdocElem = doc.documentElement;\n\n\t\t// Make sure it's not a disconnected DOM node\n\t\tif ( !jQuery.contains( docElem, elem ) ) {\n\t\t\treturn box;\n\t\t}\n\n\t\tbox = elem.getBoundingClientRect();\n\t\twin = getWindow( doc );\n\t\treturn {\n\t\t\ttop: box.top + win.pageYOffset - docElem.clientTop,\n\t\t\tleft: box.left + win.pageXOffset - docElem.clientLeft\n\t\t};\n\t},\n\n\tposition: function() {\n\t\tif ( !this[ 0 ] ) {\n\t\t\treturn;\n\t\t}\n\n\t\tvar offsetParent, offset,\n\t\t\telem = this[ 0 ],\n\t\t\tparentOffset = { top: 0, left: 0 };\n\n\t\t// Fixed elements are offset from window (parentOffset = {top:0, left: 0},\n\t\t// because it is its only offset parent\n\t\tif ( jQuery.css( elem, \"position\" ) === \"fixed\" ) {\n\n\t\t\t// Assume getBoundingClientRect is there when computed position is fixed\n\t\t\toffset = elem.getBoundingClientRect();\n\n\t\t} else {\n\n\t\t\t// Get *real* offsetParent\n\t\t\toffsetParent = this.offsetParent();\n\n\t\t\t// Get correct offsets\n\t\t\toffset = this.offset();\n\t\t\tif ( !jQuery.nodeName( offsetParent[ 0 ], \"html\" ) ) {\n\t\t\t\tparentOffset = offsetParent.offset();\n\t\t\t}\n\n\t\t\t// Add offsetParent borders\n\t\t\tparentOffset.top += jQuery.css( offsetParent[ 0 ], \"borderTopWidth\", true );\n\t\t\tparentOffset.left += jQuery.css( offsetParent[ 0 ], \"borderLeftWidth\", true );\n\t\t}\n\n\t\t// Subtract parent offsets and element margins\n\t\treturn {\n\t\t\ttop: offset.top - parentOffset.top - jQuery.css( elem, \"marginTop\", true ),\n\t\t\tleft: offset.left - parentOffset.left - jQuery.css( elem, \"marginLeft\", true )\n\t\t};\n\t},\n\n\t// This method will return documentElement in the following cases:\n\t// 1) For the element inside the iframe without offsetParent, this method will return\n\t// documentElement of the parent window\n\t// 2) For the hidden or detached element\n\t// 3) For body or html element, i.e. in case of the html node - it will return itself\n\t//\n\t// but those exceptions were never presented as a real life use-cases\n\t// and might be considered as more preferable results.\n\t//\n\t// This logic, however, is not guaranteed and can change at any point in the future\n\toffsetParent: function() {\n\t\treturn this.map( function() {\n\t\t\tvar offsetParent = this.offsetParent;\n\n\t\t\twhile ( offsetParent && jQuery.css( offsetParent, \"position\" ) === \"static\" ) {\n\t\t\t\toffsetParent = offsetParent.offsetParent;\n\t\t\t}\n\n\t\t\treturn offsetParent || documentElement;\n\t\t} );\n\t}\n} );\n\n// Create scrollLeft and scrollTop methods\njQuery.each( { scrollLeft: \"pageXOffset\", scrollTop: \"pageYOffset\" }, function( method, prop ) {\n\tvar top = \"pageYOffset\" === prop;\n\n\tjQuery.fn[ method ] = function( val ) {\n\t\treturn access( this, function( elem, method, val ) {\n\t\t\tvar win = getWindow( elem );\n\n\t\t\tif ( val === undefined ) {\n\t\t\t\treturn win ? win[ prop ] : elem[ method ];\n\t\t\t}\n\n\t\t\tif ( win ) {\n\t\t\t\twin.scrollTo(\n\t\t\t\t\t!top ? val : win.pageXOffset,\n\t\t\t\t\ttop ? val : win.pageYOffset\n\t\t\t\t);\n\n\t\t\t} else {\n\t\t\t\telem[ method ] = val;\n\t\t\t}\n\t\t}, method, val, arguments.length );\n\t};\n} );\n\n// Support: Safari<7-8+, Chrome<37-44+\n// Add the top/left cssHooks using jQuery.fn.position\n// Webkit bug: https://bugs.webkit.org/show_bug.cgi?id=29084\n// Blink bug: https://code.google.com/p/chromium/issues/detail?id=229280\n// getComputedStyle returns percent when specified for top/left/bottom/right;\n// rather than make the css module depend on the offset module, just check for it here\njQuery.each( [ \"top\", \"left\" ], function( i, prop ) {\n\tjQuery.cssHooks[ prop ] = addGetHookIf( support.pixelPosition,\n\t\tfunction( elem, computed ) {\n\t\t\tif ( computed ) {\n\t\t\t\tcomputed = curCSS( elem, prop );\n\n\t\t\t\t// If curCSS returns percentage, fallback to offset\n\t\t\t\treturn rnumnonpx.test( computed ) ?\n\t\t\t\t\tjQuery( elem ).position()[ prop ] + \"px\" :\n\t\t\t\t\tcomputed;\n\t\t\t}\n\t\t}\n\t);\n} );\n\n\n// Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods\njQuery.each( { Height: \"height\", Width: \"width\" }, function( name, type ) {\n\tjQuery.each( { padding: \"inner\" + name, content: type, \"\": \"outer\" + name },\n\t\tfunction( defaultExtra, funcName ) {\n\n\t\t// Margin is only for outerHeight, outerWidth\n\t\tjQuery.fn[ funcName ] = function( margin, value ) {\n\t\t\tvar chainable = arguments.length && ( defaultExtra || typeof margin !== \"boolean\" ),\n\t\t\t\textra = defaultExtra || ( margin === true || value === true ? \"margin\" : \"border\" );\n\n\t\t\treturn access( this, function( elem, type, value ) {\n\t\t\t\tvar doc;\n\n\t\t\t\tif ( jQuery.isWindow( elem ) ) {\n\n\t\t\t\t\t// As of 5/8/2012 this will yield incorrect results for Mobile Safari, but there\n\t\t\t\t\t// isn't a whole lot we can do. See pull request at this URL for discussion:\n\t\t\t\t\t// https://github.com/jquery/jquery/pull/764\n\t\t\t\t\treturn elem.document.documentElement[ \"client\" + name ];\n\t\t\t\t}\n\n\t\t\t\t// Get document width or height\n\t\t\t\tif ( elem.nodeType === 9 ) {\n\t\t\t\t\tdoc = elem.documentElement;\n\n\t\t\t\t\t// Either scroll[Width/Height] or offset[Width/Height] or client[Width/Height],\n\t\t\t\t\t// whichever is greatest\n\t\t\t\t\treturn Math.max(\n\t\t\t\t\t\telem.body[ \"scroll\" + name ], doc[ \"scroll\" + name ],\n\t\t\t\t\t\telem.body[ \"offset\" + name ], doc[ \"offset\" + name ],\n\t\t\t\t\t\tdoc[ \"client\" + name ]\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn value === undefined ?\n\n\t\t\t\t\t// Get width or height on the element, requesting but not forcing parseFloat\n\t\t\t\t\tjQuery.css( elem, type, extra ) :\n\n\t\t\t\t\t// Set width or height on the element\n\t\t\t\t\tjQuery.style( elem, type, value, extra );\n\t\t\t}, type, chainable ? margin : undefined, chainable, null );\n\t\t};\n\t} );\n} );\n\n\njQuery.fn.extend( {\n\n\tbind: function( types, data, fn ) {\n\t\treturn this.on( types, null, data, fn );\n\t},\n\tunbind: function( types, fn ) {\n\t\treturn this.off( types, null, fn );\n\t},\n\n\tdelegate: function( selector, types, data, fn ) {\n\t\treturn this.on( types, selector, data, fn );\n\t},\n\tundelegate: function( selector, types, fn ) {\n\n\t\t// ( namespace ) or ( selector, types [, fn] )\n\t\treturn arguments.length === 1 ?\n\t\t\tthis.off( selector, \"**\" ) :\n\t\t\tthis.off( types, selector || \"**\", fn );\n\t},\n\tsize: function() {\n\t\treturn this.length;\n\t}\n} );\n\njQuery.fn.andSelf = jQuery.fn.addBack;\n\n\n\n\n// Register as a named AMD module, since jQuery can be concatenated with other\n// files that may use define, but not via a proper concatenation script that\n// understands anonymous AMD modules. A named AMD is safest and most robust\n// way to register. Lowercase jquery is used because AMD module names are\n// derived from file names, and jQuery is normally delivered in a lowercase\n// file name. Do this after creating the global so that if an AMD module wants\n// to call noConflict to hide this version of jQuery, it will work.\n\n// Note that for maximum portability, libraries that are not jQuery should\n// declare themselves as anonymous modules, and avoid setting a global if an\n// AMD loader is present. jQuery is a special case. For more information, see\n// https://github.com/jrburke/requirejs/wiki/Updating-existing-libraries#wiki-anon\n\nif ( typeof define === \"function\" && define.amd ) {\n\tdefine( \"jquery\", [], function() {\n\t\treturn jQuery;\n\t} );\n}\n\n\n\nvar\n\n\t// Map over jQuery in case of overwrite\n\t_jQuery = window.jQuery,\n\n\t// Map over the $ in case of overwrite\n\t_$ = window.$;\n\njQuery.noConflict = function( deep ) {\n\tif ( window.$ === jQuery ) {\n\t\twindow.$ = _$;\n\t}\n\n\tif ( deep && window.jQuery === jQuery ) {\n\t\twindow.jQuery = _jQuery;\n\t}\n\n\treturn jQuery;\n};\n\n// Expose jQuery and $ identifiers, even in AMD\n// (#7102#comment:10, https://github.com/jquery/jquery/pull/557)\n// and CommonJS for browser emulators (#13566)\nif ( !noGlobal ) {\n\twindow.jQuery = window.$ = jQuery;\n}\n\nreturn jQuery;\n}));\n","(function() {\n var callWithJQuery;\n\n callWithJQuery = function(pivotModule) {\n if (typeof exports === \"object\" && typeof module === \"object\") {\n return pivotModule(require(\"jquery\"), require(\"d3\"));\n } else if (typeof define === \"function\" && define.amd) {\n return define([\"jquery\", \"d3\"], pivotModule);\n } else {\n return pivotModule(jQuery, d3);\n }\n };\n\n callWithJQuery(function($, d3) {\n return $.pivotUtilities.d3_renderers = {\n Treemap: function(pivotData, opts) {\n var addToTree, color, defaults, height, i, len, ref, result, rowKey, tree, treemap, value, width;\n defaults = {\n localeStrings: {},\n d3: {\n width: function() {\n return $(window).width() / 1.4;\n },\n height: function() {\n return $(window).height() / 1.4;\n }\n }\n };\n opts = $.extend(defaults, opts);\n result = $(\"<div>\").css({\n width: \"100%\",\n height: \"100%\"\n });\n tree = {\n name: \"All\",\n children: []\n };\n addToTree = function(tree, path, value) {\n var child, i, len, newChild, ref, x;\n if (path.length === 0) {\n tree.value = value;\n return;\n }\n if (tree.children == null) {\n tree.children = [];\n }\n x = path.shift();\n ref = tree.children;\n for (i = 0, len = ref.length; i < len; i++) {\n child = ref[i];\n if (!(child.name === x)) {\n continue;\n }\n addToTree(child, path, value);\n return;\n }\n newChild = {\n name: x\n };\n addToTree(newChild, path, value);\n return tree.children.push(newChild);\n };\n ref = pivotData.getRowKeys();\n for (i = 0, len = ref.length; i < len; i++) {\n rowKey = ref[i];\n value = pivotData.getAggregator(rowKey, []).value();\n if (value != null) {\n addToTree(tree, rowKey, value);\n }\n }\n color = d3.scale.category10();\n width = opts.d3.width();\n height = opts.d3.height();\n treemap = d3.layout.treemap().size([width, height]).sticky(true).value(function(d) {\n return d.size;\n });\n d3.select(result[0]).append(\"div\").style(\"position\", \"relative\").style(\"width\", width + \"px\").style(\"height\", height + \"px\").datum(tree).selectAll(\".node\").data(treemap.padding([15, 0, 0, 0]).value(function(d) {\n return d.value;\n }).nodes).enter().append(\"div\").attr(\"class\", \"node\").style(\"background\", function(d) {\n if (d.children != null) {\n return \"lightgrey\";\n } else {\n return color(d.name);\n }\n }).text(function(d) {\n return d.name;\n }).call(function() {\n this.style(\"left\", function(d) {\n return d.x + \"px\";\n }).style(\"top\", function(d) {\n return d.y + \"px\";\n }).style(\"width\", function(d) {\n return Math.max(0, d.dx - 1) + \"px\";\n }).style(\"height\", function(d) {\n return Math.max(0, d.dy - 1) + \"px\";\n });\n });\n return result;\n }\n };\n });\n\n}).call(this);\n\n//# sourceMappingURL=d3_renderers.js.map\n","(function() {\n var callWithJQuery;\n\n callWithJQuery = function(pivotModule) {\n if (typeof exports === \"object\" && typeof module === \"object\") {\n return pivotModule(require(\"jquery\"));\n } else if (typeof define === \"function\" && define.amd) {\n return define([\"jquery\"], pivotModule);\n } else {\n return pivotModule(jQuery);\n }\n };\n\n callWithJQuery(function($) {\n var makeGoogleChart;\n makeGoogleChart = function(chartType, extraOptions) {\n return function(pivotData, opts) {\n var agg, base, base1, colKey, colKeys, dataArray, dataTable, defaults, fullAggName, groupByTitle, h, hAxisTitle, headers, i, j, len, len1, numCharsInHAxis, options, ref, result, row, rowKey, rowKeys, title, tree2, vAxisTitle, val, wrapper, x, y;\n defaults = {\n localeStrings: {\n vs: \"vs\",\n by: \"by\"\n },\n gchart: {}\n };\n opts = $.extend(true, defaults, opts);\n if ((base = opts.gchart).width == null) {\n base.width = window.innerWidth / 1.4;\n }\n if ((base1 = opts.gchart).height == null) {\n base1.height = window.innerHeight / 1.4;\n }\n rowKeys = pivotData.getRowKeys();\n if (rowKeys.length === 0) {\n rowKeys.push([]);\n }\n colKeys = pivotData.getColKeys();\n if (colKeys.length === 0) {\n colKeys.push([]);\n }\n fullAggName = pivotData.aggregatorName;\n if (pivotData.valAttrs.length) {\n fullAggName += \"(\" + (pivotData.valAttrs.join(\", \")) + \")\";\n }\n headers = (function() {\n var i, len, results;\n results = [];\n for (i = 0, len = rowKeys.length; i < len; i++) {\n h = rowKeys[i];\n results.push(h.join(\"-\"));\n }\n return results;\n })();\n headers.unshift(\"\");\n numCharsInHAxis = 0;\n if (chartType === \"ScatterChart\") {\n dataArray = [];\n ref = pivotData.tree;\n for (y in ref) {\n tree2 = ref[y];\n for (x in tree2) {\n agg = tree2[x];\n dataArray.push([parseFloat(x), parseFloat(y), fullAggName + \": \\n\" + agg.format(agg.value())]);\n }\n }\n dataTable = new google.visualization.DataTable();\n dataTable.addColumn('number', pivotData.colAttrs.join(\"-\"));\n dataTable.addColumn('number', pivotData.rowAttrs.join(\"-\"));\n dataTable.addColumn({\n type: \"string\",\n role: \"tooltip\"\n });\n dataTable.addRows(dataArray);\n hAxisTitle = pivotData.colAttrs.join(\"-\");\n vAxisTitle = pivotData.rowAttrs.join(\"-\");\n title = \"\";\n } else {\n dataArray = [headers];\n for (i = 0, len = colKeys.length; i < len; i++) {\n colKey = colKeys[i];\n row = [colKey.join(\"-\")];\n numCharsInHAxis += row[0].length;\n for (j = 0, len1 = rowKeys.length; j < len1; j++) {\n rowKey = rowKeys[j];\n agg = pivotData.getAggregator(rowKey, colKey);\n if (agg.value() != null) {\n val = agg.value();\n if ($.isNumeric(val)) {\n if (val < 1) {\n row.push(parseFloat(val.toPrecision(3)));\n } else {\n row.push(parseFloat(val.toFixed(3)));\n }\n } else {\n row.push(val);\n }\n } else {\n row.push(null);\n }\n }\n dataArray.push(row);\n }\n dataTable = google.visualization.arrayToDataTable(dataArray);\n title = vAxisTitle = fullAggName;\n hAxisTitle = pivotData.colAttrs.join(\"-\");\n if (hAxisTitle !== \"\") {\n title += \" \" + opts.localeStrings.vs + \" \" + hAxisTitle;\n }\n groupByTitle = pivotData.rowAttrs.join(\"-\");\n if (groupByTitle !== \"\") {\n title += \" \" + opts.localeStrings.by + \" \" + groupByTitle;\n }\n }\n options = {\n title: title,\n hAxis: {\n title: hAxisTitle,\n slantedText: numCharsInHAxis > 50\n },\n vAxis: {\n title: vAxisTitle\n },\n tooltip: {\n textStyle: {\n fontName: 'Arial',\n fontSize: 12\n }\n }\n };\n if (chartType === \"ColumnChart\") {\n options.vAxis.minValue = 0;\n }\n if (chartType === \"ScatterChart\") {\n options.legend = {\n position: \"none\"\n };\n options.chartArea = {\n 'width': '80%',\n 'height': '80%'\n };\n } else if (dataArray[0].length === 2 && dataArray[0][1] === \"\") {\n options.legend = {\n position: \"none\"\n };\n }\n $.extend(options, opts.gchart, extraOptions);\n result = $(\"<div>\").css({\n width: \"100%\",\n height: \"100%\"\n });\n wrapper = new google.visualization.ChartWrapper({\n dataTable: dataTable,\n chartType: chartType,\n options: options\n });\n wrapper.draw(result[0]);\n result.bind(\"dblclick\", function() {\n var editor;\n editor = new google.visualization.ChartEditor();\n google.visualization.events.addListener(editor, 'ok', function() {\n return editor.getChartWrapper().draw(result[0]);\n });\n return editor.openDialog(wrapper);\n });\n return result;\n };\n };\n return $.pivotUtilities.gchart_renderers = {\n \"Line Chart\": makeGoogleChart(\"LineChart\"),\n \"Bar Chart\": makeGoogleChart(\"ColumnChart\"),\n \"Stacked Bar Chart\": makeGoogleChart(\"ColumnChart\", {\n isStacked: true\n }),\n \"Area Chart\": makeGoogleChart(\"AreaChart\", {\n isStacked: true\n }),\n \"Scatter Chart\": makeGoogleChart(\"ScatterChart\")\n };\n });\n\n}).call(this);\n\n//# sourceMappingURL=gchart_renderers.js.map\n","(function() {\n var callWithJQuery,\n indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; },\n slice = [].slice,\n bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n hasProp = {}.hasOwnProperty;\n\n callWithJQuery = function(pivotModule) {\n if (typeof exports === \"object\" && typeof module === \"object\") {\n return pivotModule(require(\"jquery\"));\n } else if (typeof define === \"function\" && define.amd) {\n return define([\"jquery\"], pivotModule);\n } else {\n return pivotModule(jQuery);\n }\n };\n\n callWithJQuery(function($) {\n\n /*\n Utilities\n */\n var PivotData, addSeparators, aggregatorTemplates, aggregators, dayNamesEn, derivers, getSort, locales, mthNamesEn, naturalSort, numberFormat, pivotTableRenderer, renderers, sortAs, usFmt, usFmtInt, usFmtPct, zeroPad;\n addSeparators = function(nStr, thousandsSep, decimalSep) {\n var rgx, x, x1, x2;\n nStr += '';\n x = nStr.split('.');\n x1 = x[0];\n x2 = x.length > 1 ? decimalSep + x[1] : '';\n rgx = /(\\d+)(\\d{3})/;\n while (rgx.test(x1)) {\n x1 = x1.replace(rgx, '$1' + thousandsSep + '$2');\n }\n return x1 + x2;\n };\n numberFormat = function(opts) {\n var defaults;\n defaults = {\n digitsAfterDecimal: 2,\n scaler: 1,\n thousandsSep: \",\",\n decimalSep: \".\",\n prefix: \"\",\n suffix: \"\",\n showZero: false\n };\n opts = $.extend(defaults, opts);\n return function(x) {\n var result;\n if (isNaN(x) || !isFinite(x)) {\n return \"\";\n }\n if (x === 0 && !opts.showZero) {\n return \"\";\n }\n result = addSeparators((opts.scaler * x).toFixed(opts.digitsAfterDecimal), opts.thousandsSep, opts.decimalSep);\n return \"\" + opts.prefix + result + opts.suffix;\n };\n };\n usFmt = numberFormat();\n usFmtInt = numberFormat({\n digitsAfterDecimal: 0\n });\n usFmtPct = numberFormat({\n digitsAfterDecimal: 1,\n scaler: 100,\n suffix: \"%\"\n });\n aggregatorTemplates = {\n count: function(formatter) {\n if (formatter == null) {\n formatter = usFmtInt;\n }\n return function() {\n return function(data, rowKey, colKey) {\n return {\n count: 0,\n push: function() {\n return this.count++;\n },\n value: function() {\n return this.count;\n },\n format: formatter\n };\n };\n };\n },\n countUnique: function(formatter) {\n if (formatter == null) {\n formatter = usFmtInt;\n }\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n uniq: [],\n push: function(record) {\n var ref;\n if (ref = record[attr], indexOf.call(this.uniq, ref) < 0) {\n return this.uniq.push(record[attr]);\n }\n },\n value: function() {\n return this.uniq.length;\n },\n format: formatter,\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n listUnique: function(sep) {\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n uniq: [],\n push: function(record) {\n var ref;\n if (ref = record[attr], indexOf.call(this.uniq, ref) < 0) {\n return this.uniq.push(record[attr]);\n }\n },\n value: function() {\n return this.uniq.join(sep);\n },\n format: function(x) {\n return x;\n },\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n sum: function(formatter) {\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n sum: 0,\n push: function(record) {\n if (!isNaN(parseFloat(record[attr]))) {\n return this.sum += parseFloat(record[attr]);\n }\n },\n value: function() {\n return this.sum;\n },\n format: formatter,\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n min: function(formatter) {\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n val: null,\n push: function(record) {\n var ref, x;\n x = parseFloat(record[attr]);\n if (!isNaN(x)) {\n return this.val = Math.min(x, (ref = this.val) != null ? ref : x);\n }\n },\n value: function() {\n return this.val;\n },\n format: formatter,\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n max: function(formatter) {\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n val: null,\n push: function(record) {\n var ref, x;\n x = parseFloat(record[attr]);\n if (!isNaN(x)) {\n return this.val = Math.max(x, (ref = this.val) != null ? ref : x);\n }\n },\n value: function() {\n return this.val;\n },\n format: formatter,\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n average: function(formatter) {\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var attr;\n attr = arg[0];\n return function(data, rowKey, colKey) {\n return {\n sum: 0,\n len: 0,\n push: function(record) {\n if (!isNaN(parseFloat(record[attr]))) {\n this.sum += parseFloat(record[attr]);\n return this.len++;\n }\n },\n value: function() {\n return this.sum / this.len;\n },\n format: formatter,\n numInputs: attr != null ? 0 : 1\n };\n };\n };\n },\n sumOverSum: function(formatter) {\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var denom, num;\n num = arg[0], denom = arg[1];\n return function(data, rowKey, colKey) {\n return {\n sumNum: 0,\n sumDenom: 0,\n push: function(record) {\n if (!isNaN(parseFloat(record[num]))) {\n this.sumNum += parseFloat(record[num]);\n }\n if (!isNaN(parseFloat(record[denom]))) {\n return this.sumDenom += parseFloat(record[denom]);\n }\n },\n value: function() {\n return this.sumNum / this.sumDenom;\n },\n format: formatter,\n numInputs: (num != null) && (denom != null) ? 0 : 2\n };\n };\n };\n },\n sumOverSumBound80: function(upper, formatter) {\n if (upper == null) {\n upper = true;\n }\n if (formatter == null) {\n formatter = usFmt;\n }\n return function(arg) {\n var denom, num;\n num = arg[0], denom = arg[1];\n return function(data, rowKey, colKey) {\n return {\n sumNum: 0,\n sumDenom: 0,\n push: function(record) {\n if (!isNaN(parseFloat(record[num]))) {\n this.sumNum += parseFloat(record[num]);\n }\n if (!isNaN(parseFloat(record[denom]))) {\n return this.sumDenom += parseFloat(record[denom]);\n }\n },\n value: function() {\n var sign;\n sign = upper ? 1 : -1;\n return (0.821187207574908 / this.sumDenom + this.sumNum / this.sumDenom + 1.2815515655446004 * sign * Math.sqrt(0.410593603787454 / (this.sumDenom * this.sumDenom) + (this.sumNum * (1 - this.sumNum / this.sumDenom)) / (this.sumDenom * this.sumDenom))) / (1 + 1.642374415149816 / this.sumDenom);\n },\n format: formatter,\n numInputs: (num != null) && (denom != null) ? 0 : 2\n };\n };\n };\n },\n fractionOf: function(wrapped, type, formatter) {\n if (type == null) {\n type = \"total\";\n }\n if (formatter == null) {\n formatter = usFmtPct;\n }\n return function() {\n var x;\n x = 1 <= arguments.length ? slice.call(arguments, 0) : [];\n return function(data, rowKey, colKey) {\n return {\n selector: {\n total: [[], []],\n row: [rowKey, []],\n col: [[], colKey]\n }[type],\n inner: wrapped.apply(null, x)(data, rowKey, colKey),\n push: function(record) {\n return this.inner.push(record);\n },\n format: formatter,\n value: function() {\n return this.inner.value() / data.getAggregator.apply(data, this.selector).inner.value();\n },\n numInputs: wrapped.apply(null, x)().numInputs\n };\n };\n };\n }\n };\n aggregators = (function(tpl) {\n return {\n \"Count\": tpl.count(usFmtInt),\n \"Count Unique Values\": tpl.countUnique(usFmtInt),\n \"List Unique Values\": tpl.listUnique(\", \"),\n \"Sum\": tpl.sum(usFmt),\n \"Integer Sum\": tpl.sum(usFmtInt),\n \"Average\": tpl.average(usFmt),\n \"Minimum\": tpl.min(usFmt),\n \"Maximum\": tpl.max(usFmt),\n \"Sum over Sum\": tpl.sumOverSum(usFmt),\n \"80% Upper Bound\": tpl.sumOverSumBound80(true, usFmt),\n \"80% Lower Bound\": tpl.sumOverSumBound80(false, usFmt),\n \"Sum as Fraction of Total\": tpl.fractionOf(tpl.sum(), \"total\", usFmtPct),\n \"Sum as Fraction of Rows\": tpl.fractionOf(tpl.sum(), \"row\", usFmtPct),\n \"Sum as Fraction of Columns\": tpl.fractionOf(tpl.sum(), \"col\", usFmtPct),\n \"Count as Fraction of Total\": tpl.fractionOf(tpl.count(), \"total\", usFmtPct),\n \"Count as Fraction of Rows\": tpl.fractionOf(tpl.count(), \"row\", usFmtPct),\n \"Count as Fraction of Columns\": tpl.fractionOf(tpl.count(), \"col\", usFmtPct)\n };\n })(aggregatorTemplates);\n renderers = {\n \"Table\": function(data, opts) {\n return pivotTableRenderer(data, opts);\n },\n \"Table Barchart\": function(data, opts) {\n return $(pivotTableRenderer(data, opts)).barchart();\n },\n \"Heatmap\": function(data, opts) {\n return $(pivotTableRenderer(data, opts)).heatmap(\"heatmap\", opts);\n },\n \"Row Heatmap\": function(data, opts) {\n return $(pivotTableRenderer(data, opts)).heatmap(\"rowheatmap\", opts);\n },\n \"Col Heatmap\": function(data, opts) {\n return $(pivotTableRenderer(data, opts)).heatmap(\"colheatmap\", opts);\n }\n };\n locales = {\n en: {\n aggregators: aggregators,\n renderers: renderers,\n localeStrings: {\n renderError: \"An error occurred rendering the PivotTable results.\",\n computeError: \"An error occurred computing the PivotTable results.\",\n uiRenderError: \"An error occurred rendering the PivotTable UI.\",\n selectAll: \"Select All\",\n selectNone: \"Select None\",\n tooMany: \"(too many to list)\",\n filterResults: \"Filter results\",\n totals: \"Totals\",\n vs: \"vs\",\n by: \"by\"\n }\n }\n };\n mthNamesEn = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\n dayNamesEn = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\n zeroPad = function(number) {\n return (\"0\" + number).substr(-2, 2);\n };\n derivers = {\n bin: function(col, binWidth) {\n return function(record) {\n return record[col] - record[col] % binWidth;\n };\n },\n dateFormat: function(col, formatString, utcOutput, mthNames, dayNames) {\n var utc;\n if (utcOutput == null) {\n utcOutput = false;\n }\n if (mthNames == null) {\n mthNames = mthNamesEn;\n }\n if (dayNames == null) {\n dayNames = dayNamesEn;\n }\n utc = utcOutput ? \"UTC\" : \"\";\n return function(record) {\n var date;\n date = new Date(Date.parse(record[col]));\n if (isNaN(date)) {\n return \"\";\n }\n return formatString.replace(/%(.)/g, function(m, p) {\n switch (p) {\n case \"y\":\n return date[\"get\" + utc + \"FullYear\"]();\n case \"m\":\n return zeroPad(date[\"get\" + utc + \"Month\"]() + 1);\n case \"n\":\n return mthNames[date[\"get\" + utc + \"Month\"]()];\n case \"d\":\n return zeroPad(date[\"get\" + utc + \"Date\"]());\n case \"w\":\n return dayNames[date[\"get\" + utc + \"Day\"]()];\n case \"x\":\n return date[\"get\" + utc + \"Day\"]();\n case \"H\":\n return zeroPad(date[\"get\" + utc + \"Hours\"]());\n case \"M\":\n return zeroPad(date[\"get\" + utc + \"Minutes\"]());\n case \"S\":\n return zeroPad(date[\"get\" + utc + \"Seconds\"]());\n default:\n return \"%\" + p;\n }\n });\n };\n }\n };\n naturalSort = (function(_this) {\n return function(as, bs) {\n var a, a1, b, b1, rd, rx, rz;\n rx = /(\\d+)|(\\D+)/g;\n rd = /\\d/;\n rz = /^0/;\n if (typeof as === \"number\" || typeof bs === \"number\") {\n if (isNaN(as)) {\n return 1;\n }\n if (isNaN(bs)) {\n return -1;\n }\n return as - bs;\n }\n a = String(as).toLowerCase();\n b = String(bs).toLowerCase();\n if (a === b) {\n return 0;\n }\n if (!(rd.test(a) && rd.test(b))) {\n return (a > b ? 1 : -1);\n }\n a = a.match(rx);\n b = b.match(rx);\n while (a.length && b.length) {\n a1 = a.shift();\n b1 = b.shift();\n if (a1 !== b1) {\n if (rd.test(a1) && rd.test(b1)) {\n return a1.replace(rz, \".0\") - b1.replace(rz, \".0\");\n } else {\n return (a1 > b1 ? 1 : -1);\n }\n }\n }\n return a.length - b.length;\n };\n })(this);\n sortAs = function(order) {\n var i, mapping, x;\n mapping = {};\n for (i in order) {\n x = order[i];\n mapping[x] = i;\n }\n return function(a, b) {\n if ((mapping[a] != null) && (mapping[b] != null)) {\n return mapping[a] - mapping[b];\n } else if (mapping[a] != null) {\n return -1;\n } else if (mapping[b] != null) {\n return 1;\n } else {\n return naturalSort(a, b);\n }\n };\n };\n getSort = function(sorters, attr) {\n var sort;\n sort = sorters(attr);\n if ($.isFunction(sort)) {\n return sort;\n } else {\n return naturalSort;\n }\n };\n\n /*\n Data Model class\n */\n PivotData = (function() {\n function PivotData(input, opts) {\n this.getAggregator = bind(this.getAggregator, this);\n this.getRowKeys = bind(this.getRowKeys, this);\n this.getColKeys = bind(this.getColKeys, this);\n this.sortKeys = bind(this.sortKeys, this);\n this.arrSort = bind(this.arrSort, this);\n this.aggregator = opts.aggregator;\n this.aggregatorName = opts.aggregatorName;\n this.colAttrs = opts.cols;\n this.rowAttrs = opts.rows;\n this.valAttrs = opts.vals;\n this.sorters = opts.sorters;\n this.tree = {};\n this.rowKeys = [];\n this.colKeys = [];\n this.rowTotals = {};\n this.colTotals = {};\n this.allTotal = this.aggregator(this, [], []);\n this.sorted = false;\n PivotData.forEachRecord(input, opts.derivedAttributes, (function(_this) {\n return function(record) {\n if (opts.filter(record)) {\n return _this.processRecord(record);\n }\n };\n })(this));\n }\n\n PivotData.forEachRecord = function(input, derivedAttributes, f) {\n var addRecord, compactRecord, i, j, k, l, len1, record, ref, results, results1, tblCols;\n if ($.isEmptyObject(derivedAttributes)) {\n addRecord = f;\n } else {\n addRecord = function(record) {\n var k, ref, v;\n for (k in derivedAttributes) {\n v = derivedAttributes[k];\n record[k] = (ref = v(record)) != null ? ref : record[k];\n }\n return f(record);\n };\n }\n if ($.isFunction(input)) {\n return input(addRecord);\n } else if ($.isArray(input)) {\n if ($.isArray(input[0])) {\n results = [];\n for (i in input) {\n if (!hasProp.call(input, i)) continue;\n compactRecord = input[i];\n if (!(i > 0)) {\n continue;\n }\n record = {};\n ref = input[0];\n for (j in ref) {\n if (!hasProp.call(ref, j)) continue;\n k = ref[j];\n record[k] = compactRecord[j];\n }\n results.push(addRecord(record));\n }\n return results;\n } else {\n results1 = [];\n for (l = 0, len1 = input.length; l < len1; l++) {\n record = input[l];\n results1.push(addRecord(record));\n }\n return results1;\n }\n } else if (input instanceof jQuery) {\n tblCols = [];\n $(\"thead > tr > th\", input).each(function(i) {\n return tblCols.push($(this).text());\n });\n return $(\"tbody > tr\", input).each(function(i) {\n record = {};\n $(\"td\", this).each(function(j) {\n return record[tblCols[j]] = $(this).text();\n });\n return addRecord(record);\n });\n } else {\n throw new Error(\"unknown input format\");\n }\n };\n\n PivotData.convertToArray = function(input) {\n var result;\n result = [];\n PivotData.forEachRecord(input, {}, function(record) {\n return result.push(record);\n });\n return result;\n };\n\n PivotData.prototype.arrSort = function(attrs) {\n var a, sortersArr;\n sortersArr = (function() {\n var l, len1, results;\n results = [];\n for (l = 0, len1 = attrs.length; l < len1; l++) {\n a = attrs[l];\n results.push(getSort(this.sorters, a));\n }\n return results;\n }).call(this);\n return function(a, b) {\n var comparison, i, sorter;\n for (i in sortersArr) {\n if (!hasProp.call(sortersArr, i)) continue;\n sorter = sortersArr[i];\n comparison = sorter(a[i], b[i]);\n if (comparison !== 0) {\n return comparison;\n }\n }\n return 0;\n };\n };\n\n PivotData.prototype.sortKeys = function() {\n if (!this.sorted) {\n this.sorted = true;\n this.rowKeys.sort(this.arrSort(this.rowAttrs));\n return this.colKeys.sort(this.arrSort(this.colAttrs));\n }\n };\n\n PivotData.prototype.getColKeys = function() {\n this.sortKeys();\n return this.colKeys;\n };\n\n PivotData.prototype.getRowKeys = function() {\n this.sortKeys();\n return this.rowKeys;\n };\n\n PivotData.prototype.processRecord = function(record) {\n var colKey, flatColKey, flatRowKey, l, len1, len2, n, ref, ref1, ref2, ref3, rowKey, x;\n colKey = [];\n rowKey = [];\n ref = this.colAttrs;\n for (l = 0, len1 = ref.length; l < len1; l++) {\n x = ref[l];\n colKey.push((ref1 = record[x]) != null ? ref1 : \"null\");\n }\n ref2 = this.rowAttrs;\n for (n = 0, len2 = ref2.length; n < len2; n++) {\n x = ref2[n];\n rowKey.push((ref3 = record[x]) != null ? ref3 : \"null\");\n }\n flatRowKey = rowKey.join(String.fromCharCode(0));\n flatColKey = colKey.join(String.fromCharCode(0));\n this.allTotal.push(record);\n if (rowKey.length !== 0) {\n if (!this.rowTotals[flatRowKey]) {\n this.rowKeys.push(rowKey);\n this.rowTotals[flatRowKey] = this.aggregator(this, rowKey, []);\n }\n this.rowTotals[flatRowKey].push(record);\n }\n if (colKey.length !== 0) {\n if (!this.colTotals[flatColKey]) {\n this.colKeys.push(colKey);\n this.colTotals[flatColKey] = this.aggregator(this, [], colKey);\n }\n this.colTotals[flatColKey].push(record);\n }\n if (colKey.length !== 0 && rowKey.length !== 0) {\n if (!this.tree[flatRowKey]) {\n this.tree[flatRowKey] = {};\n }\n if (!this.tree[flatRowKey][flatColKey]) {\n this.tree[flatRowKey][flatColKey] = this.aggregator(this, rowKey, colKey);\n }\n return this.tree[flatRowKey][flatColKey].push(record);\n }\n };\n\n PivotData.prototype.getAggregator = function(rowKey, colKey) {\n var agg, flatColKey, flatRowKey;\n flatRowKey = rowKey.join(String.fromCharCode(0));\n flatColKey = colKey.join(String.fromCharCode(0));\n if (rowKey.length === 0 && colKey.length === 0) {\n agg = this.allTotal;\n } else if (rowKey.length === 0) {\n agg = this.colTotals[flatColKey];\n } else if (colKey.length === 0) {\n agg = this.rowTotals[flatRowKey];\n } else {\n agg = this.tree[flatRowKey][flatColKey];\n }\n return agg != null ? agg : {\n value: (function() {\n return null;\n }),\n format: function() {\n return \"\";\n }\n };\n };\n\n return PivotData;\n\n })();\n $.pivotUtilities = {\n aggregatorTemplates: aggregatorTemplates,\n aggregators: aggregators,\n renderers: renderers,\n derivers: derivers,\n locales: locales,\n naturalSort: naturalSort,\n numberFormat: numberFormat,\n sortAs: sortAs,\n PivotData: PivotData\n };\n\n /*\n Default Renderer for hierarchical table layout\n */\n pivotTableRenderer = function(pivotData, opts) {\n var aggregator, c, colAttrs, colKey, colKeys, defaults, i, j, r, result, rowAttrs, rowKey, rowKeys, spanSize, tbody, td, th, thead, totalAggregator, tr, txt, val, x;\n defaults = {\n localeStrings: {\n totals: \"Totals\"\n }\n };\n opts = $.extend(defaults, opts);\n colAttrs = pivotData.colAttrs;\n rowAttrs = pivotData.rowAttrs;\n rowKeys = pivotData.getRowKeys();\n colKeys = pivotData.getColKeys();\n result = document.createElement(\"table\");\n result.className = \"pvtTable\";\n spanSize = function(arr, i, j) {\n var l, len, n, noDraw, ref, ref1, stop, x;\n if (i !== 0) {\n noDraw = true;\n for (x = l = 0, ref = j; 0 <= ref ? l <= ref : l >= ref; x = 0 <= ref ? ++l : --l) {\n if (arr[i - 1][x] !== arr[i][x]) {\n noDraw = false;\n }\n }\n if (noDraw) {\n return -1;\n }\n }\n len = 0;\n while (i + len < arr.length) {\n stop = false;\n for (x = n = 0, ref1 = j; 0 <= ref1 ? n <= ref1 : n >= ref1; x = 0 <= ref1 ? ++n : --n) {\n if (arr[i][x] !== arr[i + len][x]) {\n stop = true;\n }\n }\n if (stop) {\n break;\n }\n len++;\n }\n return len;\n };\n thead = document.createElement(\"thead\");\n for (j in colAttrs) {\n if (!hasProp.call(colAttrs, j)) continue;\n c = colAttrs[j];\n tr = document.createElement(\"tr\");\n if (parseInt(j) === 0 && rowAttrs.length !== 0) {\n th = document.createElement(\"th\");\n th.setAttribute(\"colspan\", rowAttrs.length);\n th.setAttribute(\"rowspan\", colAttrs.length);\n tr.appendChild(th);\n }\n th = document.createElement(\"th\");\n th.className = \"pvtAxisLabel\";\n th.textContent = c;\n tr.appendChild(th);\n for (i in colKeys) {\n if (!hasProp.call(colKeys, i)) continue;\n colKey = colKeys[i];\n x = spanSize(colKeys, parseInt(i), parseInt(j));\n if (x !== -1) {\n th = document.createElement(\"th\");\n th.className = \"pvtColLabel\";\n th.textContent = colKey[j];\n th.setAttribute(\"colspan\", x);\n if (parseInt(j) === colAttrs.length - 1 && rowAttrs.length !== 0) {\n th.setAttribute(\"rowspan\", 2);\n }\n tr.appendChild(th);\n }\n }\n if (parseInt(j) === 0) {\n th = document.createElement(\"th\");\n th.className = \"pvtTotalLabel\";\n th.innerHTML = opts.localeStrings.totals;\n th.setAttribute(\"rowspan\", colAttrs.length + (rowAttrs.length === 0 ? 0 : 1));\n tr.appendChild(th);\n }\n thead.appendChild(tr);\n }\n if (rowAttrs.length !== 0) {\n tr = document.createElement(\"tr\");\n for (i in rowAttrs) {\n if (!hasProp.call(rowAttrs, i)) continue;\n r = rowAttrs[i];\n th = document.createElement(\"th\");\n th.className = \"pvtAxisLabel\";\n th.textContent = r;\n tr.appendChild(th);\n }\n th = document.createElement(\"th\");\n if (colAttrs.length === 0) {\n th.className = \"pvtTotalLabel\";\n th.innerHTML = opts.localeStrings.totals;\n }\n tr.appendChild(th);\n thead.appendChild(tr);\n }\n result.appendChild(thead);\n tbody = document.createElement(\"tbody\");\n for (i in rowKeys) {\n if (!hasProp.call(rowKeys, i)) continue;\n rowKey = rowKeys[i];\n tr = document.createElement(\"tr\");\n for (j in rowKey) {\n if (!hasProp.call(rowKey, j)) continue;\n txt = rowKey[j];\n x = spanSize(rowKeys, parseInt(i), parseInt(j));\n if (x !== -1) {\n th = document.createElement(\"th\");\n th.className = \"pvtRowLabel\";\n th.textContent = txt;\n th.setAttribute(\"rowspan\", x);\n if (parseInt(j) === rowAttrs.length - 1 && colAttrs.length !== 0) {\n th.setAttribute(\"colspan\", 2);\n }\n tr.appendChild(th);\n }\n }\n for (j in colKeys) {\n if (!hasProp.call(colKeys, j)) continue;\n colKey = colKeys[j];\n aggregator = pivotData.getAggregator(rowKey, colKey);\n val = aggregator.value();\n td = document.createElement(\"td\");\n td.className = \"pvtVal row\" + i + \" col\" + j;\n td.textContent = aggregator.format(val);\n td.setAttribute(\"data-value\", val);\n tr.appendChild(td);\n }\n totalAggregator = pivotData.getAggregator(rowKey, []);\n val = totalAggregator.value();\n td = document.createElement(\"td\");\n td.className = \"pvtTotal rowTotal\";\n td.textContent = totalAggregator.format(val);\n td.setAttribute(\"data-value\", val);\n td.setAttribute(\"data-for\", \"row\" + i);\n tr.appendChild(td);\n tbody.appendChild(tr);\n }\n tr = document.createElement(\"tr\");\n th = document.createElement(\"th\");\n th.className = \"pvtTotalLabel\";\n th.innerHTML = opts.localeStrings.totals;\n th.setAttribute(\"colspan\", rowAttrs.length + (colAttrs.length === 0 ? 0 : 1));\n tr.appendChild(th);\n for (j in colKeys) {\n if (!hasProp.call(colKeys, j)) continue;\n colKey = colKeys[j];\n totalAggregator = pivotData.getAggregator([], colKey);\n val = totalAggregator.value();\n td = document.createElement(\"td\");\n td.className = \"pvtTotal colTotal\";\n td.textContent = totalAggregator.format(val);\n td.setAttribute(\"data-value\", val);\n td.setAttribute(\"data-for\", \"col\" + j);\n tr.appendChild(td);\n }\n totalAggregator = pivotData.getAggregator([], []);\n val = totalAggregator.value();\n td = document.createElement(\"td\");\n td.className = \"pvtGrandTotal\";\n td.textContent = totalAggregator.format(val);\n td.setAttribute(\"data-value\", val);\n tr.appendChild(td);\n tbody.appendChild(tr);\n result.appendChild(tbody);\n result.setAttribute(\"data-numrows\", rowKeys.length);\n result.setAttribute(\"data-numcols\", colKeys.length);\n return result;\n };\n\n /*\n Pivot Table core: create PivotData object and call Renderer on it\n */\n $.fn.pivot = function(input, opts) {\n var defaults, e, error, error1, pivotData, result, x;\n defaults = {\n cols: [],\n rows: [],\n vals: [],\n dataClass: PivotData,\n filter: function() {\n return true;\n },\n aggregator: aggregatorTemplates.count()(),\n aggregatorName: \"Count\",\n sorters: function() {},\n derivedAttributes: {},\n renderer: pivotTableRenderer,\n rendererOptions: null,\n localeStrings: locales.en.localeStrings\n };\n opts = $.extend(defaults, opts);\n result = null;\n try {\n pivotData = new opts.dataClass(input, opts);\n try {\n result = opts.renderer(pivotData, opts.rendererOptions);\n } catch (error) {\n e = error;\n if (typeof console !== \"undefined\" && console !== null) {\n console.error(e.stack);\n }\n result = $(\"<span>\").html(opts.localeStrings.renderError);\n }\n } catch (error1) {\n e = error1;\n if (typeof console !== \"undefined\" && console !== null) {\n console.error(e.stack);\n }\n result = $(\"<span>\").html(opts.localeStrings.computeError);\n }\n x = this[0];\n while (x.hasChildNodes()) {\n x.removeChild(x.lastChild);\n }\n return this.append(result);\n };\n\n /*\n Pivot Table UI: calls Pivot Table core above with options set by user\n */\n $.fn.pivotUI = function(input, inputOpts, overwrite, locale) {\n var a, aggregator, attrLength, axisValues, c, colList, defaults, e, error, existingOpts, fn, i, initialRender, k, l, len1, len2, len3, len4, n, o, opts, pivotTable, q, ref, ref1, ref2, ref3, ref4, refresh, refreshDelayed, renderer, rendererControl, shownAttributes, tblCols, tr1, tr2, uiTable, unusedAttrsVerticalAutoCutoff, unusedAttrsVerticalAutoOverride, x;\n if (overwrite == null) {\n overwrite = false;\n }\n if (locale == null) {\n locale = \"en\";\n }\n if (locales[locale] == null) {\n locale = \"en\";\n }\n defaults = {\n derivedAttributes: {},\n aggregators: locales[locale].aggregators,\n renderers: locales[locale].renderers,\n hiddenAttributes: [],\n menuLimit: 200,\n cols: [],\n rows: [],\n vals: [],\n dataClass: PivotData,\n exclusions: {},\n inclusions: {},\n unusedAttrsVertical: 85,\n autoSortUnusedAttrs: false,\n rendererOptions: {\n localeStrings: locales[locale].localeStrings\n },\n onRefresh: null,\n filter: function() {\n return true;\n },\n sorters: function() {},\n localeStrings: locales[locale].localeStrings\n };\n existingOpts = this.data(\"pivotUIOptions\");\n if ((existingOpts == null) || overwrite) {\n opts = $.extend(defaults, inputOpts);\n } else {\n opts = existingOpts;\n }\n try {\n input = PivotData.convertToArray(input);\n tblCols = (function() {\n var ref, results;\n ref = input[0];\n results = [];\n for (k in ref) {\n if (!hasProp.call(ref, k)) continue;\n results.push(k);\n }\n return results;\n })();\n ref = opts.derivedAttributes;\n for (c in ref) {\n if (!hasProp.call(ref, c)) continue;\n if ((indexOf.call(tblCols, c) < 0)) {\n tblCols.push(c);\n }\n }\n axisValues = {};\n for (l = 0, len1 = tblCols.length; l < len1; l++) {\n x = tblCols[l];\n axisValues[x] = {};\n }\n PivotData.forEachRecord(input, opts.derivedAttributes, function(record) {\n var base, results, v;\n results = [];\n for (k in record) {\n if (!hasProp.call(record, k)) continue;\n v = record[k];\n if (!(opts.filter(record))) {\n continue;\n }\n if (v == null) {\n v = \"null\";\n }\n if ((base = axisValues[k])[v] == null) {\n base[v] = 0;\n }\n results.push(axisValues[k][v]++);\n }\n return results;\n });\n uiTable = $(\"<table>\", {\n \"class\": \"pvtUi\"\n }).attr(\"cellpadding\", 5);\n rendererControl = $(\"<td>\");\n renderer = $(\"<select>\").addClass('pvtRenderer').appendTo(rendererControl).bind(\"change\", function() {\n return refresh();\n });\n ref1 = opts.renderers;\n for (x in ref1) {\n if (!hasProp.call(ref1, x)) continue;\n $(\"<option>\").val(x).html(x).appendTo(renderer);\n }\n colList = $(\"<td>\").addClass('pvtAxisContainer pvtUnused');\n shownAttributes = (function() {\n var len2, n, results;\n results = [];\n for (n = 0, len2 = tblCols.length; n < len2; n++) {\n c = tblCols[n];\n if (indexOf.call(opts.hiddenAttributes, c) < 0) {\n results.push(c);\n }\n }\n return results;\n })();\n unusedAttrsVerticalAutoOverride = false;\n if (opts.unusedAttrsVertical === \"auto\") {\n unusedAttrsVerticalAutoCutoff = 120;\n } else {\n unusedAttrsVerticalAutoCutoff = parseInt(opts.unusedAttrsVertical);\n }\n if (!isNaN(unusedAttrsVerticalAutoCutoff)) {\n attrLength = 0;\n for (n = 0, len2 = shownAttributes.length; n < len2; n++) {\n a = shownAttributes[n];\n attrLength += a.length;\n }\n unusedAttrsVerticalAutoOverride = attrLength > unusedAttrsVerticalAutoCutoff;\n }\n if (opts.unusedAttrsVertical === true || unusedAttrsVerticalAutoOverride) {\n colList.addClass('pvtVertList');\n } else {\n colList.addClass('pvtHorizList');\n }\n fn = function(c) {\n var attrElem, btns, checkContainer, filterItem, filterItemExcluded, hasExcludedItem, keys, len3, o, ref2, showFilterList, triangleLink, updateFilter, v, valueList;\n keys = (function() {\n var results;\n results = [];\n for (k in axisValues[c]) {\n results.push(k);\n }\n return results;\n })();\n hasExcludedItem = false;\n valueList = $(\"<div>\").addClass('pvtFilterBox').hide();\n valueList.append($(\"<h4>\").text(c + \" (\" + keys.length + \")\"));\n if (keys.length > opts.menuLimit) {\n valueList.append($(\"<p>\").html(opts.localeStrings.tooMany));\n } else {\n btns = $(\"<p>\").appendTo(valueList);\n btns.append($(\"<button>\", {\n type: \"button\"\n }).html(opts.localeStrings.selectAll).bind(\"click\", function() {\n return valueList.find(\"input:visible\").prop(\"checked\", true);\n }));\n btns.append($(\"<button>\", {\n type: \"button\"\n }).html(opts.localeStrings.selectNone).bind(\"click\", function() {\n return valueList.find(\"input:visible\").prop(\"checked\", false);\n }));\n btns.append($(\"<br>\"));\n btns.append($(\"<input>\", {\n type: \"text\",\n placeholder: opts.localeStrings.filterResults,\n \"class\": \"pvtSearch\"\n }).bind(\"keyup\", function() {\n var filter;\n filter = $(this).val().toLowerCase();\n return valueList.find('.pvtCheckContainer p').each(function() {\n var testString;\n testString = $(this).text().toLowerCase().indexOf(filter);\n if (testString !== -1) {\n return $(this).show();\n } else {\n return $(this).hide();\n }\n });\n }));\n checkContainer = $(\"<div>\").addClass(\"pvtCheckContainer\").appendTo(valueList);\n ref2 = keys.sort(getSort(opts.sorters, c));\n for (o = 0, len3 = ref2.length; o < len3; o++) {\n k = ref2[o];\n v = axisValues[c][k];\n filterItem = $(\"<label>\");\n filterItemExcluded = false;\n if (opts.inclusions[c]) {\n filterItemExcluded = (indexOf.call(opts.inclusions[c], k) < 0);\n } else if (opts.exclusions[c]) {\n filterItemExcluded = (indexOf.call(opts.exclusions[c], k) >= 0);\n }\n hasExcludedItem || (hasExcludedItem = filterItemExcluded);\n $(\"<input>\").attr(\"type\", \"checkbox\").addClass('pvtFilter').attr(\"checked\", !filterItemExcluded).data(\"filter\", [c, k]).appendTo(filterItem);\n filterItem.append($(\"<span>\").text(k));\n filterItem.append($(\"<span>\").text(\" (\" + v + \")\"));\n checkContainer.append($(\"<p>\").append(filterItem));\n }\n }\n updateFilter = function() {\n var unselectedCount;\n unselectedCount = valueList.find(\"[type='checkbox']\").length - valueList.find(\"[type='checkbox']:checked\").length;\n if (unselectedCount > 0) {\n attrElem.addClass(\"pvtFilteredAttribute\");\n } else {\n attrElem.removeClass(\"pvtFilteredAttribute\");\n }\n if (keys.length > opts.menuLimit) {\n return valueList.toggle();\n } else {\n return valueList.toggle(0, refresh);\n }\n };\n $(\"<p>\").appendTo(valueList).append($(\"<button>\", {\n type: \"button\"\n }).text(\"OK\").bind(\"click\", updateFilter));\n showFilterList = function(e) {\n var clickLeft, clickTop, ref3;\n ref3 = $(e.currentTarget).position(), clickLeft = ref3.left, clickTop = ref3.top;\n valueList.css({\n left: clickLeft + 10,\n top: clickTop + 10\n }).toggle();\n valueList.find('.pvtSearch').val('');\n return valueList.find('.pvtCheckContainer p').show();\n };\n triangleLink = $(\"<span>\").addClass('pvtTriangle').html(\" ▾\").bind(\"click\", showFilterList);\n attrElem = $(\"<li>\").addClass(\"axis_\" + i).append($(\"<span>\").addClass('pvtAttr').text(c).data(\"attrName\", c).append(triangleLink));\n if (hasExcludedItem) {\n attrElem.addClass('pvtFilteredAttribute');\n }\n colList.append(attrElem).append(valueList);\n return attrElem.bind(\"dblclick\", showFilterList);\n };\n for (i in shownAttributes) {\n if (!hasProp.call(shownAttributes, i)) continue;\n c = shownAttributes[i];\n fn(c);\n }\n tr1 = $(\"<tr>\").appendTo(uiTable);\n aggregator = $(\"<select>\").addClass('pvtAggregator').bind(\"change\", function() {\n return refresh();\n });\n ref2 = opts.aggregators;\n for (x in ref2) {\n if (!hasProp.call(ref2, x)) continue;\n aggregator.append($(\"<option>\").val(x).html(x));\n }\n $(\"<td>\").addClass('pvtVals').appendTo(tr1).append(aggregator).append($(\"<br>\"));\n $(\"<td>\").addClass('pvtAxisContainer pvtHorizList pvtCols').appendTo(tr1);\n tr2 = $(\"<tr>\").appendTo(uiTable);\n tr2.append($(\"<td>\").addClass('pvtAxisContainer pvtRows').attr(\"valign\", \"top\"));\n pivotTable = $(\"<td>\").attr(\"valign\", \"top\").addClass('pvtRendererArea').appendTo(tr2);\n if (opts.unusedAttrsVertical === true || unusedAttrsVerticalAutoOverride) {\n uiTable.find('tr:nth-child(1)').prepend(rendererControl);\n uiTable.find('tr:nth-child(2)').prepend(colList);\n } else {\n uiTable.prepend($(\"<tr>\").append(rendererControl).append(colList));\n }\n this.html(uiTable);\n ref3 = opts.cols;\n for (o = 0, len3 = ref3.length; o < len3; o++) {\n x = ref3[o];\n this.find(\".pvtCols\").append(this.find(\".axis_\" + ($.inArray(x, shownAttributes))));\n }\n ref4 = opts.rows;\n for (q = 0, len4 = ref4.length; q < len4; q++) {\n x = ref4[q];\n this.find(\".pvtRows\").append(this.find(\".axis_\" + ($.inArray(x, shownAttributes))));\n }\n if (opts.aggregatorName != null) {\n this.find(\".pvtAggregator\").val(opts.aggregatorName);\n }\n if (opts.rendererName != null) {\n this.find(\".pvtRenderer\").val(opts.rendererName);\n }\n initialRender = true;\n refreshDelayed = (function(_this) {\n return function() {\n var attr, exclusions, inclusions, len5, newDropdown, numInputsToProcess, pivotUIOptions, pvtVals, ref5, ref6, s, subopts, t, unusedAttrsContainer, vals;\n subopts = {\n derivedAttributes: opts.derivedAttributes,\n localeStrings: opts.localeStrings,\n rendererOptions: opts.rendererOptions,\n sorters: opts.sorters,\n cols: [],\n rows: [],\n dataClass: opts.dataClass\n };\n numInputsToProcess = (ref5 = opts.aggregators[aggregator.val()]([])().numInputs) != null ? ref5 : 0;\n vals = [];\n _this.find(\".pvtRows li span.pvtAttr\").each(function() {\n return subopts.rows.push($(this).data(\"attrName\"));\n });\n _this.find(\".pvtCols li span.pvtAttr\").each(function() {\n return subopts.cols.push($(this).data(\"attrName\"));\n });\n _this.find(\".pvtVals select.pvtAttrDropdown\").each(function() {\n if (numInputsToProcess === 0) {\n return $(this).remove();\n } else {\n numInputsToProcess--;\n if ($(this).val() !== \"\") {\n return vals.push($(this).val());\n }\n }\n });\n if (numInputsToProcess !== 0) {\n pvtVals = _this.find(\".pvtVals\");\n for (x = s = 0, ref6 = numInputsToProcess; 0 <= ref6 ? s < ref6 : s > ref6; x = 0 <= ref6 ? ++s : --s) {\n newDropdown = $(\"<select>\").addClass('pvtAttrDropdown').append($(\"<option>\")).bind(\"change\", function() {\n return refresh();\n });\n for (t = 0, len5 = shownAttributes.length; t < len5; t++) {\n attr = shownAttributes[t];\n newDropdown.append($(\"<option>\").val(attr).text(attr));\n }\n pvtVals.append(newDropdown);\n }\n }\n if (initialRender) {\n vals = opts.vals;\n i = 0;\n _this.find(\".pvtVals select.pvtAttrDropdown\").each(function() {\n $(this).val(vals[i]);\n return i++;\n });\n initialRender = false;\n }\n subopts.aggregatorName = aggregator.val();\n subopts.vals = vals;\n subopts.aggregator = opts.aggregators[aggregator.val()](vals);\n subopts.renderer = opts.renderers[renderer.val()];\n exclusions = {};\n _this.find('input.pvtFilter').not(':checked').each(function() {\n var filter;\n filter = $(this).data(\"filter\");\n if (exclusions[filter[0]] != null) {\n return exclusions[filter[0]].push(filter[1]);\n } else {\n return exclusions[filter[0]] = [filter[1]];\n }\n });\n inclusions = {};\n _this.find('input.pvtFilter:checked').each(function() {\n var filter;\n filter = $(this).data(\"filter\");\n if (exclusions[filter[0]] != null) {\n if (inclusions[filter[0]] != null) {\n return inclusions[filter[0]].push(filter[1]);\n } else {\n return inclusions[filter[0]] = [filter[1]];\n }\n }\n });\n subopts.filter = function(record) {\n var excludedItems, ref7;\n if (!opts.filter(record)) {\n return false;\n }\n for (k in exclusions) {\n excludedItems = exclusions[k];\n if (ref7 = \"\" + record[k], indexOf.call(excludedItems, ref7) >= 0) {\n return false;\n }\n }\n return true;\n };\n pivotTable.pivot(input, subopts);\n pivotUIOptions = $.extend(opts, {\n cols: subopts.cols,\n rows: subopts.rows,\n vals: vals,\n exclusions: exclusions,\n inclusions: inclusions,\n inclusionsInfo: inclusions,\n aggregatorName: aggregator.val(),\n rendererName: renderer.val()\n });\n _this.data(\"pivotUIOptions\", pivotUIOptions);\n if (opts.autoSortUnusedAttrs) {\n unusedAttrsContainer = _this.find(\"td.pvtUnused.pvtAxisContainer\");\n $(unusedAttrsContainer).children(\"li\").sort(function(a, b) {\n return naturalSort($(a).text(), $(b).text());\n }).appendTo(unusedAttrsContainer);\n }\n pivotTable.css(\"opacity\", 1);\n if (opts.onRefresh != null) {\n return opts.onRefresh(pivotUIOptions);\n }\n };\n })(this);\n refresh = (function(_this) {\n return function() {\n pivotTable.css(\"opacity\", 0.5);\n return setTimeout(refreshDelayed, 10);\n };\n })(this);\n refresh();\n this.find(\".pvtAxisContainer\").sortable({\n update: function(e, ui) {\n if (ui.sender == null) {\n return refresh();\n }\n },\n connectWith: this.find(\".pvtAxisContainer\"),\n items: 'li',\n placeholder: 'pvtPlaceholder'\n });\n } catch (error) {\n e = error;\n if (typeof console !== \"undefined\" && console !== null) {\n console.error(e.stack);\n }\n this.html(opts.localeStrings.uiRenderError);\n }\n return this;\n };\n\n /*\n Heatmap post-processing\n */\n $.fn.heatmap = function(scope, opts) {\n var colorScaleGenerator, heatmapper, i, j, l, n, numCols, numRows, ref, ref1, ref2;\n if (scope == null) {\n scope = \"heatmap\";\n }\n numRows = this.data(\"numrows\");\n numCols = this.data(\"numcols\");\n colorScaleGenerator = opts != null ? (ref = opts.heatmap) != null ? ref.colorScaleGenerator : void 0 : void 0;\n if (colorScaleGenerator == null) {\n colorScaleGenerator = function(values) {\n var max, min;\n min = Math.min.apply(Math, values);\n max = Math.max.apply(Math, values);\n return function(x) {\n var nonRed;\n nonRed = 255 - Math.round(255 * (x - min) / (max - min));\n return \"rgb(255,\" + nonRed + \",\" + nonRed + \")\";\n };\n };\n }\n heatmapper = (function(_this) {\n return function(scope) {\n var colorScale, forEachCell, values;\n forEachCell = function(f) {\n return _this.find(scope).each(function() {\n var x;\n x = $(this).data(\"value\");\n if ((x != null) && isFinite(x)) {\n return f(x, $(this));\n }\n });\n };\n values = [];\n forEachCell(function(x) {\n return values.push(x);\n });\n colorScale = colorScaleGenerator(values);\n return forEachCell(function(x, elem) {\n return elem.css(\"background-color\", colorScale(x));\n });\n };\n })(this);\n switch (scope) {\n case \"heatmap\":\n heatmapper(\".pvtVal\");\n break;\n case \"rowheatmap\":\n for (i = l = 0, ref1 = numRows; 0 <= ref1 ? l < ref1 : l > ref1; i = 0 <= ref1 ? ++l : --l) {\n heatmapper(\".pvtVal.row\" + i);\n }\n break;\n case \"colheatmap\":\n for (j = n = 0, ref2 = numCols; 0 <= ref2 ? n < ref2 : n > ref2; j = 0 <= ref2 ? ++n : --n) {\n heatmapper(\".pvtVal.col\" + j);\n }\n }\n heatmapper(\".pvtTotal.rowTotal\");\n heatmapper(\".pvtTotal.colTotal\");\n return this;\n };\n\n /*\n Barchart post-processing\n */\n return $.fn.barchart = function() {\n var barcharter, i, l, numCols, numRows, ref;\n numRows = this.data(\"numrows\");\n numCols = this.data(\"numcols\");\n barcharter = (function(_this) {\n return function(scope) {\n var forEachCell, max, scaler, values;\n forEachCell = function(f) {\n return _this.find(scope).each(function() {\n var x;\n x = $(this).data(\"value\");\n if ((x != null) && isFinite(x)) {\n return f(x, $(this));\n }\n });\n };\n values = [];\n forEachCell(function(x) {\n return values.push(x);\n });\n max = Math.max.apply(Math, values);\n scaler = function(x) {\n return 100 * x / (1.4 * max);\n };\n return forEachCell(function(x, elem) {\n var text, wrapper;\n text = elem.text();\n wrapper = $(\"<div>\").css({\n \"position\": \"relative\",\n \"height\": \"55px\"\n });\n wrapper.append($(\"<div>\").css({\n \"position\": \"absolute\",\n \"bottom\": 0,\n \"left\": 0,\n \"right\": 0,\n \"height\": scaler(x) + \"%\",\n \"background-color\": \"gray\"\n }));\n wrapper.append($(\"<div>\").text(text).css({\n \"position\": \"relative\",\n \"padding-left\": \"5px\",\n \"padding-right\": \"5px\"\n }));\n return elem.css({\n \"padding\": 0,\n \"padding-top\": \"5px\",\n \"text-align\": \"center\"\n }).html(wrapper);\n });\n };\n })(this);\n for (i = l = 0, ref = numRows; 0 <= ref ? l < ref : l > ref; i = 0 <= ref ? ++l : --l) {\n barcharter(\".pvtVal.row\" + i);\n }\n barcharter(\".pvtTotal.colTotal\");\n return this;\n };\n });\n\n}).call(this);\n\n//# sourceMappingURL=pivot.js.map\n","\"use strict\"\n// Module export pattern from\n// https://github.com/umdjs/umd/blob/master/returnExports.js\n;(function (root, factory) {\n if (typeof define === 'function' && define.amd) {\n // AMD. Register as an anonymous module.\n define([], factory);\n } else if (typeof exports === 'object') {\n // Node. Does not work with strict CommonJS, but\n // only CommonJS-like environments that support module.exports,\n // like Node.\n module.exports = factory();\n } else {\n // Browser globals (root is window)\n root.store = factory();\n }\n}(this, function () {\n\t\n\t// Store.js\n\tvar store = {},\n\t\twin = (typeof window != 'undefined' ? window : global),\n\t\tdoc = win.document,\n\t\tlocalStorageName = 'localStorage',\n\t\tscriptTag = 'script',\n\t\tstorage\n\n\tstore.disabled = false\n\tstore.version = '1.3.20'\n\tstore.set = function(key, value) {}\n\tstore.get = function(key, defaultVal) {}\n\tstore.has = function(key) { return store.get(key) !== undefined }\n\tstore.remove = function(key) {}\n\tstore.clear = function() {}\n\tstore.transact = function(key, defaultVal, transactionFn) {\n\t\tif (transactionFn == null) {\n\t\t\ttransactionFn = defaultVal\n\t\t\tdefaultVal = null\n\t\t}\n\t\tif (defaultVal == null) {\n\t\t\tdefaultVal = {}\n\t\t}\n\t\tvar val = store.get(key, defaultVal)\n\t\ttransactionFn(val)\n\t\tstore.set(key, val)\n\t}\n\tstore.getAll = function() {}\n\tstore.forEach = function() {}\n\n\tstore.serialize = function(value) {\n\t\treturn JSON.stringify(value)\n\t}\n\tstore.deserialize = function(value) {\n\t\tif (typeof value != 'string') { return undefined }\n\t\ttry { return JSON.parse(value) }\n\t\tcatch(e) { return value || undefined }\n\t}\n\n\t// Functions to encapsulate questionable FireFox 3.6.13 behavior\n\t// when about.config::dom.storage.enabled === false\n\t// See https://github.com/marcuswestin/store.js/issues#issue/13\n\tfunction isLocalStorageNameSupported() {\n\t\ttry { return (localStorageName in win && win[localStorageName]) }\n\t\tcatch(err) { return false }\n\t}\n\n\tif (isLocalStorageNameSupported()) {\n\t\tstorage = win[localStorageName]\n\t\tstore.set = function(key, val) {\n\t\t\tif (val === undefined) { return store.remove(key) }\n\t\t\tstorage.setItem(key, store.serialize(val))\n\t\t\treturn val\n\t\t}\n\t\tstore.get = function(key, defaultVal) {\n\t\t\tvar val = store.deserialize(storage.getItem(key))\n\t\t\treturn (val === undefined ? defaultVal : val)\n\t\t}\n\t\tstore.remove = function(key) { storage.removeItem(key) }\n\t\tstore.clear = function() { storage.clear() }\n\t\tstore.getAll = function() {\n\t\t\tvar ret = {}\n\t\t\tstore.forEach(function(key, val) {\n\t\t\t\tret[key] = val\n\t\t\t})\n\t\t\treturn ret\n\t\t}\n\t\tstore.forEach = function(callback) {\n\t\t\tfor (var i=0; i<storage.length; i++) {\n\t\t\t\tvar key = storage.key(i)\n\t\t\t\tcallback(key, store.get(key))\n\t\t\t}\n\t\t}\n\t} else if (doc && doc.documentElement.addBehavior) {\n\t\tvar storageOwner,\n\t\t\tstorageContainer\n\t\t// Since #userData storage applies only to specific paths, we need to\n\t\t// somehow link our data to a specific path. We choose /favicon.ico\n\t\t// as a pretty safe option, since all browsers already make a request to\n\t\t// this URL anyway and being a 404 will not hurt us here. We wrap an\n\t\t// iframe pointing to the favicon in an ActiveXObject(htmlfile) object\n\t\t// (see: http://msdn.microsoft.com/en-us/library/aa752574(v=VS.85).aspx)\n\t\t// since the iframe access rules appear to allow direct access and\n\t\t// manipulation of the document element, even for a 404 page. This\n\t\t// document can be used instead of the current document (which would\n\t\t// have been limited to the current path) to perform #userData storage.\n\t\ttry {\n\t\t\tstorageContainer = new ActiveXObject('htmlfile')\n\t\t\tstorageContainer.open()\n\t\t\tstorageContainer.write('<'+scriptTag+'>document.w=window</'+scriptTag+'><iframe src=\"/favicon.ico\"></iframe>')\n\t\t\tstorageContainer.close()\n\t\t\tstorageOwner = storageContainer.w.frames[0].document\n\t\t\tstorage = storageOwner.createElement('div')\n\t\t} catch(e) {\n\t\t\t// somehow ActiveXObject instantiation failed (perhaps some special\n\t\t\t// security settings or otherwse), fall back to per-path storage\n\t\t\tstorage = doc.createElement('div')\n\t\t\tstorageOwner = doc.body\n\t\t}\n\t\tvar withIEStorage = function(storeFunction) {\n\t\t\treturn function() {\n\t\t\t\tvar args = Array.prototype.slice.call(arguments, 0)\n\t\t\t\targs.unshift(storage)\n\t\t\t\t// See http://msdn.microsoft.com/en-us/library/ms531081(v=VS.85).aspx\n\t\t\t\t// and http://msdn.microsoft.com/en-us/library/ms531424(v=VS.85).aspx\n\t\t\t\tstorageOwner.appendChild(storage)\n\t\t\t\tstorage.addBehavior('#default#userData')\n\t\t\t\tstorage.load(localStorageName)\n\t\t\t\tvar result = storeFunction.apply(store, args)\n\t\t\t\tstorageOwner.removeChild(storage)\n\t\t\t\treturn result\n\t\t\t}\n\t\t}\n\n\t\t// In IE7, keys cannot start with a digit or contain certain chars.\n\t\t// See https://github.com/marcuswestin/store.js/issues/40\n\t\t// See https://github.com/marcuswestin/store.js/issues/83\n\t\tvar forbiddenCharsRegex = new RegExp(\"[!\\\"#$%&'()*+,/\\\\\\\\:;<=>?@[\\\\]^`{|}~]\", \"g\")\n\t\tvar ieKeyFix = function(key) {\n\t\t\treturn key.replace(/^d/, '___$&').replace(forbiddenCharsRegex, '___')\n\t\t}\n\t\tstore.set = withIEStorage(function(storage, key, val) {\n\t\t\tkey = ieKeyFix(key)\n\t\t\tif (val === undefined) { return store.remove(key) }\n\t\t\tstorage.setAttribute(key, store.serialize(val))\n\t\t\tstorage.save(localStorageName)\n\t\t\treturn val\n\t\t})\n\t\tstore.get = withIEStorage(function(storage, key, defaultVal) {\n\t\t\tkey = ieKeyFix(key)\n\t\t\tvar val = store.deserialize(storage.getAttribute(key))\n\t\t\treturn (val === undefined ? defaultVal : val)\n\t\t})\n\t\tstore.remove = withIEStorage(function(storage, key) {\n\t\t\tkey = ieKeyFix(key)\n\t\t\tstorage.removeAttribute(key)\n\t\t\tstorage.save(localStorageName)\n\t\t})\n\t\tstore.clear = withIEStorage(function(storage) {\n\t\t\tvar attributes = storage.XMLDocument.documentElement.attributes\n\t\t\tstorage.load(localStorageName)\n\t\t\tfor (var i=attributes.length-1; i>=0; i--) {\n\t\t\t\tstorage.removeAttribute(attributes[i].name)\n\t\t\t}\n\t\t\tstorage.save(localStorageName)\n\t\t})\n\t\tstore.getAll = function(storage) {\n\t\t\tvar ret = {}\n\t\t\tstore.forEach(function(key, val) {\n\t\t\t\tret[key] = val\n\t\t\t})\n\t\t\treturn ret\n\t\t}\n\t\tstore.forEach = withIEStorage(function(storage, callback) {\n\t\t\tvar attributes = storage.XMLDocument.documentElement.attributes\n\t\t\tfor (var i=0, attr; attr=attributes[i]; ++i) {\n\t\t\t\tcallback(attr.name, store.deserialize(storage.getAttribute(attr.name)))\n\t\t\t}\n\t\t})\n\t}\n\n\ttry {\n\t\tvar testKey = '__storejs__'\n\t\tstore.set(testKey, testKey)\n\t\tif (store.get(testKey) != testKey) { store.disabled = true }\n\t\tstore.remove(testKey)\n\t} catch(e) {\n\t\tstore.disabled = true\n\t}\n\tstore.enabled = !store.disabled\n\t\n\treturn store\n}));\n","module.exports={\n \"_args\": [\n [\n {\n \"raw\": \"yasgui-utils@^1.6.0\",\n \"scope\": null,\n \"escapedName\": \"yasgui-utils\",\n \"name\": \"yasgui-utils\",\n \"rawSpec\": \"^1.6.0\",\n \"spec\": \">=1.6.0 <2.0.0\",\n \"type\": \"range\"\n },\n \"/home/lrd900/yasgui/yasr\"\n ]\n ],\n \"_from\": \"yasgui-utils@>=1.6.0 <2.0.0\",\n \"_id\": \"yasgui-utils@1.6.0\",\n \"_inCache\": true,\n \"_installable\": true,\n \"_location\": \"/yasgui-utils\",\n \"_npmUser\": {\n \"name\": \"laurens.rietveld\",\n \"email\": \"laurens.rietveld@gmail.com\"\n },\n \"_npmVersion\": \"1.4.3\",\n \"_phantomChildren\": {},\n \"_requested\": {\n \"raw\": \"yasgui-utils@^1.6.0\",\n \"scope\": null,\n \"escapedName\": \"yasgui-utils\",\n \"name\": \"yasgui-utils\",\n \"rawSpec\": \"^1.6.0\",\n \"spec\": \">=1.6.0 <2.0.0\",\n \"type\": \"range\"\n },\n \"_requiredBy\": [\n \"/\",\n \"/yasgui-yasqe\"\n ],\n \"_resolved\": \"https://registry.npmjs.org/yasgui-utils/-/yasgui-utils-1.6.0.tgz\",\n \"_shasum\": \"bcb9091109c233e3e82737c94c202e6512389c47\",\n \"_shrinkwrap\": null,\n \"_spec\": \"yasgui-utils@^1.6.0\",\n \"_where\": \"/home/lrd900/yasgui/yasr\",\n \"author\": {\n \"name\": \"Laurens Rietveld\"\n },\n \"bugs\": {\n \"url\": \"https://github.com/YASGUI/Utils/issues\"\n },\n \"dependencies\": {\n \"store\": \"^1.3.14\"\n },\n \"description\": \"Utils for YASGUI libs\",\n \"devDependencies\": {},\n \"directories\": {},\n \"dist\": {\n \"shasum\": \"bcb9091109c233e3e82737c94c202e6512389c47\",\n \"tarball\": \"https://registry.npmjs.org/yasgui-utils/-/yasgui-utils-1.6.0.tgz\"\n },\n \"homepage\": \"https://github.com/YASGUI/Utils\",\n \"licenses\": [\n {\n \"type\": \"MIT\",\n \"url\": \"http://yasgui.github.io/license.txt\"\n }\n ],\n \"main\": \"src/main.js\",\n \"maintainers\": [\n {\n \"name\": \"laurens.rietveld\",\n \"email\": \"laurens.rietveld@gmail.com\"\n }\n ],\n \"name\": \"yasgui-utils\",\n \"optionalDependencies\": {},\n \"readme\": \"ERROR: No README data found!\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git://github.com/YASGUI/Utils.git\"\n },\n \"version\": \"1.6.0\"\n}\n","window.console = window.console || {\"log\":function(){}};//make sure any console statements don't break IE\nmodule.exports = {\n\tstorage: require(\"./storage.js\"),\n\tsvg: require(\"./svg.js\"),\n\tversion: {\n\t\t\"yasgui-utils\" : require(\"../package.json\").version,\n\t},\n\tnestedExists : function(obj) {\n\t\tvar args = Array.prototype.slice.call(arguments, 1);\n\n\t\tfor (var i = 0; i < args.length; i++) {\n\t\t\tif (!obj || !obj.hasOwnProperty(args[i])) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tobj = obj[args[i]];\n\t\t}\n\t\treturn true;\n\t}\n};\n","var store = require(\"store\");\nvar times = {\n\tday: function() {\n\t\treturn 1000 * 3600 * 24;//millis to day\n\t},\n\tmonth: function() {\n\t\ttimes.day() * 30;\n\t},\n\tyear: function() {\n\t\ttimes.month() * 12;\n\t}\n};\n\nvar root = module.exports = {\n\tset : function(key, val, exp) {\n if (!store.enabled) return;//this is probably in private mode. Don't run, as we might get Js errors\n\t\tif (key && val !== undefined) {\n\t\t\tif (typeof exp == \"string\") {\n\t\t\t\texp = times[exp]();\n\t\t\t}\n\t\t\t//try to store string for dom objects (e.g. XML result). Otherwise, we might get a circular reference error when stringifying this\n\t\t\tif (val.documentElement) val = new XMLSerializer().serializeToString(val.documentElement);\n\t\t\tstore.set(key, {\n\t\t\t\tval : val,\n\t\t\t\texp : exp,\n\t\t\t\ttime : new Date().getTime()\n\t\t\t});\n\t\t}\n\t},\n\tremove: function(key) {\n\t\tif (!store.enabled) return;//this is probably in private mode. Don't run, as we might get Js errors\n\t\tif (key) store.remove(key)\n\t},\n\tremoveAll: function(filter) {\n\t\tif (!store.enabled) return;//this is probably in private mode. Don't run, as we might get Js errors\n\t\tif (typeof filter === 'function') {\n\t\t\tfor (var key in store.getAll()) {\n\t\t\t\tif (filter(key, root.get(key))) root.remove(key);\n\t\t\t}\n\t\t}\n\t},\n\tget : function(key) {\n if (!store.enabled) return null;//this is probably in private mode. Don't run, as we might get Js errors\n\t\tif (key) {\n\t\t\tvar info = store.get(key);\n\t\t\tif (!info) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\tif (info.exp && new Date().getTime() - info.time > info.exp) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\treturn info.val;\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t}\n\n};\n","module.exports = {\n\tdraw: function(parent, svgString) {\n\t\tif (!parent) return;\n\t\tvar el = module.exports.getElement(svgString);\n\t\tif (el) {\n\t\t\tif (parent.append) {\n\t\t\t\tparent.append(el);\n\t\t\t} else {\n\t\t\t\t//regular dom doc\n\t\t\t\tparent.appendChild(el);\n\t\t\t}\n\t\t}\n\t},\n\tgetElement: function(svgString) {\n\t\tif (svgString && svgString.indexOf(\"<svg\") == 0) {\n\t\t\t//no style passed via config. guess own styles\n\t\t\tvar parser = new DOMParser();\n\t\t\tvar dom = parser.parseFromString(svgString, \"text/xml\");\n\t\t\tvar svg = dom.documentElement;\n\t\t\t\n\t\t\tvar svgContainer = document.createElement(\"div\");\n\t\t\tsvgContainer.className = 'svgImg';\n\t\t\tsvgContainer.appendChild(svg);\n\t\t\treturn svgContainer;\n\t\t}\n\t\treturn false;\n\t}\n};","module.exports={\n \"name\": \"yasgui-yasr\",\n \"description\": \"Yet Another SPARQL Resultset GUI\",\n \"version\": \"2.8.6\",\n \"main\": \"src/main.js\",\n \"license\": \"MIT\",\n \"author\": \"Laurens Rietveld\",\n \"homepage\": \"http://yasr.yasgui.org\",\n \"devDependencies\": {\n \"bootstrap-sass\": \"^3.3.7\",\n \"browserify\": \"^13.1.0\",\n \"browserify-shim\": \"^3.8.12\",\n \"browserify-transform-tools\": \"^1.6.0\",\n \"exorcist\": \"^0.4.0\",\n \"gulp\": \"^3.9.1\",\n \"gulp-autoprefixer\": \"^3.1.0\",\n \"gulp-bump\": \"^2.2.0\",\n \"gulp-clean-css\": \"^2.0.12\",\n \"gulp-concat\": \"^2.6.0\",\n \"gulp-connect\": \"^4.2.0\",\n \"gulp-cssimport\": \"^3.1.0\",\n \"gulp-embedlr\": \"^0.5.2\",\n \"gulp-filter\": \"^4.0.0\",\n \"gulp-git\": \"^1.10.0\",\n \"gulp-html-replace\": \"^1.6.1\",\n \"gulp-jsvalidate\": \"^2.1.0\",\n \"gulp-livereload\": \"^3.8.1\",\n \"gulp-minify-css\": \"1.2.4\",\n \"gulp-notify\": \"^2.2.0\",\n \"gulp-rename\": \"^1.2.2\",\n \"gulp-sass\": \"^2.3.2\",\n \"gulp-sourcemaps\": \"^1.6.0\",\n \"gulp-streamify\": \"1.0.2\",\n \"gulp-tag-version\": \"^1.3.0\",\n \"gulp-uglify\": \"^1.5.4\",\n \"node-sass\": \"^3.8.0\",\n \"require-dir\": \"^0.3.0\",\n \"run-sequence\": \"^1.2.2\",\n \"vinyl-buffer\": \"^1.0.0\",\n \"vinyl-source-stream\": \"~1.1.0\",\n \"vinyl-transform\": \"1.0.0\",\n \"watchify\": \"^3.7.0\",\n \"yasgui-yasqe\": \"^2.10.1\"\n },\n \"bugs\": \"https://github.com/YASGUI/YASR/issues/\",\n \"keywords\": [\n \"JavaScript\",\n \"SPARQL\",\n \"Editor\",\n \"Semantic Web\",\n \"Linked Data\"\n ],\n \"scripts\": {\n \"dev\": \"gulp serve\",\n \"build\": \"gulp\",\n \"patch\": \"gulp patch\",\n \"minor\": \"gulp minor\",\n \"major\": \"gulp major\"\n },\n \"maintainers\": [\n {\n \"name\": \"Laurens Rietveld\",\n \"email\": \"laurens.rietveld@gmail.com\",\n \"web\": \"http://laurensrietveld.nl\"\n }\n ],\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/YASGUI/YASR.git\"\n },\n \"dependencies\": {\n \"codemirror\": \"^5.17.0\",\n \"d3\": \"^4.1.1\",\n \"datatables.net\": \"^1.10.12\",\n \"datatables.net-dt\": \"^1.10.12\",\n \"jquery\": \"^2.2.4\",\n \"jquery-ui\": \"1.10.5\",\n \"pivottable\": \"^2.1.0\",\n \"yasgui-utils\": \"^1.6.0\"\n },\n \"browserify-shim\": {\n \"google\": \"global:google\"\n },\n \"browserify\": {\n \"transform\": [\n \"browserify-shim\"\n ]\n },\n \"optionalShim\": {\n \"codemirror\": {\n \"require\": \"codemirror\",\n \"global\": \"CodeMirror\"\n },\n \"jquery\": {\n \"require\": \"jquery\",\n \"global\": \"jQuery\"\n },\n \"../../lib/codemirror\": {\n \"require\": \"codemirror\",\n \"global\": \"CodeMirror\"\n },\n \"datatables\": {\n \"require\": \"datatables\",\n \"global\": \"jQuery\"\n },\n \"d3\": {\n \"require\": \"d3\",\n \"global\": \"d3\"\n },\n \"jquery-ui/sortable\": {\n \"require\": \"jquery-ui/sortable\",\n \"global\": \"jQuery\"\n },\n \"pivottable\": {\n \"require\": \"pivottable\",\n \"global\": \"jQuery\"\n }\n }\n}\n","'use strict';\nmodule.exports = function(result) {\n\tvar quote = \"\\\"\";\n\tvar delimiter = \",\";\n\tvar lineBreak = \"\\n\";\n\n\tvar variables = result.head.vars;\n\n\tvar querySolutions = result.results.bindings;\n\n\n\n\tvar createHeader = function() {\n\t\tfor (var i = 0; i < variables.length; i++) {\n\t\t\taddValueToString(variables[i]);\n\t\t}\n\t\tcsvString += lineBreak;\n\t};\n\n\tvar createBody = function() {\n\t\tfor (var i = 0; i < querySolutions.length; i++) {\n\t\t\taddQuerySolutionToString(querySolutions[i]);\n\t\t\tcsvString += lineBreak;\n\t\t}\n\t};\n\n\tvar addQuerySolutionToString = function(querySolution) {\n\t\tfor (var i = 0; i < variables.length; i++) {\n\t\t\tvar variable = variables[i];\n\t\t\tif (querySolution.hasOwnProperty(variable)) {\n\t\t\t\taddValueToString(querySolution[variable][\"value\"]);\n\t\t\t} else {\n\t\t\t\taddValueToString(\"\");\n\t\t\t}\n\t\t}\n\t};\n\tvar addValueToString = function(value) {\n\t\t//Quotes in the string need to be escaped\n\t\tvalue.replace(quote, quote + quote);\n\t\tif (needToQuoteString(value)) {\n\t\t\tvalue = quote + value + quote;\n\t\t}\n\t\tcsvString += \" \" + value + \" \" + delimiter;\n\t};\n\n\tvar needToQuoteString = function(value) {\n\t\t//quote when it contains whitespace or the delimiter\n\t\tvar needQuoting = false;\n\t\tif (value.match(\"[\\\\w|\" + delimiter + \"|\" + quote + \"]\")) {\n\t\t\tneedQuoting = true;\n\t\t}\n\t\treturn needQuoting;\n\t};\n\n\tvar csvString = \"\";\n\tcreateHeader();\n\tcreateBody();\n\treturn csvString;\n};","'use strict';\nvar $ = require(\"jquery\");\n\n/**\n * Constructor of plugin which displays boolean info\n * \n * @param yasr {object}\n * @param parent {DOM element}\n * @param options {object}\n * @class YASR.plugins.boolean\n * @return yasr-boolean (doc)\n * \n */\nvar root = module.exports = function(yasr) {\n\tvar container = $(\"<div class='booleanResult'></div>\");\n\tvar draw = function() {\n\t\tcontainer.empty().appendTo(yasr.resultsContainer);\n\t\tvar booleanVal = yasr.results.getBoolean();\n\n\t\tvar imgId = null;\n\t\tvar textVal = null;\n\t\tif (booleanVal === true) {\n\t\t\timgId = \"check\";\n\t\t\ttextVal = \"True\";\n\t\t} else if (booleanVal === false) {\n\t\t\timgId = \"cross\";\n\t\t\ttextVal = \"False\";\n\t\t} else {\n\t\t\tcontainer.width(\"140\");\n\t\t\ttextVal = \"Could not find boolean value in response\";\n\t\t}\n\n\t\t//add icon\n\t\tif (imgId) require(\"yasgui-utils\").svg.draw(container, require('./imgs.js')[imgId]);\n\n\t\t$(\"<span></span>\").text(textVal).appendTo(container);\n\t};\n\n\n\tvar canHandleResults = function() {\n\t\treturn yasr.results.getBoolean && (yasr.results.getBoolean() === true || yasr.results.getBoolean() == false);\n\t};\n\n\n\n\treturn {\n\t\tname: null, //don't need to set this: we don't show it in the selection widget anyway, so don't need a human-friendly name\n\t\tdraw: draw,\n\t\thideFromSelection: true,\n\t\tgetPriority: 10,\n\t\tcanHandleResults: canHandleResults\n\t}\n};\n\n\nroot.version = {\n\t\"YASR-boolean\": require(\"../package.json\").version,\n\t\"jquery\": $.fn.jquery,\n};","'use strict';\nvar $ = require('jquery');\nmodule.exports = {\n\t/**\n\t * key of default plugin to use\n\t * @property output\n\t * @type string\n\t * @default \"table\"\n\t */\n\toutput: \"table\",\n\tuseGoogleCharts: true,\n\toutputPlugins: [\"table\", \"error\", \"boolean\", \"rawResponse\", \"pivot\", \"gchart\"],\n\n\t/**\n\t * Draw the output selector widget\n\t * \n\t * @property drawOutputSelector\n\t * @type boolean\n\t * @default true\n\t */\n\tdrawOutputSelector: true,\n\n\t/**\n\t * Draw download icon. This issues html5 download functionality to 'download' files created on the client-side.\n\t * This allows the user to download results already queried for, such as a CSV when a table is shown, or the original response when the raw response output is selected\n\t * \n\t * @property drawDownloadIcon\n\t * @type boolean\n\t * @default true\n\t */\n\tdrawDownloadIcon: true,\n\n\n\tgetUsedPrefixes: null,\n\t/**\n\t * Make certain settings and values of YASR persistent. Setting a key\n\t * to null, will disable persistancy: nothing is stored between browser\n\t * sessions Setting the values to a string (or a function which returns a\n\t * string), will store the query in localstorage using the specified string.\n\t * By default, the ID is dynamically generated by finding the nearest DOM element with an \"id\" set,\n\t * to avoid collissions when using multiple YASR items on one page\n\t * \n\t * @property persistency\n\t * @type object\n\t */\n\tpersistency: {\n\t\tprefix: function(yasr) {\n\t\t\treturn \"yasr_\" + $(yasr.container).closest('[id]').attr('id') + \"_\";\n\t\t},\n\t\t/**\n\t\t * Persistency setting for the selected output\n\t\t * \n\t\t * @property persistency.outputSelector\n\t\t * @type string|function\n\t\t * @default function (determine unique id)\n\t\t */\n\t\toutputSelector: function(yasr) {\n\t\t\treturn \"selector\";\n\t\t},\n\t\t/**\n\t\t * Persistency setting for query results.\n\t\t * \n\t\t * @property persistency.results\n\t\t * @type object\n\t\t */\n\t\tresults: {\n\t\t\t/**\n\t\t\t * Get the key to store results in\n\t\t\t * \n\t\t\t * @property persistency.results.id\n\t\t\t * @type string|function\n\t\t\t * @default function (determine unique id)\n\t\t\t */\n\t\t\tid: function(yasr) {\n\t\t\t\treturn \"results_\" + $(yasr.container).closest('[id]').attr('id');\n\t\t\t},\n\t\t\tkey: 'results',\n\t\t\t/**\n\t\t\t * The result set might too large to fit in local storage. \n\t\t\t * It is impossible to detect how large the local storage is.\n\t\t\t * Therefore, we do not store all results in local storage, depending on a max number of characters in the SPARQL result serialization.\n\t\t\t * Set this function conservitavely. (especially when using multiple YASR instances on one page)\n\t\t\t * \n\t\t\t * @property persistency.results.maxSize\n\t\t\t * @type int\n\t\t\t * @default 100000\n\t\t\t */\n\t\t\tmaxSize: 100000 //char count\n\t\t}\n\n\t},\n\n\n};","//this is the entry-point for browserify.\n//the current browserify version does not support require-ing js files which are used as entry-point\n//this way, we can still require our main.js file\nmodule.exports = require('./main.js');","'use strict';\nvar $ = require(\"jquery\");\n\n/**\n * Constructor of plugin which displays SPARQL errors\n * \n * @param yasr {object}\n * @param parent {DOM element}\n * @param options {object}\n * @class YASR.plugins.boolean\n * @return yasr-erro (doc)\n * \n */\nvar root = module.exports = function(yasr) {\n\tvar $container = $(\"<div class='errorResult'></div>\");\n\tvar options = $.extend(true, {}, root.defaults);\n\n\tvar getTryBtn = function() {\n\t\tvar $tryBtn = null;\n\t\tif (options.tryQueryLink) {\n\t\t\tvar link = options.tryQueryLink();\n\t\t\t$tryBtn = $('<button>', {\n\t\t\t\t\tclass: 'yasr_btn yasr_tryQuery'\n\t\t\t\t})\n\t\t\t\t.text('Try query in new browser window')\n\t\t\t\t.click(function() {\n\t\t\t\t\twindow.open(link, '_blank');\n\t\t\t\t\t$(this).blur();\n\t\t\t\t})\n\t\t}\n\t\treturn $tryBtn;\n\t}\n\n\tvar draw = function() {\n\t\tvar error = yasr.results.getException();\n\t\t$container.empty().appendTo(yasr.resultsContainer);\n\t\tvar $header = $(\"<div>\", {\n\t\t\tclass: 'errorHeader'\n\t\t}).appendTo($container);\n\n\t\tif (error.status !== 0) {\n\t\t\tvar statusText = 'Error';\n\t\t\tif (error.statusText && error.statusText.length < 100) {\n\t\t\t\t//use a max: otherwise the alert span will look ugly\n\t\t\t\tstatusText = error.statusText;\n\t\t\t}\n\t\t\tstatusText += ' (#' + error.status + ')';\n\n\t\t\t$header\n\t\t\t\t.append(\n\t\t\t\t\t$(\"<span>\", {\n\t\t\t\t\t\tclass: 'exception'\n\t\t\t\t\t})\n\t\t\t\t\t.text(statusText)\n\t\t\t\t)\n\t\t\t\t.append(getTryBtn());\n\n\t\t\tvar responseText = null;\n\t\t\tif (error.responseText) {\n\t\t\t\tresponseText = error.responseText;\n\t\t\t} else if (typeof error == \"string\") {\n\t\t\t\t//for backwards compatability (when creating the error string was done externally\n\t\t\t\tresponseText = error;\n\t\t\t}\n\t\t\tif (responseText) $container.append($(\"<pre>\").text(responseText));\n\t\t} else {\n\t\t\t$header.append(getTryBtn());\n\t\t\t//cors disabled, wrong url, or endpoint down\n\t\t\t$container\n\t\t\t\t.append(\n\t\t\t\t\t$('<div>', {\n\t\t\t\t\t\tclass: 'corsMessage'\n\t\t\t\t\t})\n\t\t\t\t\t.append(options.corsMessage)\n\t\t\t\t);\n\t\t}\n\n\t};\n\n\n\tvar canHandleResults = function(yasr) {\n\t\treturn yasr.results.getException() || false;\n\t};\n\n\treturn {\n\t\tname: null, //don't need to set this: we don't show it in the selection widget anyway, so don't need a human-friendly name\n\t\tdraw: draw,\n\t\tgetPriority: 20,\n\t\thideFromSelection: true,\n\t\tcanHandleResults: canHandleResults,\n\t}\n};\n\n/**\n * Defaults for error plugin\n * \n * @type object\n * @attribute YASR.plugins.error.defaults\n */\nroot.defaults = {\n\tcorsMessage: 'Unable to get response from endpoint',\n\ttryQueryLink: null,\n};","module.exports = {\n\tGoogleTypeException: function(foundTypes, varName) {\n\t\tthis.foundTypes = foundTypes;\n\t\tthis.varName = varName;\n\t\tthis.toString = function() {\n\t\t\tvar string = 'Conflicting data types found for variable ' + this.varName + '. Assuming all values of this variable are \"string\".';\n\t\t\tstring += ' To avoid this issue, cast the values in your SPARQL query to the intended xsd datatype';\n\n\t\t\treturn string;\n\t\t};\n\t\tthis.toHtml = function() {\n\t\t\tvar string = 'Conflicting data types found for variable <i>' + this.varName + '</i>. Assuming all values of this variable are \"string\".';\n\t\t\tstring += ' As a result, several Google Charts will not render values of this particular variable.';\n\t\t\tstring += ' To avoid this issue, cast the values in your SPARQL query to the intended xsd datatype';\n\n\t\t\treturn string;\n\t\t};\n\t}\n}","var EventEmitter = require('events').EventEmitter,\n\t$ = require('jquery');\n//cannot package google loader via browserify....\nvar loadingMain = false;\nvar loadingFailed = false;\n\nvar loader = function() {\n\tEventEmitter.call(this);\n\tvar mod = this;\n\tthis.init = function() {\n\t\tif (!loadingFailed && !(typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null) && !loadingMain) { //not initiated yet, not currently loading, and has not failed the previous time\n\t\t\tloadingMain = true;\n\t\t\t/**\n\t\t\t * It is extremely difficult to catch script loader errors (see http://www.html5rocks.com/en/tutorials/speed/script-loading/)\n\t\t\t * Existing libraries either ignore several browsers (e.g. jquery 2.x), or use ugly hacks (timeouts or something)\n\t\t\t * So, we use our own custom ugly hack (yes, timeouts)\n\t\t\t */\n\t\t\t //use protocol relative req when served via http. Otherwise, just use http:// (e.g. when yasr is served via file://)\n\t\t\tloadScript((window.location.protocol.indexOf(\"http\") === 0 ? '//': 'http://') + 'google.com/jsapi', function() {\n\t\t\t\tloadingMain = false;\n\t\t\t\tmod.emit('initDone');\n\t\t\t});\n\n\t\t\tvar timeout = 100; //ms\n\t\t\tvar maxTimeout = 6000; //so 6 sec max\n\t\t\tvar startTime = +new Date();\n\t\t\tvar checkAndWait = function() {\n\t\t\t\tif (!(typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null)) {\n\t\t\t\t\tif ((+new Date() - startTime) > maxTimeout) {\n\t\t\t\t\t\t//ok, we've waited long enough. Obviously we could not load the googleloader...\n\t\t\t\t\t\tloadingFailed = true;\n\t\t\t\t\t\tloadingMain = false;\n\t\t\t\t\t\tmod.emit('initError');\n\n\t\t\t\t\t\t//TODO: clear initDone callbacks. they won't fire anymore anyway\n\n\t\t\t\t\t} else {\n\t\t\t\t\t\tsetTimeout(checkAndWait, timeout);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t//TODO: clear initFailed callbacks. they won't fire anymore anyway\n\t\t\t\t}\n\t\t\t}\n\t\t\tcheckAndWait();\n\t\t} else {\n\t\t\tif ((typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null)) {\n\t\t\t\t//already loaded! everything is fine\n\t\t\t\tmod.emit('initDone');\n\t\t\t} else if (loadingFailed) {\n\t\t\t\tmod.emit('initError')\n\t\t\t} else {\n\t\t\t\t//hmmm, should never get here\n\t\t\t}\n\n\t\t}\n\t}\n\tthis.googleLoad = function() {\n\n\t\tvar load = function() {\n\t\t\t(typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null).load(\"visualization\", \"1\", {\n\t\t\t\tpackages: [\"corechart\", \"charteditor\"],\n\t\t\t\tcallback: function() {\n\t\t\t\t\tmod.emit('done')\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\t\tif (loadingMain) {\n\t\t\tmod.once('initDone', load);\n\t\t\tmod.once('initError', function() {\n\t\t\t\tmod.emit('error', 'Could not load google loader')\n\t\t\t});\n\t\t} else if ((typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null)) {\n\t\t\t//google loader is there. use it\n\t\t\tload();\n\t\t} else if (loadingFailed) {\n\t\t\tmod.emit('error', 'Could not load google loader');\n\t\t} else {\n\t\t\t//not loading, no loading error, and not loaded. it must not have been initialized yet. Do that\n\t\t\tmod.once('initDone', load);\n\t\t\tmod.once('initError', function() {\n\t\t\t\tmod.emit('error', 'Could not load google loader')\n\t\t\t});\n\t\t}\n\t};\n}\n\n\nvar loadScript = function(url, callback) {\n\tvar script = document.createElement(\"script\")\n\tscript.type = \"text/javascript\";\n\n\tif (script.readyState) { //IE\n\t\tscript.onreadystatechange = function() {\n\t\t\tif (script.readyState == \"loaded\" ||\n\t\t\t\tscript.readyState == \"complete\") {\n\t\t\t\tscript.onreadystatechange = null;\n\t\t\t\tcallback();\n\t\t\t}\n\t\t};\n\t} else { //Others\n\t\tscript.onload = function() {\n\t\t\tcallback();\n\t\t};\n\t}\n\n\tscript.src = url;\n\tdocument.body.appendChild(script);\n}\nloader.prototype = new EventEmitter;\nmodule.exports = new loader();\n","'use strict';\n/**\n * todo: chart height as option\n * \n */\nvar $ = require('jquery'),\n\tutils = require('./utils.js'),\n\tyUtils = require('yasgui-utils');\n\nvar root = module.exports = function(yasr) {\n\n\tvar options = $.extend(true, {}, root.defaults);\n\tvar id = yasr.container.closest('[id]').attr('id');\n\n\tvar chartWrapper = null;\n\tvar editor = null;\n\n\tvar initEditor = function(callback) {\n\t\tvar google = (typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null);\n\t\teditor = new google.visualization.ChartEditor();\n\t\tgoogle.visualization.events.addListener(editor, 'ok', function() {\n\t\t\tvar tmp;\n\t\t\tchartWrapper = editor.getChartWrapper();\n\t\t\ttmp = chartWrapper.getDataTable();\n\t\t\tchartWrapper.setDataTable(null);\n\t\t\t//ugly: need to parse json string to json obj again, as google chart does not provide access to object directly\n\t\t\toptions.chartConfig = JSON.parse(chartWrapper.toJSON());\n\t\t\t//remove container ID though, for portability\n\t\t\tif (options.chartConfig.containerId) delete options.chartConfig['containerId'];\n\t\t\tyasr.store();\n\t\t\tchartWrapper.setDataTable(tmp);\n\t\t\tvar wrapperId = id + '_gchartWrapper';\n\t\t\tvar $wrapper = $('#' + wrapperId);\n\t\t\tchartWrapper.setOption(\"width\", $wrapper.width());\n\t\t\tchartWrapper.setOption(\"height\", $wrapper.height());\n\t\t\tchartWrapper.draw();\n\t\t\tyasr.updateHeader();\n\t\t});\n\t\tif (callback) callback();\n\t};\n\n\treturn {\n\t\tname: \"Google Chart\",\n\t\thideFromSelection: false,\n\t\tpriority: 7,\n\t\toptions: options,\n\t\tgetPersistentSettings: function() {\n\t\t\treturn {\n\t\t\t\tchartConfig: options.chartConfig,\n\t\t\t\tmotionChartState: options.motionChartState\n\t\t\t}\n\t\t},\n\t\tsetPersistentSettings: function(persSettings) {\n\t\t\tif (persSettings['chartConfig']) options.chartConfig = persSettings['chartConfig'];\n\t\t\tif (persSettings['motionChartState']) options.motionChartState = persSettings['motionChartState'];\n\t\t},\n\t\tcanHandleResults: function(yasr) {\n\t\t\tvar results, variables;\n\t\t\treturn (results = yasr.results) != null && (variables = results.getVariables()) && variables.length > 0;\n\t\t},\n\t\tgetDownloadInfo: function() {\n\t\t\tif (!yasr.results) return null;\n\t\t\tvar svgEl = yasr.resultsContainer.find('svg');\n\t\t\tif (svgEl.length > 0) {\n\t\t\t\treturn {\n\t\t\t\t\tgetContent: function() {\n\t\t\t\t\t\tif (svgEl[0].outerHTML) {\n\t\t\t\t\t\t\treturn svgEl[0].outerHTML;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t//outerHTML not supported. use workaround\n\t\t\t\t\t\t\treturn $('<div>').append(svgEl.clone()).html();\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\tfilename: \"queryResults.svg\",\n\t\t\t\t\tcontentType: \"image/svg+xml\",\n\t\t\t\t\tbuttonTitle: \"Download SVG Image\"\n\t\t\t\t};\n\t\t\t}\n\t\t\t//ok, not a svg. is it a table?\n\t\t\tvar $table = yasr.resultsContainer.find('.google-visualization-table-table');\n\t\t\tif ($table.length > 0) {\n\t\t\t\treturn {\n\t\t\t\t\tgetContent: function() {\n\t\t\t\t\t\treturn $table.tableToCsv();\n\t\t\t\t\t},\n\t\t\t\t\tfilename: \"queryResults.csv\",\n\t\t\t\t\tcontentType: \"text/csv\",\n\t\t\t\t\tbuttonTitle: \"Download as CSV\"\n\t\t\t\t};\n\t\t\t}\n\t\t},\n\t\tgetEmbedHtml: function() {\n\t\t\tif (!yasr.results) return null;\n\n\t\t\tvar svgEl = yasr.resultsContainer.find('svg')\n\t\t\t\t.clone() //create clone, as we'd like to remove height/width attributes\n\t\t\t\t.removeAttr('height').removeAttr('width')\n\t\t\t\t.css('height', '').css('width', '');\n\t\t\tif (svgEl.length == 0) return null;\n\n\t\t\tvar htmlString = svgEl[0].outerHTML;\n\t\t\tif (!htmlString) {\n\t\t\t\t//outerHTML not supported. use workaround\n\t\t\t\thtmlString = $('<div>').append(svgEl.clone()).html();\n\t\t\t}\n\t\t\t//wrap in div, so users can more easily tune width/height\n\t\t\t//don't use jquery, so we can easily influence indentation\n\t\t\treturn '<div style=\"width: 800px; height: 600px;\">\\n' + htmlString + '\\n</div>';\n\t\t},\n\t\tdraw: function() {\n\t\t\tvar doDraw = function() {\n\t\t\t\t//clear previous results (if any)\n\t\t\t\tyasr.resultsContainer.empty();\n\t\t\t\tvar wrapperId = id + '_gchartWrapper';\n\n\t\t\t\tyasr.resultsContainer.append(\n\t\t\t\t\t$('<button>', {\n\t\t\t\t\t\tclass: 'openGchartBtn yasr_btn'\n\t\t\t\t\t})\n\t\t\t\t\t.text('Chart Config')\n\t\t\t\t\t.click(function() {\n\t\t\t\t\t\teditor.openDialog(chartWrapper);\n\t\t\t\t\t})\n\t\t\t\t).append(\n\t\t\t\t\t$('<div>', {\n\t\t\t\t\t\tid: wrapperId,\n\t\t\t\t\t\tclass: 'gchartWrapper'\n\t\t\t\t\t})\n\t\t\t\t);\n\t\t\t\tvar dataTable = new google.visualization.DataTable();\n\t\t\t\tvar jsonResults = yasr.results.getAsJson();\n\n\t\t\t\tjsonResults.head.vars.forEach(function(variable) {\n\t\t\t\t\tvar type = 'string';\n\t\t\t\t\ttry {\n\t\t\t\t\t\ttype = utils.getGoogleTypeForBindings(jsonResults.results.bindings, variable);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\tif (e instanceof require('./exceptions.js').GoogleTypeException) {\n\t\t\t\t\t\t\tyasr.warn(e.toHtml())\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthrow e;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tdataTable.addColumn(type, variable);\n\t\t\t\t});\n\t\t\t\tvar usedPrefixes = null;\n\t\t\t\tif (yasr.options.getUsedPrefixes) {\n\t\t\t\t\tusedPrefixes = (typeof yasr.options.getUsedPrefixes == \"function\" ? yasr.options.getUsedPrefixes(yasr) : yasr.options.getUsedPrefixes);\n\t\t\t\t}\n\t\t\t\tjsonResults.results.bindings.forEach(function(binding) {\n\t\t\t\t\tvar row = [];\n\t\t\t\t\tjsonResults.head.vars.forEach(function(variable, columnId) {\n\t\t\t\t\t\trow.push(utils.castGoogleType(binding[variable], usedPrefixes, dataTable.getColumnType(columnId)));\n\t\t\t\t\t})\n\t\t\t\t\tdataTable.addRow(row);\n\t\t\t\t});\n\n\t\t\t\tif (options.chartConfig && options.chartConfig.chartType) {\n\t\t\t\t\toptions.chartConfig.containerId = wrapperId;\n\t\t\t\t\tchartWrapper = new google.visualization.ChartWrapper(options.chartConfig);\n\t\t\t\t\tif (chartWrapper.getChartType() === \"MotionChart\" && options.motionChartState) {\n\t\t\t\t\t\tchartWrapper.setOption(\"state\", options.motionChartState);\n\t\t\t\t\t\tgoogle.visualization.events.addListener(chartWrapper, 'ready', function() {\n\t\t\t\t\t\t\tvar motionChart;\n\t\t\t\t\t\t\tmotionChart = chartWrapper.getChart();\n\t\t\t\t\t\t\tgoogle.visualization.events.addListener(motionChart, 'statechange', function() {\n\t\t\t\t\t\t\t\toptions.motionChartState = motionChart.getState();\n\t\t\t\t\t\t\t\tyasr.store();\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t\tchartWrapper.setDataTable(dataTable);\n\t\t\t\t} else {\n\t\t\t\t\tchartWrapper = new google.visualization.ChartWrapper({\n\t\t\t\t\t\tchartType: 'Table',\n\t\t\t\t\t\tdataTable: dataTable,\n\t\t\t\t\t\tcontainerId: wrapperId\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tvar $wrapper = $('#' + wrapperId);\n\t\t\t\tchartWrapper.setOption(\"width\", $wrapper.width());\n\t\t\t\tchartWrapper.setOption(\"height\", $wrapper.height());\n\t\t\t\tchartWrapper.draw();\n\t\t\t\tgoogle.visualization.events.addListener(chartWrapper, 'ready', yasr.updateHeader);\n\t\t\t}\n\n\t\t\tif (!(typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null) || !(typeof window !== \"undefined\" ? window['google'] : typeof global !== \"undefined\" ? global['google'] : null).visualization || !editor) {\n\t\t\t\trequire('./gChartLoader.js')\n\t\t\t\t\t.on('done', function() {\n\t\t\t\t\t\tinitEditor();\n\t\t\t\t\t\tdoDraw();\n\t\t\t\t\t})\n\t\t\t\t\t.on('error', function() {\n\t\t\t\t\t\t//TODO: disable or something?\n\t\t\t\t\t})\n\t\t\t\t\t.googleLoad();\n\t\t\t} else {\n\t\t\t\t//everything (editor as well) is already initialized\n\t\t\t\tdoDraw();\n\t\t\t}\n\t\t}\n\t};\n};\nroot.defaults = {\n\theight: \"100%\",\n\twidth: \"100%\",\n\tpersistencyId: 'gchart',\n\tchartConfig: null,\n\tmotionChartState: null\n};\n\nfunction deepEq$(x, y, type) {\n\tvar toString = {}.toString,\n\t\thasOwnProperty = {}.hasOwnProperty,\n\t\thas = function(obj, key) {\n\t\t\treturn hasOwnProperty.call(obj, key);\n\t\t};\n\tvar first = true;\n\treturn eq(x, y, []);\n\n\tfunction eq(a, b, stack) {\n\t\tvar className, length, size, result, alength, blength, r, key, ref, sizeB;\n\t\tif (a == null || b == null) {\n\t\t\treturn a === b;\n\t\t}\n\t\tif (a.__placeholder__ || b.__placeholder__) {\n\t\t\treturn true;\n\t\t}\n\t\tif (a === b) {\n\t\t\treturn a !== 0 || 1 / a == 1 / b;\n\t\t}\n\t\tclassName = toString.call(a);\n\t\tif (toString.call(b) != className) {\n\t\t\treturn false;\n\t\t}\n\t\tswitch (className) {\n\t\t\tcase '[object String]':\n\t\t\t\treturn a == String(b);\n\t\t\tcase '[object Number]':\n\t\t\t\treturn a != +a ? b != +b : (a == 0 ? 1 / a == 1 / b : a == +b);\n\t\t\tcase '[object Date]':\n\t\t\tcase '[object Boolean]':\n\t\t\t\treturn +a == +b;\n\t\t\tcase '[object RegExp]':\n\t\t\t\treturn a.source == b.source &&\n\t\t\t\t\ta.global == b.global &&\n\t\t\t\t\ta.multiline == b.multiline &&\n\t\t\t\t\ta.ignoreCase == b.ignoreCase;\n\t\t}\n\t\tif (typeof a != 'object' || typeof b != 'object') {\n\t\t\treturn false;\n\t\t}\n\t\tlength = stack.length;\n\t\twhile (length--) {\n\t\t\tif (stack[length] == a) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\tstack.push(a);\n\t\tsize = 0;\n\t\tresult = true;\n\t\tif (className == '[object Array]') {\n\t\t\talength = a.length;\n\t\t\tblength = b.length;\n\t\t\tif (first) {\n\t\t\t\tswitch (type) {\n\t\t\t\t\tcase '===':\n\t\t\t\t\t\tresult = alength === blength;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase '<==':\n\t\t\t\t\t\tresult = alength <= blength;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase '<<=':\n\t\t\t\t\t\tresult = alength < blength;\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tsize = alength;\n\t\t\t\tfirst = false;\n\t\t\t} else {\n\t\t\t\tresult = alength === blength;\n\t\t\t\tsize = alength;\n\t\t\t}\n\t\t\tif (result) {\n\t\t\t\twhile (size--) {\n\t\t\t\t\tif (!(result = size in a == size in b && eq(a[size], b[size], stack))) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tif ('constructor' in a != 'constructor' in b || a.constructor != b.constructor) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tfor (key in a) {\n\t\t\t\tif (has(a, key)) {\n\t\t\t\t\tsize++;\n\t\t\t\t\tif (!(result = has(b, key) && eq(a[key], b[key], stack))) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (result) {\n\t\t\t\tsizeB = 0;\n\t\t\t\tfor (key in b) {\n\t\t\t\t\tif (has(b, key)) {\n\t\t\t\t\t\t++sizeB;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (first) {\n\t\t\t\t\tif (type === '<<=') {\n\t\t\t\t\t\tresult = size < sizeB;\n\t\t\t\t\t} else if (type === '<==') {\n\t\t\t\t\t\tresult = size <= sizeB\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult = size === sizeB;\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tfirst = false;\n\t\t\t\t\tresult = size === sizeB;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tstack.pop();\n\t\treturn result;\n\t}\n}","'use strict';\nmodule.exports = {\n\tcross: '<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" version=\"1.1\" x=\"0px\" y=\"0px\" width=\"30px\" height=\"30px\" viewBox=\"0 0 100 100\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\"><g>\t<path d=\"M83.288,88.13c-2.114,2.112-5.575,2.112-7.689,0L53.659,66.188c-2.114-2.112-5.573-2.112-7.687,0L24.251,87.907 c-2.113,2.114-5.571,2.114-7.686,0l-4.693-4.691c-2.114-2.114-2.114-5.573,0-7.688l21.719-21.721c2.113-2.114,2.113-5.573,0-7.686 L11.872,24.4c-2.114-2.113-2.114-5.571,0-7.686l4.842-4.842c2.113-2.114,5.571-2.114,7.686,0L46.12,33.591 c2.114,2.114,5.572,2.114,7.688,0l21.721-21.719c2.114-2.114,5.573-2.114,7.687,0l4.695,4.695c2.111,2.113,2.111,5.571-0.003,7.686 L66.188,45.973c-2.112,2.114-2.112,5.573,0,7.686L88.13,75.602c2.112,2.111,2.112,5.572,0,7.687L83.288,88.13z\"/></g></svg>',\n\tcheck: '<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" version=\"1.1\" x=\"0px\" y=\"0px\" width=\"30px\" height=\"30px\" viewBox=\"0 0 100 100\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\"><path fill=\"#000000\" d=\"M14.301,49.982l22.606,17.047L84.361,4.903c2.614-3.733,7.76-4.64,11.493-2.026l0.627,0.462 c3.732,2.614,4.64,7.758,2.025,11.492l-51.783,79.77c-1.955,2.791-3.896,3.762-7.301,3.988c-3.405,0.225-5.464-1.039-7.508-3.084 L2.447,61.814c-3.263-3.262-3.263-8.553,0-11.814l0.041-0.019C5.75,46.718,11.039,46.718,14.301,49.982z\"/></svg>',\n\tunsorted: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" id=\"Layer_1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"0 0 54.552711 113.78478\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\"><g id=\"g5\" transform=\"matrix(-0.70522156,-0.70898699,-0.70898699,0.70522156,97.988199,55.081205)\"><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path7\" d=\"M 57.911,66.915 45.808,55.063 42.904,52.238 31.661,41.25 31.435,41.083 31.131,40.775 30.794,40.523 30.486,40.3 30.069,40.05 29.815,39.911 29.285,39.659 29.089,39.576 28.474,39.326 28.363,39.297 H 28.336 L 27.665,39.128 27.526,39.1 26.94,38.99 26.714,38.961 26.212,38.934 h -0.31 -0.444 l -0.339,0.027 c -1.45,0.139 -2.876,0.671 -4.11,1.564 l -0.223,0.141 -0.279,0.25 -0.335,0.308 -0.054,0.029 -0.171,0.194 -0.334,0.364 -0.224,0.279 -0.25,0.336 -0.225,0.362 -0.192,0.308 -0.197,0.421 -0.142,0.279 -0.193,0.477 -0.084,0.222 -12.441,38.414 c -0.814,2.458 -0.313,5.029 1.115,6.988 v 0.026 l 0.418,0.532 0.17,0.165 0.251,0.281 0.084,0.079 0.283,0.281 0.25,0.194 0.474,0.367 0.083,0.053 c 2.015,1.371 4.641,1.874 7.131,1.094 L 55.228,80.776 c 4.303,-1.342 6.679,-5.814 5.308,-10.006 -0.387,-1.259 -1.086,-2.35 -1.979,-3.215 l -0.368,-0.337 -0.278,-0.303 z m -6.318,5.896 0.079,0.114 -37.369,11.57 11.854,-36.538 10.565,10.317 2.876,2.825 11.995,11.712 z\" /></g><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path7-9\" d=\"m 8.8748339,52.571766 16.9382111,-0.222584 4.050851,-0.06665 15.719154,-0.222166 0.27778,-0.04246 0.43276,0.0017 0.41632,-0.06121 0.37532,-0.0611 0.47132,-0.119342 0.27767,-0.08206 0.55244,-0.198047 0.19707,-0.08043 0.61095,-0.259721 0.0988,-0.05825 0.019,-0.01914 0.59303,-0.356548 0.11787,-0.0788 0.49125,-0.337892 0.17994,-0.139779 0.37317,-0.336871 0.21862,-0.219786 0.31311,-0.31479 0.21993,-0.259387 c 0.92402,-1.126057 1.55249,-2.512251 1.78961,-4.016904 l 0.0573,-0.25754 0.0195,-0.374113 0.0179,-0.454719 0.0175,-0.05874 -0.0169,-0.258049 -0.0225,-0.493503 -0.0398,-0.355569 -0.0619,-0.414201 -0.098,-0.414812 -0.083,-0.353334 L 53.23955,41.1484 53.14185,40.850967 52.93977,40.377742 52.84157,40.161628 34.38021,4.2507375 C 33.211567,1.9401875 31.035446,0.48226552 28.639484,0.11316952 l -0.01843,-0.01834 -0.671963,-0.07882 -0.236871,0.0042 L 27.335984,-4.7826577e-7 27.220736,0.00379952 l -0.398804,0.0025 -0.313848,0.04043 -0.594474,0.07724 -0.09611,0.02147 C 23.424549,0.60716252 21.216017,2.1142355 20.013025,4.4296865 L 0.93967491,40.894479 c -2.08310801,3.997178 -0.588125,8.835482 3.35080799,10.819749 1.165535,0.613495 2.43199,0.88731 3.675026,0.864202 l 0.49845,-0.02325 0.410875,0.01658 z M 9.1502369,43.934401 9.0136999,43.910011 27.164145,9.2564625 44.70942,43.42818 l -14.765289,0.214677 -4.031106,0.0468 -16.7627881,0.244744 z\" /></svg>',\n\tsortDesc: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" id=\"Layer_1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"0 0 54.552711 113.78478\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\"><g id=\"g5\" transform=\"matrix(-0.70522156,-0.70898699,-0.70898699,0.70522156,97.988199,55.081205)\"><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path7\" d=\"M 57.911,66.915 45.808,55.063 42.904,52.238 31.661,41.25 31.435,41.083 31.131,40.775 30.794,40.523 30.486,40.3 30.069,40.05 29.815,39.911 29.285,39.659 29.089,39.576 28.474,39.326 28.363,39.297 H 28.336 L 27.665,39.128 27.526,39.1 26.94,38.99 26.714,38.961 26.212,38.934 h -0.31 -0.444 l -0.339,0.027 c -1.45,0.139 -2.876,0.671 -4.11,1.564 l -0.223,0.141 -0.279,0.25 -0.335,0.308 -0.054,0.029 -0.171,0.194 -0.334,0.364 -0.224,0.279 -0.25,0.336 -0.225,0.362 -0.192,0.308 -0.197,0.421 -0.142,0.279 -0.193,0.477 -0.084,0.222 -12.441,38.414 c -0.814,2.458 -0.313,5.029 1.115,6.988 v 0.026 l 0.418,0.532 0.17,0.165 0.251,0.281 0.084,0.079 0.283,0.281 0.25,0.194 0.474,0.367 0.083,0.053 c 2.015,1.371 4.641,1.874 7.131,1.094 L 55.228,80.776 c 4.303,-1.342 6.679,-5.814 5.308,-10.006 -0.387,-1.259 -1.086,-2.35 -1.979,-3.215 l -0.368,-0.337 -0.278,-0.303 z m -6.318,5.896 0.079,0.114 -37.369,11.57 11.854,-36.538 10.565,10.317 2.876,2.825 11.995,11.712 z\" /></g><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path9\" d=\"m 27.813273,0.12823506 0.09753,0.02006 c 2.39093,0.458209 4.599455,1.96811104 5.80244,4.28639004 L 52.785897,40.894525 c 2.088044,4.002139 0.590949,8.836902 -3.348692,10.821875 -1.329078,0.688721 -2.766603,0.943695 -4.133174,0.841768 l -0.454018,0.02 L 27.910392,52.354171 23.855313,52.281851 8.14393,52.061827 7.862608,52.021477 7.429856,52.021738 7.014241,51.959818 6.638216,51.900838 6.164776,51.779369 5.889216,51.699439 5.338907,51.500691 5.139719,51.419551 4.545064,51.145023 4.430618,51.105123 4.410168,51.084563 3.817138,50.730843 3.693615,50.647783 3.207314,50.310611 3.028071,50.174369 2.652795,49.833957 2.433471,49.613462 2.140099,49.318523 1.901127,49.041407 C 0.97781,47.916059 0.347935,46.528448 0.11153,45.021676 L 0.05352,44.766255 0.05172,44.371683 0.01894,43.936017 0,43.877277 0.01836,43.62206 0.03666,43.122889 0.0765,42.765905 0.13912,42.352413 0.23568,41.940425 0.32288,41.588517 0.481021,41.151945 0.579391,40.853806 0.77369,40.381268 0.876097,40.162336 19.338869,4.2542801 c 1.172169,-2.308419 3.34759,-3.76846504 5.740829,-4.17716604 l 0.01975,0.01985 0.69605,-0.09573 0.218437,0.0225 0.490791,-0.02132 0.39809,0.0046 0.315972,0.03973 0.594462,0.08149 z\" /></svg>',\n\tsortAsc: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" id=\"Layer_1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"0 0 54.552711 113.78478\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\"><g id=\"g5\" transform=\"matrix(-0.70522156,0.70898699,-0.70898699,-0.70522156,97.988199,58.704807)\"><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path7\" d=\"M 57.911,66.915 45.808,55.063 42.904,52.238 31.661,41.25 31.435,41.083 31.131,40.775 30.794,40.523 30.486,40.3 30.069,40.05 29.815,39.911 29.285,39.659 29.089,39.576 28.474,39.326 28.363,39.297 H 28.336 L 27.665,39.128 27.526,39.1 26.94,38.99 26.714,38.961 26.212,38.934 h -0.31 -0.444 l -0.339,0.027 c -1.45,0.139 -2.876,0.671 -4.11,1.564 l -0.223,0.141 -0.279,0.25 -0.335,0.308 -0.054,0.029 -0.171,0.194 -0.334,0.364 -0.224,0.279 -0.25,0.336 -0.225,0.362 -0.192,0.308 -0.197,0.421 -0.142,0.279 -0.193,0.477 -0.084,0.222 -12.441,38.414 c -0.814,2.458 -0.313,5.029 1.115,6.988 v 0.026 l 0.418,0.532 0.17,0.165 0.251,0.281 0.084,0.079 0.283,0.281 0.25,0.194 0.474,0.367 0.083,0.053 c 2.015,1.371 4.641,1.874 7.131,1.094 L 55.228,80.776 c 4.303,-1.342 6.679,-5.814 5.308,-10.006 -0.387,-1.259 -1.086,-2.35 -1.979,-3.215 l -0.368,-0.337 -0.278,-0.303 z m -6.318,5.896 0.079,0.114 -37.369,11.57 11.854,-36.538 10.565,10.317 2.876,2.825 11.995,11.712 z\" /></g><path style=\"fill:#000000\" inkscape:connector-curvature=\"0\" id=\"path9\" d=\"m 27.813273,113.65778 0.09753,-0.0201 c 2.39093,-0.45821 4.599455,-1.96811 5.80244,-4.28639 L 52.785897,72.891487 c 2.088044,-4.002139 0.590949,-8.836902 -3.348692,-10.821875 -1.329078,-0.688721 -2.766603,-0.943695 -4.133174,-0.841768 l -0.454018,-0.02 -16.939621,0.223997 -4.055079,0.07232 -15.711383,0.220024 -0.281322,0.04035 -0.432752,-2.61e-4 -0.415615,0.06192 -0.376025,0.05898 -0.47344,0.121469 -0.27556,0.07993 -0.550309,0.198748 -0.199188,0.08114 -0.594655,0.274528 -0.114446,0.0399 -0.02045,0.02056 -0.59303,0.35372 -0.123523,0.08306 -0.486301,0.337172 -0.179243,0.136242 -0.375276,0.340412 -0.219324,0.220495 -0.293372,0.294939 -0.238972,0.277116 C 0.97781,65.869953 0.347935,67.257564 0.11153,68.764336 L 0.05352,69.019757 0.05172,69.414329 0.01894,69.849995 0,69.908735 l 0.01836,0.255217 0.0183,0.499171 0.03984,0.356984 0.06262,0.413492 0.09656,0.411988 0.0872,0.351908 0.158141,0.436572 0.09837,0.298139 0.194299,0.472538 0.102407,0.218932 18.462772,35.908054 c 1.172169,2.30842 3.34759,3.76847 5.740829,4.17717 l 0.01975,-0.0199 0.69605,0.0957 0.218437,-0.0225 0.490791,0.0213 0.39809,-0.005 0.315972,-0.0397 0.594462,-0.0815 z\" /></svg>',\n\tdownload: '<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" version=\"1.1\" baseProfile=\"tiny\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"0 0 100 100\" xml:space=\"preserve\"><g id=\"Captions\"></g><g id=\"Your_Icon\">\t<path fill-rule=\"evenodd\" fill=\"#000000\" d=\"M88,84v-2c0-2.961-0.859-4-4-4H16c-2.961,0-4,0.98-4,4v2c0,3.102,1.039,4,4,4h68 C87.02,88,88,87.039,88,84z M58,12H42c-5,0-6,0.941-6,6v22H16l34,34l34-34H64V18C64,12.941,62.939,12,58,12z\"/></g></svg>',\n\tmove: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" id=\"Layer_1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"5 -10 74.074074 100\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\" inkscape:version=\"0.48.4 r9939\" sodipodi:docname=\"noun_11656_cc.svg\"><metadata ><rdf:RDF><cc:Work rdf:about=\"\"><dc:format>image/svg+xml</dc:format><dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\" /></cc:Work></rdf:RDF></metadata><defs /><sodipodi:namedview pagecolor=\"#ffffff\" bordercolor=\"#666666\" borderopacity=\"1\" objecttolerance=\"10\" gridtolerance=\"10\" guidetolerance=\"10\" inkscape:pageopacity=\"0\" inkscape:pageshadow=\"2\" inkscape:window-width=\"753\" inkscape:window-height=\"480\" showgrid=\"false\" fit-margin-top=\"0\" fit-margin-left=\"0\" fit-margin-right=\"0\" fit-margin-bottom=\"0\" inkscape:zoom=\"2.36\" inkscape:cx=\"44.101509\" inkscape:cy=\"31.481481\" inkscape:window-x=\"287\" inkscape:window-y=\"249\" inkscape:window-maximized=\"0\" inkscape:current-layer=\"Layer_1\" /><polygon points=\"33,83 50,100 67,83 54,83 54,17 67,17 50,0 33,17 46,17 46,83 \" transform=\"translate(-7.962963,-10)\" /><polygon points=\"83,67 100,50 83,33 83,46 17,46 17,33 0,50 17,67 17,54 83,54 \" transform=\"translate(-7.962963,-10)\" /></svg>',\n\tfullscreen: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"5 -10 74.074074 100\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\" inkscape:version=\"0.48.4 r9939\" sodipodi:docname=\"noun_2186_cc.svg\"><metadata ><rdf:RDF><cc:Work rdf:about=\"\"><dc:format>image/svg+xml</dc:format><dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\" /></cc:Work></rdf:RDF></metadata><defs /><sodipodi:namedview pagecolor=\"#ffffff\" bordercolor=\"#666666\" borderopacity=\"1\" objecttolerance=\"10\" gridtolerance=\"10\" guidetolerance=\"10\" inkscape:pageopacity=\"0\" inkscape:pageshadow=\"2\" inkscape:window-width=\"640\" inkscape:window-height=\"480\" showgrid=\"false\" fit-margin-top=\"0\" fit-margin-left=\"0\" fit-margin-right=\"0\" fit-margin-bottom=\"0\" inkscape:zoom=\"2.36\" inkscape:cx=\"44.101509\" inkscape:cy=\"31.481481\" inkscape:window-x=\"65\" inkscape:window-y=\"24\" inkscape:window-maximized=\"0\" inkscape:current-layer=\"Layer_1\" /><path d=\"m -7.962963,-10 v 38.889 l 16.667,-16.667 16.667,16.667 5.555,-5.555 -16.667,-16.667 16.667,-16.667 h -38.889 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"m 92.037037,-10 v 38.889 l -16.667,-16.667 -16.666,16.667 -5.556,-5.555 16.666,-16.667 -16.666,-16.667 h 38.889 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"M -7.962963,90 V 51.111 l 16.667,16.666 16.667,-16.666 5.555,5.556 -16.667,16.666 16.667,16.667 h -38.889 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"M 92.037037,90 V 51.111 l -16.667,16.666 -16.666,-16.666 -5.556,5.556 16.666,16.666 -16.666,16.667 h 38.889 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /></svg>',\n\tsmallscreen: '<svg xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\" xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\" version=\"1.1\" x=\"0px\" y=\"0px\" width=\"100%\" height=\"100%\" viewBox=\"5 -10 74.074074 100\" enable-background=\"new 0 0 100 100\" xml:space=\"preserve\" inkscape:version=\"0.48.4 r9939\" sodipodi:docname=\"noun_2186_cc.svg\"><metadata ><rdf:RDF><cc:Work rdf:about=\"\"><dc:format>image/svg+xml</dc:format><dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\" /></cc:Work></rdf:RDF></metadata><defs /><sodipodi:namedview pagecolor=\"#ffffff\" bordercolor=\"#666666\" borderopacity=\"1\" objecttolerance=\"10\" gridtolerance=\"10\" guidetolerance=\"10\" inkscape:pageopacity=\"0\" inkscape:pageshadow=\"2\" inkscape:window-width=\"1855\" inkscape:window-height=\"1056\" showgrid=\"false\" fit-margin-top=\"0\" fit-margin-left=\"0\" fit-margin-right=\"0\" fit-margin-bottom=\"0\" inkscape:zoom=\"2.36\" inkscape:cx=\"44.101509\" inkscape:cy=\"31.481481\" inkscape:window-x=\"65\" inkscape:window-y=\"24\" inkscape:window-maximized=\"1\" inkscape:current-layer=\"Layer_1\" /><path d=\"m 30.926037,28.889 0,-38.889 -16.667,16.667 -16.667,-16.667 -5.555,5.555 16.667,16.667 -16.667,16.667 38.889,0 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"m 53.148037,28.889 0,-38.889 16.667,16.667 16.666,-16.667 5.556,5.555 -16.666,16.667 16.666,16.667 -38.889,0 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"m 30.926037,51.111 0,38.889 -16.667,-16.666 -16.667,16.666 -5.555,-5.556 16.667,-16.666 -16.667,-16.667 38.889,0 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /><path d=\"m 53.148037,51.111 0,38.889 16.667,-16.666 16.666,16.666 5.556,-5.556 -16.666,-16.666 16.666,-16.667 -38.889,0 z\" inkscape:connector-curvature=\"0\" style=\"fill:#010101\" /></svg>',\n};","require('./tableToCsv.js');","'use strict';\nvar $ = require('jquery');\n\n\n$.fn.tableToCsv = function(config) {\n\tvar csvString = \"\";\n\tconfig = $.extend({\n\t\tquote: \"\\\"\",\n\t\tdelimiter: \",\",\n\t\tlineBreak: \"\\n\",\n\t}, config)\n\n\n\n\n\tvar needToQuoteString = function(value) {\n\t\t//quote when it contains whitespace or the delimiter\n\t\tvar needQuoting = false;\n\t\tif (value.match(\"[\\\\w|\" + config.delimiter + \"|\" + config.quote + \"]\")) {\n\t\t\tneedQuoting = true;\n\t\t}\n\t\treturn needQuoting;\n\t};\n\tvar addValueToString = function(value) {\n\t\t//Quotes in the string need to be escaped\n\t\tvalue.replace(config.quote, config.quote + config.quote);\n\t\tif (needToQuoteString(value)) {\n\t\t\tvalue = config.quote + value + config.quote;\n\t\t}\n\t\tcsvString += \" \" + value + \" \" + config.delimiter;\n\t};\n\n\tvar addRowToString = function(rowArray) {\n\t\trowArray.forEach(function(val) {\n\t\t\taddValueToString(val);\n\t\t});\n\t\tcsvString += config.lineBreak;\n\t}\n\n\tvar tableArrays = [];\n\tvar $el = $(this);\n\tvar rowspans = {};\n\n\n\n\tvar totalColCount = 0;\n\t$el.find('tr:first *').each(function() {\n\t\tif ($(this).attr('colspan')) {\n\t\t\ttotalColCount += +$(this).attr('colspan');\n\t\t} else {\n\t\t\ttotalColCount++;\n\t\t}\n\t});\n\n\t$el.find('tr').each(function(rowId, tr) {\n\t\tvar $tr = $(tr);\n\t\tvar rowArray = []\n\n\t\tvar htmlColId = 0;\n\t\tvar actualColId = 0;\n\t\twhile (actualColId < totalColCount) {\n\t\t\tif (rowspans[actualColId]) {\n\t\t\t\trowArray.push(rowspans[actualColId].text);\n\t\t\t\trowspans[actualColId].rowSpan--;\n\t\t\t\tif (!rowspans[actualColId].rowSpan) rowspans[actualColId] = null;\n\t\t\t\tactualColId++;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tvar $cell = $tr.find(':nth-child(' + (htmlColId + 1) + ')');\n\t\t\tif (!$cell) break;\n\t\t\tvar colspan = $cell.attr('colspan') || 1;\n\t\t\tvar rowspan = $cell.attr('rowspan') || 1;\n\n\t\t\tfor (var i = 0; i < colspan; i++) {\n\t\t\t\trowArray.push($cell.text());\n\t\t\t\tif (rowspan > 1) {\n\t\t\t\t\trowspans[actualColId] = {\n\t\t\t\t\t\trowSpan: rowspan - 1,\n\t\t\t\t\t\ttext: $cell.text(),\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tactualColId++;\n\t\t\t}\n\t\t\thtmlColId++;\n\t\t}\n\t\taddRowToString(rowArray);\n\n\n\t})\n\n\treturn csvString;\n}\n","'use strict';\nvar $ = require(\"jquery\"),\n\tEventEmitter = require('events').EventEmitter,\n\tutils = require(\"yasgui-utils\");\nconsole = console || {\n\t\"log\": function() {}\n}; //make sure any console statements don't break in IE\n\nrequire('./jquery/extendJquery.js');\n\n\n/**\n * Main YASR constructor\n *\n * @constructor\n * @param {DOM-Element} parent element to append editor to.\n * @param {object} settings\n * @class YASR\n * @return {doc} YASR document\n */\nvar YASR = function(parent, options, queryResults) {\n\tEventEmitter.call(this);\n\tvar yasr = this;\n\t// console.log(EventEmitter.call(this));\n\n\t// var yasr = {};\n\t// EventEmitter.call(yasr);\n\tyasr.options = $.extend(true, {}, module.exports.defaults, options);\n\t//the recursive copy does merge (overwrite) array values how we want it to. Do this manually\n\tif (options && options.outputPlugins) yasr.options.outputPlugins = options.outputPlugins;\n\n\tyasr.container = $(\"<div class='yasr'></div>\").appendTo(parent);\n\tyasr.header = $(\"<div class='yasr_header'></div>\").appendTo(yasr.container);\n\tyasr.resultsContainer = $(\"<div class='yasr_results'></div>\").appendTo(yasr.container);\n\tyasr.storage = utils.storage;\n\n\tvar prefix = null;\n\tyasr.getPersistencyId = function(postfix) {\n\t\tif (prefix === null) {\n\t\t\t//instantiate prefix\n\t\t\tif (yasr.options.persistency && yasr.options.persistency.prefix) {\n\t\t\t\tprefix = (typeof yasr.options.persistency.prefix == 'string' ? yasr.options.persistency.prefix : yasr.options.persistency.prefix(yasr));\n\t\t\t} else {\n\t\t\t\tprefix = false;\n\t\t\t}\n\t\t}\n\t\tif (prefix && postfix != null) {\n\t\t\treturn prefix + (typeof postfix == 'string' ? postfix : postfix(yasr));\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t};\n\n\tif (yasr.options.useGoogleCharts) {\n\t\t//pre-load google-loader\n\t\trequire('./gChartLoader.js')\n\t\t\t.once('initError', function() {\n\t\t\t\tyasr.options.useGoogleCharts = false\n\t\t\t})\n\t\t\t.init();\n\t}\n\n\t//first initialize plugins\n\tyasr.plugins = {};\n\tfor (var pluginName in module.exports.plugins) {\n\t\tif (!yasr.options.useGoogleCharts && pluginName == \"gchart\") continue;\n\t\tyasr.plugins[pluginName] = new module.exports.plugins[pluginName](yasr);\n\t}\n\n\n\tyasr.updateHeader = function() {\n\t\tvar downloadIcon = yasr.header.find(\".yasr_downloadIcon\")\n\t\t\t.removeAttr(\"title\"); //and remove previous titles\n\t\tvar embedButton = yasr.header.find(\".yasr_embedBtn\");\n\t\tvar outputPlugin = yasr.plugins[yasr.options.output];\n\t\tif (outputPlugin) {\n\n\t\t\t//Manage download link\n\t\t\tvar info = (outputPlugin.getDownloadInfo ? outputPlugin.getDownloadInfo() : null);\n\t\t\tif (info) {\n\t\t\t\tif (info.buttonTitle) downloadIcon.attr('title', info.buttonTitle);\n\t\t\t\tdownloadIcon.prop(\"disabled\", false);\n\t\t\t\tdownloadIcon.find(\"path\").each(function() {\n\t\t\t\t\tthis.style.fill = \"black\";\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tdownloadIcon.prop(\"disabled\", true).prop(\"title\", \"Download not supported for this result representation\");\n\t\t\t\tdownloadIcon.find(\"path\").each(function() {\n\t\t\t\t\tthis.style.fill = \"gray\";\n\t\t\t\t});\n\t\t\t}\n\n\t\t\t//Manage embed button\n\t\t\tvar link = null;\n\t\t\tif (outputPlugin.getEmbedHtml) link = outputPlugin.getEmbedHtml();\n\t\t\tif (link && link.length > 0) {\n\t\t\t\tembedButton.show();\n\t\t\t} else {\n\t\t\t\tembedButton.hide();\n\t\t\t}\n\t\t}\n\t};\n\tyasr.draw = function(output) {\n\t\tif (!yasr.results) return false;\n\t\tif (!output) output = yasr.options.output;\n\n\n\t\t//ah, our default output does not take our current results. Try to autodetect\n\t\tvar selectedOutput = null;\n\t\tvar selectedOutputPriority = -1;\n\t\tvar unsupportedOutputs = [];\n\t\tfor (var tryOutput in yasr.plugins) {\n\t\t\tif (yasr.plugins[tryOutput].canHandleResults(yasr)) {\n\t\t\t\tvar priority = yasr.plugins[tryOutput].getPriority;\n\t\t\t\tif (typeof priority == \"function\") priority = priority(yasr);\n\t\t\t\tif (priority != null && priority != undefined && priority > selectedOutputPriority) {\n\t\t\t\t\tselectedOutputPriority = priority;\n\t\t\t\t\tselectedOutput = tryOutput;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tunsupportedOutputs.push(tryOutput);\n\t\t\t}\n\t\t}\n\t\tdisableOutputs(unsupportedOutputs);\n\t\tvar outputToDraw = null;\n\t\tif (output in yasr.plugins && yasr.plugins[output].canHandleResults(yasr)) {\n\t\t\toutputToDraw = output;\n\t\t} else if (selectedOutput) {\n\t\t\toutputToDraw = selectedOutput;\n\t\t}\n\n\t\tif (outputToDraw) {\n\t\t\t$(yasr.resultsContainer).empty();\n\t\t\tyasr.emit('draw', yasr, yasr.plugins[outputToDraw]);\n\t\t\tyasr.plugins[outputToDraw].draw();\n\t\t\tyasr.emit('drawn', yasr, yasr.plugins[outputToDraw]);\n\t\t\tyasr.updateHeader();\n\t\t\treturn true;\n\t\t} else {\n\t\t\tyasr.updateHeader();\n\t\t\treturn false;\n\t\t}\n\t};\n\n\tvar disableOutputs = function(outputs) {\n\t\t//first enable everything.\n\t\tyasr.header.find('.yasr_btnGroup .yasr_btn').removeClass('disabled');\n\n\n\t\t//now disable the outputs passed as param\n\t\toutputs.forEach(function(outputName) {\n\t\t\tyasr.header.find('.yasr_btnGroup .select_' + outputName).addClass('disabled');\n\t\t});\n\n\t};\n\tyasr.somethingDrawn = function() {\n\t\treturn !yasr.resultsContainer.is(\":empty\");\n\t};\n\n\tyasr.setResponse = function(dataOrJqXhr, textStatus, jqXhrOrErrorString) {\n\t\ttry {\n\t\t\tyasr.results = require(\"./parsers/wrapper.js\")(dataOrJqXhr, textStatus, jqXhrOrErrorString);\n\t\t} catch (exception) {\n\t\t\tyasr.results = {\n\t\t\t\tgetException: function() {\n\t\t\t\t\treturn exception\n\t\t\t\t}\n\t\t\t};\n\t\t}\n\t\tyasr.draw();\n\n\t\t//store if needed\n\t\tvar resultsId = yasr.getPersistencyId(yasr.options.persistency.results.key);\n\t\tif (resultsId) {\n\t\t\tif (yasr.results.getOriginalResponseAsString && yasr.results.getOriginalResponseAsString().length < yasr.options.persistency.results.maxSize) {\n\t\t\t\tutils.storage.set(resultsId, yasr.results.getAsStoreObject(), \"month\");\n\t\t\t} else {\n\t\t\t\t//remove old string\n\t\t\t\tutils.storage.remove(resultsId);\n\t\t\t}\n\t\t}\n\t};\n\tvar $toggableWarning = null;\n\tvar $toggableWarningClose = null;\n\tvar $toggableWarningMsg = null;\n\tyasr.warn = function(warning) {\n\t\tif (!$toggableWarning) {\n\t\t\t//first time instantiation\n\t\t\t$toggableWarning = $('<div>', {\n\t\t\t\tclass: 'toggableWarning'\n\t\t\t}).prependTo(yasr.container).hide();\n\t\t\t$toggableWarningClose = $('<span>', {\n\t\t\t\t\tclass: 'toggleWarning'\n\t\t\t\t})\n\t\t\t\t.html('×')\n\t\t\t\t.click(function() {\n\t\t\t\t\t$toggableWarning.hide(400);\n\t\t\t\t})\n\t\t\t\t.appendTo($toggableWarning);\n\t\t\t$toggableWarningMsg = $('<span>', {\n\t\t\t\tclass: 'toggableMsg'\n\t\t\t}).appendTo($toggableWarning);\n\t\t}\n\t\t$toggableWarningMsg.empty();\n\t\tif (warning instanceof $) {\n\t\t\t$toggableWarningMsg.append(warning);\n\t\t} else {\n\t\t\t$toggableWarningMsg.html(warning);\n\t\t}\n\t\t$toggableWarning.show(400);\n\t};\n\n\tvar blobDownloadSupported = null;\n\tvar checkBlobDownloadSupported = function() {\n\t\tif (blobDownloadSupported === null) {\n\t\t\tvar windowUrl = window.URL || window.webkitURL || window.mozURL || window.msURL;\n\t\t\tblobDownloadSupported = windowUrl && Blob;\n\t\t}\n\t\treturn blobDownloadSupported;\n\t};\n\tvar embedBtn = null;\n\tvar drawHeader = function(yasr) {\n\t\tvar drawOutputSelector = function() {\n\t\t\tvar btnGroup = $('<div class=\"yasr_btnGroup\"></div>');\n\t\t\t$.each(yasr.options.outputPlugins, function(i, pluginName) {\n\t\t\t\tvar plugin = yasr.plugins[pluginName];\n\t\t\t\tif (!plugin) return; //plugin not loaded\n\n\t\t\t\tif (plugin.hideFromSelection) return;\n\t\t\t\tvar name = plugin.name || pluginName;\n\t\t\t\tvar button = $(\"<button class='yasr_btn'></button>\")\n\t\t\t\t\t.text(name)\n\t\t\t\t\t.addClass(\"select_\" + pluginName)\n\t\t\t\t\t.click(function() {\n\t\t\t\t\t\t//update buttons\n\t\t\t\t\t\tbtnGroup.find(\"button.selected\").removeClass(\"selected\");\n\t\t\t\t\t\t$(this).addClass(\"selected\");\n\t\t\t\t\t\t//set and draw output\n\t\t\t\t\t\tyasr.options.output = pluginName;\n\n\t\t\t\t\t\t//store if needed\n\t\t\t\t\t\tyasr.store();\n\n\t\t\t\t\t\t//close warning if there is any\n\t\t\t\t\t\tif ($toggableWarning) $toggableWarning.hide(400);\n\n\t\t\t\t\t\tyasr.draw();\n\t\t\t\t\t})\n\t\t\t\t\t.appendTo(btnGroup);\n\t\t\t\tif (yasr.options.output == pluginName) button.addClass(\"selected\");\n\t\t\t});\n\n\t\t\tif (btnGroup.children().length > 1) yasr.header.append(btnGroup);\n\t\t};\n\t\tvar drawDownloadIcon = function() {\n\t\t\tvar stringToUrl = function(string, contentType) {\n\t\t\t\tvar url = null;\n\t\t\t\tvar windowUrl = window.URL || window.webkitURL || window.mozURL || window.msURL;\n\t\t\t\tif (windowUrl && Blob) {\n\t\t\t\t\tvar blob = new Blob([string], {\n\t\t\t\t\t\ttype: contentType\n\t\t\t\t\t});\n\t\t\t\t\turl = windowUrl.createObjectURL(blob);\n\t\t\t\t}\n\t\t\t\treturn url;\n\t\t\t};\n\t\t\tvar button = $(\"<button class='yasr_btn yasr_downloadIcon btn_icon'></button>\")\n\t\t\t\t.append(require(\"yasgui-utils\").svg.getElement(require('./imgs.js').download))\n\t\t\t\t.click(function() {\n\t\t\t\t\tvar currentPlugin = yasr.plugins[yasr.options.output];\n\t\t\t\t\tif (currentPlugin && currentPlugin.getDownloadInfo) {\n\t\t\t\t\t\tvar downloadInfo = currentPlugin.getDownloadInfo();\n\t\t\t\t\t\tvar downloadUrl = stringToUrl(downloadInfo.getContent(), (downloadInfo.contentType ? downloadInfo.contentType : \"text/plain\"));\n\t\t\t\t\t\tvar downloadMockLink = $(\"<a></a>\", {\n\t\t\t\t\t\t\thref: downloadUrl,\n\t\t\t\t\t\t\tdownload: downloadInfo.filename\n\t\t\t\t\t\t});\n\t\t\t\t\t\trequire('./utils.js').fireClick(downloadMockLink);\n\t\t\t\t\t\t//\t\t\t\t\t\tdownloadMockLink[0].click();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\tyasr.header.append(button);\n\t\t};\n\t\tvar drawFullscreenButton = function() {\n\t\t\tvar button = $(\"<button class='yasr_btn btn_fullscreen btn_icon'></button>\")\n\t\t\t\t.append(require(\"yasgui-utils\").svg.getElement(require('./imgs.js').fullscreen))\n\t\t\t\t.click(function() {\n\t\t\t\t\tyasr.container.addClass('yasr_fullscreen');\n\t\t\t\t});\n\t\t\tyasr.header.append(button);\n\t\t};\n\t\tvar drawSmallscreenButton = function() {\n\t\t\tvar button = $(\"<button class='yasr_btn btn_smallscreen btn_icon'></button>\")\n\t\t\t\t.append(require(\"yasgui-utils\").svg.getElement(require('./imgs.js').smallscreen))\n\t\t\t\t.click(function() {\n\t\t\t\t\tyasr.container.removeClass('yasr_fullscreen');\n\t\t\t\t});\n\t\t\tyasr.header.append(button);\n\t\t};\n\t\tvar drawEmbedButton = function() {\n\t\t\tembedBtn = $(\"<button>\", {\n\t\t\t\t\tclass: 'yasr_btn yasr_embedBtn',\n\t\t\t\t\ttitle: 'Get HTML snippet to embed results on a web page'\n\t\t\t\t})\n\t\t\t\t.text('</>')\n\t\t\t\t.click(function(event) {\n\t\t\t\t\tvar currentPlugin = yasr.plugins[yasr.options.output];\n\t\t\t\t\tif (currentPlugin && currentPlugin.getEmbedHtml) {\n\t\t\t\t\t\tvar embedLink = currentPlugin.getEmbedHtml();\n\n\t\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t\t\tvar popup = $(\"<div class='yasr_embedPopup'></div>\").appendTo(yasr.header);\n\t\t\t\t\t\t$('html').click(function() {\n\t\t\t\t\t\t\tif (popup) popup.remove();\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tpopup.click(function(event) {\n\t\t\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t\t\t\t//dont close when clicking on popup\n\t\t\t\t\t\t});\n\t\t\t\t\t\tvar prePopup = $(\"<textarea>\").val(embedLink);\n\t\t\t\t\t\tprePopup.focus(function() {\n\t\t\t\t\t\t\tvar $this = $(this);\n\t\t\t\t\t\t\t$this.select();\n\n\t\t\t\t\t\t\t// Work around Chrome's little problem\n\t\t\t\t\t\t\t$this.mouseup(function() {\n\t\t\t\t\t\t\t\t// Prevent further mouseup intervention\n\t\t\t\t\t\t\t\t$this.unbind(\"mouseup\");\n\t\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tpopup.empty().append(prePopup);\n\t\t\t\t\t\tvar positions = embedBtn.position();\n\t\t\t\t\t\tvar top = (positions.top + embedBtn.outerHeight()) + 'px';\n\t\t\t\t\t\tvar left = Math.max(((positions.left + embedBtn.outerWidth()) - popup.outerWidth()), 0) + 'px';\n\n\t\t\t\t\t\tpopup.css(\"top\", top).css(\"left\", left);\n\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\tyasr.header.append(embedBtn);\n\t\t};\n\t\tdrawFullscreenButton();\n\t\tdrawSmallscreenButton();\n\t\tif (yasr.options.drawOutputSelector) drawOutputSelector();\n\t\tif (yasr.options.drawDownloadIcon && checkBlobDownloadSupported()) drawDownloadIcon(); //only draw when it's supported\n\t\tdrawEmbedButton();\n\t};\n\n\tvar persistentId = null;\n\t//store persistent options (not results though. store these separately, as they are too large)\n\tyasr.store = function() {\n\t\tif (!persistentId) persistentId = yasr.getPersistencyId('main');\n\t\tif (persistentId) {\n\t\t\tutils.storage.set(persistentId, yasr.getPersistentSettings());\n\t\t}\n\t};\n\n\n\tyasr.load = function() {\n\t\tif (!persistentId) persistentId = yasr.getPersistencyId('main');\n\t\tyasr.setPersistentSettings(utils.storage.get(persistentId));\n\t};\n\n\n\tyasr.setPersistentSettings = function(settings) {\n\t\tif (settings) {\n\t\t\tif (settings.output) {\n\t\t\t\tyasr.options.output = settings.output;\n\t\t\t}\n\t\t\tfor (var pluginName in settings.plugins) {\n\t\t\t\tif (yasr.plugins[pluginName] && yasr.plugins[pluginName].setPersistentSettings) {\n\t\t\t\t\tyasr.plugins[pluginName].setPersistentSettings(settings.plugins[pluginName]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tyasr.getPersistentSettings = function() {\n\t\tvar settings = {\n\t\t\toutput: yasr.options.output,\n\t\t\tplugins: {}\n\t\t};\n\t\tfor (var pluginName in yasr.plugins) {\n\t\t\tif (yasr.plugins[pluginName].getPersistentSettings) {\n\t\t\t\tsettings.plugins[pluginName] = yasr.plugins[pluginName].getPersistentSettings();\n\t\t\t}\n\t\t}\n\t\treturn settings;\n\t}\n\n\n\t/**\n\t * postprocess\n\t */\n\tyasr.load();\n\tdrawHeader(yasr);\n\tif (!queryResults && yasr.options.persistency && yasr.options.persistency.results) {\n\t\tvar resultsId = yasr.getPersistencyId(yasr.options.persistency.results.key)\n\t\tvar fromStorage;\n\t\tif (resultsId) {\n\t\t\tfromStorage = utils.storage.get(resultsId);\n\t\t}\n\n\n\t\tif (!fromStorage && yasr.options.persistency.results.id) {\n\t\t\t//deprecated! But keep for backwards compatability\n\t\t\t//if results are stored under old ID. Fetch the results, and delete that key (results can be large, and clutter space)\n\t\t\t//setting the results, will automatically store it under the new key, so we don't have to worry about that here\n\t\t\tvar deprId = (typeof yasr.options.persistency.results.id == \"string\" ? yasr.options.persistency.results.id : yasr.options.persistency.results.id(yasr));\n\t\t\tif (deprId) {\n\t\t\t\tfromStorage = utils.storage.get(deprId);\n\t\t\t\tif (fromStorage) utils.storage.remove(deprId);\n\t\t\t}\n\t\t}\n\t\tif (fromStorage) {\n\t\t\tif ($.isArray(fromStorage)) {\n\t\t\t\tyasr.setResponse.apply(this, fromStorage);\n\t\t\t} else {\n\t\t\t\tyasr.setResponse(fromStorage);\n\t\t\t}\n\t\t}\n\t}\n\n\tif (queryResults) {\n\t\tyasr.setResponse(queryResults);\n\t}\n\tyasr.updateHeader();\n\n\n\treturn yasr;\n};\n\nYASR.prototype = new EventEmitter;\nmodule.exports = function(parent, options, queryResults) {\n\treturn new YASR(parent, options, queryResults);\n}\n\n\nmodule.exports.plugins = {};\nmodule.exports.registerOutput = function(name, constructor) {\n\tmodule.exports.plugins[name] = constructor;\n};\n\n\n\n\n/**\n * The default options of YASR. Either change the default options by setting YASR.defaults, or by\n * passing your own options as second argument to the YASR constructor\n *\n * @attribute YASR.defaults\n */\nmodule.exports.defaults = require('./defaults.js');\nmodule.exports.version = {\n\t\"YASR\": require(\"../package.json\").version,\n\t\"jquery\": $.fn.jquery,\n\t\"yasgui-utils\": require(\"yasgui-utils\").version\n};\nmodule.exports.$ = $;\n\n\n\n//put these in a try-catch. When using the unbundled version, and when some dependencies are missing, then YASR as a whole will still function\ntry {\n\tmodule.exports.registerOutput('boolean', require(\"./boolean.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\ntry {\n\tmodule.exports.registerOutput('rawResponse', require(\"./rawResponse.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\ntry {\n\tmodule.exports.registerOutput('table', require(\"./table.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\ntry {\n\tmodule.exports.registerOutput('error', require(\"./error.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\ntry {\n\tmodule.exports.registerOutput('pivot', require(\"./pivot.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\ntry {\n\tmodule.exports.registerOutput('gchart', require(\"./gchart.js\"))\n} catch (e) {\n\tconsole.warn(e);\n};\n","'use strict';\nvar $ = require(\"jquery\");\nvar root = module.exports = function(queryResponse) {\n\treturn require(\"./dlv.js\")(queryResponse, \",\");\n};","'use strict';\nvar $ = require('jquery');\nrequire(\"../../lib/jquery.csv-0.71.js\");\nvar root = module.exports = function(queryResponse, separator) {\n\tvar json = {};\n\tvar arrays = $.csv.toArrays(queryResponse, {\n\t\tseparator: separator\n\t});\n\tvar detectType = function(value) {\n\t\tif (value.indexOf(\"http\") == 0) {\n\t\t\treturn \"uri\";\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t};\n\n\tvar getBoolean = function() {\n\t\tif (arrays.length == 2 && arrays[0].length == 1 && arrays[1].length == 1 && arrays[0][0] == \"boolean\" && (arrays[1][0] == \"1\" || arrays[1][0] == \"0\")) {\n\t\t\tjson.boolean = (arrays[1][0] == \"1\" ? true : false);\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t};\n\n\tvar getVariables = function() {\n\t\tif (arrays.length > 0 && arrays[0].length > 0) {\n\t\t\tjson.head = {\n\t\t\t\tvars: arrays[0]\n\t\t\t};\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t};\n\n\tvar getBindings = function() {\n\t\tif (arrays.length > 1) {\n\t\t\tjson.results = {\n\t\t\t\tbindings: []\n\t\t\t};\n\t\t\tfor (var rowIt = 1; rowIt < arrays.length; rowIt++) {\n\t\t\t\tvar binding = {};\n\t\t\t\tfor (var colIt = 0; colIt < arrays[rowIt].length; colIt++) {\n\t\t\t\t\tvar varName = json.head.vars[colIt];\n\t\t\t\t\tif (varName) {\n\t\t\t\t\t\tvar value = arrays[rowIt][colIt];\n\t\t\t\t\t\tvar detectedType = detectType(value);\n\t\t\t\t\t\tbinding[varName] = {\n\t\t\t\t\t\t\tvalue: value\n\t\t\t\t\t\t};\n\t\t\t\t\t\tif (detectedType) binding[varName].type = detectedType;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tjson.results.bindings.push(binding);\n\t\t\t}\n\t\t\tjson.head = {\n\t\t\t\tvars: arrays[0]\n\t\t\t};\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t};\n\tvar isBoolean = getBoolean();\n\tif (!isBoolean) {\n\t\tvar varsFetched = getVariables();\n\t\tif (varsFetched) getBindings();\n\t}\n\n\treturn json;\n};","'use strict';\nvar $ = require(\"jquery\");\nvar root = module.exports = function(queryResponse) {\n\n\tif (typeof queryResponse == \"string\") {\n\t\ttry {\n\t\t\treturn JSON.parse(queryResponse);\n\t\t} catch (e) {\n\t\t\treturn false;\n\t\t}\n\t}\n\tif (typeof queryResponse == \"object\" && queryResponse.constructor === {}.constructor) {\n\t\treturn queryResponse;\n\t}\n\treturn false;\n\n};","'use strict';\nvar $ = require(\"jquery\");\nvar root = module.exports = function(queryResponse) {\n\treturn require(\"./dlv.js\")(queryResponse, \"\\t\");\n};","'use strict';\nvar $ = require(\"jquery\");\n\n/**\n * arg1 can be:\n * - a string (an exception, or e.g. a csv result string)\n * - an object (e.g. xml or json object)\n * - an object with exception key (contains solely a string to display)\n * - a jqXHR object (when this function is used as 'fail' callback for jquery)\n * arg2 can be:\n * - the textstatus of the response\n * arg3 can be:\n * - a jqXHR object (when this function is used as 'done/success' callback for jquery)\n * - an 'errorThrown' string (\n */\nvar root = module.exports = function(dataOrJqXhr, textStatus, jqXhrOrErrorString) {\n\tvar parsers = {\n\t\txml: require(\"./xml.js\"),\n\t\tjson: require(\"./json.js\"),\n\t\ttsv: require(\"./tsv.js\"),\n\t\tcsv: require(\"./csv.js\")\n\t};\n\tvar contentType = null;\n\tvar origResponse = null;\n\tvar json = null;\n\tvar type = null; //json, xml, csv, or tsv\n\tvar exception = null;\n\n\tvar init = function() {\n\t\tif (typeof dataOrJqXhr == \"object\") {\n\t\t\t/**\n\t\t\t * Extract exception info (if there is any)\n\t\t\t */\n\t\t\tif (dataOrJqXhr.exception) {\n\t\t\t\t//this object just has this exception string, nothing more. (here for backwards compatability)\n\t\t\t\texception = dataOrJqXhr.exception;\n\t\t\t} else if (dataOrJqXhr.status != undefined && (dataOrJqXhr.status >= 300 || dataOrJqXhr.status === 0)) {\n\t\t\t\t//this is an exception, and jquery response\n\t\t\t\texception = {\n\t\t\t\t\tstatus: dataOrJqXhr.status\n\t\t\t\t};\n\t\t\t\tif (typeof jqXhrOrErrorString == \"string\") exception.errorString = jqXhrOrErrorString;\n\t\t\t\tif (dataOrJqXhr.responseText) exception.responseText = dataOrJqXhr.responseText;\n\t\t\t\tif (dataOrJqXhr.statusText) exception.statusText = dataOrJqXhr.statusText;\n\t\t\t}\n\n\t\t\t/**\n\t\t\t * Extract content type info (if there is any)\n\t\t\t */\n\t\t\tif (dataOrJqXhr.contentType) {\n\t\t\t\t//this is not a jqXhr object, but a manually generated object (mostly for backwards compatability)\n\t\t\t\tcontentType = dataOrJqXhr.contentType.toLowerCase();\n\t\t\t} else if (dataOrJqXhr.getResponseHeader && dataOrJqXhr.getResponseHeader(\"content-type\")) {\n\t\t\t\tvar ct = dataOrJqXhr.getResponseHeader(\"content-type\").trim().toLowerCase();\n\t\t\t\tif (ct.length > 0) contentType = ct;\n\t\t\t}\n\n\t\t\t/**\n\t\t\t * extract original response\n\t\t\t */\n\t\t\tif (dataOrJqXhr.response) {\n\t\t\t\t//this is not a jqXhr object, but a manually generated object (mostly for backwards compatability)\n\t\t\t\torigResponse = dataOrJqXhr.response;\n\t\t\t} else if (!textStatus && !jqXhrOrErrorString) {\n\t\t\t\t//not called from jquery, as these other arguments are undefined.\n\t\t\t\t//so, we can only assume the current object is a proper response (e.g. xml or json) object\n\t\t\t\torigResponse = dataOrJqXhr;\n\t\t\t}\n\t\t}\n\t\tif (!exception && !origResponse) {\n\t\t\t//if this is called via a jquery complete callback, we should fetch the result for the jqXHR object\n\t\t\tif (dataOrJqXhr.responseText) {\n\t\t\t\torigResponse = dataOrJqXhr.responseText;\n\t\t\t} else {\n\t\t\t\t//if all else fails, assume first arg to be data object\n\t\t\t\t//(which should be the case for most situations)\n\t\t\t\torigResponse = dataOrJqXhr;\n\t\t\t}\n\t\t}\n\t};\n\n\tvar getAsJson = function() {\n\t\tif (json) return json;\n\t\tif (json === false || exception) return false; //already tried parsing this, and failed. do not try again... \n\t\tvar getParserFromContentType = function() {\n\t\t\tif (contentType) {\n\t\t\t\tif (contentType.indexOf(\"json\") > -1) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tjson = parsers.json(origResponse);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\texception = e;\n\t\t\t\t\t}\n\t\t\t\t\ttype = \"json\";\n\t\t\t\t} else if (contentType.indexOf(\"xml\") > -1) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tjson = parsers.xml(origResponse);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\texception = e;\n\t\t\t\t\t}\n\t\t\t\t\ttype = \"xml\";\n\t\t\t\t} else if (contentType.indexOf(\"csv\") > -1) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tjson = parsers.csv(origResponse);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\texception = e;\n\t\t\t\t\t}\n\t\t\t\t\ttype = \"csv\";\n\t\t\t\t} else if (contentType.indexOf(\"tab-separated\") > -1) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tjson = parsers.tsv(origResponse);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\texception = e;\n\t\t\t\t\t}\n\t\t\t\t\ttype = \"tsv\";\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\n\t\tvar doLuckyGuess = function() {\n\t\t\tjson = parsers.json(origResponse);\n\t\t\tif (json) {\n\t\t\t\ttype = \"json\";\n\t\t\t} else {\n\t\t\t\ttry {\n\t\t\t\t\tjson = parsers.xml(origResponse);\n\t\t\t\t\tif (json) type = \"xml\";\n\t\t\t\t} catch (err) {};\n\t\t\t}\n\t\t};\n\n\n\t\tgetParserFromContentType();\n\t\tif (!json) {\n\t\t\tdoLuckyGuess();\n\t\t}\n\t\tif (!json) json = false; //explicitly set to false, so we don't try to parse this thing again..\n\t\treturn json;\n\t};\n\n\n\tvar getVariables = function() {\n\t\tvar json = getAsJson();\n\t\tif (json && \"head\" in json) {\n\t\t\treturn json.head.vars;\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t};\n\n\tvar getBindings = function() {\n\t\tvar json = getAsJson();\n\t\tif (json && \"results\" in json) {\n\t\t\treturn json.results.bindings;\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t};\n\n\tvar getBoolean = function() {\n\t\tvar json = getAsJson();\n\t\tif (json && \"boolean\" in json) {\n\t\t\treturn json.boolean;\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t};\n\tvar getOriginalResponse = function() {\n\t\treturn origResponse;\n\t};\n\tvar getOriginalResponseAsString = function() {\n\t\tvar responseString = \"\";\n\t\tif (typeof origResponse == \"string\") {\n\t\t\tresponseString = origResponse;\n\t\t} else if (type == \"json\") {\n\t\t\tresponseString = JSON.stringify(origResponse, undefined, 2); //prettifies as well\n\t\t} else if (type == \"xml\") {\n\t\t\tresponseString = new XMLSerializer().serializeToString(origResponse);\n\t\t}\n\t\treturn responseString;\n\t};\n\tvar getException = function() {\n\t\treturn exception;\n\t};\n\tvar getType = function() {\n\t\tif (type == null) getAsJson(); //detects type as well\n\t\treturn type;\n\t};\n\n\t//process the input parameters in such a way that we can store it in local storage (i.e., no function)\n\t//and, make sure we can easily pass it on back to this wrapper function when loading it again from storage\n\tvar getAsStoreObject = function() {\n\t\tvar storeArray = [];\n\t\tvar arg1 = {};\n\t\tif (dataOrJqXhr.status) {\n\t\t\t//jqXhr object\n\t\t\targ1.status = dataOrJqXhr.status;\n\t\t\targ1.responseText = dataOrJqXhr.responseText;\n\t\t\targ1.statusText = dataOrJqXhr.statusText;\n\t\t\targ1.contentType = contentType; //this is a function in a jqXhr object (problem for storing). but this wrapper will read it as string as well\n\t\t} else {\n\t\t\t//the other instances of this param (whether it is a json, xml, or exception object), we can normally store\n\t\t\targ1 = dataOrJqXhr;\n\t\t}\n\n\n\t\tvar arg2 = textStatus;\n\t\tvar arg3 = undefined;\n\t\tif (typeof jqXhrOrErrorString == \"string\") arg3 = jqXhrOrErrorString;\n\n\t\treturn [arg1, arg2, arg3];\n\t};\n\n\n\n\tinit();\n\tjson = getAsJson();\n\n\treturn {\n\t\tgetAsStoreObject: getAsStoreObject,\n\t\tgetAsJson: getAsJson,\n\t\tgetOriginalResponse: getOriginalResponse,\n\t\tgetOriginalResponseAsString: getOriginalResponseAsString,\n\t\tgetOriginalContentType: function() {\n\t\t\treturn contentType;\n\t\t},\n\t\tgetVariables: getVariables,\n\t\tgetBindings: getBindings,\n\t\tgetBoolean: getBoolean,\n\t\tgetType: getType,\n\t\tgetException: getException\n\t};\n};","'use strict';\nvar $ = require(\"jquery\");\nvar root = module.exports = function(xml) {\n\n\n\n\t/**\n\t * head\n\t */\n\tvar parseHead = function(node) {\n\t\tjson.head = {};\n\t\tfor (var headNodeIt = 0; headNodeIt < node.childNodes.length; headNodeIt++) {\n\t\t\tvar headNode = node.childNodes[headNodeIt];\n\t\t\tif (headNode.nodeName == \"variable\") {\n\t\t\t\tif (!json.head.vars) json.head.vars = [];\n\t\t\t\tvar name = headNode.getAttribute(\"name\");\n\t\t\t\tif (name) json.head.vars.push(name);\n\t\t\t}\n\t\t}\n\t};\n\n\tvar parseResults = function(node) {\n\t\tjson.results = {};\n\t\tjson.results.bindings = [];\n\t\tfor (var resultIt = 0; resultIt < node.childNodes.length; resultIt++) {\n\t\t\tvar resultNode = node.childNodes[resultIt];\n\t\t\tvar jsonResult = null;\n\n\t\t\tfor (var bindingIt = 0; bindingIt < resultNode.childNodes.length; bindingIt++) {\n\t\t\t\tvar bindingNode = resultNode.childNodes[bindingIt];\n\t\t\t\tif (bindingNode.nodeName == \"binding\") {\n\t\t\t\t\tvar varName = bindingNode.getAttribute(\"name\");\n\t\t\t\t\tif (varName) {\n\t\t\t\t\t\tjsonResult = jsonResult || {};\n\t\t\t\t\t\tjsonResult[varName] = {};\n\t\t\t\t\t\tfor (var bindingInfIt = 0; bindingInfIt < bindingNode.childNodes.length; bindingInfIt++) {\n\t\t\t\t\t\t\tvar bindingInf = bindingNode.childNodes[bindingInfIt];\n\t\t\t\t\t\t\tvar type = bindingInf.nodeName;\n\t\t\t\t\t\t\tif (type == \"#text\") continue;\n\t\t\t\t\t\t\tjsonResult[varName].type = type;\n\t\t\t\t\t\t\tjsonResult[varName].value = bindingInf.innerHTML;\n\t\t\t\t\t\t\tvar dataType = bindingInf.getAttribute(\"datatype\");\n\t\t\t\t\t\t\tif (dataType) jsonResult[varName].datatype = dataType;\n\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (jsonResult) json.results.bindings.push(jsonResult);\n\t\t}\n\t};\n\n\tvar parseBoolean = function(node) {\n\t\tif (node.innerHTML == \"true\") {\n\t\t\tjson.boolean = true;\n\t\t} else {\n\t\t\tjson.boolean = false;\n\t\t}\n\t};\n\tvar mainXml = null;\n\tif (typeof xml == \"string\") {\n\t\tmainXml = $.parseXML(xml);\n\t} else if ($.isXMLDoc(xml)) {\n\t\tmainXml = xml;\n\t}\n\tvar xml = null;\n\tif (mainXml.childNodes.length > 0) {\n\t\t//enter the main 'sparql' node\n\t\txml = mainXml.childNodes[0];\n\t} else {\n\t\treturn null;\n\t}\n\tvar json = {};\n\n\n\tfor (var i = 0; i < xml.childNodes.length; i++) {\n\t\tvar node = xml.childNodes[i];\n\t\tif (node.nodeName == \"head\") parseHead(node);\n\t\tif (node.nodeName == \"results\") parseResults(node);\n\t\tif (node.nodeName == \"boolean\") parseBoolean(node);\n\t}\n\n\treturn json;\n};","'use strict';\nvar $ = require(\"jquery\"),\n\tutils = require('./utils.js'),\n\tyUtils = require('yasgui-utils'),\n\timgs = require('./imgs.js');\nrequire('jquery-ui/sortable');\nrequire('pivottable');\n\nif (!$.fn.pivotUI) throw new Error(\"Pivot lib not loaded\");\nvar root = module.exports = function(yasr) {\n\tvar plugin = {};\n\tvar options = $.extend(true, {}, root.defaults);\n\n\tif (options.useD3Chart) {\n\t\ttry {\n\t\t\tvar d3 = require('d3');\n\t\t\tif (d3) require('pivottable/dist/d3_renderers.js');\n\t\t} catch (e) {\n\t\t\t//do nothing. just make sure we don't use this renderer\n\t\t}\n\t\tif ($.pivotUtilities.d3_renderers) $.extend(true, $.pivotUtilities.renderers, $.pivotUtilities.d3_renderers);\n\t}\n\n\n\n\tvar $pivotWrapper;\n\tvar mergeLabelPostfix = null;\n\tvar getShownVariables = function() {\n\t\tvar variables = yasr.results.getVariables();\n\t\tif (!options.mergeLabelsWithUris) return variables;\n\t\tvar shownVariables = [];\n\n\t\tmergeLabelPostfix = (typeof options.mergeLabelsWithUris == \"string\" ? options.mergeLabelsWithUris : \"Label\");\n\t\tvariables.forEach(function(variable) {\n\t\t\tif (variable.indexOf(mergeLabelPostfix, variable.length - mergeLabelPostfix.length) !== -1) {\n\t\t\t\t//this one ends with a postfix\n\t\t\t\tif (variables.indexOf(variable.substring(0, variable.length - mergeLabelPostfix.length)) >= 0) {\n\t\t\t\t\t//we have a shorter version of this variable. So, do not include the ..<postfix> variable in the table\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\tshownVariables.push(variable);\n\t\t});\n\t\treturn shownVariables;\n\t};\n\n\tvar formatForPivot = function(callback) {\n\n\t\tvar vars = getShownVariables();\n\t\tvar usedPrefixes = null;\n\t\tif (yasr.options.getUsedPrefixes) {\n\t\t\tusedPrefixes = (typeof yasr.options.getUsedPrefixes == \"function\" ? yasr.options.getUsedPrefixes(yasr) : yasr.options.getUsedPrefixes);\n\t\t}\n\t\tyasr.results.getBindings().forEach(function(binding) {\n\t\t\tvar rowObj = {};\n\t\t\tvars.forEach(function(variable) {\n\t\t\t\tif (variable in binding) {\n\t\t\t\t\tvar val = binding[variable].value;\n\t\t\t\t\tif (mergeLabelPostfix && binding[variable + mergeLabelPostfix]) {\n\t\t\t\t\t\tval = binding[variable + mergeLabelPostfix].value;\n\t\t\t\t\t} else if (binding[variable].type == \"uri\") {\n\t\t\t\t\t\tval = utils.uriToPrefixed(usedPrefixes, val);\n\t\t\t\t\t}\n\t\t\t\t\trowObj[variable] = val;\n\t\t\t\t} else {\n\t\t\t\t\trowObj[variable] = null;\n\t\t\t\t}\n\t\t\t});\n\t\t\tcallback(rowObj);\n\t\t});\n\t}\n\n\n\tvar validatePivotTableOptions = function(pivotOptions) {\n\t\t//validate settings. we may have different variables, or renderers might be gone\n\t\tif (pivotOptions) {\n\t\t\tif (yasr.results) {\n\t\t\t\tvar vars = yasr.results.getVariables();\n\t\t\t\tvar keepColsAndRows = true;\n\t\t\t\tpivotOptions.cols.forEach(function(variable) {\n\t\t\t\t\tif (vars.indexOf(variable) < 0) keepColsAndRows = false;\n\t\t\t\t});\n\t\t\t\tif (keepColsAndRows) {\n\t\t\t\t\tpivotOptionse.rows.forEach(function(variable) {\n\t\t\t\t\t\tif (vars.indexOf(variable) < 0) keepColsAndRows = false;\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tif (!keepColsAndRows) {\n\t\t\t\t\tpivotOptions.cols = [];\n\t\t\t\t\tpivotOptions.rows = [];\n\t\t\t\t}\n\t\t\t\tif (!$.pivotUtilities.renderers[settings.rendererName]) delete pivotOptions.rendererName;\n\t\t\t}\n\t\t} else {\n\t\t\tpivotOptions = {};\n\t\t}\n\t\treturn pivotOptions;\n\t};\n\tvar draw = function() {\n\t\tvar doDraw = function() {\n\t\t\tvar onRefresh = function(pivotObj) {\n\t\t\t\toptions.pivotTable.cols = pivotObj.cols;\n\t\t\t\toptions.pivotTable.rows = pivotObj.rows;\n\t\t\t\toptions.pivotTable.rendererName = pivotObj.rendererName;\n\t\t\t\toptions.pivotTable.aggregatorName = pivotObj.aggregatorName;\n\t\t\t\toptions.pivotTable.vals = pivotObj.vals;\n\t\t\t\tyasr.store();\n\n\t\t\t\tif (pivotObj.rendererName.toLowerCase().indexOf(' chart') >= 0) {\n\t\t\t\t\topenGchartBtn.show();\n\t\t\t\t} else {\n\t\t\t\t\topenGchartBtn.hide();\n\t\t\t\t}\n\t\t\t\tyasr.updateHeader();\n\t\t\t};\n\n\n\t\t\tvar openGchartBtn = $('<button>', {\n\t\t\t\t\tclass: 'openPivotGchart yasr_btn'\n\t\t\t\t})\n\t\t\t\t.text('Chart Config')\n\t\t\t\t.click(function() {\n\t\t\t\t\t$pivotWrapper.find('div[dir=\"ltr\"]').dblclick();\n\t\t\t\t}).appendTo(yasr.resultsContainer);\n\t\t\t$pivotWrapper = $('<div>', {\n\t\t\t\tclass: 'pivotTable'\n\t\t\t}).appendTo($(yasr.resultsContainer));\n\n\t\t\toptions.pivotTable.onRefresh = (function() {\n\t\t\t\tvar originalRefresh = options.pivotTable.onRefresh;\n\t\t\t\treturn function(pivotObj) {\n\t\t\t\t\tonRefresh(pivotObj);\n\t\t\t\t\tif (originalRefresh) originalRefresh(pivotObj);\n\t\t\t\t};\n\t\t\t})();\n\n\t\t\twindow.pivot = $pivotWrapper.pivotUI(formatForPivot, options.pivotTable);\n\n\t\t\t/**\n\t\t\t * post process\n\t\t\t */\n\t\t\t//use 'move' handler for variables. This removes the 'filter' button though. Might want to re-enable this in the future\n\t\t\tvar icon = $(yUtils.svg.getElement(imgs.move));\n\t\t\t$pivotWrapper.find('.pvtTriangle').replaceWith(icon);\n\n\t\t\t//add headers to selector rows\n\t\t\t$('.pvtCols').prepend($('<div>', {\n\t\t\t\tclass: 'containerHeader'\n\t\t\t}).text(\"Columns\"));\n\t\t\t$('.pvtRows').prepend($('<div>', {\n\t\t\t\tclass: 'containerHeader'\n\t\t\t}).text(\"Rows\"));\n\t\t\t$('.pvtUnused').prepend($('<div>', {\n\t\t\t\tclass: 'containerHeader'\n\t\t\t}).text(\"Available Variables\"));\n\t\t\t$('.pvtVals').prepend($('<div>', {\n\t\t\t\tclass: 'containerHeader'\n\t\t\t}).text(\"Cells\"));\n\n\t\t\t//hmmm, directly after the callback finishes (i.e., directly after this line), the svg is draw.\n\t\t\t//just use a short timeout to update the header\n\t\t\tsetTimeout(yasr.updateHeader, 400);\n\t\t}\n\n\t\tif (yasr.options.useGoogleCharts && options.useGoogleCharts && !$.pivotUtilities.gchart_renderers) {\n\t\t\trequire('./gChartLoader.js')\n\t\t\t\t.on('done', function() {\n\t\t\t\t\ttry {\n\t\t\t\t\t\trequire('pivottable/dist/gchart_renderers.js');\n\t\t\t\t\t\t$.extend(true, $.pivotUtilities.renderers, $.pivotUtilities.gchart_renderers);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t//hmm, still something went wrong. forget about it;\n\t\t\t\t\t\toptions.useGoogleCharts = false;\n\t\t\t\t\t}\n\t\t\t\t\tdoDraw();\n\t\t\t\t})\n\t\t\t\t.on('error', function() {\n\t\t\t\t\tconsole.log('could not load gchart');\n\t\t\t\t\toptions.useGoogleCharts = false;\n\t\t\t\t\tdoDraw();\n\t\t\t\t})\n\t\t\t\t.googleLoad();\n\t\t} else {\n\t\t\t//everything is already loaded. just draw\n\t\t\tdoDraw();\n\t\t}\n\t};\n\tvar canHandleResults = function() {\n\t\treturn yasr.results && yasr.results.getVariables && yasr.results.getVariables() && yasr.results.getVariables().length > 0;\n\t};\n\n\tvar getDownloadInfo = function() {\n\t\tif (!yasr.results) return null;\n\t\tvar svgEl = yasr.resultsContainer.find('.pvtRendererArea svg');\n\t\tif (svgEl.length > 0) {\n\n\t\t\treturn {\n\t\t\t\tgetContent: function() {\n\t\t\t\t\tif (svgEl[0].outerHTML) {\n\t\t\t\t\t\treturn svgEl[0].outerHTML;\n\t\t\t\t\t} else {\n\t\t\t\t\t\t//outerHTML not supported. use workaround\n\t\t\t\t\t\treturn $('<div>').append(svgEl.clone()).html();\n\t\t\t\t\t}\n\t\t\t\t},\n\n\t\t\t\tfilename: \"queryResults.svg\",\n\t\t\t\tcontentType: \"image/svg+xml\",\n\t\t\t\tbuttonTitle: \"Download SVG Image\"\n\t\t\t};\n\t\t}\n\n\t\t//ok, not a svg. is it a table?\n\t\tvar $table = yasr.resultsContainer.find('.pvtRendererArea table');\n\t\tif ($table.length > 0) {\n\t\t\treturn {\n\t\t\t\tgetContent: function() {\n\t\t\t\t\treturn $table.tableToCsv();\n\t\t\t\t},\n\t\t\t\tfilename: \"queryResults.csv\",\n\t\t\t\tcontentType: \"text/csv\",\n\t\t\t\tbuttonTitle: \"Download as CSV\"\n\t\t\t};\n\t\t}\n\n\t};\n\tvar getEmbedHtml = function() {\n\t\tif (!yasr.results) return null;\n\n\t\tvar svgEl = yasr.resultsContainer.find('.pvtRendererArea svg')\n\t\t\t.clone() //create clone, as we'd like to remove height/width attributes\n\t\t\t.removeAttr('height').removeAttr('width')\n\t\t\t.css('height', '').css('width', '');\n\t\tif (svgEl.length == 0) return null;\n\n\t\tvar htmlString = svgEl[0].outerHTML;\n\t\tif (!htmlString) {\n\t\t\t//outerHTML not supported. use workaround\n\t\t\thtmlString = $('<div>').append(svgEl.clone()).html();\n\t\t}\n\t\t//wrap in div, so users can more easily tune width/height\n\t\t//don't use jquery, so we can easily influence indentation\n\t\treturn '<div style=\"width: 800px; height: 600px;\">\\n' + htmlString + '\\n</div>';\n\t};\n\treturn {\n\t\tgetPersistentSettings: function() {\n\t\t\treturn {\n\t\t\t\tpivotTable: options.pivotTable\n\t\t\t};\n\t\t},\n\t\tsetPersistentSettings: function(newSettings) {\n\t\t\tif (newSettings.pivotTable) {\n\t\t\t\toptions.pivotTable = validatePivotTableOptions(newSettings.pivotTable);\n\t\t\t}\n\n\t\t},\n\t\tgetDownloadInfo: getDownloadInfo,\n\t\tgetEmbedHtml: getEmbedHtml,\n\t\toptions: options,\n\t\tdraw: draw,\n\t\tname: \"Pivot Table\",\n\t\tcanHandleResults: canHandleResults,\n\t\tgetPriority: 4,\n\t}\n};\n\n\n\nroot.defaults = {\n\tmergeLabelsWithUris: false,\n\tuseGoogleCharts: true,\n\tuseD3Chart: true,\n\tpersistencyId: 'pivot',\n\tpivotTable: {}\n};\n\nroot.version = {\n\t\"YASR-rawResponse\": require(\"../package.json\").version,\n\t\"jquery\": $.fn.jquery,\n};\n","'use strict';\nvar $ = require(\"jquery\"),\n\tCodeMirror = require(\"codemirror\");\n\nrequire('codemirror/addon/fold/foldcode.js');\nrequire('codemirror/addon/fold/foldgutter.js');\nrequire('codemirror/addon/fold/xml-fold.js');\nrequire('codemirror/addon/fold/brace-fold.js');\n\nrequire('codemirror/addon/edit/matchbrackets.js');\nrequire('codemirror/mode/xml/xml.js');\nrequire('codemirror/mode/javascript/javascript.js');\n\nvar root = module.exports = function(yasr) {\n\tvar plugin = {};\n\tvar options = $.extend(true, {}, root.defaults);\n\tvar cm = null;\n\tvar draw = function() {\n\t\tvar cmOptions = options.CodeMirror;\n\t\tcmOptions.value = yasr.results.getOriginalResponseAsString();\n\n\t\tvar mode = yasr.results.getType();\n\t\tif (mode) {\n\t\t\tif (mode == \"json\") {\n\t\t\t\tmode = {\n\t\t\t\t\tname: \"javascript\",\n\t\t\t\t\tjson: true\n\t\t\t\t};\n\t\t\t}\n\t\t\tcmOptions.mode = mode;\n\t\t}\n\n\t\tcm = CodeMirror(yasr.resultsContainer.get()[0], cmOptions);\n\n\t\t//CM has some issues with folding and unfolding (blank parts in the codemirror area, which are only filled after clicking it)\n\t\t//so, refresh cm after folding/unfolding\n\t\tcm.on('fold', function() {\n\t\t\tcm.refresh();\n\t\t});\n\t\tcm.on('unfold', function() {\n\t\t\tcm.refresh();\n\t\t});\n\n\t};\n\tvar canHandleResults = function() {\n\t\tif (!yasr.results) return false;\n\t\tif (!yasr.results.getOriginalResponseAsString) return false;\n\t\tvar response = yasr.results.getOriginalResponseAsString();\n\t\tif ((!response || response.length == 0) && yasr.results.getException()) return false; //in this case, show exception instead, as we have nothing to show anyway\n\t\treturn true;\n\t};\n\n\tvar getDownloadInfo = function() {\n\t\tif (!yasr.results) return null;\n\t\tvar contentType = yasr.results.getOriginalContentType();\n\t\tvar type = yasr.results.getType();\n\t\treturn {\n\t\t\tgetContent: function() {\n\t\t\t\treturn yasr.results.getOriginalResponse();\n\t\t\t},\n\t\t\tfilename: \"queryResults\" + (type ? \".\" + type : \"\"),\n\t\t\tcontentType: (contentType ? contentType : \"text/plain\"),\n\t\t\tbuttonTitle: \"Download raw response\"\n\t\t};\n\t};\n\n\treturn {\n\t\tdraw: draw,\n\t\tname: \"Raw Response\",\n\t\tcanHandleResults: canHandleResults,\n\t\tgetPriority: 2,\n\t\tgetDownloadInfo: getDownloadInfo,\n\n\t}\n};\n\n\n\nroot.defaults = {\n\tCodeMirror: {\n\t\treadOnly: true,\n\t\tlineNumbers: true,\n\t\tlineWrapping: true,\n\t\tfoldGutter: true,\n\t\tgutters: [\"CodeMirror-linenumbers\", \"CodeMirror-foldgutter\"]\n\t}\n};\n\nroot.version = {\n\t\"YASR-rawResponse\": require(\"../package.json\").version,\n\t\"jquery\": $.fn.jquery,\n\t\"CodeMirror\": CodeMirror.version\n};","'use strict';\nvar $ = require(\"jquery\"),\n\tyutils = require(\"yasgui-utils\"),\n\tutils = require('./utils.js'),\n\timgs = require('./imgs.js');\nrequire(\"datatables.net\")();\nrequire(\"../lib/colResizable-1.4.js\");\n\n\n\n/**\n * Constructor of plugin which displays results as a table\n *\n * @param yasr {object}\n * @param parent {DOM element}\n * @param options {object}\n * @class YASR.plugins.table\n * @return yasr-table (doc)\n *\n */\nvar root = module.exports = function(yasr) {\n\tvar table = null;\n\tvar plugin = {\n\t\tname: \"Table\",\n\t\tgetPriority: 10,\n\t};\n\tvar options = plugin.options = $.extend(true, {}, root.defaults);\n\tvar tableLengthPersistencyId = (options.persistency ? yasr.getPersistencyId(options.persistency.tableLength) : null);\n\n\tvar getRows = function() {\n\t\tvar rows = [];\n\t\tvar bindings = yasr.results.getBindings();\n\t\tvar vars = yasr.results.getVariables();\n\t\tvar usedPrefixes = null;\n\t\tif (yasr.options.getUsedPrefixes) {\n\t\t\tusedPrefixes = (typeof yasr.options.getUsedPrefixes == \"function\" ? yasr.options.getUsedPrefixes(yasr) : yasr.options.getUsedPrefixes);\n\t\t}\n\t\tfor (var rowId = 0; rowId < bindings.length; rowId++) {\n\t\t\tvar row = [];\n\t\t\trow.push(\"\"); //row numbers\n\t\t\tvar binding = bindings[rowId];\n\t\t\tfor (var colId = 0; colId < vars.length; colId++) {\n\t\t\t\tvar sparqlVar = vars[colId];\n\t\t\t\tif (sparqlVar in binding) {\n\t\t\t\t\tif (options.getCellContent) {\n\t\t\t\t\t\trow.push(options.getCellContent(yasr, plugin, binding, sparqlVar, {\n\t\t\t\t\t\t\t'rowId': rowId,\n\t\t\t\t\t\t\t'colId': colId,\n\t\t\t\t\t\t\t'usedPrefixes': usedPrefixes\n\t\t\t\t\t\t}));\n\t\t\t\t\t} else {\n\t\t\t\t\t\trow.push(\"\");\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\trow.push(\"\");\n\t\t\t\t}\n\t\t\t}\n\t\t\trows.push(row);\n\t\t}\n\t\treturn rows;\n\t};\n\n\tvar eventId = yasr.getPersistencyId('eventId') || \"yasr_\" + $(yasr.container).closest('[id]').attr('id');\n\tvar addEvents = function() {\n\t\ttable.on('order.dt', function() {\n\t\t\tdrawSvgIcons();\n\t\t});\n\t\tif (tableLengthPersistencyId) {\n\t\t\ttable.on('length.dt', function(e, settings, len) {\n\t\t\t\tyutils.storage.set(tableLengthPersistencyId, len, \"month\");\n\t\t\t});\n\t\t}\n\t\t$.extend(true, options.callbacks, options.handlers);\n\t\ttable.delegate(\"td\", \"click\", function(event) {\n\t\t\tif (options.callbacks && options.callbacks.onCellClick) {\n\t\t\t\tvar result = options.callbacks.onCellClick(this, event);\n\t\t\t\tif (result === false) return false;\n\t\t\t}\n\t\t}).delegate(\"td\", 'mouseenter', function(event) {\n\t\t\tif (options.callbacks && options.callbacks.onCellMouseEnter) {\n\t\t\t\toptions.callbacks.onCellMouseEnter(this, event);\n\t\t\t}\n\t\t\tvar tdEl = $(this);\n\t\t\tif (options.fetchTitlesFromPreflabel && tdEl.attr(\"title\") === undefined && tdEl.text().trim().indexOf(\"http\") == 0) {\n\t\t\t\taddPrefLabel(tdEl);\n\t\t\t}\n\t\t}).delegate(\"td\", 'mouseleave', function(event) {\n\t\t\tif (options.callbacks && options.callbacks.onCellMouseLeave) {\n\t\t\t\toptions.callbacks.onCellMouseLeave(this, event);\n\n\t\t\t}\n\t\t});\n\t};\n\n\tplugin.draw = function() {\n\t\ttable = $('<table cellpadding=\"0\" cellspacing=\"0\" border=\"0\" class=\"resultsTable\"></table>');\n\t\t$(yasr.resultsContainer).html(table);\n\n\t\tvar dataTableConfig = options.datatable;\n\t\tdataTableConfig.data = getRows();\n\t\tdataTableConfig.columns = options.getColumns(yasr, plugin);\n\n\t\t//fetch stored datatables length value\n\t\tvar pLength = yutils.storage.get(tableLengthPersistencyId);\n\t\tif (pLength) dataTableConfig.pageLength = pLength;\n\n\n\n\t\ttable.DataTable($.extend(true, {}, dataTableConfig)); //make copy. datatables adds properties for backwards compatability reasons, and don't want this cluttering our own\n\n\n\t\tdrawSvgIcons();\n\n\t\taddEvents();\n\n\t\t//finally, make the columns dragable:\n\t\ttable.colResizable();\n\t};\n\n\tvar drawSvgIcons = function() {\n\t\tvar sortings = {\n\t\t\t\"sorting\": \"unsorted\",\n\t\t\t\"sorting_asc\": \"sortAsc\",\n\t\t\t\"sorting_desc\": \"sortDesc\"\n\t\t};\n\t\ttable.find(\".sortIcons\").remove();\n\t\tfor (var sorting in sortings) {\n\t\t\tvar svgDiv = $(\"<div class='sortIcons'></div>\");\n\t\t\tyutils.svg.draw(svgDiv, imgs[sortings[sorting]]);\n\t\t\ttable.find(\"th.\" + sorting).append(svgDiv);\n\t\t}\n\t};\n\t/**\n\t * Check whether this plugin can handler the current results\n\t *\n\t * @property canHandleResults\n\t * @type function\n\t * @default If resultset contains variables in the resultset, return true\n\t */\n\tplugin.canHandleResults = function() {\n\t\treturn yasr.results && yasr.results.getVariables && yasr.results.getVariables() && yasr.results.getVariables().length > 0;\n\t};\n\n\n\tplugin.getDownloadInfo = function() {\n\t\tif (!yasr.results) return null;\n\t\treturn {\n\t\t\tgetContent: function() {\n\t\t\t\treturn require(\"./bindingsToCsv.js\")(yasr.results.getAsJson());\n\t\t\t},\n\t\t\tfilename: \"queryResults.csv\",\n\t\t\tcontentType: \"text/csv\",\n\t\t\tbuttonTitle: \"Download as CSV\"\n\t\t};\n\t};\n\n\n\treturn plugin;\n};\n\n\nvar formatLiteral = function(yasr, plugin, literalBinding) {\n\tvar stringRepresentation = utils.escapeHtmlEntities(literalBinding.value);\n\tif (literalBinding[\"xml:lang\"]) {\n\t\tstringRepresentation = '\"' + stringRepresentation + '\"<sup>@' + literalBinding[\"xml:lang\"] + '</sup>';\n\t} else if (literalBinding.datatype) {\n\t\tvar xmlSchemaNs = \"http://www.w3.org/2001/XMLSchema#\";\n\t\tvar dataType = literalBinding.datatype;\n\t\tif (dataType.indexOf(xmlSchemaNs) === 0) {\n\t\t\tdataType = \"xsd:\" + dataType.substring(xmlSchemaNs.length);\n\t\t} else {\n\t\t\tdataType = \"<\" + dataType + \">\";\n\t\t}\n\n\t\tstringRepresentation = '\"' + stringRepresentation + '\"<sup>^^' + dataType + '</sup>';\n\t}\n\treturn stringRepresentation;\n};\nvar getCellContent = function(yasr, plugin, bindings, sparqlVar, context) {\n\tvar binding = bindings[sparqlVar];\n\tvar value = null;\n\tif (binding.type == \"uri\") {\n\t\tvar title = null;\n\t\tvar href = binding.value;\n\t\tvar visibleString = href;\n\t\tif (context.usedPrefixes) {\n\t\t\tfor (var prefix in context.usedPrefixes) {\n\t\t\t\tif (visibleString.indexOf(context.usedPrefixes[prefix]) == 0) {\n\t\t\t\t\tvisibleString = prefix + ':' + href.substring(context.usedPrefixes[prefix].length);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tif (plugin.options.mergeLabelsWithUris) {\n\t\t\tvar postFix = (typeof plugin.options.mergeLabelsWithUris == \"string\" ? plugin.options.mergeLabelsWithUris : \"Label\");\n\t\t\tif (bindings[sparqlVar + postFix]) {\n\t\t\t\tvisibleString = formatLiteral(yasr, plugin, bindings[sparqlVar + postFix]);\n\t\t\t\ttitle = href;\n\t\t\t}\n\t\t}\n\t\tvalue = \"<a \" + (title ? \"title='\" + href + \"' \" : \"\") + \"class='uri' target='_blank' href='\" + href + \"'>\" + visibleString + \"</a>\";\n\t} else {\n\t\tvalue = \"<span class='nonUri'>\" + formatLiteral(yasr, plugin, binding) + \"</span>\";\n\t}\n\treturn \"<div>\" + value + \"</div>\";\n};\n\n\n\n\n\n\nvar addPrefLabel = function(td) {\n\tvar addEmptyTitle = function() {\n\t\ttd.attr(\"title\", \"\"); //this avoids trying to fetch the label again on next hover\n\t};\n\t$.get(\"//preflabel.org/api/v1/label/\" + encodeURIComponent(td.text()) + \"?silent=true\")\n\t\t.success(function(data) {\n\t\t\tif (typeof data == \"object\" && data.label) {\n\t\t\t\ttd.attr(\"title\", data.label);\n\t\t\t} else if (typeof data == \"string\" && data.length > 0) {\n\t\t\t\ttd.attr(\"title\", data);\n\t\t\t} else {\n\t\t\t\taddEmptyTitle();\n\t\t\t}\n\n\t\t})\n\t\t.fail(addEmptyTitle);\n};\n\nvar openCellUriInNewWindow = function(cell) {\n\tif (cell.className.indexOf(\"uri\") >= 0) {\n\t\twindow.open(this.innerHTML);\n\t}\n};\n\n/**\n * Defaults for table plugin\n *\n * @type object\n * @attribute YASR.plugins.table.defaults\n */\nroot.defaults = {\n\n\t/**\n\t * Draw the cell content, from a given binding\n\t *\n\t * @property drawCellContent\n\t * @param binding {object}\n\t * @type function\n\t * @return string\n\t * @default YASR.plugins.table.getFormattedValueFromBinding\n\t */\n\tgetCellContent: getCellContent,\n\n\tpersistency: {\n\t\ttableLength: \"tableLength\",\n\t},\n\n\tgetColumns: function(yasr, plugin) {\n\t\tvar includeVariable = function(variableToCheck) {\n\t\t\tif (!plugin.options.mergeLabelsWithUris) return true;\n\t\t\tvar postFix = (typeof plugin.options.mergeLabelsWithUris == \"string\" ? plugin.options.mergeLabelsWithUris : \"Label\");\n\t\t\tif (variableToCheck.indexOf(postFix, variableToCheck.length - postFix.length) !== -1) {\n\t\t\t\t//this one ends with a postfix\n\t\t\t\tif (yasr.results.getVariables().indexOf(variableToCheck.substring(0, variableToCheck.length - postFix.length)) >= 0) {\n\t\t\t\t\t//we have a shorter version of this variable. So, do not include the ..<postfix> variable in the table\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t};\n\n\t\tvar cols = [];\n\t\tcols.push({\n\t\t\t\"title\": \"\"\n\t\t}); //row numbers column\n\t\tyasr.results.getVariables().forEach(function(variable) {\n\t\t\tcols.push({\n\t\t\t\t\"title\": \"<span>\" + variable + \"</span>\",\n\t\t\t\t\"visible\": includeVariable(variable)\n\t\t\t});\n\t\t});\n\t\treturn cols;\n\t},\n\t/**\n\t * Try to fetch the label representation for each URI, using the preflabel.org services. (fetching occurs when hovering over the cell)\n\t *\n\t * @property fetchTitlesFromPreflabel\n\t * @type boolean\n\t * @default false, if YASR is served via https\n\t */\n\t//important to keep supporting serving yasr via file:// protocol\n\tfetchTitlesFromPreflabel: (window.location.protocol === \"https:\" ? false: true),\n\n\tmergeLabelsWithUris: false,\n\t/**\n\t * Set a number of handlers for the table\n\t *\n\t * @property handlers\n\t * @type object\n\t */\n\tcallbacks: {\n\t\t/**\n\t\t * Mouse-enter-cell event\n\t\t *\n\t\t * @property handlers.onCellMouseEnter\n\t\t * @type function\n\t\t * @param td-element\n\t\t * @default null\n\t\t */\n\t\tonCellMouseEnter: null,\n\t\t/**\n\t\t * Mouse-leave-cell event\n\t\t *\n\t\t * @property handlers.onCellMouseLeave\n\t\t * @type function\n\t\t * @param td-element\n\t\t * @default null\n\t\t */\n\t\tonCellMouseLeave: null,\n\t\t/**\n\t\t * Cell clicked event\n\t\t *\n\t\t * @property handlers.onCellClick\n\t\t * @type function\n\t\t * @param td-element\n\t\t * @default null\n\t\t */\n\t\tonCellClick: null\n\t},\n\t/**\n\t * This plugin uses the datatables jquery plugin (See datatables.net). For any datatables specific defaults, change this object.\n\t * See the datatables reference for more information\n\t *\n\t * @property datatable\n\t * @type object\n\t */\n\tdatatable: {\n\t\t\"autoWidth\": false,\n\t\t\"dom\": '<\"dtTopHeader\"ilf>rtip',\n\t\t\"order\": [], //disable initial sorting\n\t\t\"pageLength\": 50, //default page length\n\t\t\"lengthMenu\": [\n\t\t\t[10, 50, 100, 1000, -1],\n\t\t\t[10, 50, 100, 1000, \"All\"]\n\t\t], //possible page lengths\n\t\t\"lengthChange\": true, //allow changing page length\n\t\t\"pagingType\": \"full_numbers\", //how to show the pagination options\n\t\t\"drawCallback\": function(oSettings) {\n\t\t\t//trick to show row numbers\n\t\t\tfor (var i = 0; i < oSettings.aiDisplay.length; i++) {\n\t\t\t\t$('td:eq(0)', oSettings.aoData[oSettings.aiDisplay[i]].nTr).html(i + 1);\n\t\t\t}\n\n\t\t\t//Hide pagination when we have a single page\n\t\t\tvar activePaginateButton = false;\n\t\t\t$(oSettings.nTableWrapper).find(\".paginate_button\").each(function() {\n\t\t\t\tif ($(this).attr(\"class\").indexOf(\"current\") == -1 && $(this).attr(\"class\").indexOf(\"disabled\") == -1) {\n\t\t\t\t\tactivePaginateButton = true;\n\t\t\t\t}\n\t\t\t});\n\t\t\tif (activePaginateButton) {\n\t\t\t\t$(oSettings.nTableWrapper).find(\".dataTables_paginate\").show();\n\t\t\t} else {\n\t\t\t\t$(oSettings.nTableWrapper).find(\".dataTables_paginate\").hide();\n\t\t\t}\n\t\t},\n\t\t\"columnDefs\": [{\n\t\t\t\t\"width\": \"32px\",\n\t\t\t\t\"orderable\": false,\n\t\t\t\t\"targets\": 0\n\t\t\t} //disable row sorting for first col\n\t\t],\n\t},\n};\nroot.version = {\n\t\"YASR-table\": require(\"../package.json\").version,\n\t\"jquery\": $.fn.jquery,\n\t\"jquery-datatables\": $.fn.DataTable.version\n};\n","'use strict';\nvar $ = require('jquery'),\n\tGoogleTypeException = require('./exceptions.js').GoogleTypeException;\n\nmodule.exports = {\n\tescapeHtmlEntities: function(unescaped) {\n\t\t//taken from http://stackoverflow.com/questions/5499078/fastest-method-to-escape-html-tags-as-html-entities\n\t\treturn unescaped.replace(/&/g, '&').replace(/</g, '<').replace(/>/g, '>');\n\t},\n\turiToPrefixed: function(prefixes, uri) {\n\t\tif (prefixes) {\n\t\t\tfor (var prefix in prefixes) {\n\t\t\t\tif (uri.indexOf(prefixes[prefix]) == 0) {\n\t\t\t\t\turi = prefix + ':' + uri.substring(prefixes[prefix].length);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn uri;\n\t},\n\tgetGoogleTypeForBinding: function(binding) {\n\t\tif (binding == null) return null;\n\t\tif (binding.type != null && (binding.type === 'typed-literal' || binding.type === 'literal')) {\n\t\t\tswitch (binding.datatype) {\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#double':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#float':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#decimal':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#int':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#integer':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#long':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gYearMonth':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gYear':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gMonthDay':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gDay':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gMonth':\n\t\t\t\t\treturn \"number\";\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#date':\n\t\t\t\t\treturn \"date\";\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#dateTime':\n\t\t\t\t\treturn \"datetime\";\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#time':\n\t\t\t\t\treturn \"timeofday\";\n\t\t\t\tdefault:\n\t\t\t\t\treturn \"string\";\n\t\t\t}\n\t\t} else {\n\t\t\treturn \"string\";\n\t\t}\n\t},\n\tgetGoogleTypeForBindings: function(bindings, varName) {\n\t\tvar types = {};\n\t\tvar typeCount = 0;\n\t\tbindings.forEach(function(binding) {\n\t\t\tvar type = module.exports.getGoogleTypeForBinding(binding[varName]);\n\t\t\tif (type != null) {\n\t\t\t\tif (!(type in types)) {\n\t\t\t\t\ttypes[type] = 0;\n\t\t\t\t\ttypeCount++;\n\t\t\t\t}\n\t\t\t\ttypes[type]++;\n\t\t\t}\n\t\t});\n\t\tif (typeCount == 0) {\n\t\t\treturn 'string';\n\t\t} else if (typeCount == 1) {\n\t\t\tfor (var type in types) {\n\t\t\t\treturn type; //just return this one\n\t\t\t}\n\t\t} else {\n\t\t\t//we have conflicting types. Throw error\n\t\t\tthrow new GoogleTypeException(types, varName);\n\t\t}\n\t},\n\n\tcastGoogleType: function(binding, prefixes, googleType) {\n\t\tif (binding == null) {\n\t\t\treturn null;\n\t\t}\n\n\t\tif (googleType != 'string' && binding.type != null && (binding.type === 'typed-literal' || binding.type === 'literal')) {\n\t\t\tswitch (binding.datatype) {\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#float':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#decimal':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#int':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#integer':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#long':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gYearMonth':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gYear':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gMonthDay':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gDay':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#gMonth':\n\t\t\t\t\treturn Number(binding.value);\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#double':\n\t\t\t\t\treturn Number(parseFloat(binding.value));\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#date':\n\t\t\t\t\t//grrr, the date function does not parse -any- date (including most xsd dates!)\n\t\t\t\t\t//datetime and time seem to be fine though.\n\t\t\t\t\t//so, first try our custom parser. if that does not work, try the regular date parser anyway\n\t\t\t\t\tvar date = parseXmlSchemaDate(binding.value);\n\t\t\t\t\tif (date) return date;\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#dateTime':\n\t\t\t\tcase 'http://www.w3.org/2001/XMLSchema#time':\n\t\t\t\t\treturn new Date(binding.value);\n\t\t\t\tdefault:\n\t\t\t\t\treturn binding.value;\n\t\t\t}\n\t\t} else {\n\t\t\tif (binding.type = 'uri') {\n\t\t\t\treturn module.exports.uriToPrefixed(prefixes, binding.value);\n\t\t\t} else {\n\t\t\t\treturn binding.value;\n\t\t\t}\n\t\t}\n\t},\n\tfireClick: function($els) {\n\t\tif (!$els)\n\t\t\treturn;\n\t\t$els.each(function(i, el) {\n\t\t\tvar $el = $(el);\n\t\t\tif (document.dispatchEvent) { // W3C\n\t\t\t\tvar oEvent = document.createEvent(\"MouseEvents\");\n\t\t\t\toEvent.initMouseEvent(\"click\", true, true, window, 1, 1, 1, 1, 1,\n\t\t\t\t\tfalse, false, false, false, 0, $el[0]);\n\t\t\t\t$el[0].dispatchEvent(oEvent);\n\t\t\t} else if (document.fireEvent) { // IE\n\t\t\t\t$el[0].click();\n\t\t\t}\n\t\t});\n\t}\n};\n//There are no PROPER xml schema to js date parsers\n//A few libraries exist: moment, jsdate, Xdate, but none of them parse valid xml schema dates (e.g. 1999-11-05+02:00).\n//And: I'm not going to write one myself\n//There are other hacky solutions (regular expressions based on trial/error) such as http://stackoverflow.com/questions/2731579/convert-an-xml-schema-date-string-to-a-javascript-date\n//But if we're doing hacky stuff, I at least want to do it MYSELF!\nvar parseXmlSchemaDate = function(dateString) {\n\t//change +02:00 to Z+02:00 (something which is parseable by js date)\n\tvar date = new Date(dateString.replace(/(\\d)([\\+-]\\d{2}:\\d{2})/, '$1Z$2'));\n\tif (isNaN(date)) return null;\n\treturn date;\n};\n"],"sourceRoot":"/source/"}