diff --git a/.travis.yml b/.travis.yml index 336ed7e..91f85e9 100644 --- a/.travis.yml +++ b/.travis.yml @@ -7,6 +7,10 @@ env: - DOKUWIKI=master - DOKUWIKI=stable - DOKUWIKI=old-stable -before_install: wget https://raw.github.com/splitbrain/dokuwiki-travis/master/travis.sh +before_install: + - wget https://raw.github.com/splitbrain/dokuwiki-travis/master/travis.sh + - npm install install: sh travis.sh -script: cd _test && phpunit --stderr --group plugin_edittable +script: + - cd _test && phpunit --stderr --group plugin_edittable + - cd ../lib/plugins/edittable && grunt diff --git a/Gruntfile.js b/Gruntfile.js new file mode 100644 index 0000000..5f5fc29 --- /dev/null +++ b/Gruntfile.js @@ -0,0 +1,17 @@ +module.exports = function(grunt) { + grunt.initConfig({ + pkg: grunt.file.readJSON('package.json'), // the package file to use + + qunit: { + all: ['_jstest/*.html'] + }, + watch: { + files: ['_jstest/*.js', '_jstest/*.html', 'script/*.js'], + tasks: ['qunit'] + } +}); +grunt.loadNpmTasks('grunt-contrib-qunit'); +grunt.loadNpmTasks('grunt-contrib-watch'); +grunt.registerTask('default', ['qunit']); +}; + diff --git a/README.handsontable b/README.handsontable index 79816d4..4c2fa2f 100644 --- a/README.handsontable +++ b/README.handsontable @@ -1,5 +1,5 @@ The handsontable version used in this plugin is slightly modified and -maintained at https://github.com/cosmocode/jquery-handsontable/tree/dokuwiki +maintained at https://github.com/cosmocode/handsontable/tree/dokuwiki No modifications should be done on the handsontable.* files here! Changes need to be done in the source files in the above repository, be compiled there diff --git a/_jstest/cellArray.tests.js b/_jstest/cellArray.tests.js new file mode 100644 index 0000000..c7c3d0f --- /dev/null +++ b/_jstest/cellArray.tests.js @@ -0,0 +1,64 @@ +QUnit.module( "Tests for cellArray" ); +QUnit.test("1 by 1", function(assert) { + var selection = { + start: { + row: 2, + col: 2 + }, + end: { + row: 2, + col: 2 + } + }; + var actual_result = cellArray(selection); + var expected_result = [{col:2, row:2}]; + assert.deepEqual(actual_result, expected_result); +}); + +QUnit.test("1 by 2", function(assert) { + var selection = { + start: { + row: 2, + col: 2 + }, + end: { + row: 2, + col: 3 + } + }; + var actual_result = cellArray(selection); + var expected_result = [{col:2, row:2}, {col:3, row:2}]; + assert.deepEqual(actual_result, expected_result); +}); + +QUnit.test("2 by 1", function(assert) { + var selection = { + start: { + row: 2, + col: 2 + }, + end: { + row: 3, + col: 2 + } + }; + var actual_result = cellArray(selection); + var expected_result = [{col:2, row:2}, {col:2, row:3}]; + assert.deepEqual(actual_result, expected_result); +}); + +QUnit.test("2 by 2", function(assert) { + var selection = { + start: { + row: 2, + col: 2 + }, + end: { + row: 3, + col: 3 + } + }; + var actual_result = cellArray(selection); + var expected_result = [{col:2, row:2}, {col:3, row:2},{col:2, row:3}, {col:3, row:3}]; + assert.deepEqual(actual_result, expected_result); +}); diff --git a/_jstest/getMerges.tests.js b/_jstest/getMerges.tests.js new file mode 100644 index 0000000..29253e8 --- /dev/null +++ b/_jstest/getMerges.tests.js @@ -0,0 +1,110 @@ +QUnit.module( "Tests for getMerges" ); +QUnit.test("merge 2x2", function(assert) { + var meta = [ + [ + { + "tag": "th", + "colspan": 1, + "rowspan": 1, + "align": "left" + }, + { + "tag": "th", + "colspan": 1, + "rowspan": 1, + "align": "left" + }, + { + "tag": "th", + "colspan": 1, + "rowspan": 1, + "align": "left" + }, + { + "tag": "th", + "colspan": 1, + "rowspan": 1, + "align": "left" + } + ], + [ + { + "tag": "td", + "colspan": 1, + "rowspan": 1, + "align": "left" + }, + { + "tag": "td", + "colspan": 1, + "rowspan": 1, + "align": "left" + }, + { + "tag": "td", + "colspan": 1, + "rowspan": 1, + "align": "left" + }, + { + "tag": "td", + "colspan": 1, + "rowspan": 1, + "align": "left" + } + ], + [ + { + "tag": "td", + "colspan": 2, + "rowspan": 2, + "align": "left" + }, + { + "hide": true, + "rowspan": 1, + "colspan": 1 + }, + { + "tag": "th", + "colspan": 1, + "rowspan": 1, + "align": "left" + }, + { + "tag": "td", + "colspan": 1, + "rowspan": 1, + "align": "left" + } + ], + [ + { + "hide": true, + "rowspan": 1, + "colspan": 1 + }, + { + "hide": true, + "rowspan": 1, + "colspan": 1 + }, + { + "tag": "td", + "colspan": 1, + "rowspan": 1, + "align": "left" + }, + { + "tag": "td", + "colspan": 1, + "rowspan": 1, + "align": "left" + } + ] + ]; + + var actual_merges = getMerges(meta); + var expected_merges = [{row:2, col:0, rowspan: 2, colspan: 2}]; + assert.deepEqual(actual_merges, expected_merges); +}); diff --git a/_jstest/qunit.test.html b/_jstest/qunit.test.html new file mode 100644 index 0000000..d7c5783 --- /dev/null +++ b/_jstest/qunit.test.html @@ -0,0 +1,22 @@ + + + + + edittable qunit tests + + + + + +
+
+ + + + + + + + + + diff --git a/_jstest/rowColMove.tests.js b/_jstest/rowColMove.tests.js new file mode 100644 index 0000000..0f2a1c4 --- /dev/null +++ b/_jstest/rowColMove.tests.js @@ -0,0 +1,132 @@ +QUnit.module( "Tests for moveRow and moveCol" ); +QUnit.test("moveRow 0 to 1", function(assert) { + var meta = [['a','b'],['c','d'],['e','f']]; + var data = [['a','b'],['c','d'],['e','f']]; + moveRow(0,1,data); + moveRow(0,1,meta); + var expected_meta = [['c','d'],['a','b'],['e','f']]; + var expected_data = [['c','d'],['a','b'],['e','f']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); + +QUnit.test("moveRow 0 to 2", function(assert) { + var meta = [['a','b'],['c','d'],['e','f']]; + var data = [['a','b'],['c','d'],['e','f']]; + moveRow(0,2,data); + moveRow(0,2,meta); + var expected_meta = [['c','d'],['e','f'],['a','b']]; + var expected_data = [['c','d'],['e','f'],['a','b']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); + +QUnit.test("moveRow 1 to 2", function(assert) { + var meta = [['a','b'],['c','d'],['e','f']]; + var data = [['a','b'],['c','d'],['e','f']]; + moveRow(1,2,data); + moveRow(1,2,meta); + var expected_meta = [['a','b'],['e','f'],['c','d']]; + var expected_data = [['a','b'],['e','f'],['c','d']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); + +QUnit.test("moveRow 2 to 1", function(assert) { + var meta = [['a','b'],['c','d'],['e','f']]; + var data = [['a','b'],['c','d'],['e','f']]; + moveRow(2,1,data); + moveRow(2,1,meta); + var expected_meta = [['a','b'],['e','f'],['c','d']]; + var expected_data = [['a','b'],['e','f'],['c','d']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); + +QUnit.test("moveRow 2 to 0", function(assert) { + var meta = [['a','b'],['c','d'],['e','f']]; + var data = [['a','b'],['c','d'],['e','f']]; + moveRow(2,0,data); + moveRow(2,0,meta); + var expected_meta = [['e','f'],['a','b'],['c','d']]; + var expected_data = [['e','f'],['a','b'],['c','d']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); + +QUnit.test("moveRow 1 to 0", function(assert) { + var meta = [['a','b'],['c','d'],['e','f']]; + var data = [['a','b'],['c','d'],['e','f']]; + moveRow(1,0,data); + moveRow(1,0,meta); + var expected_meta = [['c','d'],['a','b'],['e','f']]; + var expected_data = [['c','d'],['a','b'],['e','f']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); + +QUnit.test("moveCol 0 to 1", function(assert) { + var meta = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + var data = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + moveCol(0,1,data); + moveCol(0,1,meta); + var expected_meta = [['b','a','c'],['e','d','f'],['h','g', 'i']]; + var expected_data = [['b','a','c'],['e','d','f'],['h','g', 'i']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); + +QUnit.test("moveCol 0 to 2", function(assert) { + var meta = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + var data = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + moveCol(0,2,data); + moveCol(0,2,meta); + var expected_meta = [['b','c','a'],['e','f','d'],['h','i', 'g']]; + var expected_data = [['b','c','a'],['e','f','d'],['h','i', 'g']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); + +QUnit.test("moveCol 1 to 2", function(assert) { + var meta = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + var data = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + moveCol(1,2,data); + moveCol(1,2,meta); + var expected_meta = [['a','c','b'],['d','f','e'],['g','i', 'h']]; + var expected_data = [['a','c','b'],['d','f','e'],['g','i', 'h']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); + +QUnit.test("moveCol 1 to 0", function(assert) { + var meta = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + var data = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + moveCol(1,0,data); + moveCol(1,0,meta); + var expected_meta = [['b','a','c'],['e','d','f'],['h','g', 'i']]; + var expected_data = [['b','a','c'],['e','d','f'],['h','g', 'i']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); + +QUnit.test("moveCol 2 to 0", function(assert) { + var meta = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + var data = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + moveCol(2,0,data); + moveCol(2,0,meta); + var expected_meta = [['c','a','b'],['f','d','e'],['i','g', 'h']]; + var expected_data = [['c','a','b'],['f','d','e'],['i','g', 'h']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); + +QUnit.test("moveCol 2 to 1", function(assert) { + var meta = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + var data = [['a','b','c'],['d','e','f'],['g','h', 'i']]; + moveCol(2,1,data); + moveCol(2,1,meta); + var expected_meta = [['a','c','b'],['d','f','e'],['g','i', 'h']]; + var expected_data = [['a','c','b'],['d','f','e'],['g','i', 'h']]; + assert.deepEqual(meta, expected_meta); + assert.deepEqual(data, expected_data); +}); diff --git a/deleted.files b/deleted.files new file mode 100644 index 0000000..efdce89 --- /dev/null +++ b/deleted.files @@ -0,0 +1,10 @@ +images/merge_down.png +images/merge_right.png +images/split_down.png +images/split_right.png +script/jquery.handsontable.columnmove.js +script/jquery.handsontable.rowmove.js +script/jquery.handsontable.full.js +less/jquery.handsontable.columnmove.less +less/jquery.handsontable.rowmove.less +less/jquery.handsontable.full.less diff --git a/images/merge_cells.png b/images/merge_cells.png new file mode 100644 index 0000000..5ff8a85 Binary files /dev/null and b/images/merge_cells.png differ diff --git a/images/merge_down.png b/images/merge_down.png deleted file mode 100644 index 5eaab27..0000000 Binary files a/images/merge_down.png and /dev/null differ diff --git a/images/merge_right.png b/images/merge_right.png deleted file mode 100644 index 9219710..0000000 Binary files a/images/merge_right.png and /dev/null differ diff --git a/images/split_cells.png b/images/split_cells.png new file mode 100644 index 0000000..d30e62e Binary files /dev/null and b/images/split_cells.png differ diff --git a/images/split_down.png b/images/split_down.png deleted file mode 100644 index 3b73235..0000000 Binary files a/images/split_down.png and /dev/null differ diff --git a/images/split_right.png b/images/split_right.png deleted file mode 100644 index 93cd14d..0000000 Binary files a/images/split_right.png and /dev/null differ diff --git a/lang/de/lang.php b/lang/de/lang.php index 755e1ff..5c34466 100644 --- a/lang/de/lang.php +++ b/lang/de/lang.php @@ -18,8 +18,5 @@ $lang['js']['remove_col'] = 'Spalte entfernen'; $lang['js']['col_right'] = 'Spalte rechts hinzufügen'; -$lang['js']['colspan_add'] = 'Zelle erweitern →'; -$lang['js']['colspan_del'] = 'Zelle verkleinern ←'; - -$lang['js']['rowspan_add'] = 'Zelle erweitern ↓'; -$lang['js']['rowspan_del'] = 'Zelle verkleinern ↑'; +$lang['js']['merge_cells'] = 'Zellen verbinden'; +$lang['js']['unmerge_cells'] = 'Zellen trennen'; diff --git a/lang/en/lang.php b/lang/en/lang.php index 82fbb39..e832e67 100644 --- a/lang/en/lang.php +++ b/lang/en/lang.php @@ -18,8 +18,5 @@ $lang['js']['remove_col'] = 'Remove column'; $lang['js']['col_right'] = 'Add column on the right'; -$lang['js']['colspan_add'] = 'Increase colspan'; -$lang['js']['colspan_del'] = 'Decrease colspan'; - -$lang['js']['rowspan_add'] = 'Increase rowspan'; -$lang['js']['rowspan_del'] = 'Decrease rowspan'; \ No newline at end of file +$lang['js']['merge_cells'] = 'Merge cells'; +$lang['js']['unmerge_cells'] = 'Split cells'; diff --git a/less/contextmenu.less b/less/contextmenu.less index 4361433..994cbdb 100644 --- a/less/contextmenu.less +++ b/less/contextmenu.less @@ -1,6 +1,6 @@ -.htContextMenu tbody { +.htContextMenu table tbody { - div { + tr td div { padding-left: 20px; background-position: center left; background-repeat: no-repeat; @@ -46,6 +46,24 @@ background-image: url('../plugins/edittable/images/col_right.png'); } + &.mergeCells { + padding-left: 0px; + + & div { + padding-left: 20px; + background-position: center left; + background-repeat: no-repeat; + + &.merge { + background-image: url('../plugins/edittable/images/merge_cells.png'); + } + + &.unmerge { + background-image: url('../plugins/edittable/images/split_cells.png'); + } + } + } + &.colspan_add { background-image: url('../plugins/edittable/images/merge_right.png'); } @@ -67,4 +85,4 @@ padding-left: 0; } -} \ No newline at end of file +} diff --git a/less/editbutton.less b/less/editbutton.less index 9738bcd..815be15 100644 --- a/less/editbutton.less +++ b/less/editbutton.less @@ -5,6 +5,7 @@ display: none; // we make it visible by JavaScript margin-bottom: 1em; + form div.no button, form div.no input.button { margin-left: 0.6em; padding: 0 0.3em; diff --git a/less/editor.less b/less/editor.less index 085bf0c..4a4ff5e 100644 --- a/less/editor.less +++ b/less/editor.less @@ -25,3 +25,12 @@ div.picker { z-index: 500; } + +div.wtHolder, div.wtHider { + height: auto !important; + padding-bottom: 5px; +} + +div.ht_clone_left.handsontable, div.ht_clone_top.handsontable, div.ht_clone_corner.handsontable { + display: none; +} diff --git a/less/handsontable.full.less b/less/handsontable.full.less new file mode 100644 index 0000000..5662048 --- /dev/null +++ b/less/handsontable.full.less @@ -0,0 +1,1454 @@ +/*! + * Handsontable 0.16.1 + * Handsontable is a JavaScript library for editable tables with basic copy-paste compatibility with Excel and Google Docs + * + * Copyright 2015 Handsoncode sp. z o.o. + * Licensed under the MIT license. + * http://handsontable.com/ + * + * Date: Fri Jul 24 2015 09:09:44 GMT+0200 (CEST) + */ + +.handsontable { + position: relative; +} + +.handsontable .hide{ + display: none; +} +.handsontable .relative { + position: relative; +} + +.handsontable.htAutoSize { + visibility: hidden; + left: -99000px; + position: absolute; + top: -99000px; +} + +.handsontable .wtHider { + width: 0; +} + +.handsontable .wtSpreader { + position: relative; + width: 0; /*must be 0, otherwise blank space appears in scroll demo after scrolling max to the right */ + height: auto; +} + +.handsontable table, +.handsontable tbody, +.handsontable thead, +.handsontable td, +.handsontable th, +.handsontable input, +.handsontable textarea, +.handsontable div { + box-sizing: content-box; + -webkit-box-sizing: content-box; + -moz-box-sizing: content-box; +} + +.handsontable input, +.handsontable textarea { + min-height: initial; +} + +.handsontable table.htCore { + border-collapse: separate; + /*it must be separate, otherwise there are offset miscalculations in WebKit: http://stackoverflow.com/questions/2655987/border-collapse-differences-in-ff-and-webkit*/ + /*this actually only changes appearance of user selection - does not make text unselectable + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -o-user-select: none; + -ms-user-select: none; + /*user-select: none; /*no browser supports unprefixed version*/ + border-spacing: 0; + margin: 0; + border-width: 0; + table-layout: fixed; + width: 0; + outline-width: 0; + /* reset bootstrap table style. for more info see: https://github.com/handsontable/handsontable/issues/224 */ + max-width: none; + max-height: none; +} + +.handsontable col { + width: 50px; +} + +.handsontable col.rowHeader { + width: 50px; +} + +.handsontable th, +.handsontable td { + border-right: 1px solid #CCC; + border-bottom: 1px solid #CCC; + height: 22px; + empty-cells: show; + line-height: 21px; + padding: 0 4px 0 4px; + /* top, bottom padding different than 0 is handled poorly by FF with HTML5 doctype */ + background-color: #FFF; + vertical-align: top; + overflow: hidden; + outline-width: 0; + white-space: pre-line; + /* preserve new line character in cell */ +} + +.handsontable td.htInvalid { + background-color: #ff4c42 !important; /*gives priority over td.area selection background*/ +} + +.handsontable td.htNoWrap { + white-space: nowrap; +} + +.handsontable th:last-child { + /*Foundation framework fix*/ + border-right: 1px solid #CCC; + border-bottom: 1px solid #CCC; +} + +.handsontable tr:first-child th.htNoFrame, +.handsontable th:first-child.htNoFrame, +.handsontable th.htNoFrame { + border-left-width: 0; + background-color: white; + border-color: #FFF; +} + +.handsontable th:first-child, +.handsontable td:first-of-type, +.handsontable .htNoFrame + th, +.handsontable .htNoFrame + td { + border-left: 1px solid #CCC; +} + +.handsontable.htRowHeaders thead tr th:nth-child(2) { + border-left: 1px solid #CCC; +} + +.handsontable tr:first-child th, +.handsontable tr:first-child td { + border-top: 1px solid #CCC; +} + +.ht_master:not(.innerBorderLeft) ~ .handsontable tbody tr th, +.ht_master:not(.innerBorderLeft) ~ .handsontable:not(.ht_clone_top) thead tr th:first-child +{ + border-right-width: 0; +} + +.ht_master:not(.innerBorderTop) thead tr:last-child th, +.ht_master:not(.innerBorderTop) ~ .handsontable thead tr:last-child th, +.ht_master:not(.innerBorderTop) thead tr.lastChild th, +.ht_master:not(.innerBorderTop) ~ .handsontable thead tr.lastChild th { + border-bottom-width: 0; +} + +.handsontable th { + background-color: #EEE; + color: #222; + text-align: center; + font-weight: normal; + white-space: nowrap; +} + +.handsontable thead th { + padding: 0; +} + +.handsontable th.active { + background-color: #CCC; +} + +.handsontable thead th .relative { + padding: 2px 4px; +} + +/* plugins */ + +.handsontable .manualColumnMover { + position: fixed; + left: 0; + top: 0; + background-color: transparent; + width: 5px; + height: 25px; + z-index: 999; + cursor: move; +} + +.handsontable .manualRowMover { + position: fixed; + left: -4px; + top: 0; + background-color: transparent; + height: 5px; + width: 50px; + z-index: 999; + cursor: move; +} + +.handsontable .manualColumnMoverGuide, +.handsontable .manualRowMoverGuide { + position: fixed; + left: 0; + top: 0; + background-color: #CCC; + width: 25px; + height: 25px; + opacity: 0.7; + display: none; +} + +.handsontable .manualColumnMoverGuide.active, +.handsontable .manualRowMoverGuide.active { + display: block; +} + +.handsontable .manualColumnMover:hover, +.handsontable .manualColumnMover.active, +.handsontable .manualRowMover:hover, +.handsontable .manualRowMover.active{ + background-color: #88F; +} + +/* row + column resizer*/ + +.handsontable .manualColumnResizer { + position: fixed; + top: 0; + cursor: col-resize; + z-index: 110; + width: 5px; + height: 25px; +} + +.handsontable .manualRowResizer { + position: fixed; + left: 0; + cursor: row-resize; + z-index: 110; + height: 5px; + width: 50px; +} + +.handsontable .manualColumnResizer:hover, +.handsontable .manualColumnResizer.active, +.handsontable .manualRowResizer:hover, +.handsontable .manualRowResizer.active { + background-color: #AAB; +} + +.handsontable .manualColumnResizerGuide { + position: fixed; + right: 0; + top: 0; + background-color: #AAB; + display: none; + width: 0; + border-right: 1px dashed #777; + margin-left: 5px; +} + +.handsontable .manualRowResizerGuide { + position: fixed; + left: 0; + bottom: 0; + background-color: #AAB; + display: none; + height: 0; + border-bottom: 1px dashed #777; + margin-top: 5px; +} + +.handsontable .manualColumnResizerGuide.active, +.handsontable .manualRowResizerGuide.active { + display: block; +} + +.handsontable .columnSorting { + position: relative; +} + +.handsontable .columnSorting:hover { + text-decoration: underline; + cursor: pointer; +} + +.handsontable .columnSorting.ascending::after { + content: '\25B2'; + color: #5f5f5f; + position: absolute; + right: -15px; +} + +.handsontable .columnSorting.descending::after { + content: '\25BC'; + color: #5f5f5f; + position: absolute; + right: -15px; +} + +/* border line */ + +.handsontable .wtBorder { + position: absolute; + font-size: 0; +} +.handsontable .wtBorder.hidden{ + display:none !important; +} + +.handsontable td.area { + background: -moz-linear-gradient(top, rgba(181,209,255,0.34) 0%, rgba(181,209,255,0.34) 100%); /* FF3.6+ */ + background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(181,209,255,0.34)), color-stop(100%,rgba(181,209,255,0.34))); /* Chrome,Safari4+ */ + background: -webkit-linear-gradient(top, rgba(181,209,255,0.34) 0%,rgba(181,209,255,0.34) 100%); /* Chrome10+,Safari5.1+ */ + background: -o-linear-gradient(top, rgba(181,209,255,0.34) 0%,rgba(181,209,255,0.34) 100%); /* Opera 11.10+ */ + background: -ms-linear-gradient(top, rgba(181,209,255,0.34) 0%,rgba(181,209,255,0.34) 100%); /* IE10+ */ + background: linear-gradient(to bottom, rgba(181,209,255,0.34) 0%,rgba(181,209,255,0.34) 100%); /* W3C */ + filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#57b5d1ff', endColorstr='#57b5d1ff',GradientType=0 ); /* IE6-9 */ + background-color: #fff; +} + +/* fill handle */ + +.handsontable .wtBorder.corner { + font-size: 0; + cursor: crosshair; +} + +.handsontable .htBorder.htFillBorder { + background: red; + width: 1px; + height: 1px; +} + +.handsontableInput { + border:none; + outline-width: 0; + margin: 0 ; + padding: 1px 5px 0 5px; + font-family: inherit; + line-height: 21px; + font-size: inherit; + box-shadow: 0 0 0 2px #5292F7 inset; + resize: none; + /*below are needed to overwrite stuff added by jQuery UI Bootstrap theme*/ + display: inline-block; + color: #000; + border-radius: 0; + background-color: #FFF; + /*overwrite styles potentionally made by a framework*/ +} + +.handsontableInputHolder { + position: absolute; + top: 0; + left: 0; + z-index: 100; +} + +.htSelectEditor { + -webkit-appearance: menulist-button !important; + position: absolute; + width: auto; +} + +/* +TextRenderer readOnly cell +*/ + +.handsontable .htDimmed { + color: #777; +} + +.handsontable .htSubmenu { + position: relative; +} + +.handsontable .htSubmenu :after{ + content: '▶'; + color: #777; + position: absolute; + right: 5px; +} + + +/* +TextRenderer horizontal alignment +*/ +.handsontable .htLeft{ + text-align: left; +} +.handsontable .htCenter{ + text-align: center; +} +.handsontable .htRight{ + text-align: right; +} +.handsontable .htJustify{ + text-align: justify; +} +/* +TextRenderer vertical alignment +*/ +.handsontable .htTop{ + vertical-align: top; +} +.handsontable .htMiddle{ + vertical-align: middle; +} +.handsontable .htBottom{ + vertical-align: bottom; +} + +/* +TextRenderer placeholder value +*/ + +.handsontable .htPlaceholder { + color: #999; +} + +/* +AutocompleteRenderer down arrow +*/ + +.handsontable .htAutocompleteArrow { + float: right; + font-size: 10px; + color: #EEE; + cursor: default; + width: 16px; + text-align: center; +} + +.handsontable td .htAutocompleteArrow:hover { + color: #777; +} + +.handsontable td.area .htAutocompleteArrow { + color: #d3d3d3; +} + +/* +CheckboxRenderer +*/ + +.handsontable .htCheckboxRendererInput.noValue { + opacity: 0.5; +} + +/* +NumericRenderer +*/ + +.handsontable .htNumeric { + text-align: right; +} + +/* +Comment For Cell +*/ +.htCommentCell{ + position: relative; +} +.htCommentCell:after{ + content: ''; + position: absolute; + top: 0; + right: 0; + border-left: 6px solid transparent; + border-top: 6px solid red; +} + +@-webkit-keyframes opacity-hide { + from { + opacity: 1; + } + to { + opacity: 0; + /*display: none;*/ + } +} +@keyframes opacity-hide { + from { + /*display: block;*/ + opacity: 1; + } + to { + opacity: 0; + /*display: none;*/ + } +} + +@-webkit-keyframes opacity-show { + from { + opacity: 0; + /*display: none;*/ + } + to { + opacity: 1; + /*display: block;*/ + } +} +@keyframes opacity-show { + from { + opacity: 0; + /*display: none;*/ + } + to { + opacity: 1; + /*display: block;*/ + } +} + +/** + * Handsontable in Handsontable + */ + +.handsontable .handsontable.ht_clone_top .wtHider { + padding: 0 0 5px 0; +} + +/* removing shadows, TODO: remove the commented code and this comment */ +/*.handsontable .handsontable:not(.ht_master) table {*/ + /*-webkit-box-shadow: 1px 2px 5px rgba(0, 0, 0, 0.4);*/ + /*box-shadow: 1px 2px 5px rgba(0, 0, 0, 0.4);*/ +/*}*/ + +/** +* Autocomplete Editor +*/ +.handsontable .autocompleteEditor.handsontable { + padding-right: 17px; +} +.handsontable .autocompleteEditor.handsontable.htMacScroll { + padding-right: 15px; +} + + +/** + * Handsontable listbox theme + */ + +.handsontable.listbox { + margin: 0; +} + +.handsontable.listbox .ht_master table { + border: 1px solid #ccc; + border-collapse: separate; + background: white; +} + +.handsontable.listbox th, +.handsontable.listbox tr:first-child th, +.handsontable.listbox tr:last-child th, +.handsontable.listbox tr:first-child td, +.handsontable.listbox td { + border-width: 0; +} + +.handsontable.listbox th, +.handsontable.listbox td { + white-space: nowrap; + text-overflow: ellipsis; +} + +.handsontable.listbox td.htDimmed { + cursor: default; + color: inherit; + font-style: inherit; +} + +.handsontable.listbox .wtBorder { + visibility: hidden; +} + +.handsontable.listbox tr td.current, +.handsontable.listbox tr:hover td { + background: #eee; +} + +.htContextMenu { + display: none; + position: absolute; + z-index: 1060; /*needs to be higher than 1050 - z-index for Twitter Bootstrap modal (#1569)*/ + overflow: hidden; +} + +.htContextMenu .ht_clone_top, +.htContextMenu .ht_clone_left, +.htContextMenu .ht_clone_corner, +.htContextMenu .ht_clone_debug { + display: none; +} + +.ht_clone_top { + z-index: 101; +} + +.ht_clone_left { + z-index: 102; +} + +.ht_clone_corner { + z-index: 103; +} + +.ht_clone_debug { + z-index: 103; +} + +.htContextMenu table.htCore { + border: 1px solid #bbb; +} + +.htContextMenu .wtBorder { + visibility: hidden; +} + +.htContextMenu table tbody tr td { + background: white; + border-width: 0; + padding: 4px 6px 0px 6px; + cursor: pointer; + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; +} + +.htContextMenu table tbody tr td:first-child { + border: 0; +} + +.htContextMenu table tbody tr td.htDimmed{ + font-style: normal; + color: #323232; +} + +.htContextMenu table tbody tr td.current, +.htContextMenu table tbody tr td.zeroclipboard-is-hover { + background: rgb(233, 233, 233); +} + +.htContextMenu table tbody tr td.htSeparator { + border-top: 1px solid #bbb; + height: 0; + padding: 0; +} + +.htContextMenu table tbody tr td.htDisabled { + color: #999; +} + +.htContextMenu table tbody tr td.htDisabled:hover { + background: white; + color: #999; + cursor: default; +} +.htContextMenu table tbody tr td div{ + padding-left: 10px; +} +.htContextMenu table tbody tr td div span.selected{ + margin-top: -2px; + position: absolute; + left: 4px; +} + +.htContextMenu .ht_master .wtHolder { + overflow: hidden; +} + +.handsontable td.htSearchResult { + background: #fcedd9; + color: #583707; +} + +/* +Cell borders +*/ +.htBordered{ + /*box-sizing: border-box !important;*/ + border-width: 1px; +} +.htBordered.htTopBorderSolid{ + border-top-style: solid; + border-top-color: #000; +} +.htBordered.htRightBorderSolid{ + border-right-style: solid; + border-right-color: #000; +} +.htBordered.htBottomBorderSolid{ + border-bottom-style: solid; + border-bottom-color: #000; +} +.htBordered.htLeftBorderSolid{ + border-left-style: solid; + border-left-color: #000; +} + +.htCommentTextArea{ + -moz-box-shadow: 1px 1px 2px #bbb; + -webkit-box-shadow: 1px 1px 2px #bbb; + background-color: #FFFACD; + border: 1px solid #999; + box-shadow: 1px 1px 2px #bbb; + font-family: 'Arial'; +} + + +/* Grouping indicators */ +.handsontable colgroup col.rowHeader.htGroupCol { + width: 25px !important; +} +.handsontable colgroup col.rowHeader.htGroupColClosest { + width: 30px !important; +} + +.handsontable .htGroupIndicatorContainer { + background: #fff; + border: 0px; + padding-bottom: 0px; + vertical-align: bottom; + position: relative; +} + +.handsontable thead .htGroupIndicatorContainer { + vertical-align: top; + border-bottom: 0px; +} + +.handsontable tbody tr th:nth-last-child(2) { + border-right: 1px solid #CCC; +} + +.handsontable thead tr:nth-last-child(2) th { + border-bottom: 1px solid #CCC; + padding-bottom: 5px; +} + + +.ht_clone_corner thead tr th:nth-last-child(2) { + border-right: 1px solid #CCC; +} + +.htVerticalGroup { + height: 100%; +} + +.htHorizontalGroup { + width: 100%; + height: 100%; +} + +.htVerticalGroup:not(.htCollapseButton):after { + content: ""; + height: 100%; + width: 1px; + display: block; + background: #ccc; + margin-left: 5px; +} + +.htHorizontalGroup:not(.htCollapseButton):after { + content: ""; + width: 100%; + height: 1px; + display: block; + background: #ccc; + margin-top: 20%; +} + +.htCollapseButton { + width: 10px; + height: 10px; + line-height: 10px; + text-align: center; + border-radius: 5px; + border: 1px solid #f3f3f3; + -webkit-box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.4); + box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.4); + cursor: pointer; + margin-bottom: 3px; + position: relative; +} + +.htCollapseButton:after { + content: ""; + height: 300%; + width: 1px; + display: block; + background: #ccc; + margin-left: 4px; + position: absolute; + /*top: -300%;*/ + bottom: 10px; +} + + +thead .htCollapseButton { + right: 5px; + position: absolute; + top: 5px; + background: #fff; +} + +thead .htCollapseButton:after { + height: 1px; + width: 700%; + right: 10px; + top: 4px; +} + +.handsontable tr th .htGroupStart:after { + background: transparent; + border-left: 1px solid #ccc; + border-top: 1px solid #ccc; + width: 5px; + position: relative; + top: 50%; +} + +.handsontable thead tr th .htGroupStart:after { + background: transparent; + border-left: 1px solid #ccc; + border-top: 1px solid #ccc; + height: 5px; + width: 50%; + position: relative; + top: 0px; + left: 50%; +} + +.handsontable .htGroupLevelTrigger { + -webkit-box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.4); + box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.4); + width: 15px; + height: 15px; + margin: 4px auto; + padding: 0px; + line-height: 15px; + cursor: pointer; +} + +.handsontable tr th .htExpandButton { + position: absolute; + width: 10px; + height: 10px; + line-height: 10px; + text-align: center; + border-radius: 5px; + border: 1px solid #f3f3f3; + -webkit-box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.4); + box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.4); + cursor: pointer; + top: 0px; + display: none; +} + +.handsontable thead tr th .htExpandButton { + /*left: 5px;*/ + top: 5px; +} + +.handsontable tr th .htExpandButton.clickable { + display: block; +} + +.handsontable col.hidden { + width: 0px !important; +} + +.handsontable tr.hidden, +.handsontable tr.hidden td, +.handsontable tr.hidden th { + display: none; +} + +.ht_master, +.ht_clone_left, +.ht_clone_top { + overflow: hidden; +} + +.ht_master .wtHolder { + overflow: auto; +} + +.ht_clone_left .wtHolder { + overflow-x: hidden; + overflow-y: auto; +} + +.ht_clone_top .wtHolder { + overflow-x: auto; + overflow-y: hidden; +} + + +/*WalkontableDebugOverlay*/ + +.wtDebugHidden { + display: none; +} + +.wtDebugVisible { + display: block; + -webkit-animation-duration: 0.5s; + -webkit-animation-name: wtFadeInFromNone; + animation-duration: 0.5s; + animation-name: wtFadeInFromNone; +} + +@keyframes wtFadeInFromNone { + 0% { + display: none; + opacity: 0; + } + + 1% { + display: block; + opacity: 0; + } + + 100% { + display: block; + opacity: 1; + } +} + +@-webkit-keyframes wtFadeInFromNone { + 0% { + display: none; + opacity: 0; + } + + 1% { + display: block; + opacity: 0; + } + + 100% { + display: block; + opacity: 1; + } +} +/* + + Handsontable Mobile Text Editor stylesheet + + */ + +.handsontable.mobile, +.handsontable.mobile .wtHolder { + -webkit-touch-callout:none; + -webkit-user-select:none; + -khtml-user-select:none; + -moz-user-select:none; + -ms-user-select:none; + user-select:none; + -webkit-tap-highlight-color:rgba(0,0,0,0); + -webkit-overflow-scrolling: touch; +} + +.htMobileEditorContainer { + display: none; + position: absolute; + top: 0; + width: 70%; + height: 54pt; + background: #f8f8f8; + border-radius: 20px; + border: 1px solid #ebebeb; + z-index: 999; + box-sizing: border-box; + -webkit-box-sizing: border-box; + -webkit-text-size-adjust: none; +} + +.topLeftSelectionHandle:not(.ht_master .topLeftSelectionHandle), +.topLeftSelectionHandle-HitArea:not(.ht_master .topLeftSelectionHandle-HitArea) { + z-index: 9999; +} + +/* Initial left/top coordinates - overwritten when actual position is set */ +.topLeftSelectionHandle, +.topLeftSelectionHandle-HitArea, +.bottomRightSelectionHandle, +.bottomRightSelectionHandle-HitArea { + left: -10000px; + top: -10000px; +} + +.htMobileEditorContainer.active { + display: block; +} + +.htMobileEditorContainer .inputs { + position: absolute; + right: 210pt; + bottom: 10pt; + top: 10pt; + left: 14px; + height: 34pt; +} + +.htMobileEditorContainer .inputs textarea { + font-size: 13pt; + border: 1px solid #a1a1a1; + -webkit-appearance: none; + -webkit-box-shadow: none; + -moz-box-shadow: none; + box-shadow: none; + position: absolute; + left: 14px; + right: 14px; + top: 0; + bottom: 0; + padding: 7pt; +} + +.htMobileEditorContainer .cellPointer { + position: absolute; + top: -13pt; + height: 0; + width: 0; + left: 30px; + + border-left: 13pt solid transparent; + border-right: 13pt solid transparent; + border-bottom: 13pt solid #ebebeb; +} + +.htMobileEditorContainer .cellPointer.hidden { + display: none; +} + +.htMobileEditorContainer .cellPointer:before { + content: ''; + display: block; + position: absolute; + top: 2px; + height: 0; + width: 0; + left: -13pt; + + border-left: 13pt solid transparent; + border-right: 13pt solid transparent; + border-bottom: 13pt solid #f8f8f8; +} + +.htMobileEditorContainer .moveHandle { + position: absolute; + top: 10pt; + left: 5px; + width: 30px; + bottom: 0px; + cursor: move; + z-index: 9999; +} + +.htMobileEditorContainer .moveHandle:after { + content: "..\a..\a..\a.."; + white-space: pre; + line-height: 10px; + font-size: 20pt; + display: inline-block; + margin-top: -8px; + color: #ebebeb; +} + +.htMobileEditorContainer .positionControls { + width: 205pt; + position: absolute; + right: 5pt; + top: 0; + bottom: 0; +} + +.htMobileEditorContainer .positionControls > div { + width: 50pt; + height: 100%; + float: left; +} + +.htMobileEditorContainer .positionControls > div:after { + content: " "; + display: block; + width: 15pt; + height: 15pt; + text-align: center; + line-height: 50pt; +} + +.htMobileEditorContainer .leftButton:after, +.htMobileEditorContainer .rightButton:after, +.htMobileEditorContainer .upButton:after, +.htMobileEditorContainer .downButton:after { + transform-origin: 5pt 5pt; + -webkit-transform-origin: 5pt 5pt; + margin: 21pt 0 0 21pt; +} + +.htMobileEditorContainer .leftButton:after { + border-top: 2px solid #288ffe; + border-left: 2px solid #288ffe; + -webkit-transform: rotate(-45deg); + /*margin-top: 17pt;*/ + /*margin-left: 20pt;*/ +} +.htMobileEditorContainer .leftButton:active:after { + border-color: #cfcfcf; +} + +.htMobileEditorContainer .rightButton:after { + border-top: 2px solid #288ffe; + border-left: 2px solid #288ffe; + -webkit-transform: rotate(135deg); + /*margin-top: 17pt;*/ + /*margin-left: 10pt;*/ +} +.htMobileEditorContainer .rightButton:active:after { + border-color: #cfcfcf; +} + +.htMobileEditorContainer .upButton:after { + /*border-top: 2px solid #cfcfcf;*/ + border-top: 2px solid #288ffe; + border-left: 2px solid #288ffe; + -webkit-transform: rotate(45deg); + /*margin-top: 22pt;*/ + /*margin-left: 15pt;*/ +} +.htMobileEditorContainer .upButton:active:after { + border-color: #cfcfcf; +} + +.htMobileEditorContainer .downButton:after { + border-top: 2px solid #288ffe; + border-left: 2px solid #288ffe; + -webkit-transform: rotate(225deg); + /*margin-top: 15pt;*/ + /*margin-left: 15pt;*/ +} +.htMobileEditorContainer .downButton:active:after { + border-color: #cfcfcf; +} + +.handsontable.hide-tween { + -webkit-animation: opacity-hide 0.3s; + animation: opacity-hide 0.3s; + animation-fill-mode: forwards; + -webkit-animation-fill-mode: forwards; +} + +.handsontable.show-tween { + -webkit-animation: opacity-show 0.3s; + animation: opacity-show 0.3s; + animation-fill-mode: forwards; + -webkit-animation-fill-mode: forwards; +} +/*! + * Handsontable ContextMenu + */ + +.htContextMenu { + display: none; + position: absolute; + z-index: 1060; /*needs to be higher than 1050 - z-index for Twitter Bootstrap modal (#1569)*/ +} + +.htContextMenu .ht_clone_top, +.htContextMenu .ht_clone_left, +.htContextMenu .ht_clone_corner, +.htContextMenu .ht_clone_debug { + display: none; +} + +.htContextMenu table.htCore { + outline: 1px solid #bbb; +} + +.htContextMenu .wtBorder { + visibility: hidden; +} + +.htContextMenu table tbody tr td { + background: white; + border-width: 0; + padding: 4px 6px 0px 6px; + cursor: pointer; + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; +} + +.htContextMenu table tbody tr td:first-child { + border: 0; +} + +.htContextMenu table tbody tr td.htDimmed{ + font-style: normal; + color: #323232; +} + +.htContextMenu table tbody tr td.current, +.htContextMenu table tbody tr td.zeroclipboard-is-hover { + background: rgb(233, 233, 233); +} + +.htContextMenu table tbody tr td.htSeparator { + border-top: 1px solid #bbb; + height: 0; + padding: 0; +} + +.htContextMenu table tbody tr td.htDisabled { + color: #999; +} + +.htContextMenu table tbody tr td.htDisabled:hover { + background: white; + color: #999; + cursor: default; +} +.htContextMenu table tbody tr td div{ + padding-left: 10px; +} +.htContextMenu table tbody tr td div span.selected{ + margin-top: -2px; + position: absolute; + left: 4px; +} +@charset "UTF-8"; + +/*! + * Pikaday + * Copyright © 2014 David Bushell | BSD & MIT license | http://dbushell.com/ + */ + +.pika-single { + z-index: 9999; + display: block; + position: relative; + color: #333; + background: #fff; + border: 1px solid #ccc; + border-bottom-color: #bbb; + font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; +} + +/* +clear child float (pika-lendar), using the famous micro clearfix hack +http://nicolasgallagher.com/micro-clearfix-hack/ +*/ +.pika-single:before, +.pika-single:after { + content: " "; + display: table; +} +.pika-single:after { clear: both } +.pika-single { *zoom: 1 } + +.pika-single.is-hidden { + display: none; +} + +.pika-single.is-bound { + position: absolute; + box-shadow: 0 5px 15px -5px rgba(0,0,0,.5); +} + +.pika-lendar { + float: left; + width: 240px; + margin: 8px; +} + +.pika-title { + position: relative; + text-align: center; +} + +.pika-label { + display: inline-block; + *display: inline; + position: relative; + z-index: 9999; + overflow: hidden; + margin: 0; + padding: 5px 3px; + font-size: 14px; + line-height: 20px; + font-weight: bold; + background-color: #fff; +} +.pika-title select { + cursor: pointer; + position: absolute; + z-index: 9998; + margin: 0; + left: 0; + top: 5px; + filter: alpha(opacity=0); + opacity: 0; +} + +.pika-prev, +.pika-next { + display: block; + cursor: pointer; + position: relative; + outline: none; + border: 0; + padding: 0; + width: 20px; + height: 30px; + /* hide text using text-indent trick, using width value (it's enough) */ + text-indent: 20px; + white-space: nowrap; + overflow: hidden; + background-color: transparent; + background-position: center center; + background-repeat: no-repeat; + background-size: 75% 75%; + opacity: .5; + *position: absolute; + *top: 0; +} + +.pika-prev:hover, +.pika-next:hover { + opacity: 1; +} + +.pika-prev, +.is-rtl .pika-next { + float: left; + background-image: url(''); + *left: 0; +} + +.pika-next, +.is-rtl .pika-prev { + float: right; + background-image: url(''); + *right: 0; +} + +.pika-prev.is-disabled, +.pika-next.is-disabled { + cursor: default; + opacity: .2; +} + +.pika-select { + display: inline-block; + *display: inline; +} + +.pika-table { + width: 100%; + border-collapse: collapse; + border-spacing: 0; + border: 0; +} + +.pika-table th, +.pika-table td { + width: 14.285714285714286%; + padding: 0; +} + +.pika-table th { + color: #999; + font-size: 12px; + line-height: 25px; + font-weight: bold; + text-align: center; +} + +.pika-button { + cursor: pointer; + display: block; + box-sizing: border-box; + -moz-box-sizing: border-box; + outline: none; + border: 0; + margin: 0; + width: 100%; + padding: 5px; + color: #666; + font-size: 12px; + line-height: 15px; + text-align: right; + background: #f5f5f5; +} + +.pika-week { + font-size: 11px; + color: #999; +} + +.is-today .pika-button { + color: #33aaff; + font-weight: bold; +} + +.is-selected .pika-button { + color: #fff; + font-weight: bold; + background: #33aaff; + box-shadow: inset 0 1px 3px #178fe5; + border-radius: 3px; +} + +.is-inrange .pika-button { + background: #D5E9F7; +} + +.is-startrange .pika-button { + color: #fff; + background: #6CB31D; + box-shadow: none; + border-radius: 3px; +} + +.is-endrange .pika-button { + color: #fff; + background: #33aaff; + box-shadow: none; + border-radius: 3px; +} + +.is-disabled .pika-button { + pointer-events: none; + cursor: default; + color: #999; + opacity: .3; +} + +.pika-button:hover { + color: #fff; + background: #ff8000; + box-shadow: none; + border-radius: 3px; +} + +/* styling for abbr */ +.pika-table abbr { + border-bottom: none; + cursor: help; +} + diff --git a/less/jquery.handsontable.columnmove.less b/less/jquery.handsontable.columnmove.less deleted file mode 100644 index e0d08fe..0000000 --- a/less/jquery.handsontable.columnmove.less +++ /dev/null @@ -1,15 +0,0 @@ -.handsontable th .editTableColumnMover { - position: absolute; - left: 0; - top: 0; - background-color: transparent; - width: 5px; - height: 25px; - z-index: 999; - cursor: move; - - &:hover, - &.active { - background-color: #88F; - } -} diff --git a/less/jquery.handsontable.full.less b/less/jquery.handsontable.full.less deleted file mode 100644 index 09d05de..0000000 --- a/less/jquery.handsontable.full.less +++ /dev/null @@ -1,494 +0,0 @@ -/** - * Handsontable 0.10.1 - * Handsontable is a simple jQuery plugin for editable tables with basic copy-paste compatibility with Excel and Google Docs - * - * Copyright 2012, Marcin Warpechowski - * Licensed under the MIT license. - * http://handsontable.com/ - * - * Date: Mon Jan 20 2014 15:03:52 GMT+0100 (CET) - */ - -.handsontable { - position: relative; -} - -.handsontable.htAutoColumnSize { - visibility: hidden; - left: 0; - position: absolute; - top: 0; -} - -.handsontable table, -.handsontable tbody, -.handsontable thead, -.handsontable td, -.handsontable th, -.handsontable div { - box-sizing: content-box; - -webkit-box-sizing: content-box; - -moz-box-sizing: content-box; -} - -.handsontable table.htCore { - border-collapse: separate; - /*it must be separate, otherwise there are offset miscalculations in WebKit: http://stackoverflow.com/questions/2655987/border-collapse-differences-in-ff-and-webkit*/ - position: relative; - /*this actually only changes appearance of user selection - does not make text unselectable - -webkit-user-select: none; - -khtml-user-select: none; - -moz-user-select: none; - -o-user-select: none; - -ms-user-select: none; - /*user-select: none; /*no browser supports unprefixed version*/ - border-spacing: 0; - margin: 0; - border-width: 0; - table-layout: fixed; - width: 0; - outline-width: 0; - /* reset bootstrap table style. for more info see: https://github.com/warpech/jquery-handsontable/issues/224 */ - max-width: none; - max-height: none; -} - -.handsontable col { - width: 50px; -} - -.handsontable col.rowHeader { - width: 50px; -} - -.handsontable th, -.handsontable td { - border-right: 1px solid #CCC; - border-bottom: 1px solid #CCC; - height: 22px; - empty-cells: show; - line-height: 21px; - padding: 0; - background-color: #FFF; - vertical-align: top; - overflow: hidden; - outline-width: 0; - white-space: pre-line; - /* preserve new line character in cell */ -} - -.handsontable td { - padding: 0 4px 0 4px; - /* top, bottom padding different than 0 is handled poorly by FF with HTML5 doctype */ -} - -.handsontable td.htInvalid { - -webkit-transition: background 0.75s ease; - transition: background 0.75s ease; - background-color: #ff4c42; -} - -.handsontable th:last-child { - /*Foundation framework fix*/ - border-right: 1px solid #CCC; - border-bottom: 1px solid #CCC; -} - -.handsontable tr:first-child th.htNoFrame, -.handsontable th:first-child.htNoFrame, -.handsontable th.htNoFrame { - border-left-width: 0; - background-color: white; - border-color: #FFF; -} - -.handsontable th:first-child, -.handsontable td:first-child, -.handsontable .htNoFrame + th, -.handsontable .htNoFrame + td { - border-left: 1px solid #CCC; -} - -.handsontable tr:first-child th, -.handsontable tr:first-child td { - border-top: 1px solid #CCC; -} - -.handsontable thead tr:last-child th { - border-bottom-width: 0; -} - -.handsontable thead tr.lastChild th { - border-bottom-width: 0; -} - -.handsontable th { - background-color: #EEE; - color: #222; - text-align: center; - font-weight: normal; - white-space: nowrap; -} - -.handsontable thead th { - padding: 0; -} - -.handsontable th.active { - background-color: #CCC; -} - -.handsontable th .relative { - position: relative; - padding: 2px 4px; -} - -/* plugins */ - -.handsontable .manualColumnMover { - position: absolute; - left: 0; - top: 0; - background-color: transparent; - width: 5px; - height: 25px; - z-index: 999; - cursor: move; -} - -.handsontable th .manualColumnMover:hover, -.handsontable th .manualColumnMover.active { - background-color: #88F; -} - -.handsontable .manualColumnResizer { - position: absolute; - top: 0; - cursor: col-resize; -} - -.handsontable .manualColumnResizerHandle { - background-color: transparent; - width: 5px; - height: 25px; -} - -.handsontable .manualColumnResizer:hover .manualColumnResizerHandle, -.handsontable .manualColumnResizer.active .manualColumnResizerHandle { - background-color: #AAB; -} - -.handsontable .manualColumnResizerLine { - position: absolute; - right: 0; - top: 0; - background-color: #AAB; - display: none; - width: 0; - border-right: 1px dashed #777; -} - -.handsontable .manualColumnResizer.active .manualColumnResizerLine { - display: block; -} - -.handsontable .columnSorting:hover { - text-decoration: underline; - cursor: pointer; -} - -/* border line */ - -.handsontable .wtBorder { - position: absolute; - font-size: 0; -} - -.handsontable td.area { - background-color: #EEF4FF; -} - -/* fill handle */ - -.handsontable .wtBorder.corner { - font-size: 0; - cursor: crosshair; -} - -.handsontable .htBorder.htFillBorder { - background: red; - width: 1px; - height: 1px; -} - -.handsontableInput { - border: 2px solid #5292F7; - outline-width: 0; - margin: 0; - padding: 1px 4px 0 2px; - font-family: Arial, Helvetica, sans-serif; - /*repeat from .handsontable (inherit doesn't work with IE<8) */ - line-height: 1.3em; - /*repeat from .handsontable (inherit doesn't work with IE<8) */ - font-size: inherit; - -webkit-box-shadow: 1px 2px 5px rgba(0, 0, 0, 0.4); - box-shadow: 1px 2px 5px rgba(0, 0, 0, 0.4); - resize: none; - /*below are needed to overwrite stuff added by jQuery UI Bootstrap theme*/ - display: inline-block; - color: #000; - border-radius: 0; - background-color: #FFF; - /*overwrite styles potentionally made by a framework*/ -} - -.handsontableInputHolder { - position: absolute; - top: 0; - left: 0; - z-index: 100; -} - -.htSelectEditor { - -webkit-appearance: menulist-button !important; - position: absolute; -} - -/* -TextRenderer readOnly cell -*/ - -.handsontable .htDimmed { - color: #777; -} - -/* -TextRenderer placeholder value -*/ - -.handsontable .htPlaceholder { - color: #999; -} - -/* -AutocompleteRenderer down arrow -*/ - -.handsontable .htAutocompleteArrow { - float: right; - font-size: 10px; - color: #EEE; - cursor: default; - width: 16px; - text-align: center; -} - -.handsontable td .htAutocompleteArrow:hover { - color: #777; -} - -/* -CheckboxRenderer -*/ - -.handsontable .htCheckboxRendererInput.noValue { - opacity: 0.5; -} - -/* -NumericRenderer -*/ - -.handsontable .htNumeric { - text-align: right; -} - -/*context menu rules*/ - -ul.context-menu-list { - color: black; -} - -ul.context-menu-list li { - margin-bottom: 0; - /*Foundation framework fix*/ -} - -/** - * dragdealer - */ - -.handsontable .dragdealer { - position: relative; - width: 9px; - height: 9px; - background: #F8F8F8; - border: 1px solid #DDD; -} - -.handsontable .dragdealer .handle { - position: absolute; - width: 9px; - height: 9px; - background: #C5C5C5; -} - -.handsontable .dragdealer .disabled { - background: #898989; -} - -/** - * Handsontable in Handsontable - */ - -.handsontable .handsontable .wtHider { - padding: 0 0 5px 0; -} - -.handsontable .handsontable table { - -webkit-box-shadow: 1px 2px 5px rgba(0, 0, 0, 0.4); - box-shadow: 1px 2px 5px rgba(0, 0, 0, 0.4); -} - -/** - * Handsontable listbox theme - */ - -.handsontable.listbox { - margin: 0; -} - -.handsontable.listbox table { - border: 1px solid #ccc; - border-collapse: separate; - background: white; -} - -.handsontable.listbox th, -.handsontable.listbox tr:first-child th, -.handsontable.listbox tr:last-child th, -.handsontable.listbox tr:first-child td, -.handsontable.listbox td { - border-width: 0; -} - -.handsontable.listbox th, -.handsontable.listbox td { - white-space: nowrap; - text-overflow: ellipsis; -} - -.handsontable.listbox td.htDimmed { - cursor: default; - color: inherit; - font-style: inherit; -} - -.handsontable.listbox .wtBorder { - visibility: hidden; -} - -.handsontable.listbox tr td.current, -.handsontable.listbox tr:hover td { - background: #eee; -} - -.htContextMenu { - display: none; - position: absolute; -} - -.htContextMenu table.htCore { - outline: 1px solid #bbb; -} - -.htContextMenu .wtBorder { - visibility: hidden; -} - -.htContextMenu table tbody tr td { - background: white; - border-width: 0; - padding: 4px 6px 0px 6px; - cursor: pointer; - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; -} - -.htContextMenu table tbody tr td:first-child { - border: 0; -} - -.htContextMenu table tbody tr td.htDimmed{ - font-style: normal; - color: #323232; -} - -.htContextMenu table tbody tr td.current{ - background: rgb(233, 233, 233); -} - -.htContextMenu table tbody tr td.htSeparator { - border-top: 1px solid #bbb; - height: 0; - padding: 0; -} - -.htContextMenu table tbody tr td.htDisabled { - color: #999; -} - -.htContextMenu table tbody tr td.htDisabled:hover { - background: white; - color: #999; - cursor: default; -} - -/*WalkontableDebugOverlay*/ - -.wtDebugHidden { - display: none; -} - -.wtDebugVisible { - display: block; - -webkit-animation-duration: 0.5s; - -webkit-animation-name: wtFadeInFromNone; - animation-duration: 0.5s; - animation-name: wtFadeInFromNone; -} - -@keyframes wtFadeInFromNone { - 0% { - display: none; - opacity: 0; - } - - 1% { - display: block; - opacity: 0; - } - - 100% { - display: block; - opacity: 1; - } -} - -@-webkit-keyframes wtFadeInFromNone { - 0% { - display: none; - opacity: 0; - } - - 1% { - display: block; - opacity: 0; - } - - 100% { - display: block; - opacity: 1; - } -} \ No newline at end of file diff --git a/less/jquery.handsontable.rowmove.less b/less/jquery.handsontable.rowmove.less deleted file mode 100644 index eaad434..0000000 --- a/less/jquery.handsontable.rowmove.less +++ /dev/null @@ -1,15 +0,0 @@ -.handsontable th .editTableRowMover { - position: absolute; - left: 0; - top: 0; - background-color: transparent; - width: 50px; - height: 5px; - z-index: 999; - cursor: move; - - &:hover, - &.active { - background-color: #88F; - } -} diff --git a/package.json b/package.json new file mode 100644 index 0000000..507ce46 --- /dev/null +++ b/package.json @@ -0,0 +1,16 @@ +{ + "name": "edittable", + "keywords": ["dokuwiki", "dokuwiki-plugin"], + "repository" : + { + "type" : "git", + "url" : "https://github.com/cosmocode/edittable.git" + }, + "devDependencies": { + "grunt": "^0.4.5", + "grunt-contrib-qunit": "^0.7.0", + "grunt-contrib-watch": "^0.6.1", + "jquery": "^2.1.4", + "qunitjs": "^1.18.0" + } +} diff --git a/script.js b/script.js index a56be55..52d7550 100644 --- a/script.js +++ b/script.js @@ -1,7 +1,5 @@ /* DOKUWIKI:include_once script/json2.js */ -/* DOKUWIKI:include_once script/jquery.handsontable.full.js */ -/* DOKUWIKI:include script/jquery.handsontable.columnmove.js */ -/* DOKUWIKI:include script/jquery.handsontable.rowmove.js */ +/* DOKUWIKI:include_once script/handsontable.full.js */ /* DOKUWIKI:include script/contextmenu.js */ /* DOKUWIKI:include script/editor.js */ diff --git a/script/contextmenu.js b/script/contextmenu.js index adc389e..0ff69d6 100644 --- a/script/contextmenu.js +++ b/script/contextmenu.js @@ -1,3 +1,19 @@ +/** + * create an iterable array of selected cells from the selection object + * + * @param selection object + * @returns {Array} + */ +var cellArray = function (selection) { + var selectionArray = []; + for (var currentRow = selection.start.row; currentRow <= selection.end.row; ++currentRow) { + for (var currentCol = selection.start.col; currentCol <= selection.end.col; ++currentCol) { + selectionArray.push({row:currentRow, col: currentCol}); + } + } + return selectionArray; +}; + /** * Defines our own contextMenu with custom callbacks * @@ -11,23 +27,27 @@ function getEditTableContextMenu(data, meta) { toggle_header: { name: LANG.plugins.edittable.toggle_header, callback: function (key, selection) { - var col = selection.start.col(); - var row = selection.start.row(); - - if (meta[row][col].tag && meta[row][col].tag === 'th') { - meta[row][col].tag = 'td'; - } else { - meta[row][col].tag = 'th'; - } + jQuery.each(cellArray(selection), function (index, cell) { + var col = cell.col; + var row = cell.row; + + if (meta[row][col].tag && meta[row][col].tag === 'th') { + meta[row][col].tag = 'td'; + } else { + meta[row][col].tag = 'th'; + } + }); this.render(); } }, align_left: { name: LANG.plugins.edittable.align_left, callback: function (key, selection) { - var col = selection.start.col(); - var row = selection.start.row(); - meta[row][col].align = 'left'; + jQuery.each(cellArray(selection), function (index, cell) { + var col = cell.col; + var row = cell.row; + meta[row][col].align = 'left'; + }); this.render(); }, disabled: function () { @@ -40,9 +60,11 @@ function getEditTableContextMenu(data, meta) { align_center: { name: LANG.plugins.edittable.align_center, callback: function (key, selection) { - var col = selection.start.col(); - var row = selection.start.row(); - meta[row][col].align = 'center'; + jQuery.each(cellArray(selection), function (index, cell) { + var col = cell.col; + var row = cell.row; + meta[row][col].align = 'center'; + }); this.render(); }, disabled: function () { @@ -55,9 +77,11 @@ function getEditTableContextMenu(data, meta) { align_right: { name: LANG.plugins.edittable.align_right, callback: function (key, selection) { - var col = selection.start.col(); - var row = selection.start.row(); - meta[row][col].align = 'right'; + jQuery.each(cellArray(selection), function (index, cell) { + var col = cell.col; + var row = cell.row; + meta[row][col].align = 'right'; + }); this.render(); }, disabled: function () { @@ -81,8 +105,8 @@ function getEditTableContextMenu(data, meta) { */ callback: function (key, selection) { if (window.confirm(LANG.plugins.edittable.confirmdeleterow)) { - var amount = selection.end.row() - selection.start.row() + 1; - this.alter("remove_row", selection.start.row(), amount); + var amount = selection.end.row - selection.start.row + 1; + this.alter("remove_row", selection.start.row, amount); } }, /** @@ -109,8 +133,8 @@ function getEditTableContextMenu(data, meta) { */ callback: function (key, selection) { if (window.confirm(LANG.plugins.edittable.confirmdeletecol)) { - var amount = selection.end.col() - selection.start.col() + 1; - this.alter("remove_col", selection.start.col(), amount); + var amount = selection.end.col - selection.start.col + 1; + this.alter("remove_col", selection.start.col, amount); } }, /** @@ -124,173 +148,32 @@ function getEditTableContextMenu(data, meta) { name: LANG.plugins.edittable.col_right }, hsep3: '---------', - colspan_add: { - name: LANG.plugins.edittable.colspan_add, - /** - * Increase colspan and rerender the table - * - * @param key - * @param selection - */ - callback: function (key, selection) { - var col = selection.start.col(); - var row = selection.start.row(); - - // increase rowspan by the colspan of the cell to the right - meta[row][col].colspan += meta[row][col + 1].colspan; - - // copy over any data from the merged cells - var colspan = meta[row][col].colspan; - var rowspan = meta[row][col].rowspan; - for (var i = 0; i < rowspan; i++) { - if (data[row + i][col + colspan - 1 ] != ':::') { - data[row][col] += ' ' + data[row + i][col + colspan - 1 ]; - } + mergeCells: { + name: function() { + var sel = this.getSelected(); + var info = this.mergeCells.mergedCellInfoCollection.getInfo(sel[0], sel[1]); + if (info) { + return '
' + LANG.plugins.edittable.unmerge_cells + '
'; + } else { + return '
' + LANG.plugins.edittable.merge_cells + '
'; } - - this.render(); }, - /** - * don't show when not enough space for colspan - * - * @returns {boolean} - */ - disabled: function () { - var selection = this.getSelected(); - var row = selection[0]; - var col = selection[1]; - var end = this.countCols(); - - var rowspan = meta[row][col].rowspan; - var colspan = meta[row][col].colspan; - - // no cells to merge - if ((col + colspan) >= end) return true; - - // don't merge into hidden or spanned cells - for (var i = 0; i < rowspan; i++) { - if (meta[row + i][col + colspan].hide) return true; - if (meta[row + i][col + colspan].rowspan > 1) { - // we allow merge with same rowspanned cell only - return meta[row + i][col + colspan].rowspan != rowspan; - } - } - - return false; // merge is fine - } - }, - colspan_del: { - name: LANG.plugins.edittable.colspan_del, - /** - * Decrease colspan and rerender table - * - * @param key - * @param selection - */ - callback: function (key, selection) { - var col = selection.start.col(); - var row = selection.start.row(); - meta[row][col].colspan--; - this.render(); - }, /** - * Make available only when colspan is set + * disable if only one cell is selected * * @returns {boolean} */ disabled: function () { var selection = this.getSelected(); - var row = selection[0]; - var col = selection[1]; - - return !(meta[row][col].colspan && meta[row][col].colspan > 1); + var startRow = selection[0]; + var startCol = selection[1]; + var endRow = selection[2]; + var endCol = selection[3]; + return startRow === endRow && startCol === endCol; } - }, - rowspan_add: { - name: LANG.plugins.edittable.rowspan_add, - /** - * Increase rowspan and rerender the table - * - * @param key - * @param selection - */ - callback: function (key, selection) { - var col = selection.start.col(); - var row = selection.start.row(); - - // increase rowspan by the rowspan of the cell below - meta[row][col].rowspan += meta[row + 1][col].rowspan; - - // copy over any data from the merged cells - var colspan = meta[row][col].colspan; - var rowspan = meta[row][col].rowspan; - for (var i = 0; i < colspan; i++) { - if (data[row + rowspan - 1][col + i] != ':::') { - data[row][col] += ' ' + data[row + rowspan - 1][col + i]; - } - } - - this.render(); - }, - /** - * don't show when not enough space for rowspan - * - * @returns {boolean} - */ - disabled: function () { - var selection = this.getSelected(); - var row = selection[0]; - var col = selection[1]; - var end = this.countRows(); - - var rowspan = meta[row][col].rowspan; - var colspan = meta[row][col].colspan; - - // no cells to merge - if ((row + rowspan) >= end) return true; - - // don't merge into hidden or spanned cells - for (var i = 0; i < colspan; i++) { - if (meta[row + rowspan][col + i].hide) return true; - if (meta[row + rowspan][col + i].colspan > 1) { - // we allow merge with same colspanned cell only - return meta[row + rowspan][col + i].colspan != colspan; - } - } - - return false; // merge is fine - } - }, - rowspan_del: { - name: LANG.plugins.edittable.rowspan_del, - /** - * Decrease colspan and rerender table - * - * @param key - * @param selection - */ - callback: function (key, selection) { - var col = selection.start.col(); - var row = selection.start.row(); - - meta[row][col].rowspan--; - this.render(); - }, - /** - * Make available only when rowspan is set - * - * @returns {boolean} - */ - disabled: function () { - var selection = this.getSelected(); - var row = selection[0]; - var col = selection[1]; - return !(meta[row][col].rowspan && meta[row][col].rowspan > 1); - } } - } }; -} \ No newline at end of file +} diff --git a/script/editor.js b/script/editor.js index 299fe03..7d73b7e 100644 --- a/script/editor.js +++ b/script/editor.js @@ -1,6 +1,95 @@ /** * This configures the Handsontable Plugin */ + +var moveRow = function moveRow(startRow,endRow,dmarray) { + var metarow = dmarray.splice(startRow,1)[0]; + dmarray.splice(endRow, 0, metarow); +}; + +var moveCol = function moveCol(startCol,endCol,dmarray) { + for (var i = 0; i < dmarray.length; ++i) { + var datacol = dmarray[i].splice(startCol, 1)[0]; + dmarray[i].splice(endCol, 0, datacol); + } +}; + +/** + * If the number of rows or columns in front of some merged cells changes, update the mergedCellInfoCollection accordingly. + * + * @param direction string either col or row + * @param type string either create, remove or move + * @param start int + * @param end int optional, only for moves + */ +var updateMergeInfo = function updateMergeInfo(direction, type, start, end) { + var mergesNeedUpdate = false; + if (type === 'create' || type === 'remove') { + end = Infinity; + } + + for (var i = 0; i < this.mergeCells.mergedCellInfoCollection.length; ++i) { + if (start <= this.mergeCells.mergedCellInfoCollection[i][direction] && end > this.mergeCells.mergedCellInfoCollection[i][direction]) { + if (type === 'create') { + this.mergeCells.mergedCellInfoCollection[i][direction] += 1; + } else { + this.mergeCells.mergedCellInfoCollection[i][direction] -= 1; + } + mergesNeedUpdate = true; + } + if (start > this.mergeCells.mergedCellInfoCollection[i][direction] && end <= this.mergeCells.mergedCellInfoCollection[i][direction]) { + this.mergeCells.mergedCellInfoCollection[i][direction] += 1; + mergesNeedUpdate = true; + } + } + + if (mergesNeedUpdate) { + this.updateSettings({mergeCells: this.mergeCells.mergedCellInfoCollection}); + } +}; + +var getMerges = function getMerges (meta) { + var merges = []; + for (var row = 0; row < meta.length; row++) { + for (var col = 0; col < meta[0].length; col++) { + if (meta[row][col].hasOwnProperty('rowspan') && meta[row][col]['rowspan'] > 1 || + meta[row][col].hasOwnProperty('colspan') && meta[row][col]['colspan'] > 1) { + var merge = {}; + merge['row'] = row; + merge['col'] = col; + merge['rowspan'] = meta[row][col]['rowspan']; + merge['colspan'] = meta[row][col]['colspan']; + merges.push(merge); + } + } + } + return merges; +}; + +/** + * If the top-left cell of a set of merged cells is removed by an 'remove row'/'remove column' action, then split the merge + * + * @param index int + * @param amount int + * @param direction string either 'row' or 'col' + */ +var unmergeRemovedMerges = function unmergeRemovedMerges(index, amount, direction) { + var mergesToSplit = []; + for (var span = 0; span < amount; ++span) { + for (var i = 0; i < this.mergeCells.mergedCellInfoCollection.length; ++i) { + if (this.mergeCells.mergedCellInfoCollection[i][direction] === index + span) { + mergesToSplit.push(i); + } + } + } + if (mergesToSplit !== []) { + for (var merge = mergesToSplit.length - 1; merge >= 0; --merge) { + this.mergeCells.mergedCellInfoCollection.splice(mergesToSplit[merge], 1); + } + this.updateSettings({mergeCells: this.mergeCells.mergedCellInfoCollection}); + } +}; + jQuery(function () { var $container = jQuery('#edittable__editor'); if (!$container.length) return; @@ -11,6 +100,8 @@ jQuery(function () { var data = JSON.parse($datafield.val()); var meta = JSON.parse($metafield.val()); + var merges = getMerges(meta); + if (merges === []) merges = true; var lastselect = {row: 0, col: 0}; $container.handsontable({ @@ -19,14 +110,13 @@ jQuery(function () { startCols: 5, colHeaders: true, rowHeaders: true, - multiSelect: false, // until properly tested with col/row span - fillHandle: false, // until properly tested with col/row span - undo: false, // until properly tested with col/row span manualColumnResize: true, - editTableColumnMove: true, // custom plugin - editTableRowMove: true, // custom plugin outsideClickDeselects: false, contextMenu: getEditTableContextMenu(data, meta), + manualColumnMove: true, + manualRowMove: true, + mergeCells: merges, + /** * Attach pointers to our raw data structures in the instance @@ -121,7 +211,7 @@ jQuery(function () { this.selectCell(0, 0); // we need an ID on the input field - this.rootElement.find('textarea.handsontableInput').attr('id', 'handsontable__input'); + jQuery('textarea.handsontableInput').attr('id', 'handsontable__input'); // we're ready to intialize the toolbar now initToolbar('tool__bar', 'handsontable__input', window.toolbar, false); @@ -157,72 +247,68 @@ jQuery(function () { meta[row][col].hide = false; data[row][col] = ''; } + // unset all row/colspans + meta[row][col].colspan = 1; + meta[row][col].rowspan = 1; // make sure no data cell is undefined/null if (!data[row][col]) data[row][col] = ''; } } - // rehide needed cells - for (row = 0; row < data.length; row++) { - for (col = 0; col < data[0].length; col++) { - var colspan = meta[row][col].colspan; - var rowspan = meta[row][col].rowspan; - - for (c = 1; c < colspan; c++) { - // does the colspan reach out of the table? decrease it - if (!meta[row][col + c]) { - meta[row][col].colspan--; - continue; + var manualRowMoveDisable = []; + var manualColumnMoveDisable = []; + for (var merge = 0; merge < this.mergeCells.mergedCellInfoCollection.length; ++merge) { + row = this.mergeCells.mergedCellInfoCollection[merge].row; + col = this.mergeCells.mergedCellInfoCollection[merge].col; + var colspan = this.mergeCells.mergedCellInfoCollection[merge].colspan; + var rowspan = this.mergeCells.mergedCellInfoCollection[merge].rowspan; + if (rowspan > 1) { + for (i = row; i < row+rowspan; ++i ) { + if (manualRowMoveDisable.indexOf(i) === -1) { + manualRowMoveDisable.push(i); } - - // hide colspanned cell in same row - meta[row][col + c].hide = true; - meta[row][col + c].rowspan = 1; - meta[row][col + c].colspan = 1; - data[row][col + c] = ''; - - this.raw.colinfo[col].colspan = true; - this.raw.colinfo[col + c].colspan = true; - - // hide colspanned rows below if rowspan is in effect as well - for (r = 1; r < rowspan; r++) { - // does the rowspan reach out of the table? decrease it - if (!meta[row + r]) { - meta[row][col].rowspan--; - continue; - } - - meta[row + r][col + c].hide = true; - meta[row + r][col + c].rowspan = 1; - meta[row + r][col + c].colspan = 1; - data[row + r][col + c] = ''; - - this.raw.rowinfo[row + r].rowspan = true; + } + } + if (colspan > 1) { + for (i = col; i < col+colspan; ++i ) { + if (manualColumnMoveDisable.indexOf(i) === -1) { + manualColumnMoveDisable.push(i); } - } - - // hide rowspanned columns - rowspan = meta[row][col].rowspan; // might have changed above - for (r = 1; r < rowspan; r++) { - // does the rowspan reach out of the table? decrease it - if (!meta[row + r]) { - meta[row][col].rowspan--; - continue; + } + meta[row][col]['colspan'] = colspan; + meta[row][col]['rowspan'] = rowspan; + + // hide the cells hidden by the row/colspan + + for (r = row; r < row + rowspan; ++r) { + for (c = col; c < col + colspan; ++c) { + if (r === row && c === col) continue; + meta[r][c].hide = true; + meta[r][c].rowspan = 1; + meta[r][c].colspan = 1; + if (data[r][c] && data[r][c] !== ':::') { + data[row][col] += ' ' + data[r][c]; + } + if (r === row) { + data[r][c] = ''; + } else { + data[r][c] = ':::'; } - - meta[row + r][col].hide = true; - meta[row + r][col].rowspan = 1; - meta[row + r][col].colspan = 1; - data[row + r][col] = ':::'; - - this.raw.rowinfo[row].rowspan = true; - this.raw.rowinfo[row + r].rowspan = true; } } } + if (!this.manualRowMoveDisable || JSON.stringify(manualRowMoveDisable.sort()) != JSON.stringify(this.manualRowMoveDisable.sort())) { + this.manualRowMoveDisable = manualRowMoveDisable; + this.updateSettings({manualRowMoveDisable: manualRowMoveDisable}); + } + if (!this.manualColumnMoveDisable || JSON.stringify(manualColumnMoveDisable.sort()) != JSON.stringify(this.manualColumnMoveDisable.sort())) { + this.manualColumnMoveDisable = manualColumnMoveDisable; + this.updateSettings({manualColumnMoveDisable: manualColumnMoveDisable}); + } + // Store data and meta back in the form $datafield.val(JSON.stringify(data)); $metafield.val(JSON.stringify(meta)); @@ -240,6 +326,26 @@ jQuery(function () { } }, + beforeColumnMove: function(startCol, endCol) { + moveCol(startCol, endCol, meta); + moveCol(startCol, endCol, data); + updateMergeInfo.call(this, 'col','move',startCol, endCol); + }, + + afterColumnMove: function () { + this.updateSettings({manualColumnMove: true}); + }, + + beforeRowMove: function(startRow, endRow) { + moveRow(startRow, endRow, meta); + moveRow(startRow, endRow, data); + updateMergeInfo.call(this, 'row','move',startRow, endRow); + }, + + afterRowMove: function () { + this.updateSettings({manualRowMove: true}); + }, + /** * Update meta data array when rows are added * @@ -263,8 +369,21 @@ jQuery(function () { for (i = 0; i < cols; i++) newrow.push({rowspan: 1, colspan: 1}); meta.splice(index, 0, newrow); } + updateMergeInfo.call(this, 'row','create',index); }, + + /** + * if rows are removed which contain the beginning of a set of merged cells, split the merge + * + * @param index + * @param amount + */ + beforeRemoveRow: function (index, amount) { + unmergeRemovedMerges.call(this, index, amount, 'row'); + }, + + /** * Update meta data array when rows are removed * @@ -273,6 +392,7 @@ jQuery(function () { */ afterRemoveRow: function (index, amount) { meta.splice(index, amount); + updateMergeInfo.call(this, 'row','remove',index); }, /** @@ -293,6 +413,17 @@ jQuery(function () { meta[row].splice(index, 0, {rowspan: 1, colspan: 1}); } } + updateMergeInfo.call(this, 'col','create',index); + }, + + /** + * if colmuns are removed which contain the beginning of a set of merged cells, split the merge + * + * @param index + * @param amount + */ + beforeRemoveCol: function (index, amount) { + unmergeRemovedMerges.call(this, index, amount, 'col'); }, /** @@ -305,6 +436,7 @@ jQuery(function () { for (var row = 0; row < data.length; row++) { meta[row].splice(index, amount); } + updateMergeInfo.call(this, 'col','remove',index); }, /** @@ -365,4 +497,4 @@ jQuery(function () { } }); -}); \ No newline at end of file +}); diff --git a/script/handsontable.full.js b/script/handsontable.full.js new file mode 100644 index 0000000..00de8e3 --- /dev/null +++ b/script/handsontable.full.js @@ -0,0 +1,26604 @@ +/*! + * Handsontable 0.16.1 + * Handsontable is a JavaScript library for editable tables with basic copy-paste compatibility with Excel and Google Docs + * + * Copyright (c) 2012-2014 Marcin Warpechowski + * Copyright 2015 Handsoncode sp. z o.o. + * Licensed under the MIT license. + * http://handsontable.com/ + * + * Date: Mon Aug 17 2015 16:30:46 GMT+0200 (CEST) + */ +/*jslint white: true, browser: true, plusplus: true, indent: 4, maxerr: 50 */ + +window.Handsontable = { + version: '0.16.1', + buildDate: 'Mon Aug 17 2015 16:30:46 GMT+0200 (CEST)' +}; +(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.Handsontable = f()}})(function(){var define,module,exports;return (function init(modules, cache, entry) { + (function outer (modules, cache, entry) { + // Save the require from previous bundle to this closure if any + var previousRequire = typeof require == "function" && require; + var globalNS = JSON.parse('{"zeroclipboard":"ZeroClipboard","moment":"moment","pikaday":"Pikaday"}') || {}; + + function newRequire(name, jumped){ + if(!cache[name]) { + + if(!modules[name]) { + // if we cannot find the the module within our internal map or + // cache jump to the current global require ie. the last bundle + // that was added to the page. + var currentRequire = typeof require == "function" && require; + if (!jumped && currentRequire) return currentRequire(name, true); + + // If there are other bundles on this page the require from the + // previous one is saved to 'previousRequire'. Repeat this as + // many times as there are bundles until the module is found or + // we exhaust the require chain. + if (previousRequire) return previousRequire(name, true); + + // Try find module from global scope + if (globalNS[name] && typeof window[globalNS[name]] !== 'undefined') { + return window[globalNS[name]]; + } + + var err = new Error('Cannot find module \'' + name + '\''); + err.code = 'MODULE_NOT_FOUND'; + throw err; + } + var m = cache[name] = {exports:{}}; + modules[name][0].call(m.exports, function(x){ + var id = modules[name][1][x]; + return newRequire(id ? id : x); + },m,m.exports,outer,modules,cache,entry); + } + + return cache[name].exports; + } + for(var i=0;i 1) { + for (i = 1, ilen = arguments.length; i < ilen; i++) { + args.push(arguments[i]); + } + } + if (instance) { + if (typeof instance[action] !== 'undefined') { + output = instance[action].apply(instance, args); + if (action === 'destroy') { + $this.removeData(); + } + } else { + throw new Error('Handsontable do not provide action: ' + action); + } + } + return output; + } + }; + })(window, jQuery, Handsontable); +} + +//# +},{}],2:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableBorder: {get: function() { + return WalkontableBorder; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47__46__46__47_eventManager_46_js__, + $__cell_47_coords_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_dom_46_js__}); +var EventManager = ($___46__46__47__46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_eventManager_46_js__}).EventManager; +var WalkontableCellCoords = ($__cell_47_coords_46_js__ = require("cell/coords.js"), $__cell_47_coords_46_js__ && $__cell_47_coords_46_js__.__esModule && $__cell_47_coords_46_js__ || {default: $__cell_47_coords_46_js__}).WalkontableCellCoords; +var WalkontableBorder = function WalkontableBorder(wotInstance, settings) { + if (!settings) { + return; + } + this.eventManager = new EventManager(wotInstance); + this.instance = wotInstance; + this.wot = wotInstance; + this.settings = settings; + this.mouseDown = false; + this.main = null; + this.top = null; + this.left = null; + this.bottom = null; + this.right = null; + this.topStyle = null; + this.leftStyle = null; + this.bottomStyle = null; + this.rightStyle = null; + this.cornerDefaultStyle = { + width: '5px', + height: '5px', + borderWidth: '2px', + borderStyle: 'solid', + borderColor: '#FFF' + }; + this.corner = null; + this.cornerStyle = null; + this.createBorders(settings); + this.registerListeners(); +}; +($traceurRuntime.createClass)(WalkontableBorder, { + registerListeners: function() { + var $__2 = this; + this.eventManager.addEventListener(document.body, 'mousedown', (function() { + return $__2.onMouseDown(); + })); + this.eventManager.addEventListener(document.body, 'mouseup', (function() { + return $__2.onMouseUp(); + })); + for (var c = 0, + len = this.main.childNodes.length; c < len; c++) { + this.eventManager.addEventListener(this.main.childNodes[c], 'mouseenter', (function(event) { + return $__2.onMouseEnter(event); + })); + } + }, + onMouseDown: function() { + this.mouseDown = true; + }, + onMouseUp: function() { + this.mouseDown = false; + }, + onMouseEnter: function(event) { + if (!this.mouseDown || !this.wot.getSetting('hideBorderOnMouseDownOver')) { + return; + } + event.preventDefault(); + event.stopImmediatePropagation(); + var _this = this; + var bounds = this.getBoundingClientRect(); + this.style.display = 'none'; + function isOutside(event) { + if (event.clientY < Math.floor(bounds.top)) { + return true; + } + if (event.clientY > Math.ceil(bounds.top + bounds.height)) { + return true; + } + if (event.clientX < Math.floor(bounds.left)) { + return true; + } + if (event.clientX > Math.ceil(bounds.left + bounds.width)) { + return true; + } + } + function handler(event) { + if (isOutside(event)) { + _this.eventManager.removeEventListener(document.body, 'mousemove', handler); + _this.style.display = 'block'; + } + } + this.eventManager.addEventListener(document.body, 'mousemove', handler); + }, + createBorders: function(settings) { + this.main = document.createElement('div'); + var borderDivs = ['top', 'left', 'bottom', 'right', 'corner']; + var style = this.main.style; + style.position = 'absolute'; + style.top = 0; + style.left = 0; + for (var i = 0; i < 5; i++) { + var position = borderDivs[i]; + var div = document.createElement('div'); + div.className = 'wtBorder ' + (this.settings.className || ''); + if (this.settings[position] && this.settings[position].hide) { + div.className += ' hidden'; + } + style = div.style; + style.backgroundColor = (this.settings[position] && this.settings[position].color) ? this.settings[position].color : settings.border.color; + style.height = (this.settings[position] && this.settings[position].width) ? this.settings[position].width + 'px' : settings.border.width + 'px'; + style.width = (this.settings[position] && this.settings[position].width) ? this.settings[position].width + 'px' : settings.border.width + 'px'; + this.main.appendChild(div); + } + this.top = this.main.childNodes[0]; + this.left = this.main.childNodes[1]; + this.bottom = this.main.childNodes[2]; + this.right = this.main.childNodes[3]; + this.topStyle = this.top.style; + this.leftStyle = this.left.style; + this.bottomStyle = this.bottom.style; + this.rightStyle = this.right.style; + this.corner = this.main.childNodes[4]; + this.corner.className += ' corner'; + this.cornerStyle = this.corner.style; + this.cornerStyle.width = this.cornerDefaultStyle.width; + this.cornerStyle.height = this.cornerDefaultStyle.height; + this.cornerStyle.border = [this.cornerDefaultStyle.borderWidth, this.cornerDefaultStyle.borderStyle, this.cornerDefaultStyle.borderColor].join(' '); + if (Handsontable.mobileBrowser) { + this.createMultipleSelectorHandles(); + } + this.disappear(); + if (!this.wot.wtTable.bordersHolder) { + this.wot.wtTable.bordersHolder = document.createElement('div'); + this.wot.wtTable.bordersHolder.className = 'htBorders'; + this.wot.wtTable.spreader.appendChild(this.wot.wtTable.bordersHolder); + } + this.wot.wtTable.bordersHolder.insertBefore(this.main, this.wot.wtTable.bordersHolder.firstChild); + }, + createMultipleSelectorHandles: function() { + this.selectionHandles = { + topLeft: document.createElement('DIV'), + topLeftHitArea: document.createElement('DIV'), + bottomRight: document.createElement('DIV'), + bottomRightHitArea: document.createElement('DIV') + }; + var width = 10; + var hitAreaWidth = 40; + this.selectionHandles.topLeft.className = 'topLeftSelectionHandle'; + this.selectionHandles.topLeftHitArea.className = 'topLeftSelectionHandle-HitArea'; + this.selectionHandles.bottomRight.className = 'bottomRightSelectionHandle'; + this.selectionHandles.bottomRightHitArea.className = 'bottomRightSelectionHandle-HitArea'; + this.selectionHandles.styles = { + topLeft: this.selectionHandles.topLeft.style, + topLeftHitArea: this.selectionHandles.topLeftHitArea.style, + bottomRight: this.selectionHandles.bottomRight.style, + bottomRightHitArea: this.selectionHandles.bottomRightHitArea.style + }; + var hitAreaStyle = { + 'position': 'absolute', + 'height': hitAreaWidth + 'px', + 'width': hitAreaWidth + 'px', + 'border-radius': parseInt(hitAreaWidth / 1.5, 10) + 'px' + }; + for (var prop in hitAreaStyle) { + if (hitAreaStyle.hasOwnProperty(prop)) { + this.selectionHandles.styles.bottomRightHitArea[prop] = hitAreaStyle[prop]; + this.selectionHandles.styles.topLeftHitArea[prop] = hitAreaStyle[prop]; + } + } + var handleStyle = { + 'position': 'absolute', + 'height': width + 'px', + 'width': width + 'px', + 'border-radius': parseInt(width / 1.5, 10) + 'px', + 'background': '#F5F5FF', + 'border': '1px solid #4285c8' + }; + for (var prop$__4 in handleStyle) { + if (handleStyle.hasOwnProperty(prop$__4)) { + this.selectionHandles.styles.bottomRight[prop$__4] = handleStyle[prop$__4]; + this.selectionHandles.styles.topLeft[prop$__4] = handleStyle[prop$__4]; + } + } + this.main.appendChild(this.selectionHandles.topLeft); + this.main.appendChild(this.selectionHandles.bottomRight); + this.main.appendChild(this.selectionHandles.topLeftHitArea); + this.main.appendChild(this.selectionHandles.bottomRightHitArea); + }, + isPartRange: function(row, col) { + if (this.wot.selections.area.cellRange) { + if (row != this.wot.selections.area.cellRange.to.row || col != this.wot.selections.area.cellRange.to.col) { + return true; + } + } + return false; + }, + updateMultipleSelectionHandlesPosition: function(row, col, top, left, width, height) { + var handleWidth = parseInt(this.selectionHandles.styles.topLeft.width, 10); + var hitAreaWidth = parseInt(this.selectionHandles.styles.topLeftHitArea.width, 10); + this.selectionHandles.styles.topLeft.top = parseInt(top - handleWidth, 10) + "px"; + this.selectionHandles.styles.topLeft.left = parseInt(left - handleWidth, 10) + "px"; + this.selectionHandles.styles.topLeftHitArea.top = parseInt(top - (hitAreaWidth / 4) * 3, 10) + "px"; + this.selectionHandles.styles.topLeftHitArea.left = parseInt(left - (hitAreaWidth / 4) * 3, 10) + "px"; + this.selectionHandles.styles.bottomRight.top = parseInt(top + height, 10) + "px"; + this.selectionHandles.styles.bottomRight.left = parseInt(left + width, 10) + "px"; + this.selectionHandles.styles.bottomRightHitArea.top = parseInt(top + height - hitAreaWidth / 4, 10) + "px"; + this.selectionHandles.styles.bottomRightHitArea.left = parseInt(left + width - hitAreaWidth / 4, 10) + "px"; + if (this.settings.border.multipleSelectionHandlesVisible && this.settings.border.multipleSelectionHandlesVisible()) { + this.selectionHandles.styles.topLeft.display = "block"; + this.selectionHandles.styles.topLeftHitArea.display = "block"; + if (!this.isPartRange(row, col)) { + this.selectionHandles.styles.bottomRight.display = "block"; + this.selectionHandles.styles.bottomRightHitArea.display = "block"; + } else { + this.selectionHandles.styles.bottomRight.display = "none"; + this.selectionHandles.styles.bottomRightHitArea.display = "none"; + } + } else { + this.selectionHandles.styles.topLeft.display = "none"; + this.selectionHandles.styles.bottomRight.display = "none"; + this.selectionHandles.styles.topLeftHitArea.display = "none"; + this.selectionHandles.styles.bottomRightHitArea.display = "none"; + } + if (row == this.wot.wtSettings.getSetting('fixedRowsTop') || col == this.wot.wtSettings.getSetting('fixedColumnsLeft')) { + this.selectionHandles.styles.topLeft.zIndex = "9999"; + this.selectionHandles.styles.topLeftHitArea.zIndex = "9999"; + } else { + this.selectionHandles.styles.topLeft.zIndex = ""; + this.selectionHandles.styles.topLeftHitArea.zIndex = ""; + } + }, + appear: function(corners) { + if (this.disabled) { + return; + } + var isMultiple, + fromTD, + toTD, + fromOffset, + toOffset, + containerOffset, + top, + minTop, + left, + minLeft, + height, + width, + fromRow, + fromColumn, + toRow, + toColumn, + ilen; + if (this.wot.cloneOverlay instanceof WalkontableTopOverlay || this.wot.cloneOverlay instanceof WalkontableCornerOverlay) { + ilen = this.wot.getSetting('fixedRowsTop'); + } else { + ilen = this.wot.wtTable.getRenderedRowsCount(); + } + for (var i = 0; i < ilen; i++) { + var s = this.wot.wtTable.rowFilter.renderedToSource(i); + if (s >= corners[0] && s <= corners[2]) { + fromRow = s; + break; + } + } + for (var i$__5 = ilen - 1; i$__5 >= 0; i$__5--) { + var s$__6 = this.wot.wtTable.rowFilter.renderedToSource(i$__5); + if (s$__6 >= corners[0] && s$__6 <= corners[2]) { + toRow = s$__6; + break; + } + } + ilen = this.wot.wtTable.getRenderedColumnsCount(); + for (var i$__7 = 0; i$__7 < ilen; i$__7++) { + var s$__8 = this.wot.wtTable.columnFilter.renderedToSource(i$__7); + if (s$__8 >= corners[1] && s$__8 <= corners[3]) { + fromColumn = s$__8; + break; + } + } + for (var i$__9 = ilen - 1; i$__9 >= 0; i$__9--) { + var s$__10 = this.wot.wtTable.columnFilter.renderedToSource(i$__9); + if (s$__10 >= corners[1] && s$__10 <= corners[3]) { + toColumn = s$__10; + break; + } + } + if (fromRow === void 0 || fromColumn === void 0) { + this.disappear(); + return; + } + isMultiple = (fromRow !== toRow || fromColumn !== toColumn); + fromTD = this.wot.wtTable.getCell(new WalkontableCellCoords(fromRow, fromColumn)); + toTD = isMultiple ? this.wot.wtTable.getCell(new WalkontableCellCoords(toRow, toColumn)) : fromTD; + fromOffset = dom.offset(fromTD); + toOffset = isMultiple ? dom.offset(toTD) : fromOffset; + containerOffset = dom.offset(this.wot.wtTable.TABLE); + minTop = fromOffset.top; + height = toOffset.top + dom.outerHeight(toTD) - minTop; + minLeft = fromOffset.left; + width = toOffset.left + dom.outerWidth(toTD) - minLeft; + top = minTop - containerOffset.top - 1; + left = minLeft - containerOffset.left - 1; + var style = dom.getComputedStyle(fromTD); + if (parseInt(style.borderTopWidth, 10) > 0) { + top += 1; + height = height > 0 ? height - 1 : 0; + } + if (parseInt(style.borderLeftWidth, 10) > 0) { + left += 1; + width = width > 0 ? width - 1 : 0; + } + this.topStyle.top = top + 'px'; + this.topStyle.left = left + 'px'; + this.topStyle.width = width + 'px'; + this.topStyle.display = 'block'; + this.leftStyle.top = top + 'px'; + this.leftStyle.left = left + 'px'; + this.leftStyle.height = height + 'px'; + this.leftStyle.display = 'block'; + var delta = Math.floor(this.settings.border.width / 2); + this.bottomStyle.top = top + height - delta + 'px'; + this.bottomStyle.left = left + 'px'; + this.bottomStyle.width = width + 'px'; + this.bottomStyle.display = 'block'; + this.rightStyle.top = top + 'px'; + this.rightStyle.left = left + width - delta + 'px'; + this.rightStyle.height = height + 1 + 'px'; + this.rightStyle.display = 'block'; + if (Handsontable.mobileBrowser || (!this.hasSetting(this.settings.border.cornerVisible) || this.isPartRange(toRow, toColumn))) { + this.cornerStyle.display = 'none'; + } else { + this.cornerStyle.top = top + height - 4 + 'px'; + this.cornerStyle.left = left + width - 4 + 'px'; + this.cornerStyle.borderRightWidth = this.cornerDefaultStyle.borderWidth; + this.cornerStyle.width = this.cornerDefaultStyle.width; + this.cornerStyle.display = 'block'; + if (toColumn === this.wot.getSetting('totalColumns') - 1) { + var trimmingContainer = dom.getTrimmingContainer(this.wot.wtTable.TABLE); + var cornerOverlappingContainer = toTD.offsetLeft + dom.outerWidth(toTD) >= dom.innerWidth(trimmingContainer); + if (cornerOverlappingContainer) { + this.cornerStyle.left = Math.floor(left + width - 3 - parseInt(this.cornerDefaultStyle.width) / 2) + "px"; + this.cornerStyle.borderRightWidth = 0; + } + } + } + if (Handsontable.mobileBrowser) { + this.updateMultipleSelectionHandlesPosition(fromRow, fromColumn, top, left, width, height); + } + }, + disappear: function() { + this.topStyle.display = 'none'; + this.leftStyle.display = 'none'; + this.bottomStyle.display = 'none'; + this.rightStyle.display = 'none'; + this.cornerStyle.display = 'none'; + if (Handsontable.mobileBrowser) { + this.selectionHandles.styles.topLeft.display = 'none'; + this.selectionHandles.styles.bottomRight.display = 'none'; + } + }, + hasSetting: function(setting) { + if (typeof setting === 'function') { + return setting(); + } + return !!setting; + } +}, {}); +; +window.WalkontableBorder = WalkontableBorder; + +//# +},{"cell/coords.js":5,"dom.js":27,"eventManager.js":41}],3:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableViewportColumnsCalculator: {get: function() { + return WalkontableViewportColumnsCalculator; + }}, + __esModule: {value: true} +}); +var privatePool = new WeakMap(); +var WalkontableViewportColumnsCalculator = function WalkontableViewportColumnsCalculator(viewportWidth, scrollOffset, totalColumns, columnWidthFn, overrideFn, onlyFullyVisible, stretchH) { + privatePool.set(this, { + viewportWidth: viewportWidth, + scrollOffset: scrollOffset, + totalColumns: totalColumns, + columnWidthFn: columnWidthFn, + overrideFn: overrideFn, + onlyFullyVisible: onlyFullyVisible + }); + this.count = 0; + this.startColumn = null; + this.endColumn = null; + this.startPosition = null; + this.stretchAllRatio = 0; + this.stretchLastWidth = 0; + this.stretch = stretchH; + this.totalTargetWidth = 0; + this.needVerifyLastColumnWidth = true; + this.stretchAllColumnsWidth = []; + this.calculate(); +}; +var $WalkontableViewportColumnsCalculator = WalkontableViewportColumnsCalculator; +($traceurRuntime.createClass)(WalkontableViewportColumnsCalculator, { + calculate: function() { + var sum = 0; + var needReverse = true; + var startPositions = []; + var columnWidth; + var priv = privatePool.get(this); + var onlyFullyVisible = priv.onlyFullyVisible; + var overrideFn = priv.overrideFn; + var scrollOffset = priv.scrollOffset; + var totalColumns = priv.totalColumns; + var viewportWidth = priv.viewportWidth; + for (var i = 0; i < totalColumns; i++) { + columnWidth = this._getColumnWidth(i); + if (sum <= scrollOffset && !onlyFullyVisible) { + this.startColumn = i; + } + if (sum >= scrollOffset && sum + columnWidth <= scrollOffset + viewportWidth) { + if (this.startColumn == null) { + this.startColumn = i; + } + this.endColumn = i; + } + startPositions.push(sum); + sum += columnWidth; + if (!onlyFullyVisible) { + this.endColumn = i; + } + if (sum >= scrollOffset + viewportWidth) { + needReverse = false; + break; + } + } + if (this.endColumn === totalColumns - 1 && needReverse) { + this.startColumn = this.endColumn; + while (this.startColumn > 0) { + var viewportSum = startPositions[this.endColumn] + columnWidth - startPositions[this.startColumn - 1]; + if (viewportSum <= viewportWidth || !onlyFullyVisible) { + this.startColumn--; + } + if (viewportSum > viewportWidth) { + break; + } + } + } + if (this.startColumn !== null && overrideFn) { + overrideFn(this); + } + this.startPosition = startPositions[this.startColumn]; + if (this.startPosition == void 0) { + this.startPosition = null; + } + if (this.startColumn !== null) { + this.count = this.endColumn - this.startColumn + 1; + } + }, + refreshStretching: function(totalWidth) { + if (this.stretch === 'none') { + return; + } + var sumAll = 0; + var columnWidth; + var remainingSize; + var priv = privatePool.get(this); + var totalColumns = priv.totalColumns; + for (var i = 0; i < totalColumns; i++) { + columnWidth = this._getColumnWidth(i); + sumAll += columnWidth; + } + this.totalTargetWidth = totalWidth; + remainingSize = sumAll - totalWidth; + if (this.stretch === 'all' && remainingSize < 0) { + this.stretchAllRatio = totalWidth / sumAll; + this.stretchAllColumnsWidth = []; + this.needVerifyLastColumnWidth = true; + } else if (this.stretch === 'last' && totalWidth !== Infinity) { + this.stretchLastWidth = -remainingSize + this._getColumnWidth(totalColumns - 1); + } + }, + getStretchedColumnWidth: function(column, baseWidth) { + var result = null; + if (this.stretch === 'all' && this.stretchAllRatio !== 0) { + result = this._getStretchedAllColumnWidth(column, baseWidth); + } else if (this.stretch === 'last' && this.stretchLastWidth !== 0) { + result = this._getStretchedLastColumnWidth(column); + } + return result; + }, + _getStretchedAllColumnWidth: function(column, baseWidth) { + var sumRatioWidth = 0; + var priv = privatePool.get(this); + var totalColumns = priv.totalColumns; + if (!this.stretchAllColumnsWidth[column]) { + this.stretchAllColumnsWidth[column] = Math.round(baseWidth * this.stretchAllRatio); + } + if (this.stretchAllColumnsWidth.length === totalColumns && this.needVerifyLastColumnWidth) { + this.needVerifyLastColumnWidth = false; + for (var i = 0; i < this.stretchAllColumnsWidth.length; i++) { + sumRatioWidth += this.stretchAllColumnsWidth[i]; + } + if (sumRatioWidth !== this.totalTargetWidth) { + this.stretchAllColumnsWidth[this.stretchAllColumnsWidth.length - 1] += this.totalTargetWidth - sumRatioWidth; + } + } + return this.stretchAllColumnsWidth[column]; + }, + _getStretchedLastColumnWidth: function(column) { + var priv = privatePool.get(this); + var totalColumns = priv.totalColumns; + if (column === totalColumns - 1) { + return this.stretchLastWidth; + } + return null; + }, + _getColumnWidth: function(column) { + var width = privatePool.get(this).columnWidthFn(column); + if (width === undefined) { + width = $WalkontableViewportColumnsCalculator.DEFAULT_WIDTH; + } + return width; + } +}, {get DEFAULT_WIDTH() { + return 50; + }}); +; +window.WalkontableViewportColumnsCalculator = WalkontableViewportColumnsCalculator; + +//# +},{}],4:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableViewportRowsCalculator: {get: function() { + return WalkontableViewportRowsCalculator; + }}, + __esModule: {value: true} +}); +var privatePool = new WeakMap(); +var WalkontableViewportRowsCalculator = function WalkontableViewportRowsCalculator(viewportHeight, scrollOffset, totalRows, rowHeightFn, overrideFn, onlyFullyVisible) { + privatePool.set(this, { + viewportHeight: viewportHeight, + scrollOffset: scrollOffset, + totalRows: totalRows, + rowHeightFn: rowHeightFn, + overrideFn: overrideFn, + onlyFullyVisible: onlyFullyVisible + }); + this.count = 0; + this.startRow = null; + this.endRow = null; + this.startPosition = null; + this.calculate(); +}; +var $WalkontableViewportRowsCalculator = WalkontableViewportRowsCalculator; +($traceurRuntime.createClass)(WalkontableViewportRowsCalculator, {calculate: function() { + var sum = 0; + var needReverse = true; + var startPositions = []; + var priv = privatePool.get(this); + var onlyFullyVisible = priv.onlyFullyVisible; + var overrideFn = priv.overrideFn; + var rowHeightFn = priv.rowHeightFn; + var scrollOffset = priv.scrollOffset; + var totalRows = priv.totalRows; + var viewportHeight = priv.viewportHeight; + for (var i = 0; i < totalRows; i++) { + var rowHeight = rowHeightFn(i); + if (rowHeight === undefined) { + rowHeight = $WalkontableViewportRowsCalculator.DEFAULT_HEIGHT; + } + if (sum <= scrollOffset && !onlyFullyVisible) { + this.startRow = i; + } + if (sum >= scrollOffset && sum + rowHeight <= scrollOffset + viewportHeight) { + if (this.startRow === null) { + this.startRow = i; + } + this.endRow = i; + } + startPositions.push(sum); + sum += rowHeight; + if (!onlyFullyVisible) { + this.endRow = i; + } + if (sum >= scrollOffset + viewportHeight) { + needReverse = false; + break; + } + } + if (this.endRow === totalRows - 1 && needReverse) { + this.startRow = this.endRow; + while (this.startRow > 0) { + var viewportSum = startPositions[this.endRow] + rowHeight - startPositions[this.startRow - 1]; + if (viewportSum <= viewportHeight || !onlyFullyVisible) { + this.startRow--; + } + if (viewportSum >= viewportHeight) { + break; + } + } + } + if (this.startRow !== null && overrideFn) { + overrideFn(this); + } + this.startPosition = startPositions[this.startRow]; + if (this.startPosition == void 0) { + this.startPosition = null; + } + if (this.startRow !== null) { + this.count = this.endRow - this.startRow + 1; + } + }}, {get DEFAULT_HEIGHT() { + return 23; + }}); +; +window.WalkontableViewportRowsCalculator = WalkontableViewportRowsCalculator; + +//# +},{}],5:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableCellCoords: {get: function() { + return WalkontableCellCoords; + }}, + __esModule: {value: true} +}); +var WalkontableCellCoords = function WalkontableCellCoords(row, col) { + if (typeof row !== 'undefined' && typeof col !== 'undefined') { + this.row = row; + this.col = col; + } else { + this.row = null; + this.col = null; + } +}; +($traceurRuntime.createClass)(WalkontableCellCoords, { + isValid: function(wotInstance) { + if (this.row < 0 || this.col < 0) { + return false; + } + if (this.row >= wotInstance.getSetting('totalRows') || this.col >= wotInstance.getSetting('totalColumns')) { + return false; + } + return true; + }, + isEqual: function(cellCoords) { + if (cellCoords === this) { + return true; + } + return this.row === cellCoords.row && this.col === cellCoords.col; + }, + isSouthEastOf: function(testedCoords) { + return this.row >= testedCoords.row && this.col >= testedCoords.col; + }, + isNorthWestOf: function(testedCoords) { + return this.row <= testedCoords.row && this.col <= testedCoords.col; + }, + isSouthWestOf: function(testedCoords) { + return this.row >= testedCoords.row && this.col <= testedCoords.col; + }, + isNorthEastOf: function(testedCoords) { + return this.row <= testedCoords.row && this.col >= testedCoords.col; + } +}, {}); +; +window.WalkontableCellCoords = WalkontableCellCoords; + +//# +},{}],6:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableCellRange: {get: function() { + return WalkontableCellRange; + }}, + __esModule: {value: true} +}); +var $___46__46__47_cell_47_coords_46_js__; +var WalkontableCellCoords = ($___46__46__47_cell_47_coords_46_js__ = require("cell/coords.js"), $___46__46__47_cell_47_coords_46_js__ && $___46__46__47_cell_47_coords_46_js__.__esModule && $___46__46__47_cell_47_coords_46_js__ || {default: $___46__46__47_cell_47_coords_46_js__}).WalkontableCellCoords; +var WalkontableCellRange = function WalkontableCellRange(highlight, from, to) { + this.highlight = highlight; + this.from = from; + this.to = to; +}; +var $WalkontableCellRange = WalkontableCellRange; +($traceurRuntime.createClass)(WalkontableCellRange, { + isValid: function(wotInstance) { + return this.from.isValid(wotInstance) && this.to.isValid(wotInstance); + }, + isSingle: function() { + return this.from.row === this.to.row && this.from.col === this.to.col; + }, + getHeight: function() { + return Math.max(this.from.row, this.to.row) - Math.min(this.from.row, this.to.row) + 1; + }, + getWidth: function() { + return Math.max(this.from.col, this.to.col) - Math.min(this.from.col, this.to.col) + 1; + }, + includes: function(cellCoords) { + var topLeft = this.getTopLeftCorner(); + var bottomRight = this.getBottomRightCorner(); + if (cellCoords.row < 0) { + cellCoords.row = 0; + } + if (cellCoords.col < 0) { + cellCoords.col = 0; + } + return topLeft.row <= cellCoords.row && bottomRight.row >= cellCoords.row && topLeft.col <= cellCoords.col && bottomRight.col >= cellCoords.col; + }, + includesRange: function(testedRange) { + return this.includes(testedRange.getTopLeftCorner()) && this.includes(testedRange.getBottomRightCorner()); + }, + isEqual: function(testedRange) { + return (Math.min(this.from.row, this.to.row) == Math.min(testedRange.from.row, testedRange.to.row)) && (Math.max(this.from.row, this.to.row) == Math.max(testedRange.from.row, testedRange.to.row)) && (Math.min(this.from.col, this.to.col) == Math.min(testedRange.from.col, testedRange.to.col)) && (Math.max(this.from.col, this.to.col) == Math.max(testedRange.from.col, testedRange.to.col)); + }, + overlaps: function(testedRange) { + return testedRange.isSouthEastOf(this.getTopLeftCorner()) && testedRange.isNorthWestOf(this.getBottomRightCorner()); + }, + isSouthEastOf: function(testedCoords) { + return this.getTopLeftCorner().isSouthEastOf(testedCoords) || this.getBottomRightCorner().isSouthEastOf(testedCoords); + }, + isNorthWestOf: function(testedCoords) { + return this.getTopLeftCorner().isNorthWestOf(testedCoords) || this.getBottomRightCorner().isNorthWestOf(testedCoords); + }, + expand: function(cellCoords) { + var topLeft = this.getTopLeftCorner(); + var bottomRight = this.getBottomRightCorner(); + if (cellCoords.row < topLeft.row || cellCoords.col < topLeft.col || cellCoords.row > bottomRight.row || cellCoords.col > bottomRight.col) { + this.from = new WalkontableCellCoords(Math.min(topLeft.row, cellCoords.row), Math.min(topLeft.col, cellCoords.col)); + this.to = new WalkontableCellCoords(Math.max(bottomRight.row, cellCoords.row), Math.max(bottomRight.col, cellCoords.col)); + return true; + } + return false; + }, + expandByRange: function(expandingRange) { + if (this.includesRange(expandingRange) || !this.overlaps(expandingRange)) { + return false; + } + var topLeft = this.getTopLeftCorner(); + var bottomRight = this.getBottomRightCorner(); + var topRight = this.getTopRightCorner(); + var bottomLeft = this.getBottomLeftCorner(); + var expandingTopLeft = expandingRange.getTopLeftCorner(); + var expandingBottomRight = expandingRange.getBottomRightCorner(); + var resultTopRow = Math.min(topLeft.row, expandingTopLeft.row); + var resultTopCol = Math.min(topLeft.col, expandingTopLeft.col); + var resultBottomRow = Math.max(bottomRight.row, expandingBottomRight.row); + var resultBottomCol = Math.max(bottomRight.col, expandingBottomRight.col); + var finalFrom = new WalkontableCellCoords(resultTopRow, resultTopCol), + finalTo = new WalkontableCellCoords(resultBottomRow, resultBottomCol); + var isCorner = new $WalkontableCellRange(finalFrom, finalFrom, finalTo).isCorner(this.from, expandingRange), + onlyMerge = expandingRange.isEqual(new $WalkontableCellRange(finalFrom, finalFrom, finalTo)); + if (isCorner && !onlyMerge) { + if (this.from.col > finalFrom.col) { + finalFrom.col = resultBottomCol; + finalTo.col = resultTopCol; + } + if (this.from.row > finalFrom.row) { + finalFrom.row = resultBottomRow; + finalTo.row = resultTopRow; + } + } + this.from = finalFrom; + this.to = finalTo; + return true; + }, + getDirection: function() { + if (this.from.isNorthWestOf(this.to)) { + return 'NW-SE'; + } else if (this.from.isNorthEastOf(this.to)) { + return 'NE-SW'; + } else if (this.from.isSouthEastOf(this.to)) { + return 'SE-NW'; + } else if (this.from.isSouthWestOf(this.to)) { + return 'SW-NE'; + } + }, + setDirection: function(direction) { + switch (direction) { + case 'NW-SE': + this.from = this.getTopLeftCorner(); + this.to = this.getBottomRightCorner(); + break; + case 'NE-SW': + this.from = this.getTopRightCorner(); + this.to = this.getBottomLeftCorner(); + break; + case 'SE-NW': + this.from = this.getBottomRightCorner(); + this.to = this.getTopLeftCorner(); + break; + case 'SW-NE': + this.from = this.getBottomLeftCorner(); + this.to = this.getTopRightCorner(); + break; + } + }, + getTopLeftCorner: function() { + return new WalkontableCellCoords(Math.min(this.from.row, this.to.row), Math.min(this.from.col, this.to.col)); + }, + getBottomRightCorner: function() { + return new WalkontableCellCoords(Math.max(this.from.row, this.to.row), Math.max(this.from.col, this.to.col)); + }, + getTopRightCorner: function() { + return new WalkontableCellCoords(Math.min(this.from.row, this.to.row), Math.max(this.from.col, this.to.col)); + }, + getBottomLeftCorner: function() { + return new WalkontableCellCoords(Math.max(this.from.row, this.to.row), Math.min(this.from.col, this.to.col)); + }, + isCorner: function(coords, expandedRange) { + if (expandedRange) { + if (expandedRange.includes(coords)) { + if (this.getTopLeftCorner().isEqual(new WalkontableCellCoords(expandedRange.from.row, expandedRange.from.col)) || this.getTopRightCorner().isEqual(new WalkontableCellCoords(expandedRange.from.row, expandedRange.to.col)) || this.getBottomLeftCorner().isEqual(new WalkontableCellCoords(expandedRange.to.row, expandedRange.from.col)) || this.getBottomRightCorner().isEqual(new WalkontableCellCoords(expandedRange.to.row, expandedRange.to.col))) { + return true; + } + } + } + return coords.isEqual(this.getTopLeftCorner()) || coords.isEqual(this.getTopRightCorner()) || coords.isEqual(this.getBottomLeftCorner()) || coords.isEqual(this.getBottomRightCorner()); + }, + getOppositeCorner: function(coords, expandedRange) { + if (!(coords instanceof WalkontableCellCoords)) { + return false; + } + if (expandedRange) { + if (expandedRange.includes(coords)) { + if (this.getTopLeftCorner().isEqual(new WalkontableCellCoords(expandedRange.from.row, expandedRange.from.col))) { + return this.getBottomRightCorner(); + } + if (this.getTopRightCorner().isEqual(new WalkontableCellCoords(expandedRange.from.row, expandedRange.to.col))) { + return this.getBottomLeftCorner(); + } + if (this.getBottomLeftCorner().isEqual(new WalkontableCellCoords(expandedRange.to.row, expandedRange.from.col))) { + return this.getTopRightCorner(); + } + if (this.getBottomRightCorner().isEqual(new WalkontableCellCoords(expandedRange.to.row, expandedRange.to.col))) { + return this.getTopLeftCorner(); + } + } + } + if (coords.isEqual(this.getBottomRightCorner())) { + return this.getTopLeftCorner(); + } else if (coords.isEqual(this.getTopLeftCorner())) { + return this.getBottomRightCorner(); + } else if (coords.isEqual(this.getTopRightCorner())) { + return this.getBottomLeftCorner(); + } else if (coords.isEqual(this.getBottomLeftCorner())) { + return this.getTopRightCorner(); + } + }, + getBordersSharedWith: function(range) { + if (!this.includesRange(range)) { + return []; + } + var thisBorders = { + top: Math.min(this.from.row, this.to.row), + bottom: Math.max(this.from.row, this.to.row), + left: Math.min(this.from.col, this.to.col), + right: Math.max(this.from.col, this.to.col) + }; + var rangeBorders = { + top: Math.min(range.from.row, range.to.row), + bottom: Math.max(range.from.row, range.to.row), + left: Math.min(range.from.col, range.to.col), + right: Math.max(range.from.col, range.to.col) + }; + var result = []; + if (thisBorders.top == rangeBorders.top) { + result.push('top'); + } + if (thisBorders.right == rangeBorders.right) { + result.push('right'); + } + if (thisBorders.bottom == rangeBorders.bottom) { + result.push('bottom'); + } + if (thisBorders.left == rangeBorders.left) { + result.push('left'); + } + return result; + }, + getInner: function() { + var topLeft = this.getTopLeftCorner(); + var bottomRight = this.getBottomRightCorner(); + var out = []; + for (var r = topLeft.row; r <= bottomRight.row; r++) { + for (var c = topLeft.col; c <= bottomRight.col; c++) { + if (!(this.from.row === r && this.from.col === c) && !(this.to.row === r && this.to.col === c)) { + out.push(new WalkontableCellCoords(r, c)); + } + } + } + return out; + }, + getAll: function() { + var topLeft = this.getTopLeftCorner(); + var bottomRight = this.getBottomRightCorner(); + var out = []; + for (var r = topLeft.row; r <= bottomRight.row; r++) { + for (var c = topLeft.col; c <= bottomRight.col; c++) { + if (topLeft.row === r && topLeft.col === c) { + out.push(topLeft); + } else if (bottomRight.row === r && bottomRight.col === c) { + out.push(bottomRight); + } else { + out.push(new WalkontableCellCoords(r, c)); + } + } + } + return out; + }, + forAll: function(callback) { + var topLeft = this.getTopLeftCorner(); + var bottomRight = this.getBottomRightCorner(); + for (var r = topLeft.row; r <= bottomRight.row; r++) { + for (var c = topLeft.col; c <= bottomRight.col; c++) { + var breakIteration = callback(r, c); + if (breakIteration === false) { + return; + } + } + } + } +}, {}); +; +window.WalkontableCellRange = WalkontableCellRange; + +//# +},{"cell/coords.js":5}],7:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + Walkontable: {get: function() { + return Walkontable; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47__46__46__47_helpers_46_js__, + $___46__46__47__46__46__47__46__46__47_helpers_46_js__, + $__event_46_js__, + $__overlays_46_js__, + $__scroll_46_js__, + $__settings_46_js__, + $__table_46_js__, + $__viewport_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_dom_46_js__}); +var $__0 = ($___46__46__47__46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_helpers_46_js__}), + objectEach = $__0.objectEach, + toUpperCaseFirst = $__0.toUpperCaseFirst; +var randomString = ($___46__46__47__46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_helpers_46_js__}).randomString; +var WalkontableEvent = ($__event_46_js__ = require("event.js"), $__event_46_js__ && $__event_46_js__.__esModule && $__event_46_js__ || {default: $__event_46_js__}).WalkontableEvent; +var WalkontableOverlays = ($__overlays_46_js__ = require("overlays.js"), $__overlays_46_js__ && $__overlays_46_js__.__esModule && $__overlays_46_js__ || {default: $__overlays_46_js__}).WalkontableOverlays; +var WalkontableScroll = ($__scroll_46_js__ = require("scroll.js"), $__scroll_46_js__ && $__scroll_46_js__.__esModule && $__scroll_46_js__ || {default: $__scroll_46_js__}).WalkontableScroll; +var WalkontableSettings = ($__settings_46_js__ = require("settings.js"), $__settings_46_js__ && $__settings_46_js__.__esModule && $__settings_46_js__ || {default: $__settings_46_js__}).WalkontableSettings; +var WalkontableTable = ($__table_46_js__ = require("table.js"), $__table_46_js__ && $__table_46_js__.__esModule && $__table_46_js__ || {default: $__table_46_js__}).WalkontableTable; +var WalkontableViewport = ($__viewport_46_js__ = require("viewport.js"), $__viewport_46_js__ && $__viewport_46_js__.__esModule && $__viewport_46_js__ || {default: $__viewport_46_js__}).WalkontableViewport; +var Walkontable = function Walkontable(settings) { + var originalHeaders = []; + this.guid = 'wt_' + randomString(); + if (settings.cloneSource) { + this.cloneSource = settings.cloneSource; + this.cloneOverlay = settings.cloneOverlay; + this.wtSettings = settings.cloneSource.wtSettings; + this.wtTable = new WalkontableTable(this, settings.table, settings.wtRootElement); + this.wtScroll = new WalkontableScroll(this); + this.wtViewport = settings.cloneSource.wtViewport; + this.wtEvent = new WalkontableEvent(this); + this.selections = this.cloneSource.selections; + } else { + this.wtSettings = new WalkontableSettings(this, settings); + this.wtTable = new WalkontableTable(this, settings.table); + this.wtScroll = new WalkontableScroll(this); + this.wtViewport = new WalkontableViewport(this); + this.wtEvent = new WalkontableEvent(this); + this.selections = this.getSetting('selections'); + this.wtOverlays = new WalkontableOverlays(this); + this.exportSettingsAsClassNames(); + } + if (this.wtTable.THEAD.childNodes.length && this.wtTable.THEAD.childNodes[0].childNodes.length) { + for (var c = 0, + clen = this.wtTable.THEAD.childNodes[0].childNodes.length; c < clen; c++) { + originalHeaders.push(this.wtTable.THEAD.childNodes[0].childNodes[c].innerHTML); + } + if (!this.getSetting('columnHeaders').length) { + this.update('columnHeaders', [function(column, TH) { + dom.fastInnerText(TH, originalHeaders[column]); + }]); + } + } + this.drawn = false; + this.drawInterrupted = false; +}; +($traceurRuntime.createClass)(Walkontable, { + draw: function() { + var fastDraw = arguments[0] !== (void 0) ? arguments[0] : false; + this.drawInterrupted = false; + if (!fastDraw && !dom.isVisible(this.wtTable.TABLE)) { + this.drawInterrupted = true; + } else { + this.wtTable.draw(fastDraw); + } + return this; + }, + getCell: function(coords) { + var topmost = arguments[1] !== (void 0) ? arguments[1] : false; + if (!topmost) { + return this.wtTable.getCell(coords); + } + var fixedRows = this.wtSettings.getSetting('fixedRowsTop'); + var fixedColumns = this.wtSettings.getSetting('fixedColumnsLeft'); + if (coords.row < fixedRows && coords.col < fixedColumns) { + return this.wtOverlays.topLeftCornerOverlay.clone.wtTable.getCell(coords); + } else if (coords.row < fixedRows) { + return this.wtOverlays.topOverlay.clone.wtTable.getCell(coords); + } else if (coords.col < fixedColumns) { + return this.wtOverlays.leftOverlay.clone.wtTable.getCell(coords); + } + return this.wtTable.getCell(coords); + }, + update: function(settings, value) { + return this.wtSettings.update(settings, value); + }, + scrollVertical: function(row) { + this.wtOverlays.topOverlay.scrollTo(row); + this.getSetting('onScrollVertically'); + return this; + }, + scrollHorizontal: function(column) { + this.wtOverlays.leftOverlay.scrollTo(column); + this.getSetting('onScrollHorizontally'); + return this; + }, + scrollViewport: function(coords) { + this.wtScroll.scrollViewport(coords); + return this; + }, + getViewport: function() { + return [this.wtTable.getFirstVisibleRow(), this.wtTable.getFirstVisibleColumn(), this.wtTable.getLastVisibleRow(), this.wtTable.getLastVisibleColumn()]; + }, + getOverlayName: function() { + return this.cloneOverlay ? this.cloneOverlay.type : 'master'; + }, + exportSettingsAsClassNames: function() { + var $__8 = this; + var toExport = { + rowHeaders: ['array'], + columnHeaders: ['array'] + }; + var allClassNames = []; + var newClassNames = []; + objectEach(toExport, (function(optionType, key) { + if (optionType.indexOf('array') > -1 && $__8.getSetting(key).length) { + newClassNames.push('ht' + toUpperCaseFirst(key)); + } + allClassNames.push('ht' + toUpperCaseFirst(key)); + })); + dom.removeClass(this.wtTable.wtRootElement.parentNode, allClassNames); + dom.addClass(this.wtTable.wtRootElement.parentNode, newClassNames); + }, + getSetting: function(key, param1, param2, param3, param4) { + return this.wtSettings.getSetting(key, param1, param2, param3, param4); + }, + hasSetting: function(key) { + return this.wtSettings.has(key); + }, + destroy: function() { + this.wtOverlays.destroy(); + this.wtEvent.destroy(); + } +}, {}); +; +window.Walkontable = Walkontable; + +//# +},{"dom.js":27,"event.js":8,"helpers.js":42,"overlays.js":16,"scroll.js":17,"settings.js":19,"table.js":20,"viewport.js":22}],8:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableEvent: {get: function() { + return WalkontableEvent; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47__46__46__47_eventManager_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_dom_46_js__}); +var eventManagerObject = ($___46__46__47__46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_eventManager_46_js__}).eventManager; +function WalkontableEvent(instance) { + var that = this; + var eventManager = eventManagerObject(instance); + this.instance = instance; + var dblClickOrigin = [null, null]; + this.dblClickTimeout = [null, null]; + var onMouseDown = function(event) { + var cell = that.parentCell(event.realTarget); + if (dom.hasClass(event.realTarget, 'corner')) { + that.instance.getSetting('onCellCornerMouseDown', event, event.realTarget); + } else if (cell.TD) { + if (that.instance.hasSetting('onCellMouseDown')) { + that.instance.getSetting('onCellMouseDown', event, cell.coords, cell.TD, that.instance); + } + } + if (event.button !== 2) { + if (cell.TD) { + dblClickOrigin[0] = cell.TD; + clearTimeout(that.dblClickTimeout[0]); + that.dblClickTimeout[0] = setTimeout(function() { + dblClickOrigin[0] = null; + }, 1000); + } + } + }; + var onTouchMove = function(event) { + that.instance.touchMoving = true; + }; + var longTouchTimeout; + var onTouchStart = function(event) { + var container = this; + eventManager.addEventListener(this, 'touchmove', onTouchMove); + that.checkIfTouchMove = setTimeout(function() { + if (that.instance.touchMoving === true) { + that.instance.touchMoving = void 0; + eventManager.removeEventListener("touchmove", onTouchMove, false); + return; + } else { + onMouseDown(event); + } + }, 30); + }; + var lastMouseOver; + var onMouseOver = function(event) { + var table, + td; + if (that.instance.hasSetting('onCellMouseOver')) { + table = that.instance.wtTable.TABLE; + td = dom.closest(event.realTarget, ['TD', 'TH'], table); + if (td && td !== lastMouseOver && dom.isChildOf(td, table)) { + lastMouseOver = td; + that.instance.getSetting('onCellMouseOver', event, that.instance.wtTable.getCoords(td), td, that.instance); + } + } + }; + var onMouseUp = function(event) { + if (event.button !== 2) { + var cell = that.parentCell(event.realTarget); + if (cell.TD === dblClickOrigin[0] && cell.TD === dblClickOrigin[1]) { + if (dom.hasClass(event.realTarget, 'corner')) { + that.instance.getSetting('onCellCornerDblClick', event, cell.coords, cell.TD, that.instance); + } else { + that.instance.getSetting('onCellDblClick', event, cell.coords, cell.TD, that.instance); + } + dblClickOrigin[0] = null; + dblClickOrigin[1] = null; + } else if (cell.TD === dblClickOrigin[0]) { + dblClickOrigin[1] = cell.TD; + clearTimeout(that.dblClickTimeout[1]); + that.dblClickTimeout[1] = setTimeout(function() { + dblClickOrigin[1] = null; + }, 500); + } + } + }; + var onTouchEnd = function(event) { + clearTimeout(longTouchTimeout); + event.preventDefault(); + onMouseUp(event); + }; + eventManager.addEventListener(this.instance.wtTable.holder, 'mousedown', onMouseDown); + eventManager.addEventListener(this.instance.wtTable.TABLE, 'mouseover', onMouseOver); + eventManager.addEventListener(this.instance.wtTable.holder, 'mouseup', onMouseUp); + if (this.instance.wtTable.holder.parentNode.parentNode && Handsontable.mobileBrowser && !that.instance.wtTable.isWorkingOnClone()) { + var classSelector = "." + this.instance.wtTable.holder.parentNode.className.split(" ").join("."); + eventManager.addEventListener(this.instance.wtTable.holder, 'touchstart', function(event) { + that.instance.touchApplied = true; + if (dom.isChildOf(event.target, classSelector)) { + onTouchStart.call(event.target, event); + } + }); + eventManager.addEventListener(this.instance.wtTable.holder, 'touchend', function(event) { + that.instance.touchApplied = false; + if (dom.isChildOf(event.target, classSelector)) { + onTouchEnd.call(event.target, event); + } + }); + if (!that.instance.momentumScrolling) { + that.instance.momentumScrolling = {}; + } + eventManager.addEventListener(this.instance.wtTable.holder, 'scroll', function(event) { + clearTimeout(that.instance.momentumScrolling._timeout); + if (!that.instance.momentumScrolling.ongoing) { + that.instance.getSetting('onBeforeTouchScroll'); + } + that.instance.momentumScrolling.ongoing = true; + that.instance.momentumScrolling._timeout = setTimeout(function() { + if (!that.instance.touchApplied) { + that.instance.momentumScrolling.ongoing = false; + that.instance.getSetting('onAfterMomentumScroll'); + } + }, 200); + }); + } + eventManager.addEventListener(window, 'resize', function() { + if (that.instance.getSetting('stretchH') !== 'none') { + that.instance.draw(); + } + }); + this.destroy = function() { + clearTimeout(this.dblClickTimeout[0]); + clearTimeout(this.dblClickTimeout[1]); + eventManager.destroy(); + }; +} +WalkontableEvent.prototype.parentCell = function(elem) { + var cell = {}; + var TABLE = this.instance.wtTable.TABLE; + var TD = dom.closest(elem, ['TD', 'TH'], TABLE); + if (TD && dom.isChildOf(TD, TABLE)) { + cell.coords = this.instance.wtTable.getCoords(TD); + cell.TD = TD; + } else if (dom.hasClass(elem, 'wtBorder') && dom.hasClass(elem, 'current')) { + cell.coords = this.instance.selections.current.cellRange.highlight; + cell.TD = this.instance.wtTable.getCell(cell.coords); + } else if (dom.hasClass(elem, 'wtBorder') && dom.hasClass(elem, 'area')) { + if (this.instance.selections.area.cellRange) { + cell.coords = this.instance.selections.area.cellRange.to; + cell.TD = this.instance.wtTable.getCell(cell.coords); + } + } + return cell; +}; +; +window.WalkontableEvent = WalkontableEvent; + +//# +},{"dom.js":27,"eventManager.js":41}],9:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableColumnFilter: {get: function() { + return WalkontableColumnFilter; + }}, + __esModule: {value: true} +}); +var WalkontableColumnFilter = function WalkontableColumnFilter(offset, total, countTH) { + this.offset = offset; + this.total = total; + this.countTH = countTH; +}; +($traceurRuntime.createClass)(WalkontableColumnFilter, { + offsetted: function(index) { + return index + this.offset; + }, + unOffsetted: function(index) { + return index - this.offset; + }, + renderedToSource: function(index) { + return this.offsetted(index); + }, + sourceToRendered: function(index) { + return this.unOffsetted(index); + }, + offsettedTH: function(index) { + return index - this.countTH; + }, + unOffsettedTH: function(index) { + return index + this.countTH; + }, + visibleRowHeadedColumnToSourceColumn: function(index) { + return this.renderedToSource(this.offsettedTH(index)); + }, + sourceColumnToVisibleRowHeadedColumn: function(index) { + return this.unOffsettedTH(this.sourceToRendered(index)); + } +}, {}); +; +window.WalkontableColumnFilter = WalkontableColumnFilter; + +//# +},{}],10:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableRowFilter: {get: function() { + return WalkontableRowFilter; + }}, + __esModule: {value: true} +}); +var WalkontableRowFilter = function WalkontableRowFilter(offset, total, countTH) { + this.offset = offset; + this.total = total; + this.countTH = countTH; +}; +($traceurRuntime.createClass)(WalkontableRowFilter, { + offsetted: function(index) { + return index + this.offset; + }, + unOffsetted: function(index) { + return index - this.offset; + }, + renderedToSource: function(index) { + return this.offsetted(index); + }, + sourceToRendered: function(index) { + return this.unOffsetted(index); + }, + offsettedTH: function(index) { + return index - this.countTH; + }, + unOffsettedTH: function(index) { + return index + this.countTH; + }, + visibleColHeadedRowToSourceRow: function(index) { + return this.renderedToSource(this.offsettedTH(index)); + }, + sourceRowToVisibleColHeadedRow: function(index) { + return this.unOffsettedTH(this.sourceToRendered(index)); + } +}, {}); +; +window.WalkontableRowFilter = WalkontableRowFilter; + +//# +},{}],11:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableOverlay: {get: function() { + return WalkontableOverlay; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47__46__46__47__46__46__47_helpers_46_js__, + $___46__46__47__46__46__47__46__46__47__46__46__47_eventManager_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__}); +var defineGetter = ($___46__46__47__46__46__47__46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47__46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47__46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47__46__46__47__46__46__47_helpers_46_js__}).defineGetter; +var eventManagerObject = ($___46__46__47__46__46__47__46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47__46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47__46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47__46__46__47__46__46__47_eventManager_46_js__}).eventManager; +var WalkontableOverlay = function WalkontableOverlay(wotInstance) { + defineGetter(this, 'wot', wotInstance, {writable: false}); + this.instance = this.wot; + this.type = ''; + this.TABLE = this.wot.wtTable.TABLE; + this.hider = this.wot.wtTable.hider; + this.spreader = this.wot.wtTable.spreader; + this.holder = this.wot.wtTable.holder; + this.wtRootElement = this.wot.wtTable.wtRootElement; + this.trimmingContainer = dom.getTrimmingContainer(this.hider.parentNode.parentNode); + this.mainTableScrollableElement = dom.getScrollableElement(this.wot.wtTable.TABLE); + this.needFullRender = this.shouldBeRendered(); + this.isElementSizesAdjusted = false; +}; +var $WalkontableOverlay = WalkontableOverlay; +($traceurRuntime.createClass)(WalkontableOverlay, { + shouldBeRendered: function() { + return true; + }, + makeClone: function(direction) { + if ($WalkontableOverlay.CLONE_TYPES.indexOf(direction) === -1) { + throw new Error('Clone type "' + direction + '" is not supported.'); + } + var clone = document.createElement('DIV'); + var clonedTable = document.createElement('TABLE'); + clone.className = 'ht_clone_' + direction + ' handsontable'; + clone.style.position = 'absolute'; + clone.style.top = 0; + clone.style.left = 0; + clone.style.overflow = 'hidden'; + clonedTable.className = this.wot.wtTable.TABLE.className; + clone.appendChild(clonedTable); + this.type = direction; + this.wot.wtTable.wtRootElement.parentNode.appendChild(clone); + return new Walkontable({ + cloneSource: this.wot, + cloneOverlay: this, + table: clonedTable + }); + }, + refresh: function() { + var fastDraw = arguments[0] !== (void 0) ? arguments[0] : false; + var nextCycleRenderFlag = this.shouldBeRendered(); + if (this.clone && (this.needFullRender || nextCycleRenderFlag)) { + this.clone.draw(fastDraw); + } + this.needFullRender = nextCycleRenderFlag; + }, + destroy: function() { + eventManagerObject(this.clone).destroy(); + } +}, { + get CLONE_TOP() { + return 'top'; + }, + get CLONE_LEFT() { + return 'left'; + }, + get CLONE_CORNER() { + return 'corner'; + }, + get CLONE_DEBUG() { + return 'debug'; + }, + get CLONE_TYPES() { + return [$WalkontableOverlay.CLONE_TOP, $WalkontableOverlay.CLONE_LEFT, $WalkontableOverlay.CLONE_CORNER, $WalkontableOverlay.CLONE_DEBUG]; + } +}); +; +window.WalkontableOverlay = WalkontableOverlay; + +//# +},{"dom.js":27,"eventManager.js":41,"helpers.js":42}],12:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableCornerOverlay: {get: function() { + return WalkontableCornerOverlay; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__, + $___95_base_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__}); +var WalkontableOverlay = ($___95_base_46_js__ = require("_base.js"), $___95_base_46_js__ && $___95_base_46_js__.__esModule && $___95_base_46_js__ || {default: $___95_base_46_js__}).WalkontableOverlay; +var WalkontableCornerOverlay = function WalkontableCornerOverlay(wotInstance) { + $traceurRuntime.superConstructor($WalkontableCornerOverlay).call(this, wotInstance); + this.clone = this.makeClone(WalkontableOverlay.CLONE_CORNER); +}; +var $WalkontableCornerOverlay = WalkontableCornerOverlay; +($traceurRuntime.createClass)(WalkontableCornerOverlay, { + shouldBeRendered: function() { + return (this.wot.getSetting('fixedRowsTop') || this.wot.getSetting('columnHeaders').length) && (this.wot.getSetting('fixedColumnsLeft') || this.wot.getSetting('rowHeaders').length) ? true : false; + }, + resetFixedPosition: function() { + if (!this.wot.wtTable.holder.parentNode) { + return; + } + var overlayRoot = this.clone.wtTable.holder.parentNode; + var tableHeight = dom.outerHeight(this.clone.wtTable.TABLE); + var tableWidth = dom.outerWidth(this.clone.wtTable.TABLE); + if (this.trimmingContainer === window) { + var box = this.wot.wtTable.hider.getBoundingClientRect(); + var top = Math.ceil(box.top); + var left = Math.ceil(box.left); + var bottom = Math.ceil(box.bottom); + var right = Math.ceil(box.right); + var finalLeft; + var finalTop; + if (left < 0 && (right - overlayRoot.offsetWidth) > 0) { + finalLeft = -left + 'px'; + } else { + finalLeft = '0'; + } + if (top < 0 && (bottom - overlayRoot.offsetHeight) > 0) { + finalTop = -top + 'px'; + } else { + finalTop = '0'; + } + dom.setOverlayPosition(overlayRoot, finalLeft, finalTop); + } + overlayRoot.style.height = (tableHeight === 0 ? tableHeight : tableHeight + 4) + 'px'; + overlayRoot.style.width = (tableWidth === 0 ? tableWidth : tableWidth + 4) + 'px'; + } +}, {}, WalkontableOverlay); +; +window.WalkontableCornerOverlay = WalkontableCornerOverlay; + +//# +},{"_base.js":11,"dom.js":27}],13:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableDebugOverlay: {get: function() { + return WalkontableDebugOverlay; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__, + $___95_base_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__}); +var WalkontableOverlay = ($___95_base_46_js__ = require("_base.js"), $___95_base_46_js__ && $___95_base_46_js__.__esModule && $___95_base_46_js__ || {default: $___95_base_46_js__}).WalkontableOverlay; +var WalkontableDebugOverlay = function WalkontableDebugOverlay(wotInstance) { + $traceurRuntime.superConstructor($WalkontableDebugOverlay).call(this, wotInstance); + this.clone = this.makeClone(WalkontableOverlay.CLONE_DEBUG); + this.clone.wtTable.holder.style.opacity = 0.4; + this.clone.wtTable.holder.style.textShadow = '0 0 2px #ff0000'; + dom.addClass(this.clone.wtTable.holder.parentNode, 'wtDebugVisible'); +}; +var $WalkontableDebugOverlay = WalkontableDebugOverlay; +($traceurRuntime.createClass)(WalkontableDebugOverlay, {}, {}, WalkontableOverlay); +; +window.WalkontableDebugOverlay = WalkontableDebugOverlay; + +//# +},{"_base.js":11,"dom.js":27}],14:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableLeftOverlay: {get: function() { + return WalkontableLeftOverlay; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__, + $___95_base_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__}); +var WalkontableOverlay = ($___95_base_46_js__ = require("_base.js"), $___95_base_46_js__ && $___95_base_46_js__.__esModule && $___95_base_46_js__ || {default: $___95_base_46_js__}).WalkontableOverlay; +var WalkontableLeftOverlay = function WalkontableLeftOverlay(wotInstance) { + $traceurRuntime.superConstructor($WalkontableLeftOverlay).call(this, wotInstance); + this.clone = this.makeClone(WalkontableOverlay.CLONE_LEFT); +}; +var $WalkontableLeftOverlay = WalkontableLeftOverlay; +($traceurRuntime.createClass)(WalkontableLeftOverlay, { + shouldBeRendered: function() { + return this.wot.getSetting('fixedColumnsLeft') || this.wot.getSetting('rowHeaders').length ? true : false; + }, + resetFixedPosition: function() { + if (!this.needFullRender || !this.wot.wtTable.holder.parentNode) { + return; + } + var overlayRoot = this.clone.wtTable.holder.parentNode; + var headerPosition = 0; + if (this.trimmingContainer === window) { + var box = this.wot.wtTable.hider.getBoundingClientRect(); + var left = Math.ceil(box.left); + var right = Math.ceil(box.right); + var finalLeft; + var finalTop; + finalTop = this.wot.wtTable.hider.style.top; + finalTop = finalTop === '' ? 0 : finalTop; + if (left < 0 && (right - overlayRoot.offsetWidth) > 0) { + finalLeft = -left; + } else { + finalLeft = 0; + } + headerPosition = finalLeft; + finalLeft = finalLeft + 'px'; + dom.setOverlayPosition(overlayRoot, finalLeft, finalTop); + } else { + headerPosition = this.getScrollPosition(); + } + this.adjustHeaderBordersPosition(headerPosition); + }, + setScrollPosition: function(pos) { + if (this.mainTableScrollableElement === window) { + window.scrollTo(pos, dom.getWindowScrollTop()); + } else { + this.mainTableScrollableElement.scrollLeft = pos; + } + }, + onScroll: function() { + this.wot.getSetting('onScrollHorizontally'); + }, + sumCellSizes: function(from, to) { + var sum = 0; + var defaultColumnWidth = this.wot.wtSettings.defaultColumnWidth; + while (from < to) { + sum += this.wot.wtTable.getStretchedColumnWidth(from) || defaultColumnWidth; + from++; + } + return sum; + }, + adjustElementsSize: function() { + var force = arguments[0] !== (void 0) ? arguments[0] : false; + if (this.needFullRender || force) { + this.adjustRootElementSize(); + this.adjustRootChildsSize(); + if (!force) { + this.isElementSizesAdjusted = true; + } + } + }, + adjustRootElementSize: function() { + var masterHolder = this.wot.wtTable.holder; + var scrollbarHeight = masterHolder.clientHeight !== masterHolder.offsetHeight ? dom.getScrollbarWidth() : 0; + var overlayRoot = this.clone.wtTable.holder.parentNode; + var overlayRootStyle = overlayRoot.style; + var tableWidth; + if (this.trimmingContainer !== window) { + overlayRootStyle.height = this.wot.wtViewport.getWorkspaceHeight() - scrollbarHeight + 'px'; + } + this.clone.wtTable.holder.style.height = overlayRootStyle.height; + tableWidth = dom.outerWidth(this.clone.wtTable.TABLE); + overlayRootStyle.width = (tableWidth === 0 ? tableWidth : tableWidth + 4) + 'px'; + }, + adjustRootChildsSize: function() { + var scrollbarWidth = dom.getScrollbarWidth(); + this.clone.wtTable.hider.style.height = this.hider.style.height; + this.clone.wtTable.holder.style.height = this.clone.wtTable.holder.parentNode.style.height; + if (scrollbarWidth === 0) { + scrollbarWidth = 30; + } + this.clone.wtTable.holder.style.width = parseInt(this.clone.wtTable.holder.parentNode.style.width, 10) + scrollbarWidth + 'px'; + }, + applyToDOM: function() { + var total = this.wot.getSetting('totalColumns'); + if (!this.isElementSizesAdjusted) { + this.adjustElementsSize(); + } + if (typeof this.wot.wtViewport.columnsRenderCalculator.startPosition === 'number') { + this.spreader.style.left = this.wot.wtViewport.columnsRenderCalculator.startPosition + 'px'; + } else if (total === 0) { + this.spreader.style.left = '0'; + } else { + throw new Error('Incorrect value of the columnsRenderCalculator'); + } + this.spreader.style.right = ''; + if (this.needFullRender) { + this.syncOverlayOffset(); + } + }, + syncOverlayOffset: function() { + if (typeof this.wot.wtViewport.rowsRenderCalculator.startPosition === 'number') { + this.clone.wtTable.spreader.style.top = this.wot.wtViewport.rowsRenderCalculator.startPosition + 'px'; + } else { + this.clone.wtTable.spreader.style.top = ''; + } + }, + scrollTo: function(sourceCol, beyondRendered) { + var newX = this.getTableParentOffset(); + var sourceInstance = this.wot.cloneSource ? this.wot.cloneSource : this.wot; + var mainHolder = sourceInstance.wtTable.holder; + var scrollbarCompensation = 0; + if (beyondRendered && mainHolder.offsetWidth !== mainHolder.clientWidth) { + scrollbarCompensation = dom.getScrollbarWidth(); + } + if (beyondRendered) { + newX += this.sumCellSizes(0, sourceCol + 1); + newX -= this.wot.wtViewport.getViewportWidth(); + } else { + newX += this.sumCellSizes(this.wot.getSetting('fixedColumnsLeft'), sourceCol); + } + newX += scrollbarCompensation; + this.setScrollPosition(newX); + }, + getTableParentOffset: function() { + if (this.trimmingContainer === window) { + return this.wot.wtTable.holderOffset.left; + } else { + return 0; + } + }, + getScrollPosition: function() { + return dom.getScrollLeft(this.mainTableScrollableElement); + }, + adjustHeaderBordersPosition: function(position) { + var masterParent = this.wot.wtTable.holder.parentNode; + var rowHeaders = this.wot.getSetting('rowHeaders'); + var fixedColumnsLeft = this.wot.getSetting('fixedColumnsLeft'); + if (fixedColumnsLeft && !rowHeaders.length) { + dom.addClass(masterParent, 'innerBorderLeft'); + } else if (!fixedColumnsLeft && rowHeaders.length) { + var previousState = dom.hasClass(masterParent, 'innerBorderLeft'); + if (position) { + dom.addClass(masterParent, 'innerBorderLeft'); + } else { + dom.removeClass(masterParent, 'innerBorderLeft'); + } + if (!previousState && position || previousState && !position) { + this.wot.wtOverlays.adjustElementsSize(); + } + } + } +}, {}, WalkontableOverlay); +; +window.WalkontableLeftOverlay = WalkontableLeftOverlay; + +//# +},{"_base.js":11,"dom.js":27}],15:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableTopOverlay: {get: function() { + return WalkontableTopOverlay; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__, + $___95_base_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47__46__46__47_dom_46_js__}); +var WalkontableOverlay = ($___95_base_46_js__ = require("_base.js"), $___95_base_46_js__ && $___95_base_46_js__.__esModule && $___95_base_46_js__ || {default: $___95_base_46_js__}).WalkontableOverlay; +var WalkontableTopOverlay = function WalkontableTopOverlay(wotInstance) { + $traceurRuntime.superConstructor($WalkontableTopOverlay).call(this, wotInstance); + this.clone = this.makeClone(WalkontableOverlay.CLONE_TOP); +}; +var $WalkontableTopOverlay = WalkontableTopOverlay; +($traceurRuntime.createClass)(WalkontableTopOverlay, { + shouldBeRendered: function() { + return this.wot.getSetting('fixedRowsTop') || this.wot.getSetting('columnHeaders').length ? true : false; + }, + resetFixedPosition: function() { + if (!this.needFullRender || !this.wot.wtTable.holder.parentNode) { + return; + } + var overlayRoot = this.clone.wtTable.holder.parentNode; + var headerPosition = 0; + if (this.wot.wtOverlays.leftOverlay.trimmingContainer === window) { + var box = this.wot.wtTable.hider.getBoundingClientRect(); + var top = Math.ceil(box.top); + var bottom = Math.ceil(box.bottom); + var finalLeft; + var finalTop; + finalLeft = this.wot.wtTable.hider.style.left; + finalLeft = finalLeft === '' ? 0 : finalLeft; + if (top < 0 && (bottom - overlayRoot.offsetHeight) > 0) { + finalTop = -top; + } else { + finalTop = 0; + } + headerPosition = finalTop; + finalTop = finalTop + 'px'; + dom.setOverlayPosition(overlayRoot, finalLeft, finalTop); + } else { + headerPosition = this.getScrollPosition(); + } + this.adjustHeaderBordersPosition(headerPosition); + }, + setScrollPosition: function(pos) { + if (this.mainTableScrollableElement === window) { + window.scrollTo(dom.getWindowScrollLeft(), pos); + } else { + this.mainTableScrollableElement.scrollTop = pos; + } + }, + onScroll: function() { + this.wot.getSetting('onScrollVertically'); + }, + sumCellSizes: function(from, to) { + var sum = 0; + var defaultRowHeight = this.wot.wtSettings.settings.defaultRowHeight; + while (from < to) { + sum += this.wot.wtTable.getRowHeight(from) || defaultRowHeight; + from++; + } + return sum; + }, + adjustElementsSize: function() { + var force = arguments[0] !== (void 0) ? arguments[0] : false; + if (this.needFullRender || force) { + this.adjustRootElementSize(); + this.adjustRootChildsSize(); + if (!force) { + this.isElementSizesAdjusted = true; + } + } + }, + adjustRootElementSize: function() { + var masterHolder = this.wot.wtTable.holder; + var scrollbarWidth = masterHolder.clientWidth !== masterHolder.offsetWidth ? dom.getScrollbarWidth() : 0; + var overlayRoot = this.clone.wtTable.holder.parentNode; + var overlayRootStyle = overlayRoot.style; + var tableHeight; + if (this.trimmingContainer !== window) { + overlayRootStyle.width = this.wot.wtViewport.getWorkspaceWidth() - scrollbarWidth + 'px'; + } + this.clone.wtTable.holder.style.width = overlayRootStyle.width; + tableHeight = dom.outerHeight(this.clone.wtTable.TABLE); + overlayRootStyle.height = (tableHeight === 0 ? tableHeight : tableHeight + 4) + 'px'; + }, + adjustRootChildsSize: function() { + var scrollbarWidth = dom.getScrollbarWidth(); + this.clone.wtTable.hider.style.width = this.hider.style.width; + this.clone.wtTable.holder.style.width = this.clone.wtTable.holder.parentNode.style.width; + if (scrollbarWidth === 0) { + scrollbarWidth = 30; + } + this.clone.wtTable.holder.style.height = parseInt(this.clone.wtTable.holder.parentNode.style.height, 10) + scrollbarWidth + 'px'; + }, + applyToDOM: function() { + var total = this.wot.getSetting('totalRows'); + if (!this.isElementSizesAdjusted) { + this.adjustElementsSize(); + } + if (typeof this.wot.wtViewport.rowsRenderCalculator.startPosition === 'number') { + this.spreader.style.top = this.wot.wtViewport.rowsRenderCalculator.startPosition + 'px'; + } else if (total === 0) { + this.spreader.style.top = '0'; + } else { + throw new Error("Incorrect value of the rowsRenderCalculator"); + } + this.spreader.style.bottom = ''; + if (this.needFullRender) { + this.syncOverlayOffset(); + } + }, + syncOverlayOffset: function() { + if (typeof this.wot.wtViewport.columnsRenderCalculator.startPosition === 'number') { + this.clone.wtTable.spreader.style.left = this.wot.wtViewport.columnsRenderCalculator.startPosition + 'px'; + } else { + this.clone.wtTable.spreader.style.left = ''; + } + }, + scrollTo: function(sourceRow, bottomEdge) { + var newY = this.getTableParentOffset(); + var sourceInstance = this.wot.cloneSource ? this.wot.cloneSource : this.wot; + var mainHolder = sourceInstance.wtTable.holder; + var scrollbarCompensation = 0; + if (bottomEdge && mainHolder.offsetHeight !== mainHolder.clientHeight) { + scrollbarCompensation = dom.getScrollbarWidth(); + } + if (bottomEdge) { + newY += this.sumCellSizes(0, sourceRow + 1); + newY -= this.wot.wtViewport.getViewportHeight(); + newY += 1; + } else { + newY += this.sumCellSizes(this.wot.getSetting('fixedRowsTop'), sourceRow); + } + newY += scrollbarCompensation; + this.setScrollPosition(newY); + }, + getTableParentOffset: function() { + if (this.mainTableScrollableElement === window) { + return this.wot.wtTable.holderOffset.top; + } else { + return 0; + } + }, + getScrollPosition: function() { + return dom.getScrollTop(this.mainTableScrollableElement); + }, + adjustHeaderBordersPosition: function(position) { + if (this.wot.getSetting('fixedRowsTop') === 0 && this.wot.getSetting('columnHeaders').length > 0) { + var masterParent = this.wot.wtTable.holder.parentNode; + var previousState = dom.hasClass(masterParent, 'innerBorderTop'); + if (position) { + dom.addClass(masterParent, 'innerBorderTop'); + } else { + dom.removeClass(masterParent, 'innerBorderTop'); + } + if (!previousState && position || previousState && !position) { + this.wot.wtOverlays.adjustElementsSize(); + } + } + if (this.wot.getSetting('rowHeaders').length === 0) { + var secondHeaderCell = this.clone.wtTable.THEAD.querySelector('th:nth-of-type(2)'); + if (secondHeaderCell) { + secondHeaderCell.style['border-left-width'] = 0; + } + } + } +}, {}, WalkontableOverlay); +; +window.WalkontableTopOverlay = WalkontableTopOverlay; + +//# +},{"_base.js":11,"dom.js":27}],16:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableOverlays: {get: function() { + return WalkontableOverlays; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47__46__46__47_eventManager_46_js__, + $__overlay_47_corner_46_js__, + $__overlay_47_debug_46_js__, + $__overlay_47_left_46_js__, + $__overlay_47_top_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_dom_46_js__}); +var EventManager = ($___46__46__47__46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_eventManager_46_js__}).EventManager; +var WalkontableCornerOverlay = ($__overlay_47_corner_46_js__ = require("overlay/corner.js"), $__overlay_47_corner_46_js__ && $__overlay_47_corner_46_js__.__esModule && $__overlay_47_corner_46_js__ || {default: $__overlay_47_corner_46_js__}).WalkontableCornerOverlay; +var WalkontableDebugOverlay = ($__overlay_47_debug_46_js__ = require("overlay/debug.js"), $__overlay_47_debug_46_js__ && $__overlay_47_debug_46_js__.__esModule && $__overlay_47_debug_46_js__ || {default: $__overlay_47_debug_46_js__}).WalkontableDebugOverlay; +var WalkontableLeftOverlay = ($__overlay_47_left_46_js__ = require("overlay/left.js"), $__overlay_47_left_46_js__ && $__overlay_47_left_46_js__.__esModule && $__overlay_47_left_46_js__ || {default: $__overlay_47_left_46_js__}).WalkontableLeftOverlay; +var WalkontableTopOverlay = ($__overlay_47_top_46_js__ = require("overlay/top.js"), $__overlay_47_top_46_js__ && $__overlay_47_top_46_js__.__esModule && $__overlay_47_top_46_js__ || {default: $__overlay_47_top_46_js__}).WalkontableTopOverlay; +var WalkontableOverlays = function WalkontableOverlays(wotInstance) { + this.wot = wotInstance; + this.instance = this.wot; + this.eventManager = new EventManager(this.wot); + this.wot.update('scrollbarWidth', dom.getScrollbarWidth()); + this.wot.update('scrollbarHeight', dom.getScrollbarWidth()); + this.mainTableScrollableElement = dom.getScrollableElement(this.wot.wtTable.TABLE); + this.topOverlay = new WalkontableTopOverlay(this.wot); + this.leftOverlay = new WalkontableLeftOverlay(this.wot); + if (this.topOverlay.needFullRender && this.leftOverlay.needFullRender) { + this.topLeftCornerOverlay = new WalkontableCornerOverlay(this.wot); + } + if (this.wot.getSetting('debug')) { + this.debug = new WalkontableDebugOverlay(this.wot); + } + this.destroyed = false; + this.keyPressed = false; + this.spreaderLastSize = { + width: null, + height: null + }; + this.overlayScrollPositions = { + 'master': { + top: 0, + left: 0 + }, + 'top': { + top: null, + left: 0 + }, + 'left': { + top: 0, + left: null + } + }; + this.registerListeners(); +}; +($traceurRuntime.createClass)(WalkontableOverlays, { + refreshAll: function() { + if (!this.wot.drawn) { + return; + } + if (!this.wot.wtTable.holder.parentNode) { + this.destroy(); + return; + } + this.wot.draw(true); + this.topOverlay.onScroll(); + this.leftOverlay.onScroll(); + }, + registerListeners: function() { + var $__5 = this; + this.eventManager.addEventListener(document.documentElement, 'keydown', (function() { + return $__5.onKeyDown(); + })); + this.eventManager.addEventListener(document.documentElement, 'keyup', (function() { + return $__5.onKeyUp(); + })); + this.eventManager.addEventListener(document, 'visibilitychange', (function() { + return $__5.onKeyUp(); + })); + this.eventManager.addEventListener(this.mainTableScrollableElement, 'scroll', (function(event) { + return $__5.onTableScroll(event); + })); + if (this.topOverlay.needFullRender) { + this.eventManager.addEventListener(this.topOverlay.clone.wtTable.holder, 'scroll', (function(event) { + return $__5.onTableScroll(event); + })); + this.eventManager.addEventListener(this.topOverlay.clone.wtTable.holder, 'wheel', (function(event) { + return $__5.onTableScroll(event); + })); + } + if (this.leftOverlay.needFullRender) { + this.eventManager.addEventListener(this.leftOverlay.clone.wtTable.holder, 'scroll', (function(event) { + return $__5.onTableScroll(event); + })); + this.eventManager.addEventListener(this.leftOverlay.clone.wtTable.holder, 'wheel', (function(event) { + return $__5.onTableScroll(event); + })); + } + if (this.topOverlay.trimmingContainer !== window && this.leftOverlay.trimmingContainer !== window) { + this.eventManager.addEventListener(window, 'wheel', (function(event) { + var overlay; + var deltaY = event.wheelDeltaY || event.deltaY; + var deltaX = event.wheelDeltaX || event.deltaX; + if ($__5.topOverlay.clone.wtTable.holder.contains(event.realTarget)) { + overlay = 'top'; + } else if ($__5.leftOverlay.clone.wtTable.holder.contains(event.realTarget)) { + overlay = 'left'; + } + if (overlay == 'top' && deltaY !== 0) { + event.preventDefault(); + } else if (overlay == 'left' && deltaX !== 0) { + event.preventDefault(); + } + })); + } + }, + onTableScroll: function(event) { + if (Handsontable.mobileBrowser) { + return; + } + if (this.keyPressed && this.mainTableScrollableElement !== window && !event.target.contains(this.mainTableScrollableElement)) { + return; + } + if (event.type === 'scroll') { + this.syncScrollPositions(event); + } else { + this.translateMouseWheelToScroll(event); + } + }, + onKeyDown: function() { + this.keyPressed = true; + }, + onKeyUp: function() { + this.keyPressed = false; + }, + translateMouseWheelToScroll: function(event) { + var topOverlay = this.topOverlay.clone.wtTable.holder; + var leftOverlay = this.leftOverlay.clone.wtTable.holder; + var eventMockup = {type: 'wheel'}; + var tempElem = event.target; + var deltaY = event.wheelDeltaY || (-1) * event.deltaY; + var deltaX = event.wheelDeltaX || (-1) * event.deltaX; + var parentHolder; + while (tempElem != document && tempElem != null) { + if (tempElem.className.indexOf('wtHolder') > -1) { + parentHolder = tempElem; + break; + } + tempElem = tempElem.parentNode; + } + eventMockup.target = parentHolder; + if (parentHolder == topOverlay) { + this.syncScrollPositions(eventMockup, (-0.2) * deltaY); + } else if (parentHolder == leftOverlay) { + this.syncScrollPositions(eventMockup, (-0.2) * deltaX); + } + return false; + }, + syncScrollPositions: function(event) { + var fakeScrollValue = arguments[1] !== (void 0) ? arguments[1] : null; + if (this.destroyed) { + return; + } + if (arguments.length === 0) { + this.syncScrollWithMaster(); + return; + } + var master = this.mainTableScrollableElement; + var target = event.target; + var tempScrollValue = 0; + var scrollValueChanged = false; + var topOverlay; + var leftOverlay; + if (this.topOverlay.needFullRender) { + topOverlay = this.topOverlay.clone.wtTable.holder; + } + if (this.leftOverlay.needFullRender) { + leftOverlay = this.leftOverlay.clone.wtTable.holder; + } + if (target === document) { + target = window; + } + if (target === master) { + tempScrollValue = dom.getScrollLeft(target); + if (this.overlayScrollPositions.master.left !== tempScrollValue) { + this.overlayScrollPositions.master.left = tempScrollValue; + scrollValueChanged = true; + if (topOverlay) { + topOverlay.scrollLeft = tempScrollValue; + } + } + tempScrollValue = dom.getScrollTop(target); + if (this.overlayScrollPositions.master.top !== tempScrollValue) { + this.overlayScrollPositions.master.top = tempScrollValue; + scrollValueChanged = true; + if (leftOverlay) { + leftOverlay.scrollTop = tempScrollValue; + } + } + } else if (target === topOverlay) { + tempScrollValue = dom.getScrollLeft(target); + if (this.overlayScrollPositions.top.left !== tempScrollValue) { + this.overlayScrollPositions.top.left = tempScrollValue; + scrollValueChanged = true; + master.scrollLeft = tempScrollValue; + } + if (fakeScrollValue !== null) { + scrollValueChanged = true; + master.scrollTop += fakeScrollValue; + } + } else if (target === leftOverlay) { + tempScrollValue = dom.getScrollTop(target); + if (this.overlayScrollPositions.left.top !== tempScrollValue) { + this.overlayScrollPositions.left.top = tempScrollValue; + scrollValueChanged = true; + master.scrollTop = tempScrollValue; + } + if (fakeScrollValue !== null) { + scrollValueChanged = true; + master.scrollLeft += fakeScrollValue; + } + } + if (!this.keyPressed && scrollValueChanged && event.type === 'scroll') { + this.refreshAll(); + } + }, + syncScrollWithMaster: function() { + var master = this.topOverlay.mainTableScrollableElement; + if (this.topOverlay.needFullRender) { + this.topOverlay.clone.wtTable.holder.scrollLeft = master.scrollLeft; + } + if (this.leftOverlay.needFullRender) { + this.leftOverlay.clone.wtTable.holder.scrollTop = master.scrollTop; + } + }, + destroy: function() { + this.eventManager.destroy(); + this.topOverlay.destroy(); + this.leftOverlay.destroy(); + if (this.topLeftCornerOverlay) { + this.topLeftCornerOverlay.destroy(); + } + if (this.debug) { + this.debug.destroy(); + } + this.destroyed = true; + }, + refresh: function() { + var fastDraw = arguments[0] !== (void 0) ? arguments[0] : false; + if (this.topOverlay.isElementSizesAdjusted && this.leftOverlay.isElementSizesAdjusted) { + var container = this.wot.wtTable.wtRootElement.parentNode || this.wot.wtTable.wtRootElement; + var width = container.clientWidth; + var height = container.clientHeight; + if (width !== this.spreaderLastSize.width || height !== this.spreaderLastSize.height) { + this.spreaderLastSize.width = width; + this.spreaderLastSize.height = height; + this.adjustElementsSize(); + } + } + this.leftOverlay.refresh(fastDraw); + this.topOverlay.refresh(fastDraw); + if (this.topLeftCornerOverlay) { + this.topLeftCornerOverlay.refresh(fastDraw); + } + if (this.debug) { + this.debug.refresh(fastDraw); + } + }, + adjustElementsSize: function() { + var force = arguments[0] !== (void 0) ? arguments[0] : false; + var totalColumns = this.wot.getSetting('totalColumns'); + var totalRows = this.wot.getSetting('totalRows'); + var headerRowSize = this.wot.wtViewport.getRowHeaderWidth(); + var headerColumnSize = this.wot.wtViewport.getColumnHeaderHeight(); + var hiderStyle = this.wot.wtTable.hider.style; + hiderStyle.width = (headerRowSize + this.leftOverlay.sumCellSizes(0, totalColumns)) + 'px'; + hiderStyle.height = (headerColumnSize + this.topOverlay.sumCellSizes(0, totalRows) + 1) + 'px'; + this.topOverlay.adjustElementsSize(force); + this.leftOverlay.adjustElementsSize(force); + }, + applyToDOM: function() { + if (!this.topOverlay.isElementSizesAdjusted || !this.leftOverlay.isElementSizesAdjusted) { + this.adjustElementsSize(); + } + this.topOverlay.applyToDOM(); + this.leftOverlay.applyToDOM(); + } +}, {}); +; +window.WalkontableOverlays = WalkontableOverlays; + +//# +},{"dom.js":27,"eventManager.js":41,"overlay/corner.js":12,"overlay/debug.js":13,"overlay/left.js":14,"overlay/top.js":15}],17:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableScroll: {get: function() { + return WalkontableScroll; + }}, + __esModule: {value: true} +}); +var WalkontableScroll = function WalkontableScroll(wotInstance) { + this.wot = wotInstance; + this.instance = wotInstance; +}; +($traceurRuntime.createClass)(WalkontableScroll, {scrollViewport: function(coords) { + if (!this.wot.drawn) { + return; + } + var totalRows = this.wot.getSetting('totalRows'); + var totalColumns = this.wot.getSetting('totalColumns'); + if (coords.row < 0 || coords.row > totalRows - 1) { + throw new Error('row ' + coords.row + ' does not exist'); + } + if (coords.col < 0 || coords.col > totalColumns - 1) { + throw new Error('column ' + coords.col + ' does not exist'); + } + if (coords.row > this.instance.wtTable.getLastVisibleRow()) { + this.wot.wtOverlays.topOverlay.scrollTo(coords.row, true); + } else if (coords.row >= this.instance.getSetting('fixedRowsTop') && coords.row < this.instance.wtTable.getFirstVisibleRow()) { + this.wot.wtOverlays.topOverlay.scrollTo(coords.row); + } + if (coords.col > this.instance.wtTable.getLastVisibleColumn()) { + this.wot.wtOverlays.leftOverlay.scrollTo(coords.col, true); + } else if (coords.col >= this.instance.getSetting('fixedColumnsLeft') && coords.col < this.instance.wtTable.getFirstVisibleColumn()) { + this.wot.wtOverlays.leftOverlay.scrollTo(coords.col); + } + }}, {}); +; +window.WalkontableScroll = WalkontableScroll; + +//# +},{}],18:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableSelection: {get: function() { + return WalkontableSelection; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47_dom_46_js__, + $__border_46_js__, + $__cell_47_coords_46_js__, + $__cell_47_range_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_dom_46_js__}); +var WalkontableBorder = ($__border_46_js__ = require("border.js"), $__border_46_js__ && $__border_46_js__.__esModule && $__border_46_js__ || {default: $__border_46_js__}).WalkontableBorder; +var WalkontableCellCoords = ($__cell_47_coords_46_js__ = require("cell/coords.js"), $__cell_47_coords_46_js__ && $__cell_47_coords_46_js__.__esModule && $__cell_47_coords_46_js__ || {default: $__cell_47_coords_46_js__}).WalkontableCellCoords; +var WalkontableCellRange = ($__cell_47_range_46_js__ = require("cell/range.js"), $__cell_47_range_46_js__ && $__cell_47_range_46_js__.__esModule && $__cell_47_range_46_js__ || {default: $__cell_47_range_46_js__}).WalkontableCellRange; +var WalkontableSelection = function WalkontableSelection(settings, cellRange) { + this.settings = settings; + this.cellRange = cellRange || null; + this.instanceBorders = {}; +}; +($traceurRuntime.createClass)(WalkontableSelection, { + getBorder: function(wotInstance) { + if (this.instanceBorders[wotInstance.guid]) { + return this.instanceBorders[wotInstance.guid]; + } + this.instanceBorders[wotInstance.guid] = new WalkontableBorder(wotInstance, this.settings); + }, + isEmpty: function() { + return this.cellRange === null; + }, + add: function(coords) { + if (this.isEmpty()) { + this.cellRange = new WalkontableCellRange(coords, coords, coords); + } else { + this.cellRange.expand(coords); + } + }, + replace: function(oldCoords, newCoords) { + if (!this.isEmpty()) { + if (this.cellRange.from.isEqual(oldCoords)) { + this.cellRange.from = newCoords; + return true; + } + if (this.cellRange.to.isEqual(oldCoords)) { + this.cellRange.to = newCoords; + return true; + } + } + return false; + }, + clear: function() { + this.cellRange = null; + }, + getCorners: function() { + var topLeft = this.cellRange.getTopLeftCorner(); + var bottomRight = this.cellRange.getBottomRightCorner(); + return [topLeft.row, topLeft.col, bottomRight.row, bottomRight.col]; + }, + addClassAtCoords: function(wotInstance, sourceRow, sourceColumn, className) { + var TD = wotInstance.wtTable.getCell(new WalkontableCellCoords(sourceRow, sourceColumn)); + if (typeof TD === 'object') { + dom.addClass(TD, className); + } + }, + draw: function(wotInstance) { + if (this.isEmpty()) { + if (this.settings.border) { + var border = this.getBorder(wotInstance); + if (border) { + border.disappear(); + } + } + return; + } + var renderedRows = wotInstance.wtTable.getRenderedRowsCount(); + var renderedColumns = wotInstance.wtTable.getRenderedColumnsCount(); + var corners = this.getCorners(); + var sourceRow, + sourceCol, + TH; + for (var column = 0; column < renderedColumns; column++) { + sourceCol = wotInstance.wtTable.columnFilter.renderedToSource(column); + if (sourceCol >= corners[1] && sourceCol <= corners[3]) { + TH = wotInstance.wtTable.getColumnHeader(sourceCol); + if (TH && this.settings.highlightColumnClassName) { + dom.addClass(TH, this.settings.highlightColumnClassName); + } + } + } + for (var row = 0; row < renderedRows; row++) { + sourceRow = wotInstance.wtTable.rowFilter.renderedToSource(row); + if (sourceRow >= corners[0] && sourceRow <= corners[2]) { + TH = wotInstance.wtTable.getRowHeader(sourceRow); + if (TH && this.settings.highlightRowClassName) { + dom.addClass(TH, this.settings.highlightRowClassName); + } + } + for (var column$__4 = 0; column$__4 < renderedColumns; column$__4++) { + sourceCol = wotInstance.wtTable.columnFilter.renderedToSource(column$__4); + if (sourceRow >= corners[0] && sourceRow <= corners[2] && sourceCol >= corners[1] && sourceCol <= corners[3]) { + if (this.settings.className) { + this.addClassAtCoords(wotInstance, sourceRow, sourceCol, this.settings.className); + } + } else if (sourceRow >= corners[0] && sourceRow <= corners[2]) { + if (this.settings.highlightRowClassName) { + this.addClassAtCoords(wotInstance, sourceRow, sourceCol, this.settings.highlightRowClassName); + } + } else if (sourceCol >= corners[1] && sourceCol <= corners[3]) { + if (this.settings.highlightColumnClassName) { + this.addClassAtCoords(wotInstance, sourceRow, sourceCol, this.settings.highlightColumnClassName); + } + } + } + } + wotInstance.getSetting('onBeforeDrawBorders', corners, this.settings.className); + if (this.settings.border) { + var border$__5 = this.getBorder(wotInstance); + if (border$__5) { + border$__5.appear(corners); + } + } + } +}, {}); +; +window.WalkontableSelection = WalkontableSelection; + +//# +},{"border.js":2,"cell/coords.js":5,"cell/range.js":6,"dom.js":27}],19:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableSettings: {get: function() { + return WalkontableSettings; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47_dom_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_dom_46_js__}); +var WalkontableSettings = function WalkontableSettings(wotInstance, settings) { + var $__0 = this; + this.wot = wotInstance; + this.instance = wotInstance; + this.defaults = { + table: void 0, + debug: false, + externalRowCalculator: false, + stretchH: 'none', + currentRowClassName: null, + currentColumnClassName: null, + data: void 0, + fixedColumnsLeft: 0, + fixedRowsTop: 0, + rowHeaders: function() { + return []; + }, + columnHeaders: function() { + return []; + }, + totalRows: void 0, + totalColumns: void 0, + cellRenderer: (function(row, column, TD) { + var cellData = $__0.getSetting('data', row, column); + dom.fastInnerText(TD, cellData === void 0 || cellData === null ? '' : cellData); + }), + columnWidth: function(col) { + return; + }, + rowHeight: function(row) { + return; + }, + defaultRowHeight: 23, + defaultColumnWidth: 50, + selections: null, + hideBorderOnMouseDownOver: false, + viewportRowCalculatorOverride: null, + viewportColumnCalculatorOverride: null, + onCellMouseDown: null, + onCellMouseOver: null, + onCellDblClick: null, + onCellCornerMouseDown: null, + onCellCornerDblClick: null, + beforeDraw: null, + onDraw: null, + onBeforeDrawBorders: null, + onScrollVertically: null, + onScrollHorizontally: null, + onBeforeTouchScroll: null, + onAfterMomentumScroll: null, + scrollbarWidth: 10, + scrollbarHeight: 10, + renderAllRows: false, + groups: false + }; + this.settings = {}; + for (var i in this.defaults) { + if (this.defaults.hasOwnProperty(i)) { + if (settings[i] !== void 0) { + this.settings[i] = settings[i]; + } else if (this.defaults[i] === void 0) { + throw new Error('A required setting "' + i + '" was not provided'); + } else { + this.settings[i] = this.defaults[i]; + } + } + } +}; +($traceurRuntime.createClass)(WalkontableSettings, { + update: function(settings, value) { + if (value === void 0) { + for (var i in settings) { + if (settings.hasOwnProperty(i)) { + this.settings[i] = settings[i]; + } + } + } else { + this.settings[settings] = value; + } + return this.wot; + }, + getSetting: function(key, param1, param2, param3, param4) { + if (typeof this.settings[key] === 'function') { + return this.settings[key](param1, param2, param3, param4); + } else if (param1 !== void 0 && Array.isArray(this.settings[key])) { + return this.settings[key][param1]; + } else { + return this.settings[key]; + } + }, + has: function(key) { + return !!this.settings[key]; + } +}, {}); +; +window.WalkontableSettings = WalkontableSettings; + +//# +},{"dom.js":27}],20:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableTable: {get: function() { + return WalkontableTable; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47_dom_46_js__, + $__cell_47_coords_46_js__, + $__cell_47_range_46_js__, + $__filter_47_column_46_js__, + $__overlay_47_corner_46_js__, + $__overlay_47_debug_46_js__, + $__overlay_47_left_46_js__, + $__filter_47_row_46_js__, + $__tableRenderer_46_js__, + $__overlay_47_top_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_dom_46_js__}); +var WalkontableCellCoords = ($__cell_47_coords_46_js__ = require("cell/coords.js"), $__cell_47_coords_46_js__ && $__cell_47_coords_46_js__.__esModule && $__cell_47_coords_46_js__ || {default: $__cell_47_coords_46_js__}).WalkontableCellCoords; +var WalkontableCellRange = ($__cell_47_range_46_js__ = require("cell/range.js"), $__cell_47_range_46_js__ && $__cell_47_range_46_js__.__esModule && $__cell_47_range_46_js__ || {default: $__cell_47_range_46_js__}).WalkontableCellRange; +var WalkontableColumnFilter = ($__filter_47_column_46_js__ = require("filter/column.js"), $__filter_47_column_46_js__ && $__filter_47_column_46_js__.__esModule && $__filter_47_column_46_js__ || {default: $__filter_47_column_46_js__}).WalkontableColumnFilter; +var WalkontableCornerOverlay = ($__overlay_47_corner_46_js__ = require("overlay/corner.js"), $__overlay_47_corner_46_js__ && $__overlay_47_corner_46_js__.__esModule && $__overlay_47_corner_46_js__ || {default: $__overlay_47_corner_46_js__}).WalkontableCornerOverlay; +var WalkontableDebugOverlay = ($__overlay_47_debug_46_js__ = require("overlay/debug.js"), $__overlay_47_debug_46_js__ && $__overlay_47_debug_46_js__.__esModule && $__overlay_47_debug_46_js__ || {default: $__overlay_47_debug_46_js__}).WalkontableDebugOverlay; +var WalkontableLeftOverlay = ($__overlay_47_left_46_js__ = require("overlay/left.js"), $__overlay_47_left_46_js__ && $__overlay_47_left_46_js__.__esModule && $__overlay_47_left_46_js__ || {default: $__overlay_47_left_46_js__}).WalkontableLeftOverlay; +var WalkontableRowFilter = ($__filter_47_row_46_js__ = require("filter/row.js"), $__filter_47_row_46_js__ && $__filter_47_row_46_js__.__esModule && $__filter_47_row_46_js__ || {default: $__filter_47_row_46_js__}).WalkontableRowFilter; +var WalkontableTableRenderer = ($__tableRenderer_46_js__ = require("tableRenderer.js"), $__tableRenderer_46_js__ && $__tableRenderer_46_js__.__esModule && $__tableRenderer_46_js__ || {default: $__tableRenderer_46_js__}).WalkontableTableRenderer; +var WalkontableTopOverlay = ($__overlay_47_top_46_js__ = require("overlay/top.js"), $__overlay_47_top_46_js__ && $__overlay_47_top_46_js__.__esModule && $__overlay_47_top_46_js__ || {default: $__overlay_47_top_46_js__}).WalkontableTopOverlay; +var WalkontableTable = function WalkontableTable(wotInstance, table) { + this.wot = wotInstance; + this.instance = this.wot; + this.TABLE = table; + this.TBODY = null; + this.THEAD = null; + this.COLGROUP = null; + this.tableOffset = 0; + this.holderOffset = 0; + dom.removeTextNodes(this.TABLE); + this.spreader = this.createSpreader(this.TABLE); + this.hider = this.createHider(this.spreader); + this.holder = this.createHolder(this.hider); + this.wtRootElement = this.holder.parentNode; + this.alignOverlaysWithTrimmingContainer(); + this.fixTableDomTree(); + this.colgroupChildrenLength = this.COLGROUP.childNodes.length; + this.theadChildrenLength = this.THEAD.firstChild ? this.THEAD.firstChild.childNodes.length : 0; + this.tbodyChildrenLength = this.TBODY.childNodes.length; + this.rowFilter = null; + this.columnFilter = null; +}; +($traceurRuntime.createClass)(WalkontableTable, { + fixTableDomTree: function() { + this.TBODY = this.TABLE.querySelector('tbody'); + if (!this.TBODY) { + this.TBODY = document.createElement('tbody'); + this.TABLE.appendChild(this.TBODY); + } + this.THEAD = this.TABLE.querySelector('thead'); + if (!this.THEAD) { + this.THEAD = document.createElement('thead'); + this.TABLE.insertBefore(this.THEAD, this.TBODY); + } + this.COLGROUP = this.TABLE.querySelector('colgroup'); + if (!this.COLGROUP) { + this.COLGROUP = document.createElement('colgroup'); + this.TABLE.insertBefore(this.COLGROUP, this.THEAD); + } + if (this.wot.getSetting('columnHeaders').length && !this.THEAD.childNodes.length) { + this.THEAD.appendChild(document.createElement('TR')); + } + }, + createSpreader: function(table) { + var parent = table.parentNode; + var spreader; + if (!parent || parent.nodeType !== 1 || !dom.hasClass(parent, 'wtHolder')) { + spreader = document.createElement('div'); + spreader.className = 'wtSpreader'; + if (parent) { + parent.insertBefore(spreader, table); + } + spreader.appendChild(table); + } + spreader.style.position = 'relative'; + return spreader; + }, + createHider: function(spreader) { + var parent = spreader.parentNode; + var hider; + if (!parent || parent.nodeType !== 1 || !dom.hasClass(parent, 'wtHolder')) { + hider = document.createElement('div'); + hider.className = 'wtHider'; + if (parent) { + parent.insertBefore(hider, spreader); + } + hider.appendChild(spreader); + } + return hider; + }, + createHolder: function(hider) { + var parent = hider.parentNode; + var holder; + if (!parent || parent.nodeType !== 1 || !dom.hasClass(parent, 'wtHolder')) { + holder = document.createElement('div'); + holder.style.position = 'relative'; + holder.className = 'wtHolder'; + if (parent) { + parent.insertBefore(holder, hider); + } + if (!this.isWorkingOnClone()) { + holder.parentNode.className += 'ht_master handsontable'; + } + holder.appendChild(hider); + } + return holder; + }, + alignOverlaysWithTrimmingContainer: function() { + var trimmingElement = dom.getTrimmingContainer(this.wtRootElement); + if (!this.isWorkingOnClone()) { + this.holder.parentNode.style.position = 'relative'; + if (trimmingElement !== window) { + this.holder.style.width = dom.getStyle(trimmingElement, 'width'); + this.holder.style.height = dom.getStyle(trimmingElement, 'height'); + this.holder.style.overflow = ''; + } else { + this.holder.style.overflow = 'visible'; + this.wtRootElement.style.overflow = 'visible'; + } + } + }, + isWorkingOnClone: function() { + return !!this.wot.cloneSource; + }, + draw: function(fastDraw) { + if (!this.isWorkingOnClone()) { + this.holderOffset = dom.offset(this.holder); + fastDraw = this.wot.wtViewport.createRenderCalculators(fastDraw); + } + if (!fastDraw) { + if (this.isWorkingOnClone()) { + this.tableOffset = this.wot.cloneSource.wtTable.tableOffset; + } else { + this.tableOffset = dom.offset(this.TABLE); + } + var startRow; + if (this.wot.cloneOverlay instanceof WalkontableDebugOverlay || this.wot.cloneOverlay instanceof WalkontableTopOverlay || this.wot.cloneOverlay instanceof WalkontableCornerOverlay) { + startRow = 0; + } else { + startRow = this.wot.wtViewport.rowsRenderCalculator.startRow; + } + var startColumn; + if (this.wot.cloneOverlay instanceof WalkontableDebugOverlay || this.wot.cloneOverlay instanceof WalkontableLeftOverlay || this.wot.cloneOverlay instanceof WalkontableCornerOverlay) { + startColumn = 0; + } else { + startColumn = this.wot.wtViewport.columnsRenderCalculator.startColumn; + } + this.rowFilter = new WalkontableRowFilter(startRow, this.wot.getSetting('totalRows'), this.wot.getSetting('columnHeaders').length); + this.columnFilter = new WalkontableColumnFilter(startColumn, this.wot.getSetting('totalColumns'), this.wot.getSetting('rowHeaders').length); + this._doDraw(); + this.alignOverlaysWithTrimmingContainer(); + } else { + if (!this.isWorkingOnClone()) { + this.wot.wtViewport.createVisibleCalculators(); + } + if (this.wot.wtOverlays) { + this.wot.wtOverlays.refresh(true); + } + } + this.refreshSelections(fastDraw); + if (!this.isWorkingOnClone()) { + this.wot.wtOverlays.topOverlay.resetFixedPosition(); + this.wot.wtOverlays.leftOverlay.resetFixedPosition(); + if (this.wot.wtOverlays.topLeftCornerOverlay) { + this.wot.wtOverlays.topLeftCornerOverlay.resetFixedPosition(); + } + } + this.wot.drawn = true; + return this; + }, + _doDraw: function() { + var wtRenderer = new WalkontableTableRenderer(this); + wtRenderer.render(); + }, + removeClassFromCells: function(className) { + var nodes = this.TABLE.querySelectorAll('.' + className); + for (var i = 0, + len = nodes.length; i < len; i++) { + dom.removeClass(nodes[i], className); + } + }, + refreshSelections: function(fastDraw) { + if (!this.wot.selections) { + return; + } + var len = this.wot.selections.length; + if (fastDraw) { + for (var i = 0; i < len; i++) { + if (this.wot.selections[i].settings.className) { + this.removeClassFromCells(this.wot.selections[i].settings.className); + } + if (this.wot.selections[i].settings.highlightRowClassName) { + this.removeClassFromCells(this.wot.selections[i].settings.highlightRowClassName); + } + if (this.wot.selections[i].settings.highlightColumnClassName) { + this.removeClassFromCells(this.wot.selections[i].settings.highlightColumnClassName); + } + } + } + for (var i$__10 = 0; i$__10 < len; i$__10++) { + this.wot.selections[i$__10].draw(this.wot, fastDraw); + } + }, + getCell: function(coords) { + if (this.isRowBeforeRenderedRows(coords.row)) { + return -1; + } else if (this.isRowAfterRenderedRows(coords.row)) { + return -2; + } + var TR = this.TBODY.childNodes[this.rowFilter.sourceToRendered(coords.row)]; + if (TR) { + return TR.childNodes[this.columnFilter.sourceColumnToVisibleRowHeadedColumn(coords.col)]; + } + }, + getColumnHeader: function(col) { + var level = arguments[1] !== (void 0) ? arguments[1] : 0; + var TR = this.THEAD.childNodes[level]; + if (TR) { + return TR.childNodes[this.columnFilter.sourceColumnToVisibleRowHeadedColumn(col)]; + } + }, + getRowHeader: function(row) { + if (this.columnFilter.sourceColumnToVisibleRowHeadedColumn(0) === 0) { + return null; + } + var TR = this.TBODY.childNodes[this.rowFilter.sourceToRendered(row)]; + if (TR) { + return TR.childNodes[0]; + } + }, + getCoords: function(TD) { + var TR = TD.parentNode; + var row = dom.index(TR); + if (TR.parentNode === this.THEAD) { + row = this.rowFilter.visibleColHeadedRowToSourceRow(row); + } else { + row = this.rowFilter.renderedToSource(row); + } + return new WalkontableCellCoords(row, this.columnFilter.visibleRowHeadedColumnToSourceColumn(TD.cellIndex)); + }, + getTrForRow: function(row) { + return this.TBODY.childNodes[this.rowFilter.sourceToRendered(row)]; + }, + getFirstRenderedRow: function() { + return this.wot.wtViewport.rowsRenderCalculator.startRow; + }, + getFirstVisibleRow: function() { + return this.wot.wtViewport.rowsVisibleCalculator.startRow; + }, + getFirstRenderedColumn: function() { + return this.wot.wtViewport.columnsRenderCalculator.startColumn; + }, + getFirstVisibleColumn: function() { + return this.wot.wtViewport.columnsVisibleCalculator.startColumn; + }, + getLastRenderedRow: function() { + return this.wot.wtViewport.rowsRenderCalculator.endRow; + }, + getLastVisibleRow: function() { + return this.wot.wtViewport.rowsVisibleCalculator.endRow; + }, + getLastRenderedColumn: function() { + return this.wot.wtViewport.columnsRenderCalculator.endColumn; + }, + getLastVisibleColumn: function() { + return this.wot.wtViewport.columnsVisibleCalculator.endColumn; + }, + isRowBeforeRenderedRows: function(row) { + return (this.rowFilter.sourceToRendered(row) < 0 && row >= 0); + }, + isRowAfterViewport: function(row) { + return (row > this.getLastVisibleRow()); + }, + isRowAfterRenderedRows: function(row) { + return (row > this.getLastRenderedRow()); + }, + isColumnBeforeViewport: function(column) { + return this.columnFilter.sourceToRendered(column) < 0 && column >= 0; + }, + isColumnAfterViewport: function(column) { + return column > this.getLastVisibleColumn(); + }, + isLastRowFullyVisible: function() { + return this.getLastVisibleRow() === this.getLastRenderedRow(); + }, + isLastColumnFullyVisible: function() { + return this.getLastVisibleColumn() === this.getLastRenderedColumn(); + }, + getRenderedColumnsCount: function() { + if (this.wot.cloneOverlay instanceof WalkontableDebugOverlay) { + return this.wot.getSetting('totalColumns'); + } else if (this.wot.cloneOverlay instanceof WalkontableLeftOverlay || this.wot.cloneOverlay instanceof WalkontableCornerOverlay) { + return this.wot.getSetting('fixedColumnsLeft'); + } else { + return this.wot.wtViewport.columnsRenderCalculator.count; + } + }, + getRenderedRowsCount: function() { + if (this.wot.cloneOverlay instanceof WalkontableDebugOverlay) { + return this.wot.getSetting('totalRows'); + } else if (this.wot.cloneOverlay instanceof WalkontableTopOverlay || this.wot.cloneOverlay instanceof WalkontableCornerOverlay) { + return this.wot.getSetting('fixedRowsTop'); + } + return this.wot.wtViewport.rowsRenderCalculator.count; + }, + getVisibleRowsCount: function() { + return this.wot.wtViewport.rowsVisibleCalculator.count; + }, + allRowsInViewport: function() { + return this.wot.getSetting('totalRows') == this.getVisibleRowsCount(); + }, + getRowHeight: function(sourceRow) { + var height = this.wot.wtSettings.settings.rowHeight(sourceRow); + var oversizedHeight = this.wot.wtViewport.oversizedRows[sourceRow]; + if (oversizedHeight !== void 0) { + height = height ? Math.max(height, oversizedHeight) : oversizedHeight; + } + return height; + }, + getColumnHeaderHeight: function(level) { + var height = this.wot.wtSettings.settings.defaultRowHeight; + var oversizedHeight = this.wot.wtViewport.oversizedColumnHeaders[level]; + if (oversizedHeight !== void 0) { + height = height ? Math.max(height, oversizedHeight) : oversizedHeight; + } + return height; + }, + getVisibleColumnsCount: function() { + return this.wot.wtViewport.columnsVisibleCalculator.count; + }, + allColumnsInViewport: function() { + return this.wot.getSetting('totalColumns') == this.getVisibleColumnsCount(); + }, + getColumnWidth: function(sourceColumn) { + var width = this.wot.wtSettings.settings.columnWidth; + if (typeof width === 'function') { + width = width(sourceColumn); + } else if (typeof width === 'object') { + width = width[sourceColumn]; + } + return width || this.wot.wtSettings.settings.defaultColumnWidth; + }, + getStretchedColumnWidth: function(sourceColumn) { + var width = this.getColumnWidth(sourceColumn); + var calculator = this.wot.wtViewport.columnsRenderCalculator; + if (calculator) { + var stretchedWidth = calculator.getStretchedColumnWidth(sourceColumn, width); + if (stretchedWidth) { + width = stretchedWidth; + } + } + return width; + } +}, {}); +; +window.WalkontableTable = WalkontableTable; + +//# +},{"cell/coords.js":5,"cell/range.js":6,"dom.js":27,"filter/column.js":9,"filter/row.js":10,"overlay/corner.js":12,"overlay/debug.js":13,"overlay/left.js":14,"overlay/top.js":15,"tableRenderer.js":21}],21:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableTableRenderer: {get: function() { + return WalkontableTableRenderer; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47_dom_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_dom_46_js__}); +var isMarkedOversizedColumn = {}; +var WalkontableTableRenderer = function WalkontableTableRenderer(wtTable) { + this.wtTable = wtTable; + this.wot = wtTable.instance; + this.instance = wtTable.instance; + this.rowFilter = wtTable.rowFilter; + this.columnFilter = wtTable.columnFilter; + this.TABLE = wtTable.TABLE; + this.THEAD = wtTable.THEAD; + this.TBODY = wtTable.TBODY; + this.COLGROUP = wtTable.COLGROUP; + this.rowHeaders = []; + this.rowHeaderCount = 0; + this.columnHeaders = []; + this.columnHeaderCount = 0; + this.fixedRowsTop = 0; +}; +($traceurRuntime.createClass)(WalkontableTableRenderer, { + render: function() { + if (!this.wtTable.isWorkingOnClone()) { + this.wot.getSetting('beforeDraw', true); + } + this.rowHeaders = this.wot.getSetting('rowHeaders'); + this.rowHeaderCount = this.rowHeaders.length; + this.fixedRowsTop = this.wot.getSetting('fixedRowsTop'); + this.columnHeaders = this.wot.getSetting('columnHeaders'); + this.columnHeaderCount = this.columnHeaders.length; + var columnsToRender = this.wtTable.getRenderedColumnsCount(); + var rowsToRender = this.wtTable.getRenderedRowsCount(); + var totalColumns = this.wot.getSetting('totalColumns'); + var totalRows = this.wot.getSetting('totalRows'); + var workspaceWidth; + var adjusted = false; + if (totalColumns > 0) { + this.adjustAvailableNodes(); + adjusted = true; + this.renderColumnHeaders(); + this.renderRows(totalRows, rowsToRender, columnsToRender); + if (!this.wtTable.isWorkingOnClone()) { + workspaceWidth = this.wot.wtViewport.getWorkspaceWidth(); + this.wot.wtViewport.containerWidth = null; + } + this.adjustColumnHeaderHeights(); + this.adjustColumnWidths(columnsToRender); + this.markOversizedColumns(); + } + if (!adjusted) { + this.adjustAvailableNodes(); + } + this.removeRedundantRows(rowsToRender); + if (!this.wtTable.isWorkingOnClone()) { + this.markOversizedRows(); + this.wot.wtViewport.createVisibleCalculators(); + this.wot.wtOverlays.refresh(false); + this.wot.wtOverlays.applyToDOM(); + if (workspaceWidth !== this.wot.wtViewport.getWorkspaceWidth()) { + this.wot.wtViewport.containerWidth = null; + var firstRendered = this.wtTable.getFirstRenderedColumn(); + var lastRendered = this.wtTable.getLastRenderedColumn(); + for (var i = firstRendered; i < lastRendered; i++) { + var width = this.wtTable.getStretchedColumnWidth(i); + var renderedIndex = this.columnFilter.sourceToRendered(i); + this.COLGROUP.childNodes[renderedIndex + this.rowHeaderCount].style.width = width + 'px'; + } + } + this.wot.getSetting('onDraw', true); + } + }, + removeRedundantRows: function(renderedRowsCount) { + while (this.wtTable.tbodyChildrenLength > renderedRowsCount) { + this.TBODY.removeChild(this.TBODY.lastChild); + this.wtTable.tbodyChildrenLength--; + } + }, + renderRows: function(totalRows, rowsToRender, columnsToRender) { + var lastTD, + TR; + var visibleRowIndex = 0; + var sourceRowIndex = this.rowFilter.renderedToSource(visibleRowIndex); + var isWorkingOnClone = this.wtTable.isWorkingOnClone(); + while (sourceRowIndex < totalRows && sourceRowIndex >= 0) { + if (visibleRowIndex > 1000) { + throw new Error('Security brake: Too much TRs. Please define height for your table, which will enforce scrollbars.'); + } + if (rowsToRender !== void 0 && visibleRowIndex === rowsToRender) { + break; + } + TR = this.getOrCreateTrForRow(visibleRowIndex, TR); + this.renderRowHeaders(sourceRowIndex, TR); + this.adjustColumns(TR, columnsToRender + this.rowHeaderCount); + lastTD = this.renderCells(sourceRowIndex, TR, columnsToRender); + if (!isWorkingOnClone) { + this.resetOversizedRow(sourceRowIndex); + } + if (TR.firstChild) { + var height = this.wot.wtTable.getRowHeight(sourceRowIndex); + if (height) { + height--; + TR.firstChild.style.height = height + 'px'; + } else { + TR.firstChild.style.height = ''; + } + } + visibleRowIndex++; + sourceRowIndex = this.rowFilter.renderedToSource(visibleRowIndex); + } + }, + resetOversizedRow: function(sourceRow) { + if (this.wot.getSetting('externalRowCalculator')) { + return; + } + if (this.wot.wtViewport.oversizedRows && this.wot.wtViewport.oversizedRows[sourceRow]) { + this.wot.wtViewport.oversizedRows[sourceRow] = void 0; + } + }, + markOversizedRows: function() { + if (this.wot.getSetting('externalRowCalculator')) { + return; + } + var rowCount = this.instance.wtTable.TBODY.childNodes.length; + var expectedTableHeight = rowCount * this.instance.wtSettings.settings.defaultRowHeight; + var actualTableHeight = dom.innerHeight(this.instance.wtTable.TBODY) - 1; + var previousRowHeight; + var rowInnerHeight; + var sourceRowIndex; + var currentTr; + var rowHeader; + if (expectedTableHeight === actualTableHeight) { + return; + } + while (rowCount) { + rowCount--; + sourceRowIndex = this.instance.wtTable.rowFilter.renderedToSource(rowCount); + previousRowHeight = this.instance.wtTable.getRowHeight(sourceRowIndex); + currentTr = this.instance.wtTable.getTrForRow(sourceRowIndex); + rowHeader = currentTr.querySelector('th'); + if (rowHeader) { + rowInnerHeight = dom.innerHeight(rowHeader); + } else { + rowInnerHeight = dom.innerHeight(currentTr) - 1; + } + if ((!previousRowHeight && this.instance.wtSettings.settings.defaultRowHeight < rowInnerHeight || previousRowHeight < rowInnerHeight)) { + this.instance.wtViewport.oversizedRows[sourceRowIndex] = ++rowInnerHeight; + } + } + }, + markOversizedColumns: function() { + var overlayName = this.wot.getOverlayName(); + if (!this.columnHeaderCount || isMarkedOversizedColumn[overlayName] || this.wtTable.isWorkingOnClone()) { + return; + } + var columnCount = this.wtTable.getRenderedColumnsCount(); + for (var i = 0; i < this.columnHeaderCount; i++) { + for (var renderedColumnIndex = (-1) * this.rowHeaderCount; renderedColumnIndex < columnCount; renderedColumnIndex++) { + this.markIfOversizedColumnHeader(renderedColumnIndex); + } + } + isMarkedOversizedColumn[overlayName] = true; + }, + adjustColumnHeaderHeights: function() { + var columnHeaders = this.wot.getSetting('columnHeaders'); + var childs = this.wot.wtTable.THEAD.childNodes; + var oversizedCols = this.wot.wtViewport.oversizedColumnHeaders; + for (var i = 0, + len = columnHeaders.length; i < len; i++) { + if (oversizedCols[i]) { + if (childs[i].childNodes.length === 0) { + return; + } + childs[i].childNodes[0].style.height = oversizedCols[i] + 'px'; + } + } + }, + markIfOversizedColumnHeader: function(col) { + var sourceColIndex = this.wot.wtTable.columnFilter.renderedToSource(col); + var level = this.columnHeaderCount; + var defaultRowHeight = this.wot.wtSettings.settings.defaultRowHeight; + var previousColHeaderHeight; + var currentHeader; + var currentHeaderHeight; + while (level) { + level--; + previousColHeaderHeight = this.wot.wtTable.getColumnHeaderHeight(level); + currentHeader = this.wot.wtTable.getColumnHeader(sourceColIndex, level); + if (!currentHeader) { + continue; + } + currentHeaderHeight = dom.innerHeight(currentHeader); + if (!previousColHeaderHeight && defaultRowHeight < currentHeaderHeight || previousColHeaderHeight < currentHeaderHeight) { + this.wot.wtViewport.oversizedColumnHeaders[level] = currentHeaderHeight; + } + } + }, + renderCells: function(sourceRowIndex, TR, columnsToRender) { + var TD; + var sourceColIndex; + for (var visibleColIndex = 0; visibleColIndex < columnsToRender; visibleColIndex++) { + sourceColIndex = this.columnFilter.renderedToSource(visibleColIndex); + if (visibleColIndex === 0) { + TD = TR.childNodes[this.columnFilter.sourceColumnToVisibleRowHeadedColumn(sourceColIndex)]; + } else { + TD = TD.nextSibling; + } + if (TD.nodeName == 'TH') { + TD = replaceThWithTd(TD, TR); + } + if (!dom.hasClass(TD, 'hide')) { + TD.className = ''; + } + TD.removeAttribute('style'); + this.wot.wtSettings.settings.cellRenderer(sourceRowIndex, sourceColIndex, TD); + } + return TD; + }, + adjustColumnWidths: function(columnsToRender) { + var scrollbarCompensation = 0; + var sourceInstance = this.wot.cloneSource ? this.wot.cloneSource : this.wot; + var mainHolder = sourceInstance.wtTable.holder; + if (mainHolder.offsetHeight < mainHolder.scrollHeight) { + scrollbarCompensation = dom.getScrollbarWidth(); + } + this.wot.wtViewport.columnsRenderCalculator.refreshStretching(this.wot.wtViewport.getViewportWidth() - scrollbarCompensation); + for (var renderedColIndex = 0; renderedColIndex < columnsToRender; renderedColIndex++) { + var width = this.wtTable.getStretchedColumnWidth(this.columnFilter.renderedToSource(renderedColIndex)); + this.COLGROUP.childNodes[renderedColIndex + this.rowHeaderCount].style.width = width + 'px'; + } + }, + appendToTbody: function(TR) { + this.TBODY.appendChild(TR); + this.wtTable.tbodyChildrenLength++; + }, + getOrCreateTrForRow: function(rowIndex, currentTr) { + var TR; + if (rowIndex >= this.wtTable.tbodyChildrenLength) { + TR = this.createRow(); + this.appendToTbody(TR); + } else if (rowIndex === 0) { + TR = this.TBODY.firstChild; + } else { + TR = currentTr.nextSibling; + } + return TR; + }, + createRow: function() { + var TR = document.createElement('TR'); + for (var visibleColIndex = 0; visibleColIndex < this.rowHeaderCount; visibleColIndex++) { + TR.appendChild(document.createElement('TH')); + } + return TR; + }, + renderRowHeader: function(row, col, TH) { + TH.className = ''; + TH.removeAttribute('style'); + this.rowHeaders[col](row, TH, col); + }, + renderRowHeaders: function(row, TR) { + for (var TH = TR.firstChild, + visibleColIndex = 0; visibleColIndex < this.rowHeaderCount; visibleColIndex++) { + if (!TH) { + TH = document.createElement('TH'); + TR.appendChild(TH); + } else if (TH.nodeName == 'TD') { + TH = replaceTdWithTh(TH, TR); + } + this.renderRowHeader(row, visibleColIndex, TH); + TH = TH.nextSibling; + } + }, + adjustAvailableNodes: function() { + this.adjustColGroups(); + this.adjustThead(); + }, + renderColumnHeaders: function() { + var overlayName = this.wot.getOverlayName(); + if (!this.columnHeaderCount) { + return; + } + var columnCount = this.wtTable.getRenderedColumnsCount(); + for (var i = 0; i < this.columnHeaderCount; i++) { + var TR = this.getTrForColumnHeaders(i); + for (var renderedColumnIndex = (-1) * this.rowHeaderCount; renderedColumnIndex < columnCount; renderedColumnIndex++) { + var sourceCol = this.columnFilter.renderedToSource(renderedColumnIndex); + this.renderColumnHeader(i, sourceCol, TR.childNodes[renderedColumnIndex + this.rowHeaderCount]); + } + } + }, + adjustColGroups: function() { + var columnCount = this.wtTable.getRenderedColumnsCount(); + while (this.wtTable.colgroupChildrenLength < columnCount + this.rowHeaderCount) { + this.COLGROUP.appendChild(document.createElement('COL')); + this.wtTable.colgroupChildrenLength++; + } + while (this.wtTable.colgroupChildrenLength > columnCount + this.rowHeaderCount) { + this.COLGROUP.removeChild(this.COLGROUP.lastChild); + this.wtTable.colgroupChildrenLength--; + } + if (this.rowHeaderCount) { + dom.addClass(this.COLGROUP.childNodes[0], 'rowHeader'); + } + }, + adjustThead: function() { + var columnCount = this.wtTable.getRenderedColumnsCount(); + var TR = this.THEAD.firstChild; + if (this.columnHeaders.length) { + for (var i = 0, + len = this.columnHeaders.length; i < len; i++) { + TR = this.THEAD.childNodes[i]; + if (!TR) { + TR = document.createElement('TR'); + this.THEAD.appendChild(TR); + } + this.theadChildrenLength = TR.childNodes.length; + while (this.theadChildrenLength < columnCount + this.rowHeaderCount) { + TR.appendChild(document.createElement('TH')); + this.theadChildrenLength++; + } + while (this.theadChildrenLength > columnCount + this.rowHeaderCount) { + TR.removeChild(TR.lastChild); + this.theadChildrenLength--; + } + } + var theadChildrenLength = this.THEAD.childNodes.length; + if (theadChildrenLength > this.columnHeaders.length) { + for (var i$__1 = this.columnHeaders.length; i$__1 < theadChildrenLength; i$__1++) { + this.THEAD.removeChild(this.THEAD.lastChild); + } + } + } else if (TR) { + dom.empty(TR); + } + }, + getTrForColumnHeaders: function(index) { + return this.THEAD.childNodes[index]; + }, + renderColumnHeader: function(row, col, TH) { + TH.className = ''; + TH.removeAttribute('style'); + return this.columnHeaders[row](col, TH, row); + }, + adjustColumns: function(TR, desiredCount) { + var count = TR.childNodes.length; + while (count < desiredCount) { + var TD = document.createElement('TD'); + TR.appendChild(TD); + count++; + } + while (count > desiredCount) { + TR.removeChild(TR.lastChild); + count--; + } + }, + removeRedundantColumns: function(columnsToRender) { + while (this.wtTable.tbodyChildrenLength > columnsToRender) { + this.TBODY.removeChild(this.TBODY.lastChild); + this.wtTable.tbodyChildrenLength--; + } + } +}, {}); +function replaceTdWithTh(TD, TR) { + var TH = document.createElement('TH'); + TR.insertBefore(TH, TD); + TR.removeChild(TD); + return TH; +} +function replaceThWithTd(TH, TR) { + var TD = document.createElement('TD'); + TR.insertBefore(TD, TH); + TR.removeChild(TH); + return TD; +} +; +window.WalkontableTableRenderer = WalkontableTableRenderer; + +//# +},{"dom.js":27}],22:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + WalkontableViewport: {get: function() { + return WalkontableViewport; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47__46__46__47_eventManager_46_js__, + $__calculator_47_viewportColumns_46_js__, + $__calculator_47_viewportRows_46_js__; +var dom = ($___46__46__47__46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_dom_46_js__}); +var EventManager = ($___46__46__47__46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47__46__46__47_eventManager_46_js__}).EventManager; +var WalkontableViewportColumnsCalculator = ($__calculator_47_viewportColumns_46_js__ = require("calculator/viewportColumns.js"), $__calculator_47_viewportColumns_46_js__ && $__calculator_47_viewportColumns_46_js__.__esModule && $__calculator_47_viewportColumns_46_js__ || {default: $__calculator_47_viewportColumns_46_js__}).WalkontableViewportColumnsCalculator; +var WalkontableViewportRowsCalculator = ($__calculator_47_viewportRows_46_js__ = require("calculator/viewportRows.js"), $__calculator_47_viewportRows_46_js__ && $__calculator_47_viewportRows_46_js__.__esModule && $__calculator_47_viewportRows_46_js__ || {default: $__calculator_47_viewportRows_46_js__}).WalkontableViewportRowsCalculator; +var WalkontableViewport = function WalkontableViewport(wotInstance) { + var $__3 = this; + this.wot = wotInstance; + this.instance = this.wot; + this.oversizedRows = []; + this.oversizedColumnHeaders = []; + this.clientHeight = 0; + this.containerWidth = NaN; + this.rowHeaderWidth = NaN; + this.rowsVisibleCalculator = null; + this.columnsVisibleCalculator = null; + this.eventManager = new EventManager(this.wot); + this.eventManager.addEventListener(window, 'resize', (function() { + $__3.clientHeight = $__3.getWorkspaceHeight(); + })); +}; +($traceurRuntime.createClass)(WalkontableViewport, { + getWorkspaceHeight: function() { + var trimmingContainer = this.instance.wtOverlays.topOverlay.trimmingContainer; + var elemHeight; + var height = 0; + if (trimmingContainer === window) { + height = document.documentElement.clientHeight; + } else { + elemHeight = dom.outerHeight(trimmingContainer); + height = (elemHeight > 0 && trimmingContainer.clientHeight > 0) ? trimmingContainer.clientHeight : Infinity; + } + return height; + }, + getWorkspaceWidth: function() { + var width; + var totalColumns = this.instance.getSetting("totalColumns"); + var trimmingContainer = this.instance.wtOverlays.leftOverlay.trimmingContainer; + var overflow; + var stretchSetting = this.instance.getSetting('stretchH'); + var docOffsetWidth = document.documentElement.offsetWidth; + if (Handsontable.freezeOverlays) { + width = Math.min(docOffsetWidth - this.getWorkspaceOffset().left, docOffsetWidth); + } else { + width = Math.min(this.getContainerFillWidth(), docOffsetWidth - this.getWorkspaceOffset().left, docOffsetWidth); + } + if (trimmingContainer === window && totalColumns > 0 && this.sumColumnWidths(0, totalColumns - 1) > width) { + return document.documentElement.clientWidth; + } + if (trimmingContainer !== window) { + overflow = dom.getStyle(this.instance.wtOverlays.leftOverlay.trimmingContainer, 'overflow'); + if (overflow == "scroll" || overflow == "hidden" || overflow == "auto") { + return Math.max(width, trimmingContainer.clientWidth); + } + } + if (stretchSetting === 'none' || !stretchSetting) { + return Math.max(width, dom.outerWidth(this.instance.wtTable.TABLE)); + } else { + return width; + } + }, + hasVerticalScroll: function() { + return this.getWorkspaceActualHeight() > this.getWorkspaceHeight(); + }, + hasHorizontalScroll: function() { + return this.getWorkspaceActualWidth() > this.getWorkspaceWidth(); + }, + sumColumnWidths: function(from, length) { + var sum = 0; + while (from < length) { + sum += this.wot.wtTable.getColumnWidth(from); + from++; + } + return sum; + }, + getContainerFillWidth: function() { + if (this.containerWidth) { + return this.containerWidth; + } + var mainContainer = this.instance.wtTable.holder; + var fillWidth; + var dummyElement; + dummyElement = document.createElement("DIV"); + dummyElement.style.width = "100%"; + dummyElement.style.height = "1px"; + mainContainer.appendChild(dummyElement); + fillWidth = dummyElement.offsetWidth; + this.containerWidth = fillWidth; + mainContainer.removeChild(dummyElement); + return fillWidth; + }, + getWorkspaceOffset: function() { + return dom.offset(this.wot.wtTable.TABLE); + }, + getWorkspaceActualHeight: function() { + return dom.outerHeight(this.wot.wtTable.TABLE); + }, + getWorkspaceActualWidth: function() { + return dom.outerWidth(this.wot.wtTable.TABLE) || dom.outerWidth(this.wot.wtTable.TBODY) || dom.outerWidth(this.wot.wtTable.THEAD); + }, + getColumnHeaderHeight: function() { + if (isNaN(this.columnHeaderHeight)) { + this.columnHeaderHeight = dom.outerHeight(this.wot.wtTable.THEAD); + } + return this.columnHeaderHeight; + }, + getViewportHeight: function() { + var containerHeight = this.getWorkspaceHeight(); + var columnHeaderHeight; + if (containerHeight === Infinity) { + return containerHeight; + } + columnHeaderHeight = this.getColumnHeaderHeight(); + if (columnHeaderHeight > 0) { + containerHeight -= columnHeaderHeight; + } + return containerHeight; + }, + getRowHeaderWidth: function() { + if (this.wot.cloneSource) { + return this.wot.cloneSource.wtViewport.getRowHeaderWidth(); + } + if (isNaN(this.rowHeaderWidth)) { + var rowHeaders = this.instance.getSetting('rowHeaders'); + if (rowHeaders.length) { + var TH = this.instance.wtTable.TABLE.querySelector('TH'); + this.rowHeaderWidth = 0; + for (var i = 0, + len = rowHeaders.length; i < len; i++) { + if (TH) { + this.rowHeaderWidth += dom.outerWidth(TH); + TH = TH.nextSibling; + } else { + this.rowHeaderWidth += 50; + } + } + } else { + this.rowHeaderWidth = 0; + } + } + return this.rowHeaderWidth; + }, + getViewportWidth: function() { + var containerWidth = this.getWorkspaceWidth(); + var rowHeaderWidth; + if (containerWidth === Infinity) { + return containerWidth; + } + rowHeaderWidth = this.getRowHeaderWidth(); + if (rowHeaderWidth > 0) { + return containerWidth - rowHeaderWidth; + } + return containerWidth; + }, + createRowsCalculator: function() { + var visible = arguments[0] !== (void 0) ? arguments[0] : false; + var $__3 = this; + var height; + var pos; + var fixedRowsTop; + this.rowHeaderWidth = NaN; + if (this.wot.wtSettings.settings.renderAllRows) { + height = Infinity; + } else { + height = this.getViewportHeight(); + } + pos = dom.getScrollTop(this.wot.wtOverlays.mainTableScrollableElement) - this.wot.wtOverlays.topOverlay.getTableParentOffset(); + if (pos < 0) { + pos = 0; + } + fixedRowsTop = this.wot.getSetting('fixedRowsTop'); + if (fixedRowsTop) { + var fixedRowsHeight = this.wot.wtOverlays.topOverlay.sumCellSizes(0, fixedRowsTop); + pos += fixedRowsHeight; + height -= fixedRowsHeight; + } + return new WalkontableViewportRowsCalculator(height, pos, this.wot.getSetting('totalRows'), (function(sourceRow) { + return $__3.wot.wtTable.getRowHeight(sourceRow); + }), visible ? null : this.wot.wtSettings.settings.viewportRowCalculatorOverride, visible); + }, + createColumnsCalculator: function() { + var visible = arguments[0] !== (void 0) ? arguments[0] : false; + var $__3 = this; + var width = this.getViewportWidth(); + var pos; + var fixedColumnsLeft; + this.columnHeaderHeight = NaN; + pos = this.wot.wtOverlays.leftOverlay.getScrollPosition() - this.wot.wtOverlays.topOverlay.getTableParentOffset(); + if (pos < 0) { + pos = 0; + } + fixedColumnsLeft = this.wot.getSetting('fixedColumnsLeft'); + if (fixedColumnsLeft) { + var fixedColumnsWidth = this.wot.wtOverlays.leftOverlay.sumCellSizes(0, fixedColumnsLeft); + pos += fixedColumnsWidth; + width -= fixedColumnsWidth; + } + if (this.wot.wtTable.holder.clientWidth !== this.wot.wtTable.holder.offsetWidth) { + width -= dom.getScrollbarWidth(); + } + return new WalkontableViewportColumnsCalculator(width, pos, this.wot.getSetting('totalColumns'), (function(sourceCol) { + return $__3.wot.wtTable.getColumnWidth(sourceCol); + }), visible ? null : this.wot.wtSettings.settings.viewportColumnCalculatorOverride, visible, this.wot.getSetting('stretchH')); + }, + createRenderCalculators: function() { + var fastDraw = arguments[0] !== (void 0) ? arguments[0] : false; + if (fastDraw) { + var proposedRowsVisibleCalculator = this.createRowsCalculator(true); + var proposedColumnsVisibleCalculator = this.createColumnsCalculator(true); + if (!(this.areAllProposedVisibleRowsAlreadyRendered(proposedRowsVisibleCalculator) && this.areAllProposedVisibleColumnsAlreadyRendered(proposedColumnsVisibleCalculator))) { + fastDraw = false; + } + } + if (!fastDraw) { + this.rowsRenderCalculator = this.createRowsCalculator(); + this.columnsRenderCalculator = this.createColumnsCalculator(); + } + this.rowsVisibleCalculator = null; + this.columnsVisibleCalculator = null; + return fastDraw; + }, + createVisibleCalculators: function() { + this.rowsVisibleCalculator = this.createRowsCalculator(true); + this.columnsVisibleCalculator = this.createColumnsCalculator(true); + }, + areAllProposedVisibleRowsAlreadyRendered: function(proposedRowsVisibleCalculator) { + if (this.rowsVisibleCalculator) { + if (proposedRowsVisibleCalculator.startRow < this.rowsRenderCalculator.startRow || (proposedRowsVisibleCalculator.startRow === this.rowsRenderCalculator.startRow && proposedRowsVisibleCalculator.startRow > 0)) { + return false; + } else if (proposedRowsVisibleCalculator.endRow > this.rowsRenderCalculator.endRow || (proposedRowsVisibleCalculator.endRow === this.rowsRenderCalculator.endRow && proposedRowsVisibleCalculator.endRow < this.wot.getSetting('totalRows') - 1)) { + return false; + } else { + return true; + } + } + return false; + }, + areAllProposedVisibleColumnsAlreadyRendered: function(proposedColumnsVisibleCalculator) { + if (this.columnsVisibleCalculator) { + if (proposedColumnsVisibleCalculator.startColumn < this.columnsRenderCalculator.startColumn || (proposedColumnsVisibleCalculator.startColumn === this.columnsRenderCalculator.startColumn && proposedColumnsVisibleCalculator.startColumn > 0)) { + return false; + } else if (proposedColumnsVisibleCalculator.endColumn > this.columnsRenderCalculator.endColumn || (proposedColumnsVisibleCalculator.endColumn === this.columnsRenderCalculator.endColumn && proposedColumnsVisibleCalculator.endColumn < this.wot.getSetting('totalColumns') - 1)) { + return false; + } else { + return true; + } + } + return false; + } +}, {}); +; +window.WalkontableViewport = WalkontableViewport; + +//# +},{"calculator/viewportColumns.js":3,"calculator/viewportRows.js":4,"dom.js":27,"eventManager.js":41}],23:[function(require,module,exports){ +"use strict"; +var $__shims_47_classes_46_js__, + $__es6collections__, + $__pluginHooks_46_js__, + $__core_46_js__, + $__renderers_47__95_cellDecorator_46_js__, + $__cellTypes_46_js__, + $___46__46__47_plugins_47_jqueryHandsontable_46_js__; +var version = Handsontable.version; +var buildDate = Handsontable.buildDate; +window.Handsontable = function Handsontable(rootElement, userSettings) { + var instance = new Handsontable.Core(rootElement, userSettings || {}); + instance.init(); + return instance; +}; +Handsontable.version = version; +Handsontable.buildDate = buildDate; +($__shims_47_classes_46_js__ = require("shims/classes.js"), $__shims_47_classes_46_js__ && $__shims_47_classes_46_js__.__esModule && $__shims_47_classes_46_js__ || {default: $__shims_47_classes_46_js__}); +($__es6collections__ = require("es6collections"), $__es6collections__ && $__es6collections__.__esModule && $__es6collections__ || {default: $__es6collections__}); +Handsontable.plugins = {}; +var Hooks = ($__pluginHooks_46_js__ = require("pluginHooks.js"), $__pluginHooks_46_js__ && $__pluginHooks_46_js__.__esModule && $__pluginHooks_46_js__ || {default: $__pluginHooks_46_js__}).Hooks; +if (!Handsontable.hooks) { + Handsontable.hooks = new Hooks(); +} +($__core_46_js__ = require("core.js"), $__core_46_js__ && $__core_46_js__.__esModule && $__core_46_js__ || {default: $__core_46_js__}); +($__renderers_47__95_cellDecorator_46_js__ = require("renderers/_cellDecorator.js"), $__renderers_47__95_cellDecorator_46_js__ && $__renderers_47__95_cellDecorator_46_js__.__esModule && $__renderers_47__95_cellDecorator_46_js__ || {default: $__renderers_47__95_cellDecorator_46_js__}); +($__cellTypes_46_js__ = require("cellTypes.js"), $__cellTypes_46_js__ && $__cellTypes_46_js__.__esModule && $__cellTypes_46_js__ || {default: $__cellTypes_46_js__}); +($___46__46__47_plugins_47_jqueryHandsontable_46_js__ = require("plugins/jqueryHandsontable.js"), $___46__46__47_plugins_47_jqueryHandsontable_46_js__ && $___46__46__47_plugins_47_jqueryHandsontable_46_js__.__esModule && $___46__46__47_plugins_47_jqueryHandsontable_46_js__ || {default: $___46__46__47_plugins_47_jqueryHandsontable_46_js__}); + +//# +},{"cellTypes.js":24,"core.js":25,"es6collections":"es6collections","pluginHooks.js":44,"plugins/jqueryHandsontable.js":1,"renderers/_cellDecorator.js":72,"shims/classes.js":79}],24:[function(require,module,exports){ +"use strict"; +var $__helpers_46_js__, + $__editors_46_js__, + $__renderers_46_js__, + $__editors_47_autocompleteEditor_46_js__, + $__editors_47_checkboxEditor_46_js__, + $__editors_47_dateEditor_46_js__, + $__editors_47_dropdownEditor_46_js__, + $__editors_47_handsontableEditor_46_js__, + $__editors_47_mobileTextEditor_46_js__, + $__editors_47_numericEditor_46_js__, + $__editors_47_passwordEditor_46_js__, + $__editors_47_selectEditor_46_js__, + $__editors_47_textEditor_46_js__, + $__renderers_47_autocompleteRenderer_46_js__, + $__renderers_47_checkboxRenderer_46_js__, + $__renderers_47_htmlRenderer_46_js__, + $__renderers_47_numericRenderer_46_js__, + $__renderers_47_passwordRenderer_46_js__, + $__renderers_47_textRenderer_46_js__, + $__validators_47_autocompleteValidator_46_js__, + $__validators_47_dateValidator_46_js__, + $__validators_47_numericValidator_46_js__; +var helper = ($__helpers_46_js__ = require("helpers.js"), $__helpers_46_js__ && $__helpers_46_js__.__esModule && $__helpers_46_js__ || {default: $__helpers_46_js__}); +var getEditorConstructor = ($__editors_46_js__ = require("editors.js"), $__editors_46_js__ && $__editors_46_js__.__esModule && $__editors_46_js__ || {default: $__editors_46_js__}).getEditorConstructor; +var getRenderer = ($__renderers_46_js__ = require("renderers.js"), $__renderers_46_js__ && $__renderers_46_js__.__esModule && $__renderers_46_js__ || {default: $__renderers_46_js__}).getRenderer; +var AutocompleteEditor = ($__editors_47_autocompleteEditor_46_js__ = require("editors/autocompleteEditor.js"), $__editors_47_autocompleteEditor_46_js__ && $__editors_47_autocompleteEditor_46_js__.__esModule && $__editors_47_autocompleteEditor_46_js__ || {default: $__editors_47_autocompleteEditor_46_js__}).AutocompleteEditor; +var CheckboxEditor = ($__editors_47_checkboxEditor_46_js__ = require("editors/checkboxEditor.js"), $__editors_47_checkboxEditor_46_js__ && $__editors_47_checkboxEditor_46_js__.__esModule && $__editors_47_checkboxEditor_46_js__ || {default: $__editors_47_checkboxEditor_46_js__}).CheckboxEditor; +var DateEditor = ($__editors_47_dateEditor_46_js__ = require("editors/dateEditor.js"), $__editors_47_dateEditor_46_js__ && $__editors_47_dateEditor_46_js__.__esModule && $__editors_47_dateEditor_46_js__ || {default: $__editors_47_dateEditor_46_js__}).DateEditor; +var DropdownEditor = ($__editors_47_dropdownEditor_46_js__ = require("editors/dropdownEditor.js"), $__editors_47_dropdownEditor_46_js__ && $__editors_47_dropdownEditor_46_js__.__esModule && $__editors_47_dropdownEditor_46_js__ || {default: $__editors_47_dropdownEditor_46_js__}).DropdownEditor; +var HandsontableEditor = ($__editors_47_handsontableEditor_46_js__ = require("editors/handsontableEditor.js"), $__editors_47_handsontableEditor_46_js__ && $__editors_47_handsontableEditor_46_js__.__esModule && $__editors_47_handsontableEditor_46_js__ || {default: $__editors_47_handsontableEditor_46_js__}).HandsontableEditor; +var MobileTextEditor = ($__editors_47_mobileTextEditor_46_js__ = require("editors/mobileTextEditor.js"), $__editors_47_mobileTextEditor_46_js__ && $__editors_47_mobileTextEditor_46_js__.__esModule && $__editors_47_mobileTextEditor_46_js__ || {default: $__editors_47_mobileTextEditor_46_js__}).MobileTextEditor; +var NumericEditor = ($__editors_47_numericEditor_46_js__ = require("editors/numericEditor.js"), $__editors_47_numericEditor_46_js__ && $__editors_47_numericEditor_46_js__.__esModule && $__editors_47_numericEditor_46_js__ || {default: $__editors_47_numericEditor_46_js__}).NumericEditor; +var PasswordEditor = ($__editors_47_passwordEditor_46_js__ = require("editors/passwordEditor.js"), $__editors_47_passwordEditor_46_js__ && $__editors_47_passwordEditor_46_js__.__esModule && $__editors_47_passwordEditor_46_js__ || {default: $__editors_47_passwordEditor_46_js__}).PasswordEditor; +var SelectEditor = ($__editors_47_selectEditor_46_js__ = require("editors/selectEditor.js"), $__editors_47_selectEditor_46_js__ && $__editors_47_selectEditor_46_js__.__esModule && $__editors_47_selectEditor_46_js__ || {default: $__editors_47_selectEditor_46_js__}).SelectEditor; +var TextEditor = ($__editors_47_textEditor_46_js__ = require("editors/textEditor.js"), $__editors_47_textEditor_46_js__ && $__editors_47_textEditor_46_js__.__esModule && $__editors_47_textEditor_46_js__ || {default: $__editors_47_textEditor_46_js__}).TextEditor; +var AutocompleteRenderer = ($__renderers_47_autocompleteRenderer_46_js__ = require("renderers/autocompleteRenderer.js"), $__renderers_47_autocompleteRenderer_46_js__ && $__renderers_47_autocompleteRenderer_46_js__.__esModule && $__renderers_47_autocompleteRenderer_46_js__ || {default: $__renderers_47_autocompleteRenderer_46_js__}).AutocompleteRenderer; +var CheckboxRenderer = ($__renderers_47_checkboxRenderer_46_js__ = require("renderers/checkboxRenderer.js"), $__renderers_47_checkboxRenderer_46_js__ && $__renderers_47_checkboxRenderer_46_js__.__esModule && $__renderers_47_checkboxRenderer_46_js__ || {default: $__renderers_47_checkboxRenderer_46_js__}).CheckboxRenderer; +var HtmlRenderer = ($__renderers_47_htmlRenderer_46_js__ = require("renderers/htmlRenderer.js"), $__renderers_47_htmlRenderer_46_js__ && $__renderers_47_htmlRenderer_46_js__.__esModule && $__renderers_47_htmlRenderer_46_js__ || {default: $__renderers_47_htmlRenderer_46_js__}).HtmlRenderer; +var NumericRenderer = ($__renderers_47_numericRenderer_46_js__ = require("renderers/numericRenderer.js"), $__renderers_47_numericRenderer_46_js__ && $__renderers_47_numericRenderer_46_js__.__esModule && $__renderers_47_numericRenderer_46_js__ || {default: $__renderers_47_numericRenderer_46_js__}).NumericRenderer; +var PasswordRenderer = ($__renderers_47_passwordRenderer_46_js__ = require("renderers/passwordRenderer.js"), $__renderers_47_passwordRenderer_46_js__ && $__renderers_47_passwordRenderer_46_js__.__esModule && $__renderers_47_passwordRenderer_46_js__ || {default: $__renderers_47_passwordRenderer_46_js__}).PasswordRenderer; +var TextRenderer = ($__renderers_47_textRenderer_46_js__ = require("renderers/textRenderer.js"), $__renderers_47_textRenderer_46_js__ && $__renderers_47_textRenderer_46_js__.__esModule && $__renderers_47_textRenderer_46_js__ || {default: $__renderers_47_textRenderer_46_js__}).TextRenderer; +var AutocompleteValidator = ($__validators_47_autocompleteValidator_46_js__ = require("validators/autocompleteValidator.js"), $__validators_47_autocompleteValidator_46_js__ && $__validators_47_autocompleteValidator_46_js__.__esModule && $__validators_47_autocompleteValidator_46_js__ || {default: $__validators_47_autocompleteValidator_46_js__}).AutocompleteValidator; +var DateValidator = ($__validators_47_dateValidator_46_js__ = require("validators/dateValidator.js"), $__validators_47_dateValidator_46_js__ && $__validators_47_dateValidator_46_js__.__esModule && $__validators_47_dateValidator_46_js__ || {default: $__validators_47_dateValidator_46_js__}).DateValidator; +var NumericValidator = ($__validators_47_numericValidator_46_js__ = require("validators/numericValidator.js"), $__validators_47_numericValidator_46_js__ && $__validators_47_numericValidator_46_js__.__esModule && $__validators_47_numericValidator_46_js__ || {default: $__validators_47_numericValidator_46_js__}).NumericValidator; +Handsontable.mobileBrowser = helper.isMobileBrowser(); +Handsontable.AutocompleteCell = { + editor: getEditorConstructor('autocomplete'), + renderer: getRenderer('autocomplete'), + validator: Handsontable.AutocompleteValidator +}; +Handsontable.CheckboxCell = { + editor: getEditorConstructor('checkbox'), + renderer: getRenderer('checkbox') +}; +Handsontable.TextCell = { + editor: Handsontable.mobileBrowser ? getEditorConstructor('mobile') : getEditorConstructor('text'), + renderer: getRenderer('text') +}; +Handsontable.NumericCell = { + editor: getEditorConstructor('numeric'), + renderer: getRenderer('numeric'), + validator: Handsontable.NumericValidator, + dataType: 'number' +}; +Handsontable.DateCell = { + editor: getEditorConstructor('date'), + validator: Handsontable.DateValidator, + renderer: getRenderer('autocomplete') +}; +Handsontable.HandsontableCell = { + editor: getEditorConstructor('handsontable'), + renderer: getRenderer('autocomplete') +}; +Handsontable.PasswordCell = { + editor: getEditorConstructor('password'), + renderer: getRenderer('password'), + copyable: false +}; +Handsontable.DropdownCell = { + editor: getEditorConstructor('dropdown'), + renderer: getRenderer('autocomplete'), + validator: Handsontable.AutocompleteValidator +}; +Handsontable.cellTypes = { + text: Handsontable.TextCell, + date: Handsontable.DateCell, + numeric: Handsontable.NumericCell, + checkbox: Handsontable.CheckboxCell, + autocomplete: Handsontable.AutocompleteCell, + handsontable: Handsontable.HandsontableCell, + password: Handsontable.PasswordCell, + dropdown: Handsontable.DropdownCell +}; +Handsontable.cellLookup = {validator: { + numeric: Handsontable.NumericValidator, + autocomplete: Handsontable.AutocompleteValidator + }}; + +//# +},{"editors.js":29,"editors/autocompleteEditor.js":31,"editors/checkboxEditor.js":32,"editors/dateEditor.js":33,"editors/dropdownEditor.js":34,"editors/handsontableEditor.js":35,"editors/mobileTextEditor.js":36,"editors/numericEditor.js":37,"editors/passwordEditor.js":38,"editors/selectEditor.js":39,"editors/textEditor.js":40,"helpers.js":42,"renderers.js":71,"renderers/autocompleteRenderer.js":73,"renderers/checkboxRenderer.js":74,"renderers/htmlRenderer.js":75,"renderers/numericRenderer.js":76,"renderers/passwordRenderer.js":77,"renderers/textRenderer.js":78,"validators/autocompleteValidator.js":83,"validators/dateValidator.js":84,"validators/numericValidator.js":85}],25:[function(require,module,exports){ +"use strict"; +var $__dom_46_js__, + $__helpers_46_js__, + $__numeral__, + $__dataMap_46_js__, + $__editorManager_46_js__, + $__eventManager_46_js__, + $__plugins_46_js__, + $__renderers_46_js__, + $__tableView_46_js__, + $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__, + $__3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__, + $__3rdparty_47_walkontable_47_src_47_selection_46_js__, + $__3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__; +var dom = ($__dom_46_js__ = require("dom.js"), $__dom_46_js__ && $__dom_46_js__.__esModule && $__dom_46_js__ || {default: $__dom_46_js__}); +var helper = ($__helpers_46_js__ = require("helpers.js"), $__helpers_46_js__ && $__helpers_46_js__.__esModule && $__helpers_46_js__ || {default: $__helpers_46_js__}); +var numeral = ($__numeral__ = require("numeral"), $__numeral__ && $__numeral__.__esModule && $__numeral__ || {default: $__numeral__}).default; +var DataMap = ($__dataMap_46_js__ = require("dataMap.js"), $__dataMap_46_js__ && $__dataMap_46_js__.__esModule && $__dataMap_46_js__ || {default: $__dataMap_46_js__}).DataMap; +var EditorManager = ($__editorManager_46_js__ = require("editorManager.js"), $__editorManager_46_js__ && $__editorManager_46_js__.__esModule && $__editorManager_46_js__ || {default: $__editorManager_46_js__}).EditorManager; +var eventManagerObject = ($__eventManager_46_js__ = require("eventManager.js"), $__eventManager_46_js__ && $__eventManager_46_js__.__esModule && $__eventManager_46_js__ || {default: $__eventManager_46_js__}).eventManager; +var getPlugin = ($__plugins_46_js__ = require("plugins.js"), $__plugins_46_js__ && $__plugins_46_js__.__esModule && $__plugins_46_js__ || {default: $__plugins_46_js__}).getPlugin; +var getRenderer = ($__renderers_46_js__ = require("renderers.js"), $__renderers_46_js__ && $__renderers_46_js__.__esModule && $__renderers_46_js__ || {default: $__renderers_46_js__}).getRenderer; +var TableView = ($__tableView_46_js__ = require("tableView.js"), $__tableView_46_js__ && $__tableView_46_js__.__esModule && $__tableView_46_js__ || {default: $__tableView_46_js__}).TableView; +var WalkontableCellCoords = ($__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ = require("3rdparty/walkontable/src/cell/coords.js"), $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ && $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__.__esModule && $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ || {default: $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__}).WalkontableCellCoords; +var WalkontableCellRange = ($__3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ = require("3rdparty/walkontable/src/cell/range.js"), $__3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ && $__3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__.__esModule && $__3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ || {default: $__3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__}).WalkontableCellRange; +var WalkontableSelection = ($__3rdparty_47_walkontable_47_src_47_selection_46_js__ = require("3rdparty/walkontable/src/selection.js"), $__3rdparty_47_walkontable_47_src_47_selection_46_js__ && $__3rdparty_47_walkontable_47_src_47_selection_46_js__.__esModule && $__3rdparty_47_walkontable_47_src_47_selection_46_js__ || {default: $__3rdparty_47_walkontable_47_src_47_selection_46_js__}).WalkontableSelection; +var WalkontableViewportColumnsCalculator = ($__3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__ = require("3rdparty/walkontable/src/calculator/viewportColumns.js"), $__3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__ && $__3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__.__esModule && $__3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__ || {default: $__3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__}).WalkontableViewportColumnsCalculator; +Handsontable.activeGuid = null; +Handsontable.Core = function Core(rootElement, userSettings) { + var priv, + datamap, + grid, + selection, + editorManager, + instance = this, + GridSettings = function() {}, + eventManager = eventManagerObject(instance); + helper.extend(GridSettings.prototype, DefaultSettings.prototype); + helper.extend(GridSettings.prototype, userSettings); + helper.extend(GridSettings.prototype, expandType(userSettings)); + this.rootElement = rootElement; + this.isHotTableEnv = dom.isChildOfWebComponentTable(this.rootElement); + Handsontable.eventManager.isHotTableEnv = this.isHotTableEnv; + this.container = document.createElement('DIV'); + this.renderCall = false; + rootElement.insertBefore(this.container, rootElement.firstChild); + this.guid = 'ht_' + helper.randomString(); + if (!this.rootElement.id || this.rootElement.id.substring(0, 3) === "ht_") { + this.rootElement.id = this.guid; + } + priv = { + cellSettings: [], + columnSettings: [], + columnsSettingConflicts: ['data', 'width'], + settings: new GridSettings(), + selRange: null, + isPopulated: null, + scrollable: null, + firstRun: true + }; + grid = { + alter: function(action, index, amount, source, keepEmptyRows) { + var delta; + amount = amount || 1; + switch (action) { + case "insert_row": + if (instance.getSettings().maxRows === instance.countRows()) { + return; + } + delta = datamap.createRow(index, amount); + if (delta) { + if (selection.isSelected() && priv.selRange.from.row >= index) { + priv.selRange.from.row = priv.selRange.from.row + delta; + selection.transformEnd(delta, 0); + } else { + selection.refreshBorders(); + } + } + break; + case "insert_col": + delta = datamap.createCol(index, amount); + if (delta) { + if (Array.isArray(instance.getSettings().colHeaders)) { + var spliceArray = [index, 0]; + spliceArray.length += delta; + Array.prototype.splice.apply(instance.getSettings().colHeaders, spliceArray); + } + if (selection.isSelected() && priv.selRange.from.col >= index) { + priv.selRange.from.col = priv.selRange.from.col + delta; + selection.transformEnd(0, delta); + } else { + selection.refreshBorders(); + } + } + break; + case "remove_row": + index = instance.runHooks('modifyCol', index); + datamap.removeRow(index, amount); + priv.cellSettings.splice(index, amount); + var fixedRowsTop = instance.getSettings().fixedRowsTop; + if (fixedRowsTop >= index + 1) { + instance.getSettings().fixedRowsTop -= Math.min(amount, fixedRowsTop - index); + } + grid.adjustRowsAndCols(); + selection.refreshBorders(); + break; + case "remove_col": + datamap.removeCol(index, amount); + for (var row = 0, + len = datamap.getAll().length; row < len; row++) { + if (row in priv.cellSettings) { + priv.cellSettings[row].splice(index, amount); + } + } + var fixedColumnsLeft = instance.getSettings().fixedColumnsLeft; + if (fixedColumnsLeft >= index + 1) { + instance.getSettings().fixedColumnsLeft -= Math.min(amount, fixedColumnsLeft - index); + } + if (Array.isArray(instance.getSettings().colHeaders)) { + if (typeof index == 'undefined') { + index = -1; + } + instance.getSettings().colHeaders.splice(index, amount); + } + grid.adjustRowsAndCols(); + selection.refreshBorders(); + break; + default: + throw new Error('There is no such action "' + action + '"'); + break; + } + if (!keepEmptyRows) { + grid.adjustRowsAndCols(); + } + }, + adjustRowsAndCols: function() { + if (priv.settings.minRows) { + var rows = instance.countRows(); + if (rows < priv.settings.minRows) { + for (var r = 0, + minRows = priv.settings.minRows; r < minRows - rows; r++) { + datamap.createRow(instance.countRows(), 1, true); + } + } + } + if (priv.settings.minSpareRows) { + var emptyRows = instance.countEmptyRows(true); + if (emptyRows < priv.settings.minSpareRows) { + for (; emptyRows < priv.settings.minSpareRows && instance.countRows() < priv.settings.maxRows; emptyRows++) { + datamap.createRow(instance.countRows(), 1, true); + } + } + } + { + var emptyCols; + if (priv.settings.minCols || priv.settings.minSpareCols) { + emptyCols = instance.countEmptyCols(true); + } + if (priv.settings.minCols && !priv.settings.columns && instance.countCols() < priv.settings.minCols) { + for (; instance.countCols() < priv.settings.minCols; emptyCols++) { + datamap.createCol(instance.countCols(), 1, true); + } + } + if (priv.settings.minSpareCols && !priv.settings.columns && instance.dataType === 'array' && emptyCols < priv.settings.minSpareCols) { + for (; emptyCols < priv.settings.minSpareCols && instance.countCols() < priv.settings.maxCols; emptyCols++) { + datamap.createCol(instance.countCols(), 1, true); + } + } + } + var rowCount = instance.countRows(); + var colCount = instance.countCols(); + if (rowCount === 0 || colCount === 0) { + selection.deselect(); + } + if (selection.isSelected()) { + var selectionChanged = false; + var fromRow = priv.selRange.from.row; + var fromCol = priv.selRange.from.col; + var toRow = priv.selRange.to.row; + var toCol = priv.selRange.to.col; + if (fromRow > rowCount - 1) { + fromRow = rowCount - 1; + selectionChanged = true; + if (toRow > fromRow) { + toRow = fromRow; + } + } else if (toRow > rowCount - 1) { + toRow = rowCount - 1; + selectionChanged = true; + if (fromRow > toRow) { + fromRow = toRow; + } + } + if (fromCol > colCount - 1) { + fromCol = colCount - 1; + selectionChanged = true; + if (toCol > fromCol) { + toCol = fromCol; + } + } else if (toCol > colCount - 1) { + toCol = colCount - 1; + selectionChanged = true; + if (fromCol > toCol) { + fromCol = toCol; + } + } + if (selectionChanged) { + instance.selectCell(fromRow, fromCol, toRow, toCol); + } + } + if (instance.view) { + instance.view.wt.wtOverlays.adjustElementsSize(); + } + }, + populateFromArray: function(start, input, end, source, method, direction, deltas) { + var r, + rlen, + c, + clen, + setData = [], + current = {}; + rlen = input.length; + if (rlen === 0) { + return false; + } + var repeatCol, + repeatRow, + cmax, + rmax; + switch (method) { + case 'shift_down': + repeatCol = end ? end.col - start.col + 1 : 0; + repeatRow = end ? end.row - start.row + 1 : 0; + input = helper.translateRowsToColumns(input); + for (c = 0, clen = input.length, cmax = Math.max(clen, repeatCol); c < cmax; c++) { + if (c < clen) { + for (r = 0, rlen = input[c].length; r < repeatRow - rlen; r++) { + input[c].push(input[c][r % rlen]); + } + input[c].unshift(start.col + c, start.row, 0); + instance.spliceCol.apply(instance, input[c]); + } else { + input[c % clen][0] = start.col + c; + instance.spliceCol.apply(instance, input[c % clen]); + } + } + break; + case 'shift_right': + repeatCol = end ? end.col - start.col + 1 : 0; + repeatRow = end ? end.row - start.row + 1 : 0; + for (r = 0, rlen = input.length, rmax = Math.max(rlen, repeatRow); r < rmax; r++) { + if (r < rlen) { + for (c = 0, clen = input[r].length; c < repeatCol - clen; c++) { + input[r].push(input[r][c % clen]); + } + input[r].unshift(start.row + r, start.col, 0); + instance.spliceRow.apply(instance, input[r]); + } else { + input[r % rlen][0] = start.row + r; + instance.spliceRow.apply(instance, input[r % rlen]); + } + } + break; + case 'overwrite': + default: + current.row = start.row; + current.col = start.col; + var iterators = { + row: 0, + col: 0 + }, + selected = { + row: (end && start) ? (end.row - start.row + 1) : 1, + col: (end && start) ? (end.col - start.col + 1) : 1 + }, + pushData = true; + if (['up', 'left'].indexOf(direction) !== -1) { + iterators = { + row: Math.ceil(selected.row / rlen) || 1, + col: Math.ceil(selected.col / input[0].length) || 1 + }; + } else if (['down', 'right'].indexOf(direction) !== -1) { + iterators = { + row: 1, + col: 1 + }; + } + for (r = 0; r < rlen; r++) { + if ((end && current.row > end.row) || (!priv.settings.allowInsertRow && current.row > instance.countRows() - 1) || (current.row >= priv.settings.maxRows)) { + break; + } + current.col = start.col; + clen = input[r] ? input[r].length : 0; + for (c = 0; c < clen; c++) { + if ((end && current.col > end.col) || (!priv.settings.allowInsertColumn && current.col > instance.countCols() - 1) || (current.col >= priv.settings.maxCols)) { + break; + } + if (!instance.getCellMeta(current.row, current.col).readOnly) { + var result, + value = input[r][c], + orgValue = instance.getDataAtCell(current.row, current.col), + index = { + row: r, + col: c + }, + valueSchema, + orgValueSchema; + if (source === 'autofill') { + result = instance.runHooks('beforeAutofillInsidePopulate', index, direction, input, deltas, iterators, selected); + if (result) { + iterators = typeof(result.iterators) !== 'undefined' ? result.iterators : iterators; + value = typeof(result.value) !== 'undefined' ? result.value : value; + } + } + if (value !== null && typeof value === 'object') { + if (orgValue === null || typeof orgValue !== 'object') { + pushData = false; + } else { + orgValueSchema = Handsontable.helper.duckSchema(orgValue[0] || orgValue); + valueSchema = Handsontable.helper.duckSchema(value[0] || value); + if (Handsontable.helper.isObjectEquals(orgValueSchema, valueSchema)) { + value = Handsontable.helper.deepClone(value); + } else { + pushData = false; + } + } + } else if (orgValue !== null && typeof orgValue === 'object') { + pushData = false; + } + if (pushData) { + setData.push([current.row, current.col, value]); + } + pushData = true; + } + current.col++; + if (end && c === clen - 1) { + c = -1; + if (['down', 'right'].indexOf(direction) !== -1) { + iterators.col++; + } else if (['up', 'left'].indexOf(direction) !== -1) { + if (iterators.col > 1) { + iterators.col--; + } + } + } + } + current.row++; + iterators.col = 1; + if (end && r === rlen - 1) { + r = -1; + if (['down', 'right'].indexOf(direction) !== -1) { + iterators.row++; + } else if (['up', 'left'].indexOf(direction) !== -1) { + if (iterators.row > 1) { + iterators.row--; + } + } + } + } + instance.setDataAtCell(setData, null, null, source || 'populateFromArray'); + break; + } + } + }; + this.selection = selection = { + inProgress: false, + selectedHeader: { + cols: false, + rows: false + }, + setSelectedHeaders: function(rows, cols) { + instance.selection.selectedHeader.rows = rows; + instance.selection.selectedHeader.cols = cols; + }, + begin: function() { + instance.selection.inProgress = true; + }, + finish: function() { + var sel = instance.getSelected(); + Handsontable.hooks.run(instance, "afterSelectionEnd", sel[0], sel[1], sel[2], sel[3]); + Handsontable.hooks.run(instance, "afterSelectionEndByProp", sel[0], instance.colToProp(sel[1]), sel[2], instance.colToProp(sel[3])); + instance.selection.inProgress = false; + }, + isInProgress: function() { + return instance.selection.inProgress; + }, + setRangeStart: function(coords, keepEditorOpened) { + Handsontable.hooks.run(instance, "beforeSetRangeStart", coords); + priv.selRange = new WalkontableCellRange(coords, coords, coords); + selection.setRangeEnd(coords, null, keepEditorOpened); + }, + setRangeEnd: function(coords, scrollToCell, keepEditorOpened) { + if (priv.selRange === null) { + return; + } + var disableVisualSelection; + Handsontable.hooks.run(instance, "beforeSetRangeEnd", coords); + instance.selection.begin(); + priv.selRange.to = new WalkontableCellCoords(coords.row, coords.col); + if (!priv.settings.multiSelect) { + priv.selRange.from = coords; + } + instance.view.wt.selections.current.clear(); + disableVisualSelection = instance.getCellMeta(priv.selRange.highlight.row, priv.selRange.highlight.col).disableVisualSelection; + if (typeof disableVisualSelection === 'string') { + disableVisualSelection = [disableVisualSelection]; + } + if (disableVisualSelection === false || Array.isArray(disableVisualSelection) && disableVisualSelection.indexOf('current') === -1) { + instance.view.wt.selections.current.add(priv.selRange.highlight); + } + instance.view.wt.selections.area.clear(); + if ((disableVisualSelection === false || Array.isArray(disableVisualSelection) && disableVisualSelection.indexOf('area') === -1) && selection.isMultiple()) { + instance.view.wt.selections.area.add(priv.selRange.from); + instance.view.wt.selections.area.add(priv.selRange.to); + } + if (priv.settings.currentRowClassName || priv.settings.currentColClassName) { + instance.view.wt.selections.highlight.clear(); + instance.view.wt.selections.highlight.add(priv.selRange.from); + instance.view.wt.selections.highlight.add(priv.selRange.to); + } + Handsontable.hooks.run(instance, "afterSelection", priv.selRange.from.row, priv.selRange.from.col, priv.selRange.to.row, priv.selRange.to.col); + Handsontable.hooks.run(instance, "afterSelectionByProp", priv.selRange.from.row, datamap.colToProp(priv.selRange.from.col), priv.selRange.to.row, datamap.colToProp(priv.selRange.to.col)); + if (scrollToCell !== false && instance.view.mainViewIsActive()) { + if (priv.selRange.from && !selection.isMultiple()) { + instance.view.scrollViewport(priv.selRange.from); + } else { + instance.view.scrollViewport(coords); + } + } + selection.refreshBorders(null, keepEditorOpened); + }, + refreshBorders: function(revertOriginal, keepEditor) { + if (!keepEditor) { + editorManager.destroyEditor(revertOriginal); + } + instance.view.render(); + if (selection.isSelected() && !keepEditor) { + editorManager.prepareEditor(); + } + }, + isMultiple: function() { + var isMultiple = !(priv.selRange.to.col === priv.selRange.from.col && priv.selRange.to.row === priv.selRange.from.row), + modifier = Handsontable.hooks.run(instance, 'afterIsMultipleSelection', isMultiple); + if (isMultiple) { + return modifier; + } + }, + transformStart: function(rowDelta, colDelta, force, keepEditorOpened) { + var delta = new WalkontableCellCoords(rowDelta, colDelta), + rowTransformDir = 0, + colTransformDir = 0, + totalRows, + totalCols, + coords; + instance.runHooks('modifyTransformStart', delta); + totalRows = instance.countRows(); + totalCols = instance.countCols(); + if (priv.selRange.highlight.row + rowDelta > totalRows - 1) { + if (force && priv.settings.minSpareRows > 0) { + instance.alter("insert_row", totalRows); + totalRows = instance.countRows(); + } else if (priv.settings.autoWrapCol) { + delta.row = 1 - totalRows; + delta.col = priv.selRange.highlight.col + delta.col == totalCols - 1 ? 1 - totalCols : 1; + } + } else if (priv.settings.autoWrapCol && priv.selRange.highlight.row + delta.row < 0 && priv.selRange.highlight.col + delta.col >= 0) { + delta.row = totalRows - 1; + delta.col = priv.selRange.highlight.col + delta.col == 0 ? totalCols - 1 : -1; + } + if (priv.selRange.highlight.col + delta.col > totalCols - 1) { + if (force && priv.settings.minSpareCols > 0) { + instance.alter("insert_col", totalCols); + totalCols = instance.countCols(); + } else if (priv.settings.autoWrapRow) { + delta.row = priv.selRange.highlight.row + delta.row == totalRows - 1 ? 1 - totalRows : 1; + delta.col = 1 - totalCols; + } + } else if (priv.settings.autoWrapRow && priv.selRange.highlight.col + delta.col < 0 && priv.selRange.highlight.row + delta.row >= 0) { + delta.row = priv.selRange.highlight.row + delta.row == 0 ? totalRows - 1 : -1; + delta.col = totalCols - 1; + } + coords = new WalkontableCellCoords(priv.selRange.highlight.row + delta.row, priv.selRange.highlight.col + delta.col); + if (coords.row < 0) { + rowTransformDir = -1; + coords.row = 0; + } else if (coords.row > 0 && coords.row >= totalRows) { + rowTransformDir = 1; + coords.row = totalRows - 1; + } + if (coords.col < 0) { + colTransformDir = -1; + coords.col = 0; + } else if (coords.col > 0 && coords.col >= totalCols) { + colTransformDir = 1; + coords.col = totalCols - 1; + } + instance.runHooks('afterModifyTransformStart', coords, rowTransformDir, colTransformDir); + selection.setRangeStart(coords, keepEditorOpened); + }, + transformEnd: function(rowDelta, colDelta) { + var delta = new WalkontableCellCoords(rowDelta, colDelta), + rowTransformDir = 0, + colTransformDir = 0, + totalRows, + totalCols, + coords; + instance.runHooks('modifyTransformEnd', delta); + totalRows = instance.countRows(); + totalCols = instance.countCols(); + coords = new WalkontableCellCoords(priv.selRange.to.row + delta.row, priv.selRange.to.col + delta.col); + if (coords.row < 0) { + rowTransformDir = -1; + coords.row = 0; + } else if (coords.row > 0 && coords.row >= totalRows) { + rowTransformDir = 1; + coords.row = totalRows - 1; + } + if (coords.col < 0) { + colTransformDir = -1; + coords.col = 0; + } else if (coords.col > 0 && coords.col >= totalCols) { + colTransformDir = 1; + coords.col = totalCols - 1; + } + instance.runHooks('afterModifyTransformEnd', coords, rowTransformDir, colTransformDir); + selection.setRangeEnd(coords, true); + }, + isSelected: function() { + return (priv.selRange !== null); + }, + inInSelection: function(coords) { + if (!selection.isSelected()) { + return false; + } + return priv.selRange.includes(coords); + }, + deselect: function() { + if (!selection.isSelected()) { + return; + } + instance.selection.inProgress = false; + priv.selRange = null; + instance.view.wt.selections.current.clear(); + instance.view.wt.selections.area.clear(); + if (priv.settings.currentRowClassName || priv.settings.currentColClassName) { + instance.view.wt.selections.highlight.clear(); + } + editorManager.destroyEditor(); + selection.refreshBorders(); + Handsontable.hooks.run(instance, 'afterDeselect'); + }, + selectAll: function() { + if (!priv.settings.multiSelect) { + return; + } + selection.setRangeStart(new WalkontableCellCoords(0, 0)); + selection.setRangeEnd(new WalkontableCellCoords(instance.countRows() - 1, instance.countCols() - 1), false); + }, + empty: function() { + if (!selection.isSelected()) { + return; + } + var topLeft = priv.selRange.getTopLeftCorner(); + var bottomRight = priv.selRange.getBottomRightCorner(); + var r, + c, + changes = []; + for (r = topLeft.row; r <= bottomRight.row; r++) { + for (c = topLeft.col; c <= bottomRight.col; c++) { + if (!instance.getCellMeta(r, c).readOnly) { + changes.push([r, c, '']); + } + } + } + instance.setDataAtCell(changes); + } + }; + this.init = function() { + Handsontable.hooks.run(instance, 'beforeInit'); + if (Handsontable.mobileBrowser) { + dom.addClass(instance.rootElement, 'mobile'); + } + this.updateSettings(priv.settings, true); + this.view = new TableView(this); + editorManager = new EditorManager(instance, priv, selection, datamap); + this.forceFullRender = true; + Handsontable.hooks.run(instance, 'init'); + this.view.render(); + if (typeof priv.firstRun === 'object') { + Handsontable.hooks.run(instance, 'afterChange', priv.firstRun[0], priv.firstRun[1]); + priv.firstRun = false; + } + Handsontable.hooks.run(instance, 'afterInit'); + }; + function ValidatorsQueue() { + var resolved = false; + return { + validatorsInQueue: 0, + addValidatorToQueue: function() { + this.validatorsInQueue++; + resolved = false; + }, + removeValidatorFormQueue: function() { + this.validatorsInQueue = this.validatorsInQueue - 1 < 0 ? 0 : this.validatorsInQueue - 1; + this.checkIfQueueIsEmpty(); + }, + onQueueEmpty: function() {}, + checkIfQueueIsEmpty: function() { + if (this.validatorsInQueue == 0 && resolved == false) { + resolved = true; + this.onQueueEmpty(); + } + } + }; + } + function validateChanges(changes, source, callback) { + var waitingForValidator = new ValidatorsQueue(); + waitingForValidator.onQueueEmpty = resolve; + for (var i = changes.length - 1; i >= 0; i--) { + if (changes[i] === null) { + changes.splice(i, 1); + } else { + var row = changes[i][0]; + var col = datamap.propToCol(changes[i][1]); + var logicalCol = instance.runHooks('modifyCol', col); + var cellProperties = instance.getCellMeta(row, logicalCol); + if (cellProperties.type === 'numeric' && typeof changes[i][3] === 'string') { + if (changes[i][3].length > 0 && (/^-?[\d\s]*(\.|\,)?\d*$/.test(changes[i][3]) || cellProperties.format)) { + var len = changes[i][3].length; + if (typeof cellProperties.language == 'undefined') { + numeral.language('en'); + } else if (changes[i][3].indexOf(".") === len - 3 && changes[i][3].indexOf(",") === -1) { + numeral.language('en'); + } else { + numeral.language(cellProperties.language); + } + if (numeral.validate(changes[i][3])) { + changes[i][3] = numeral().unformat(changes[i][3]); + } + } + } + if (instance.getCellValidator(cellProperties)) { + waitingForValidator.addValidatorToQueue(); + instance.validateCell(changes[i][3], cellProperties, (function(i, cellProperties) { + return function(result) { + if (typeof result !== 'boolean') { + throw new Error("Validation error: result is not boolean"); + } + if (result === false && cellProperties.allowInvalid === false) { + changes.splice(i, 1); + cellProperties.valid = true; + --i; + } + waitingForValidator.removeValidatorFormQueue(); + }; + })(i, cellProperties), source); + } + } + } + waitingForValidator.checkIfQueueIsEmpty(); + function resolve() { + var beforeChangeResult; + if (changes.length) { + beforeChangeResult = Handsontable.hooks.run(instance, "beforeChange", changes, source); + if (typeof beforeChangeResult === 'function') { + console.warn("Your beforeChange callback returns a function. It's not supported since Handsontable 0.12.1 (and the returned function will not be executed)."); + } else if (beforeChangeResult === false) { + changes.splice(0, changes.length); + } + } + callback(); + } + } + function applyChanges(changes, source) { + var i = changes.length - 1; + if (i < 0) { + return; + } + for (; 0 <= i; i--) { + if (changes[i] === null) { + changes.splice(i, 1); + continue; + } + if (changes[i][2] == null && changes[i][3] == null) { + continue; + } + if (priv.settings.allowInsertRow) { + while (changes[i][0] > instance.countRows() - 1) { + datamap.createRow(); + } + } + if (instance.dataType === 'array' && priv.settings.allowInsertColumn) { + while (datamap.propToCol(changes[i][1]) > instance.countCols() - 1) { + datamap.createCol(); + } + } + datamap.set(changes[i][0], changes[i][1], changes[i][3]); + } + instance.forceFullRender = true; + grid.adjustRowsAndCols(); + Handsontable.hooks.run(instance, 'beforeChangeRender', changes, source); + selection.refreshBorders(null, true); + instance.view.wt.wtOverlays.adjustElementsSize(); + Handsontable.hooks.run(instance, 'afterChange', changes, source || 'edit'); + } + this.validateCell = function(value, cellProperties, callback, source) { + var validator = instance.getCellValidator(cellProperties); + function done(valid) { + var col = cellProperties.col, + row = cellProperties.row, + td = instance.getCell(row, col, true); + if (td) { + instance.view.wt.wtSettings.settings.cellRenderer(row, col, td); + } + callback(valid); + } + if (Object.prototype.toString.call(validator) === '[object RegExp]') { + validator = (function(validator) { + return function(value, callback) { + callback(validator.test(value)); + }; + })(validator); + } + if (typeof validator == 'function') { + value = Handsontable.hooks.run(instance, "beforeValidate", value, cellProperties.row, cellProperties.prop, source); + instance._registerTimeout(setTimeout(function() { + validator.call(cellProperties, value, function(valid) { + valid = Handsontable.hooks.run(instance, "afterValidate", valid, value, cellProperties.row, cellProperties.prop, source); + cellProperties.valid = valid; + done(valid); + Handsontable.hooks.run(instance, "postAfterValidate", valid, value, cellProperties.row, cellProperties.prop, source); + }); + }, 0)); + } else { + cellProperties.valid = true; + done(cellProperties.valid); + } + }; + function setDataInputToArray(row, propOrCol, value) { + if (typeof row === "object") { + return row; + } else { + return [[row, propOrCol, value]]; + } + } + this.setDataAtCell = function(row, col, value, source) { + var input = setDataInputToArray(row, col, value), + i, + ilen, + changes = [], + prop; + for (i = 0, ilen = input.length; i < ilen; i++) { + if (typeof input[i] !== 'object') { + throw new Error('Method `setDataAtCell` accepts row number or changes array of arrays as its first parameter'); + } + if (typeof input[i][1] !== 'number') { + throw new Error('Method `setDataAtCell` accepts row and column number as its parameters. If you want to use object property name, use method `setDataAtRowProp`'); + } + prop = datamap.colToProp(input[i][1]); + changes.push([input[i][0], prop, datamap.get(input[i][0], prop), input[i][2]]); + } + if (!source && typeof row === "object") { + source = col; + } + validateChanges(changes, source, function() { + applyChanges(changes, source); + }); + }; + this.setDataAtRowProp = function(row, prop, value, source) { + var input = setDataInputToArray(row, prop, value), + i, + ilen, + changes = []; + for (i = 0, ilen = input.length; i < ilen; i++) { + changes.push([input[i][0], input[i][1], datamap.get(input[i][0], input[i][1]), input[i][2]]); + } + if (!source && typeof row === "object") { + source = prop; + } + validateChanges(changes, source, function() { + applyChanges(changes, source); + }); + }; + this.listen = function() { + Handsontable.activeGuid = instance.guid; + if (document.activeElement && document.activeElement !== document.body) { + document.activeElement.blur(); + } else if (!document.activeElement) { + document.body.focus(); + } + }; + this.unlisten = function() { + Handsontable.activeGuid = null; + }; + this.isListening = function() { + return Handsontable.activeGuid === instance.guid; + }; + this.destroyEditor = function(revertOriginal) { + selection.refreshBorders(revertOriginal); + }; + this.populateFromArray = function(row, col, input, endRow, endCol, source, method, direction, deltas) { + var c; + if (!(typeof input === 'object' && typeof input[0] === 'object')) { + throw new Error("populateFromArray parameter `input` must be an array of arrays"); + } + c = typeof endRow === 'number' ? new WalkontableCellCoords(endRow, endCol) : null; + return grid.populateFromArray(new WalkontableCellCoords(row, col), input, c, source, method, direction, deltas); + }; + this.spliceCol = function(col, index, amount) { + return datamap.spliceCol.apply(datamap, arguments); + }; + this.spliceRow = function(row, index, amount) { + return datamap.spliceRow.apply(datamap, arguments); + }; + this.getSelected = function() { + if (selection.isSelected()) { + return [priv.selRange.from.row, priv.selRange.from.col, priv.selRange.to.row, priv.selRange.to.col]; + } + }; + this.getSelectedRange = function() { + if (selection.isSelected()) { + return priv.selRange; + } + }; + this.render = function() { + if (instance.view) { + instance.renderCall = true; + instance.forceFullRender = true; + selection.refreshBorders(null, true); + } + }; + this.loadData = function(data) { + if (typeof data === 'object' && data !== null) { + if (!(data.push && data.splice)) { + data = [data]; + } + } else if (data === null) { + data = []; + var row; + for (var r = 0, + rlen = priv.settings.startRows; r < rlen; r++) { + row = []; + for (var c = 0, + clen = priv.settings.startCols; c < clen; c++) { + row.push(null); + } + data.push(row); + } + } else { + throw new Error("loadData only accepts array of objects or array of arrays (" + typeof data + " given)"); + } + priv.isPopulated = false; + GridSettings.prototype.data = data; + if (Array.isArray(priv.settings.dataSchema) || Array.isArray(data[0])) { + instance.dataType = 'array'; + } else if (typeof priv.settings.dataSchema === 'function') { + instance.dataType = 'function'; + } else { + instance.dataType = 'object'; + } + datamap = new DataMap(instance, priv, GridSettings); + clearCellSettingCache(); + grid.adjustRowsAndCols(); + Handsontable.hooks.run(instance, 'afterLoadData'); + if (priv.firstRun) { + priv.firstRun = [null, 'loadData']; + } else { + Handsontable.hooks.run(instance, 'afterChange', null, 'loadData'); + instance.render(); + } + priv.isPopulated = true; + function clearCellSettingCache() { + priv.cellSettings.length = 0; + } + }; + this.getData = function(r, c, r2, c2) { + if (typeof r === 'undefined') { + return datamap.getAll(); + } else { + return datamap.getRange(new WalkontableCellCoords(r, c), new WalkontableCellCoords(r2, c2), datamap.DESTINATION_RENDERER); + } + }; + this.getCopyableData = function(startRow, startCol, endRow, endCol) { + return datamap.getCopyableText(new WalkontableCellCoords(startRow, startCol), new WalkontableCellCoords(endRow, endCol)); + }; + this.getSchema = function() { + return datamap.getSchema(); + }; + this.updateSettings = function(settings, init) { + var i, + clen; + if (typeof settings.rows !== "undefined") { + throw new Error("'rows' setting is no longer supported. do you mean startRows, minRows or maxRows?"); + } + if (typeof settings.cols !== "undefined") { + throw new Error("'cols' setting is no longer supported. do you mean startCols, minCols or maxCols?"); + } + for (i in settings) { + if (i === 'data') { + continue; + } else { + if (Handsontable.hooks.getRegistered().indexOf(i) > -1) { + if (typeof settings[i] === 'function' || Array.isArray(settings[i])) { + instance.addHook(i, settings[i]); + } + } else { + if (!init && settings.hasOwnProperty(i)) { + GridSettings.prototype[i] = settings[i]; + } + } + } + } + if (settings.data === void 0 && priv.settings.data === void 0) { + instance.loadData(null); + } else if (settings.data !== void 0) { + instance.loadData(settings.data); + } else if (settings.columns !== void 0) { + datamap.createMap(); + } + clen = instance.countCols(); + priv.cellSettings.length = 0; + if (clen > 0) { + var proto, + column; + for (i = 0; i < clen; i++) { + priv.columnSettings[i] = helper.columnFactory(GridSettings, priv.columnsSettingConflicts); + proto = priv.columnSettings[i].prototype; + if (GridSettings.prototype.columns) { + column = GridSettings.prototype.columns[i]; + helper.extend(proto, column); + helper.extend(proto, expandType(column)); + } + } + } + if (typeof settings.cell !== 'undefined') { + for (i in settings.cell) { + if (settings.cell.hasOwnProperty(i)) { + var cell = settings.cell[i]; + instance.setCellMetaObject(cell.row, cell.col, cell); + } + } + } + Handsontable.hooks.run(instance, 'afterCellMetaReset'); + if (typeof settings.className !== "undefined") { + if (GridSettings.prototype.className) { + dom.removeClass(instance.rootElement, GridSettings.prototype.className); + } + if (settings.className) { + dom.addClass(instance.rootElement, settings.className); + } + } + if (typeof settings.height != 'undefined') { + var height = settings.height; + if (typeof height == 'function') { + height = height(); + } + instance.rootElement.style.height = height + 'px'; + } + if (typeof settings.width != 'undefined') { + var width = settings.width; + if (typeof width == 'function') { + width = width(); + } + instance.rootElement.style.width = width + 'px'; + } + if (height) { + instance.rootElement.style.overflow = 'hidden'; + } + if (!init) { + Handsontable.hooks.run(instance, 'afterUpdateSettings'); + } + grid.adjustRowsAndCols(); + if (instance.view && !priv.firstRun) { + instance.forceFullRender = true; + selection.refreshBorders(null, true); + } + }; + this.getValue = function() { + var sel = instance.getSelected(); + if (GridSettings.prototype.getValue) { + if (typeof GridSettings.prototype.getValue === 'function') { + return GridSettings.prototype.getValue.call(instance); + } else if (sel) { + return instance.getData()[sel[0]][GridSettings.prototype.getValue]; + } + } else if (sel) { + return instance.getDataAtCell(sel[0], sel[1]); + } + }; + function expandType(obj) { + if (!obj.hasOwnProperty('type')) { + return; + } + var type, + expandedType = {}; + if (typeof obj.type === 'object') { + type = obj.type; + } else if (typeof obj.type === 'string') { + type = Handsontable.cellTypes[obj.type]; + if (type === void 0) { + throw new Error('You declared cell type "' + obj.type + '" as a string that is not mapped to a known object. Cell type must be an object or a string mapped to an object in Handsontable.cellTypes'); + } + } + for (var i in type) { + if (type.hasOwnProperty(i) && !obj.hasOwnProperty(i)) { + expandedType[i] = type[i]; + } + } + return expandedType; + } + this.getSettings = function() { + return priv.settings; + }; + this.clear = function() { + selection.selectAll(); + selection.empty(); + }; + this.alter = function(action, index, amount, source, keepEmptyRows) { + grid.alter(action, index, amount, source, keepEmptyRows); + }; + this.getCell = function(row, col, topmost) { + return instance.view.getCellAtCoords(new WalkontableCellCoords(row, col), topmost); + }; + this.getCoords = function(elem) { + return this.view.wt.wtTable.getCoords.call(this.view.wt.wtTable, elem); + }; + this.colToProp = function(col) { + return datamap.colToProp(col); + }; + this.propToCol = function(prop) { + return datamap.propToCol(prop); + }; + this.getDataAtCell = function(row, col) { + return datamap.get(row, datamap.colToProp(col)); + }; + this.getDataAtRowProp = function(row, prop) { + return datamap.get(row, prop); + }; + this.getDataAtCol = function(col) { + var out = []; + return out.concat.apply(out, datamap.getRange(new WalkontableCellCoords(0, col), new WalkontableCellCoords(priv.settings.data.length - 1, col), datamap.DESTINATION_RENDERER)); + }; + this.getDataAtProp = function(prop) { + var out = [], + range; + range = datamap.getRange(new WalkontableCellCoords(0, datamap.propToCol(prop)), new WalkontableCellCoords(priv.settings.data.length - 1, datamap.propToCol(prop)), datamap.DESTINATION_RENDERER); + return out.concat.apply(out, range); + }; + this.getSourceDataAtCol = function(col) { + var out = [], + data = priv.settings.data; + for (var i = 0; i < data.length; i++) { + out.push(data[i][col]); + } + return out; + }; + this.getSourceDataAtRow = function(row) { + return priv.settings.data[row]; + }; + this.getDataAtRow = function(row) { + var data = datamap.getRange(new WalkontableCellCoords(row, 0), new WalkontableCellCoords(row, this.countCols() - 1), datamap.DESTINATION_RENDERER); + return data[0]; + }; + this.removeCellMeta = function(row, col, key) { + var cellMeta = instance.getCellMeta(row, col); + if (cellMeta[key] != undefined) { + delete priv.cellSettings[row][col][key]; + } + }; + this.setCellMetaObject = function(row, col, prop) { + if (typeof prop === 'object') { + for (var key in prop) { + if (prop.hasOwnProperty(key)) { + var value = prop[key]; + this.setCellMeta(row, col, key, value); + } + } + } + }; + this.setCellMeta = function(row, col, key, val) { + if (!priv.cellSettings[row]) { + priv.cellSettings[row] = []; + } + if (!priv.cellSettings[row][col]) { + priv.cellSettings[row][col] = new priv.columnSettings[col](); + } + priv.cellSettings[row][col][key] = val; + Handsontable.hooks.run(instance, 'afterSetCellMeta', row, col, key, val); + }; + this.getCellMeta = function(row, col) { + var prop = datamap.colToProp(col), + cellProperties; + row = translateRowIndex(row); + col = translateColIndex(col); + if (!priv.columnSettings[col]) { + priv.columnSettings[col] = helper.columnFactory(GridSettings, priv.columnsSettingConflicts); + } + if (!priv.cellSettings[row]) { + priv.cellSettings[row] = []; + } + if (!priv.cellSettings[row][col]) { + priv.cellSettings[row][col] = new priv.columnSettings[col](); + } + cellProperties = priv.cellSettings[row][col]; + cellProperties.row = row; + cellProperties.col = col; + cellProperties.prop = prop; + cellProperties.instance = instance; + Handsontable.hooks.run(instance, 'beforeGetCellMeta', row, col, cellProperties); + helper.extend(cellProperties, expandType(cellProperties)); + if (cellProperties.cells) { + var settings = cellProperties.cells.call(cellProperties, row, col, prop); + if (settings) { + helper.extend(cellProperties, settings); + helper.extend(cellProperties, expandType(settings)); + } + } + Handsontable.hooks.run(instance, 'afterGetCellMeta', row, col, cellProperties); + return cellProperties; + }; + this.isColumnModificationAllowed = function() { + return !(instance.dataType === 'object' || instance.getSettings().columns); + }; + function translateRowIndex(row) { + return Handsontable.hooks.run(instance, 'modifyRow', row); + } + function translateColIndex(col) { + return Handsontable.hooks.run(instance, 'modifyCol', col); + } + var rendererLookup = helper.cellMethodLookupFactory('renderer'); + this.getCellRenderer = function(row, col) { + var renderer = rendererLookup.call(this, row, col); + return getRenderer(renderer); + }; + this.getCellEditor = helper.cellMethodLookupFactory('editor'); + this.getCellValidator = helper.cellMethodLookupFactory('validator'); + this.validateCells = function(callback) { + var waitingForValidator = new ValidatorsQueue(); + waitingForValidator.onQueueEmpty = callback; + var i = instance.countRows() - 1; + while (i >= 0) { + var j = instance.countCols() - 1; + while (j >= 0) { + waitingForValidator.addValidatorToQueue(); + instance.validateCell(instance.getDataAtCell(i, j), instance.getCellMeta(i, j), function() { + waitingForValidator.removeValidatorFormQueue(); + }, 'validateCells'); + j--; + } + i--; + } + waitingForValidator.checkIfQueueIsEmpty(); + }; + this.getRowHeader = function(row) { + if (row === void 0) { + var out = []; + for (var i = 0, + ilen = instance.countRows(); i < ilen; i++) { + out.push(instance.getRowHeader(i)); + } + return out; + } else if (Array.isArray(priv.settings.rowHeaders) && priv.settings.rowHeaders[row] !== void 0) { + return priv.settings.rowHeaders[row]; + } else if (typeof priv.settings.rowHeaders === 'function') { + return priv.settings.rowHeaders(row); + } else if (priv.settings.rowHeaders && typeof priv.settings.rowHeaders !== 'string' && typeof priv.settings.rowHeaders !== 'number') { + return row + 1; + } else { + return priv.settings.rowHeaders; + } + }; + this.hasRowHeaders = function() { + return !!priv.settings.rowHeaders; + }; + this.hasColHeaders = function() { + if (priv.settings.colHeaders !== void 0 && priv.settings.colHeaders !== null) { + return !!priv.settings.colHeaders; + } + for (var i = 0, + ilen = instance.countCols(); i < ilen; i++) { + if (instance.getColHeader(i)) { + return true; + } + } + return false; + }; + this.getColHeader = function(col) { + if (col === void 0) { + var out = []; + for (var i = 0, + ilen = instance.countCols(); i < ilen; i++) { + out.push(instance.getColHeader(i)); + } + return out; + } else { + var baseCol = col; + col = Handsontable.hooks.run(instance, 'modifyCol', col); + if (priv.settings.columns && priv.settings.columns[col] && priv.settings.columns[col].title) { + return priv.settings.columns[col].title; + } else if (Array.isArray(priv.settings.colHeaders) && priv.settings.colHeaders[col] !== void 0) { + return priv.settings.colHeaders[col]; + } else if (typeof priv.settings.colHeaders === 'function') { + return priv.settings.colHeaders(col); + } else if (priv.settings.colHeaders && typeof priv.settings.colHeaders !== 'string' && typeof priv.settings.colHeaders !== 'number') { + return helper.spreadsheetColumnLabel(baseCol); + } else { + return priv.settings.colHeaders; + } + } + }; + this._getColWidthFromSettings = function(col) { + var cellProperties = instance.getCellMeta(0, col); + var width = cellProperties.width; + if (width === void 0 || width === priv.settings.width) { + width = cellProperties.colWidths; + } + if (width !== void 0 && width !== null) { + switch (typeof width) { + case 'object': + width = width[col]; + break; + case 'function': + width = width(col); + break; + } + if (typeof width === 'string') { + width = parseInt(width, 10); + } + } + return width; + }; + this.getColWidth = function(col) { + var width = instance._getColWidthFromSettings(col); + width = Handsontable.hooks.run(instance, 'modifyColWidth', width, col); + if (width === void 0) { + width = WalkontableViewportColumnsCalculator.DEFAULT_WIDTH; + } + return width; + }; + this._getRowHeightFromSettings = function(row) { + var height = priv.settings.rowHeights; + if (height !== void 0 && height !== null) { + switch (typeof height) { + case 'object': + height = height[row]; + break; + case 'function': + height = height(row); + break; + } + if (typeof height === 'string') { + height = parseInt(height, 10); + } + } + return height; + }; + this.getRowHeight = function(row) { + var height = instance._getRowHeightFromSettings(row); + height = Handsontable.hooks.run(instance, 'modifyRowHeight', height, row); + return height; + }; + this.countRows = function() { + return priv.settings.data.length; + }; + this.countCols = function() { + if (instance.dataType === 'object' || instance.dataType === 'function') { + if (priv.settings.columns && priv.settings.columns.length) { + return priv.settings.columns.length; + } else { + return datamap.colToPropCache.length; + } + } else if (instance.dataType === 'array') { + if (priv.settings.columns && priv.settings.columns.length) { + return priv.settings.columns.length; + } else if (priv.settings.data && priv.settings.data[0] && priv.settings.data[0].length) { + return priv.settings.data[0].length; + } else { + return 0; + } + } + }; + this.rowOffset = function() { + return instance.view.wt.wtTable.getFirstRenderedRow(); + }; + this.colOffset = function() { + return instance.view.wt.wtTable.getFirstRenderedColumn(); + }; + this.countRenderedRows = function() { + return instance.view.wt.drawn ? instance.view.wt.wtTable.getRenderedRowsCount() : -1; + }; + this.countVisibleRows = function() { + return instance.view.wt.drawn ? instance.view.wt.wtTable.getVisibleRowsCount() : -1; + }; + this.countRenderedCols = function() { + return instance.view.wt.drawn ? instance.view.wt.wtTable.getRenderedColumnsCount() : -1; + }; + this.countVisibleCols = function() { + return instance.view.wt.drawn ? instance.view.wt.wtTable.getVisibleColumnsCount() : -1; + }; + this.countEmptyRows = function(ending) { + var i = instance.countRows() - 1, + empty = 0, + row; + while (i >= 0) { + row = Handsontable.hooks.run(this, 'modifyRow', i); + if (instance.isEmptyRow(row)) { + empty++; + } else if (ending) { + break; + } + i--; + } + return empty; + }; + this.countEmptyCols = function(ending) { + if (instance.countRows() < 1) { + return 0; + } + var i = instance.countCols() - 1, + empty = 0; + while (i >= 0) { + if (instance.isEmptyCol(i)) { + empty++; + } else if (ending) { + break; + } + i--; + } + return empty; + }; + this.isEmptyRow = function(row) { + return priv.settings.isEmptyRow.call(instance, row); + }; + this.isEmptyCol = function(col) { + return priv.settings.isEmptyCol.call(instance, col); + }; + this.selectCell = function(row, col, endRow, endCol, scrollToCell, changeListener) { + var coords; + changeListener = typeof changeListener === 'undefined' || changeListener === true; + if (typeof row !== 'number' || row < 0 || row >= instance.countRows()) { + return false; + } + if (typeof col !== 'number' || col < 0 || col >= instance.countCols()) { + return false; + } + if (typeof endRow !== 'undefined') { + if (typeof endRow !== 'number' || endRow < 0 || endRow >= instance.countRows()) { + return false; + } + if (typeof endCol !== 'number' || endCol < 0 || endCol >= instance.countCols()) { + return false; + } + } + coords = new WalkontableCellCoords(row, col); + priv.selRange = new WalkontableCellRange(coords, coords, coords); + if (document.activeElement && document.activeElement !== document.documentElement && document.activeElement !== document.body) { + document.activeElement.blur(); + } + if (changeListener) { + instance.listen(); + } + if (typeof endRow === 'undefined') { + selection.setRangeEnd(priv.selRange.from, scrollToCell); + } else { + selection.setRangeEnd(new WalkontableCellCoords(endRow, endCol), scrollToCell); + } + instance.selection.finish(); + return true; + }; + this.selectCellByProp = function(row, prop, endRow, endProp, scrollToCell) { + arguments[1] = datamap.propToCol(arguments[1]); + if (typeof arguments[3] !== "undefined") { + arguments[3] = datamap.propToCol(arguments[3]); + } + return instance.selectCell.apply(instance, arguments); + }; + this.deselectCell = function() { + selection.deselect(); + }; + this.destroy = function() { + instance._clearTimeouts(); + if (instance.view) { + instance.view.destroy(); + } + dom.empty(instance.rootElement); + eventManager.destroy(); + Handsontable.hooks.run(instance, 'afterDestroy'); + Handsontable.hooks.destroy(instance); + for (var i in instance) { + if (instance.hasOwnProperty(i)) { + if (typeof instance[i] === "function") { + instance[i] = postMortem; + } else if (i !== "guid") { + instance[i] = null; + } + } + } + priv = null; + datamap = null; + grid = null; + selection = null; + editorManager = null; + instance = null; + GridSettings = null; + }; + function postMortem() { + throw new Error("This method cannot be called because this Handsontable instance has been destroyed"); + } + this.getActiveEditor = function() { + return editorManager.getActiveEditor(); + }; + this.getPlugin = function(pluginName) { + return getPlugin(this, pluginName); + }; + this.getInstance = function() { + return instance; + }; + this.addHook = function(key, callback) { + Handsontable.hooks.add(key, callback, instance); + }; + this.addHookOnce = function(key, callback) { + Handsontable.hooks.once(key, callback, instance); + }; + this.removeHook = function(key, callback) { + Handsontable.hooks.remove(key, callback, instance); + }; + this.runHooks = function(key, p1, p2, p3, p4, p5, p6) { + return Handsontable.hooks.run(instance, key, p1, p2, p3, p4, p5, p6); + }; + this.timeouts = []; + this._registerTimeout = function(handle) { + this.timeouts.push(handle); + }; + this._clearTimeouts = function() { + for (var i = 0, + ilen = this.timeouts.length; i < ilen; i++) { + clearTimeout(this.timeouts[i]); + } + }; + this.version = Handsontable.version; + Handsontable.hooks.run(instance, 'construct'); +}; +var DefaultSettings = function() {}; +DefaultSettings.prototype = { + data: void 0, + dataSchema: void 0, + width: void 0, + height: void 0, + startRows: 5, + startCols: 5, + rowHeaders: null, + colHeaders: null, + colWidths: void 0, + columns: void 0, + cells: void 0, + cell: [], + comments: false, + customBorders: false, + minRows: 0, + minCols: 0, + maxRows: Infinity, + maxCols: Infinity, + minSpareRows: 0, + minSpareCols: 0, + allowInsertRow: true, + allowInsertColumn: true, + allowRemoveRow: true, + allowRemoveColumn: true, + multiSelect: true, + fillHandle: true, + fixedRowsTop: 0, + fixedColumnsLeft: 0, + outsideClickDeselects: true, + enterBeginsEditing: true, + enterMoves: { + row: 1, + col: 0 + }, + tabMoves: { + row: 0, + col: 1 + }, + autoWrapRow: false, + autoWrapCol: false, + copyRowsLimit: 1000, + copyColsLimit: 1000, + pasteMode: 'overwrite', + persistentState: false, + currentRowClassName: void 0, + currentColClassName: void 0, + stretchH: 'none', + isEmptyRow: function(row) { + var col, + colLen, + value, + meta; + for (col = 0, colLen = this.countCols(); col < colLen; col++) { + value = this.getDataAtCell(row, col); + if (value !== '' && value !== null && typeof value !== 'undefined') { + if (typeof value === 'object') { + meta = this.getCellMeta(row, col); + return helper.isObjectEquals(this.getSchema()[meta.prop], value); + } + return false; + } + } + return true; + }, + isEmptyCol: function(col) { + var row, + rowLen, + value; + for (row = 0, rowLen = this.countRows(); row < rowLen; row++) { + value = this.getDataAtCell(row, col); + if (value !== '' && value !== null && typeof value !== 'undefined') { + return false; + } + } + return true; + }, + observeDOMVisibility: true, + allowInvalid: true, + invalidCellClassName: 'htInvalid', + placeholder: false, + placeholderCellClassName: 'htPlaceholder', + readOnlyCellClassName: 'htDimmed', + renderer: void 0, + commentedCellClassName: 'htCommentCell', + fragmentSelection: false, + readOnly: false, + search: false, + type: 'text', + copyable: true, + editor: void 0, + autoComplete: void 0, + debug: false, + wordWrap: true, + noWordWrapClassName: 'htNoWrap', + contextMenu: void 0, + undo: void 0, + columnSorting: void 0, + manualColumnMove: void 0, + manualColumnResize: void 0, + manualRowMove: void 0, + manualRowResize: void 0, + mergeCells: false, + viewportRowRenderingOffset: 'auto', + viewportColumnRenderingOffset: 'auto', + groups: void 0, + validator: void 0, + disableVisualSelection: false, + sortIndicator: false, + manualColumnFreeze: void 0, + trimWhitespace: true, + settings: void 0, + source: void 0, + title: void 0, + checkedTemplate: void 0, + uncheckedTemplate: void 0, + format: void 0, + className: void 0, + autoColumnSize: void 0, + autoRowSize: void 0 +}; +Handsontable.DefaultSettings = DefaultSettings; + +//# +},{"3rdparty/walkontable/src/calculator/viewportColumns.js":3,"3rdparty/walkontable/src/cell/coords.js":5,"3rdparty/walkontable/src/cell/range.js":6,"3rdparty/walkontable/src/selection.js":18,"dataMap.js":26,"dom.js":27,"editorManager.js":28,"eventManager.js":41,"helpers.js":42,"numeral":"numeral","plugins.js":45,"renderers.js":71,"tableView.js":80}],26:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + DataMap: {get: function() { + return DataMap; + }}, + __esModule: {value: true} +}); +var $__helpers_46_js__, + $__multiMap_46_js__, + $__SheetClip__; +var helper = ($__helpers_46_js__ = require("helpers.js"), $__helpers_46_js__ && $__helpers_46_js__.__esModule && $__helpers_46_js__ || {default: $__helpers_46_js__}); +var MultiMap = ($__multiMap_46_js__ = require("multiMap.js"), $__multiMap_46_js__ && $__multiMap_46_js__.__esModule && $__multiMap_46_js__ || {default: $__multiMap_46_js__}).MultiMap; +var SheetClip = ($__SheetClip__ = require("SheetClip"), $__SheetClip__ && $__SheetClip__.__esModule && $__SheetClip__ || {default: $__SheetClip__}).default; +; +Handsontable.DataMap = DataMap; +function DataMap(instance, priv, GridSettings) { + this.instance = instance; + this.priv = priv; + this.GridSettings = GridSettings; + this.dataSource = this.instance.getSettings().data; + if (this.dataSource[0]) { + this.duckSchema = this.recursiveDuckSchema(this.dataSource[0]); + } else { + this.duckSchema = {}; + } + this.createMap(); +} +DataMap.prototype.DESTINATION_RENDERER = 1; +DataMap.prototype.DESTINATION_CLIPBOARD_GENERATOR = 2; +DataMap.prototype.recursiveDuckSchema = function(object) { + return Handsontable.helper.duckSchema(object); +}; +DataMap.prototype.recursiveDuckColumns = function(schema, lastCol, parent) { + var prop, + i; + if (typeof lastCol === 'undefined') { + lastCol = 0; + parent = ''; + } + if (typeof schema === "object" && !Array.isArray(schema)) { + for (i in schema) { + if (schema.hasOwnProperty(i)) { + if (schema[i] === null) { + prop = parent + i; + this.colToPropCache.push(prop); + this.propToColCache.set(prop, lastCol); + lastCol++; + } else { + lastCol = this.recursiveDuckColumns(schema[i], lastCol, i + '.'); + } + } + } + } + return lastCol; +}; +DataMap.prototype.createMap = function() { + var i, + ilen, + schema = this.getSchema(); + if (typeof schema === "undefined") { + throw new Error("trying to create `columns` definition but you didnt' provide `schema` nor `data`"); + } + this.colToPropCache = []; + this.propToColCache = new MultiMap(); + var columns = this.instance.getSettings().columns; + if (columns) { + for (i = 0, ilen = columns.length; i < ilen; i++) { + if (typeof columns[i].data != 'undefined') { + this.colToPropCache[i] = columns[i].data; + this.propToColCache.set(columns[i].data, i); + } + } + } else { + this.recursiveDuckColumns(schema); + } +}; +DataMap.prototype.colToProp = function(col) { + col = Handsontable.hooks.run(this.instance, 'modifyCol', col); + if (this.colToPropCache && typeof this.colToPropCache[col] !== 'undefined') { + return this.colToPropCache[col]; + } + return col; +}; +DataMap.prototype.propToCol = function(prop) { + var col; + if (typeof this.propToColCache.get(prop) !== 'undefined') { + col = this.propToColCache.get(prop); + } else { + col = prop; + } + col = Handsontable.hooks.run(this.instance, 'modifyCol', col); + return col; +}; +DataMap.prototype.getSchema = function() { + var schema = this.instance.getSettings().dataSchema; + if (schema) { + if (typeof schema === 'function') { + return schema(); + } + return schema; + } + return this.duckSchema; +}; +DataMap.prototype.createRow = function(index, amount, createdAutomatically) { + var row, + colCount = this.instance.countCols(), + numberOfCreatedRows = 0, + currentIndex; + if (!amount) { + amount = 1; + } + if (typeof index !== 'number' || index >= this.instance.countRows()) { + index = this.instance.countRows(); + } + currentIndex = index; + var maxRows = this.instance.getSettings().maxRows; + while (numberOfCreatedRows < amount && this.instance.countRows() < maxRows) { + if (this.instance.dataType === 'array') { + row = []; + for (var c = 0; c < colCount; c++) { + row.push(null); + } + } else if (this.instance.dataType === 'function') { + row = this.instance.getSettings().dataSchema(index); + } else { + row = {}; + helper.deepExtend(row, this.getSchema()); + } + if (index === this.instance.countRows()) { + this.dataSource.push(row); + } else { + this.dataSource.splice(index, 0, row); + } + numberOfCreatedRows++; + currentIndex++; + } + Handsontable.hooks.run(this.instance, 'afterCreateRow', index, numberOfCreatedRows, createdAutomatically); + this.instance.forceFullRender = true; + return numberOfCreatedRows; +}; +DataMap.prototype.createCol = function(index, amount, createdAutomatically) { + if (!this.instance.isColumnModificationAllowed()) { + throw new Error("Cannot create new column. When data source in an object, " + "you can only have as much columns as defined in first data row, data schema or in the 'columns' setting." + "If you want to be able to add new columns, you have to use array datasource."); + } + var rlen = this.instance.countRows(), + data = this.dataSource, + constructor, + numberOfCreatedCols = 0, + currentIndex; + if (!amount) { + amount = 1; + } + currentIndex = index; + var maxCols = this.instance.getSettings().maxCols; + while (numberOfCreatedCols < amount && this.instance.countCols() < maxCols) { + constructor = helper.columnFactory(this.GridSettings, this.priv.columnsSettingConflicts); + if (typeof index !== 'number' || index >= this.instance.countCols()) { + for (var r = 0; r < rlen; r++) { + if (typeof data[r] === 'undefined') { + data[r] = []; + } + data[r].push(null); + } + this.priv.columnSettings.push(constructor); + } else { + for (var r = 0; r < rlen; r++) { + data[r].splice(currentIndex, 0, null); + } + this.priv.columnSettings.splice(currentIndex, 0, constructor); + } + numberOfCreatedCols++; + currentIndex++; + } + Handsontable.hooks.run(this.instance, 'afterCreateCol', index, numberOfCreatedCols, createdAutomatically); + this.instance.forceFullRender = true; + return numberOfCreatedCols; +}; +DataMap.prototype.removeRow = function(index, amount) { + if (!amount) { + amount = 1; + } + if (typeof index !== 'number') { + index = -amount; + } + index = (this.instance.countRows() + index) % this.instance.countRows(); + var logicRows = this.physicalRowsToLogical(index, amount); + var actionWasNotCancelled = Handsontable.hooks.run(this.instance, 'beforeRemoveRow', index, amount); + if (actionWasNotCancelled === false) { + return; + } + var data = this.dataSource; + var newData = data.filter(function(row, index) { + return logicRows.indexOf(index) == -1; + }); + data.length = 0; + Array.prototype.push.apply(data, newData); + Handsontable.hooks.run(this.instance, 'afterRemoveRow', index, amount); + this.instance.forceFullRender = true; +}; +DataMap.prototype.removeCol = function(index, amount) { + if (this.instance.dataType === 'object' || this.instance.getSettings().columns) { + throw new Error("cannot remove column with object data source or columns option specified"); + } + if (!amount) { + amount = 1; + } + if (typeof index !== 'number') { + index = -amount; + } + index = (this.instance.countCols() + index) % this.instance.countCols(); + var actionWasNotCancelled = Handsontable.hooks.run(this.instance, 'beforeRemoveCol', index, amount); + if (actionWasNotCancelled === false) { + return; + } + var data = this.dataSource; + for (var r = 0, + rlen = this.instance.countRows(); r < rlen; r++) { + data[r].splice(index, amount); + } + this.priv.columnSettings.splice(index, amount); + Handsontable.hooks.run(this.instance, 'afterRemoveCol', index, amount); + this.instance.forceFullRender = true; +}; +DataMap.prototype.spliceCol = function(col, index, amount) { + var elements = 4 <= arguments.length ? [].slice.call(arguments, 3) : []; + var colData = this.instance.getDataAtCol(col); + var removed = colData.slice(index, index + amount); + var after = colData.slice(index + amount); + helper.extendArray(elements, after); + var i = 0; + while (i < amount) { + elements.push(null); + i++; + } + helper.to2dArray(elements); + this.instance.populateFromArray(index, col, elements, null, null, 'spliceCol'); + return removed; +}; +DataMap.prototype.spliceRow = function(row, index, amount) { + var elements = 4 <= arguments.length ? [].slice.call(arguments, 3) : []; + var rowData = this.instance.getSourceDataAtRow(row); + var removed = rowData.slice(index, index + amount); + var after = rowData.slice(index + amount); + helper.extendArray(elements, after); + var i = 0; + while (i < amount) { + elements.push(null); + i++; + } + this.instance.populateFromArray(row, index, [elements], null, null, 'spliceRow'); + return removed; +}; +DataMap.prototype.get = function(row, prop) { + row = Handsontable.hooks.run(this.instance, 'modifyRow', row); + if (typeof prop === 'string' && prop.indexOf('.') > -1) { + var sliced = prop.split("."); + var out = this.dataSource[row]; + if (!out) { + return null; + } + for (var i = 0, + ilen = sliced.length; i < ilen; i++) { + out = out[sliced[i]]; + if (typeof out === 'undefined') { + return null; + } + } + return out; + } else if (typeof prop === 'function') { + return prop(this.dataSource.slice(row, row + 1)[0]); + } else { + return this.dataSource[row] ? this.dataSource[row][prop] : null; + } +}; +var copyableLookup = helper.cellMethodLookupFactory('copyable', false); +DataMap.prototype.getCopyable = function(row, prop) { + if (copyableLookup.call(this.instance, row, this.propToCol(prop))) { + return this.get(row, prop); + } + return ''; +}; +DataMap.prototype.set = function(row, prop, value, source) { + row = Handsontable.hooks.run(this.instance, 'modifyRow', row, source || "datamapGet"); + if (typeof prop === 'string' && prop.indexOf('.') > -1) { + var sliced = prop.split("."); + var out = this.dataSource[row]; + for (var i = 0, + ilen = sliced.length - 1; i < ilen; i++) { + if (typeof out[sliced[i]] === 'undefined') { + out[sliced[i]] = {}; + } + out = out[sliced[i]]; + } + out[sliced[i]] = value; + } else if (typeof prop === 'function') { + prop(this.dataSource.slice(row, row + 1)[0], value); + } else { + this.dataSource[row][prop] = value; + } +}; +DataMap.prototype.physicalRowsToLogical = function(index, amount) { + var totalRows = this.instance.countRows(); + var physicRow = (totalRows + index) % totalRows; + var logicRows = []; + var rowsToRemove = amount; + var row; + while (physicRow < totalRows && rowsToRemove) { + row = Handsontable.hooks.run(this.instance, 'modifyRow', physicRow); + logicRows.push(row); + rowsToRemove--; + physicRow++; + } + return logicRows; +}; +DataMap.prototype.clear = function() { + for (var r = 0; r < this.instance.countRows(); r++) { + for (var c = 0; c < this.instance.countCols(); c++) { + this.set(r, this.colToProp(c), ''); + } + } +}; +DataMap.prototype.getAll = function() { + return this.dataSource; +}; +DataMap.prototype.getRange = function(start, end, destination) { + var r, + rlen, + c, + clen, + output = [], + row; + var getFn = destination === this.DESTINATION_CLIPBOARD_GENERATOR ? this.getCopyable : this.get; + rlen = Math.max(start.row, end.row); + clen = Math.max(start.col, end.col); + for (r = Math.min(start.row, end.row); r <= rlen; r++) { + row = []; + for (c = Math.min(start.col, end.col); c <= clen; c++) { + row.push(getFn.call(this, r, this.colToProp(c))); + } + output.push(row); + } + return output; +}; +DataMap.prototype.getText = function(start, end) { + return SheetClip.stringify(this.getRange(start, end, this.DESTINATION_RENDERER)); +}; +DataMap.prototype.getCopyableText = function(start, end) { + return SheetClip.stringify(this.getRange(start, end, this.DESTINATION_CLIPBOARD_GENERATOR)); +}; + +//# +},{"SheetClip":"SheetClip","helpers.js":42,"multiMap.js":43}],27:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + enableImmediatePropagation: {get: function() { + return enableImmediatePropagation; + }}, + closest: {get: function() { + return closest; + }}, + isChildOf: {get: function() { + return isChildOf; + }}, + isChildOfWebComponentTable: {get: function() { + return isChildOfWebComponentTable; + }}, + polymerWrap: {get: function() { + return polymerWrap; + }}, + polymerUnwrap: {get: function() { + return polymerUnwrap; + }}, + isWebComponentSupportedNatively: {get: function() { + return isWebComponentSupportedNatively; + }}, + index: {get: function() { + return index; + }}, + hasClass: {get: function() { + return hasClass; + }}, + addClass: {get: function() { + return addClass; + }}, + removeClass: {get: function() { + return removeClass; + }}, + removeTextNodes: {get: function() { + return removeTextNodes; + }}, + empty: {get: function() { + return empty; + }}, + HTML_CHARACTERS: {get: function() { + return HTML_CHARACTERS; + }}, + fastInnerHTML: {get: function() { + return fastInnerHTML; + }}, + fastInnerText: {get: function() { + return fastInnerText; + }}, + isVisible: {get: function() { + return isVisible; + }}, + offset: {get: function() { + return offset; + }}, + getWindowScrollTop: {get: function() { + return getWindowScrollTop; + }}, + getWindowScrollLeft: {get: function() { + return getWindowScrollLeft; + }}, + getScrollTop: {get: function() { + return getScrollTop; + }}, + getScrollLeft: {get: function() { + return getScrollLeft; + }}, + getScrollableElement: {get: function() { + return getScrollableElement; + }}, + getTrimmingContainer: {get: function() { + return getTrimmingContainer; + }}, + getStyle: {get: function() { + return getStyle; + }}, + getComputedStyle: {get: function() { + return getComputedStyle; + }}, + outerWidth: {get: function() { + return outerWidth; + }}, + outerHeight: {get: function() { + return outerHeight; + }}, + innerHeight: {get: function() { + return innerHeight; + }}, + innerWidth: {get: function() { + return innerWidth; + }}, + addEvent: {get: function() { + return addEvent; + }}, + removeEvent: {get: function() { + return removeEvent; + }}, + hasCaptionProblem: {get: function() { + return hasCaptionProblem; + }}, + getCaretPosition: {get: function() { + return getCaretPosition; + }}, + getSelectionEndPosition: {get: function() { + return getSelectionEndPosition; + }}, + setCaretPosition: {get: function() { + return setCaretPosition; + }}, + getScrollbarWidth: {get: function() { + return getScrollbarWidth; + }}, + isIE8: {get: function() { + return isIE8; + }}, + isIE9: {get: function() { + return isIE9; + }}, + isSafari: {get: function() { + return isSafari; + }}, + isChrome: {get: function() { + return isChrome; + }}, + setOverlayPosition: {get: function() { + return setOverlayPosition; + }}, + getCssTransform: {get: function() { + return getCssTransform; + }}, + resetCssTransform: {get: function() { + return resetCssTransform; + }}, + __esModule: {value: true} +}); +function enableImmediatePropagation(event) { + if (event != null && event.isImmediatePropagationEnabled == null) { + event.stopImmediatePropagation = function() { + this.isImmediatePropagationEnabled = false; + this.cancelBubble = true; + }; + event.isImmediatePropagationEnabled = true; + event.isImmediatePropagationStopped = function() { + return !this.isImmediatePropagationEnabled; + }; + } +} +function closest(element, nodes, until) { + while (element != null && element !== until) { + if (element.nodeType === Node.ELEMENT_NODE && (nodes.indexOf(element.nodeName) > -1 || nodes.indexOf(element) > -1)) { + return element; + } + if (element.host && element.nodeType === Node.DOCUMENT_FRAGMENT_NODE) { + element = element.host; + } else { + element = element.parentNode; + } + } + return null; +} +function isChildOf(child, parent) { + var node = child.parentNode; + var queriedParents = []; + if (typeof parent === "string") { + queriedParents = Array.prototype.slice.call(document.querySelectorAll(parent), 0); + } else { + queriedParents.push(parent); + } + while (node != null) { + if (queriedParents.indexOf(node) > -1) { + return true; + } + node = node.parentNode; + } + return false; +} +function isChildOfWebComponentTable(element) { + var hotTableName = 'hot-table', + result = false, + parentNode; + parentNode = polymerWrap(element); + function isHotTable(element) { + return element.nodeType === Node.ELEMENT_NODE && element.nodeName === hotTableName.toUpperCase(); + } + while (parentNode != null) { + if (isHotTable(parentNode)) { + result = true; + break; + } else if (parentNode.host && parentNode.nodeType === Node.DOCUMENT_FRAGMENT_NODE) { + result = isHotTable(parentNode.host); + if (result) { + break; + } + parentNode = parentNode.host; + } + parentNode = parentNode.parentNode; + } + return result; +} +function polymerWrap(element) { + return typeof Polymer !== 'undefined' && typeof wrap === 'function' ? wrap(element) : element; +} +function polymerUnwrap(element) { + return typeof Polymer !== 'undefined' && typeof unwrap === 'function' ? unwrap(element) : element; +} +function isWebComponentSupportedNatively() { + var test = document.createElement('div'); + return test.createShadowRoot && test.createShadowRoot.toString().match(/\[native code\]/) ? true : false; +} +function index(elem) { + var i = 0; + if (elem.previousSibling) { + while (elem = elem.previousSibling) { + ++i; + } + } + return i; +} +var classListSupport = document.documentElement.classList ? true : false; +var _hasClass, + _addClass, + _removeClass; +function filterEmptyClassNames(classNames) { + var len = 0, + result = []; + if (!classNames || !classNames.length) { + return result; + } + while (classNames[len]) { + result.push(classNames[len]); + len++; + } + return result; +} +if (classListSupport) { + var isSupportMultipleClassesArg = (function() { + var element = document.createElement('div'); + element.classList.add('test', 'test2'); + return element.classList.contains('test2'); + }()); + _hasClass = function _hasClass(element, className) { + if (className === '') { + return false; + } + return element.classList.contains(className); + }; + _addClass = function _addClass(element, className) { + var len = 0; + if (typeof className === 'string') { + className = className.split(' '); + } + className = filterEmptyClassNames(className); + if (isSupportMultipleClassesArg) { + element.classList.add.apply(element.classList, className); + } else { + while (className && className[len]) { + element.classList.add(className[len]); + len++; + } + } + }; + _removeClass = function _removeClass(element, className) { + var len = 0; + if (typeof className === 'string') { + className = className.split(' '); + } + className = filterEmptyClassNames(className); + if (isSupportMultipleClassesArg) { + element.classList.remove.apply(element.classList, className); + } else { + while (className && className[len]) { + element.classList.remove(className[len]); + len++; + } + } + }; +} else { + var createClassNameRegExp = function createClassNameRegExp(className) { + return new RegExp('(\\s|^)' + className + '(\\s|$)'); + }; + _hasClass = function _hasClass(element, className) { + return element.className.match(createClassNameRegExp(className)) ? true : false; + }; + _addClass = function _addClass(element, className) { + var len = 0, + _className = element.className; + if (typeof className === 'string') { + className = className.split(' '); + } + if (_className === '') { + _className = className.join(' '); + } else { + while (className && className[len]) { + if (!createClassNameRegExp(className[len]).test(_className)) { + _className += ' ' + className[len]; + } + len++; + } + } + element.className = _className; + }; + _removeClass = function _removeClass(element, className) { + var len = 0, + _className = element.className; + if (typeof className === 'string') { + className = className.split(' '); + } + while (className && className[len]) { + _className = _className.replace(createClassNameRegExp(className[len]), ' ').trim(); + len++; + } + if (element.className !== _className) { + element.className = _className; + } + }; +} +function hasClass(element, className) { + return _hasClass(element, className); +} +function addClass(element, className) { + return _addClass(element, className); +} +function removeClass(element, className) { + return _removeClass(element, className); +} +function removeTextNodes(elem, parent) { + if (elem.nodeType === 3) { + parent.removeChild(elem); + } else if (['TABLE', 'THEAD', 'TBODY', 'TFOOT', 'TR'].indexOf(elem.nodeName) > -1) { + var childs = elem.childNodes; + for (var i = childs.length - 1; i >= 0; i--) { + removeTextNodes(childs[i], elem); + } + } +} +function empty(element) { + var child; + while (child = element.lastChild) { + element.removeChild(child); + } +} +var HTML_CHARACTERS = /(<(.*)>|&(.*);)/; +function fastInnerHTML(element, content) { + if (HTML_CHARACTERS.test(content)) { + element.innerHTML = content; + } else { + fastInnerText(element, content); + } +} +var textContextSupport = document.createTextNode('test').textContent ? true : false; +function fastInnerText(element, content) { + var child = element.firstChild; + if (child && child.nodeType === 3 && child.nextSibling === null) { + if (textContextSupport) { + child.textContent = content; + } else { + child.data = content; + } + } else { + empty(element); + element.appendChild(document.createTextNode(content)); + } +} +function isVisible(elem) { + var next = elem; + while (polymerUnwrap(next) !== document.documentElement) { + if (next === null) { + return false; + } else if (next.nodeType === Node.DOCUMENT_FRAGMENT_NODE) { + if (next.host) { + if (next.host.impl) { + return isVisible(next.host.impl); + } else if (next.host) { + return isVisible(next.host); + } else { + throw new Error("Lost in Web Components world"); + } + } else { + return false; + } + } else if (next.style.display === 'none') { + return false; + } + next = next.parentNode; + } + return true; +} +function offset(elem) { + var offsetLeft, + offsetTop, + lastElem, + docElem, + box; + docElem = document.documentElement; + if (hasCaptionProblem() && elem.firstChild && elem.firstChild.nodeName === 'CAPTION') { + box = elem.getBoundingClientRect(); + return { + top: box.top + (window.pageYOffset || docElem.scrollTop) - (docElem.clientTop || 0), + left: box.left + (window.pageXOffset || docElem.scrollLeft) - (docElem.clientLeft || 0) + }; + } + offsetLeft = elem.offsetLeft; + offsetTop = elem.offsetTop; + lastElem = elem; + while (elem = elem.offsetParent) { + if (elem === document.body) { + break; + } + offsetLeft += elem.offsetLeft; + offsetTop += elem.offsetTop; + lastElem = elem; + } + if (lastElem && lastElem.style.position === 'fixed') { + offsetLeft += window.pageXOffset || docElem.scrollLeft; + offsetTop += window.pageYOffset || docElem.scrollTop; + } + return { + left: offsetLeft, + top: offsetTop + }; +} +function getWindowScrollTop() { + var res = window.scrollY; + if (res == void 0) { + res = document.documentElement.scrollTop; + } + return res; +} +function getWindowScrollLeft() { + var res = window.scrollX; + if (res == void 0) { + res = document.documentElement.scrollLeft; + } + return res; +} +function getScrollTop(elem) { + if (elem === window) { + return getWindowScrollTop(elem); + } else { + return elem.scrollTop; + } +} +function getScrollLeft(elem) { + if (elem === window) { + return getWindowScrollLeft(elem); + } else { + return elem.scrollLeft; + } +} +function getScrollableElement(element) { + var el = element.parentNode, + props = ['auto', 'scroll'], + overflow, + overflowX, + overflowY, + computedStyle = '', + computedOverflow = '', + computedOverflowY = '', + computedOverflowX = ''; + while (el && el.style && document.body !== el) { + overflow = el.style.overflow; + overflowX = el.style.overflowX; + overflowY = el.style.overflowY; + if (overflow == 'scroll' || overflowX == 'scroll' || overflowY == 'scroll') { + return el; + } else if (window.getComputedStyle) { + computedStyle = window.getComputedStyle(el); + computedOverflow = computedStyle.getPropertyValue('overflow'); + computedOverflowY = computedStyle.getPropertyValue('overflow-y'); + computedOverflowX = computedStyle.getPropertyValue('overflow-x'); + if (computedOverflow === 'scroll' || computedOverflowX === 'scroll' || computedOverflowY === 'scroll') { + return el; + } + } + if (el.clientHeight <= el.scrollHeight && (props.indexOf(overflowY) !== -1 || props.indexOf(overflow) !== -1 || props.indexOf(computedOverflow) !== -1 || props.indexOf(computedOverflowY) !== -1)) { + return el; + } + if (el.clientWidth <= el.scrollWidth && (props.indexOf(overflowX) !== -1 || props.indexOf(overflow) !== -1 || props.indexOf(computedOverflow) !== -1 || props.indexOf(computedOverflowX) !== -1)) { + return el; + } + el = el.parentNode; + } + return window; +} +function getTrimmingContainer(base) { + var el = base.parentNode; + while (el && el.style && document.body !== el) { + if (el.style.overflow !== 'visible' && el.style.overflow !== '') { + return el; + } else if (window.getComputedStyle) { + var computedStyle = window.getComputedStyle(el); + if (computedStyle.getPropertyValue('overflow') !== 'visible' && computedStyle.getPropertyValue('overflow') !== '') { + return el; + } + } + el = el.parentNode; + } + return window; +} +function getStyle(elem, prop) { + if (!elem) { + return; + } else if (elem === window) { + if (prop === 'width') { + return window.innerWidth + 'px'; + } else if (prop === 'height') { + return window.innerHeight + 'px'; + } + return; + } + var styleProp = elem.style[prop], + computedStyle; + if (styleProp !== "" && styleProp !== void 0) { + return styleProp; + } else { + computedStyle = getComputedStyle(elem); + if (computedStyle[prop] !== "" && computedStyle[prop] !== void 0) { + return computedStyle[prop]; + } + return void 0; + } +} +function getComputedStyle(elem) { + return elem.currentStyle || document.defaultView.getComputedStyle(elem); +} +function outerWidth(elem) { + return elem.offsetWidth; +} +function outerHeight(elem) { + if (hasCaptionProblem() && elem.firstChild && elem.firstChild.nodeName === 'CAPTION') { + return elem.offsetHeight + elem.firstChild.offsetHeight; + } else { + return elem.offsetHeight; + } +} +function innerHeight(elem) { + return elem.clientHeight || elem.innerHeight; +} +function innerWidth(elem) { + return elem.clientWidth || elem.innerWidth; +} +function addEvent(element, event, callback) { + if (window.addEventListener) { + element.addEventListener(event, callback, false); + } else { + element.attachEvent('on' + event, callback); + } +} +function removeEvent(element, event, callback) { + if (window.removeEventListener) { + element.removeEventListener(event, callback, false); + } else { + element.detachEvent('on' + event, callback); + } +} +var _hasCaptionProblem; +function detectCaptionProblem() { + var TABLE = document.createElement('TABLE'); + TABLE.style.borderSpacing = 0; + TABLE.style.borderWidth = 0; + TABLE.style.padding = 0; + var TBODY = document.createElement('TBODY'); + TABLE.appendChild(TBODY); + TBODY.appendChild(document.createElement('TR')); + TBODY.firstChild.appendChild(document.createElement('TD')); + TBODY.firstChild.firstChild.innerHTML = 't
t'; + var CAPTION = document.createElement('CAPTION'); + CAPTION.innerHTML = 'c
c
c
c'; + CAPTION.style.padding = 0; + CAPTION.style.margin = 0; + TABLE.insertBefore(CAPTION, TBODY); + document.body.appendChild(TABLE); + _hasCaptionProblem = (TABLE.offsetHeight < 2 * TABLE.lastChild.offsetHeight); + document.body.removeChild(TABLE); +} +function hasCaptionProblem() { + if (_hasCaptionProblem === void 0) { + detectCaptionProblem(); + } + return _hasCaptionProblem; +} +function getCaretPosition(el) { + if (el.selectionStart) { + return el.selectionStart; + } else if (document.selection) { + el.focus(); + var r = document.selection.createRange(); + if (r == null) { + return 0; + } + var re = el.createTextRange(); + var rc = re.duplicate(); + re.moveToBookmark(r.getBookmark()); + rc.setEndPoint('EndToStart', re); + return rc.text.length; + } + return 0; +} +function getSelectionEndPosition(el) { + if (el.selectionEnd) { + return el.selectionEnd; + } else if (document.selection) { + var r = document.selection.createRange(); + if (r == null) { + return 0; + } + var re = el.createTextRange(); + return re.text.indexOf(r.text) + r.text.length; + } +} +function setCaretPosition(el, pos, endPos) { + if (endPos === void 0) { + endPos = pos; + } + if (el.setSelectionRange) { + el.focus(); + try { + el.setSelectionRange(pos, endPos); + } catch (err) { + var elementParent = el.parentNode; + var parentDisplayValue = elementParent.style.display; + elementParent.style.display = 'block'; + el.setSelectionRange(pos, endPos); + elementParent.style.display = parentDisplayValue; + } + } else if (el.createTextRange) { + var range = el.createTextRange(); + range.collapse(true); + range.moveEnd('character', endPos); + range.moveStart('character', pos); + range.select(); + } +} +var cachedScrollbarWidth; +function walkontableCalculateScrollbarWidth() { + var inner = document.createElement('p'); + inner.style.width = "100%"; + inner.style.height = "200px"; + var outer = document.createElement('div'); + outer.style.position = "absolute"; + outer.style.top = "0px"; + outer.style.left = "0px"; + outer.style.visibility = "hidden"; + outer.style.width = "200px"; + outer.style.height = "150px"; + outer.style.overflow = "hidden"; + outer.appendChild(inner); + (document.body || document.documentElement).appendChild(outer); + var w1 = inner.offsetWidth; + outer.style.overflow = 'scroll'; + var w2 = inner.offsetWidth; + if (w1 == w2) { + w2 = outer.clientWidth; + } + (document.body || document.documentElement).removeChild(outer); + return (w1 - w2); +} +function getScrollbarWidth() { + if (cachedScrollbarWidth === void 0) { + cachedScrollbarWidth = walkontableCalculateScrollbarWidth(); + } + return cachedScrollbarWidth; +} +var _isIE8 = !(document.createTextNode('test').textContent); +function isIE8() { + return isIE8; +} +var _isIE9 = !!(document.documentMode); +function isIE9() { + return _isIE9; +} +var _isSafari = (/Safari/.test(navigator.userAgent) && /Apple Computer/.test(navigator.vendor)); +function isSafari() { + return _isSafari; +} +var _isChrome = (/Chrome/.test(navigator.userAgent) && /Google/.test(navigator.vendor)); +function isChrome() { + return _isChrome; +} +function setOverlayPosition(overlayElem, left, top) { + if (_isIE8 || _isIE9) { + overlayElem.style.top = top; + overlayElem.style.left = left; + } else if (_isSafari) { + overlayElem.style['-webkit-transform'] = 'translate3d(' + left + ',' + top + ',0)'; + } else { + overlayElem.style.transform = 'translate3d(' + left + ',' + top + ',0)'; + } +} +function getCssTransform(elem) { + var transform; + if (elem.style['transform'] && (transform = elem.style['transform']) !== '') { + return ['transform', transform]; + } else if (elem.style['-webkit-transform'] && (transform = elem.style['-webkit-transform']) !== '') { + return ['-webkit-transform', transform]; + } + return -1; +} +function resetCssTransform(elem) { + if (elem['transform'] && elem['transform'] !== '') { + elem['transform'] = ''; + } else if (elem['-webkit-transform'] && elem['-webkit-transform'] !== '') { + elem['-webkit-transform'] = ''; + } +} +window.Handsontable = window.Handsontable || {}; +Handsontable.Dom = { + addClass: addClass, + addEvent: addEvent, + closest: closest, + empty: empty, + enableImmediatePropagation: enableImmediatePropagation, + fastInnerHTML: fastInnerHTML, + fastInnerText: fastInnerText, + getCaretPosition: getCaretPosition, + getComputedStyle: getComputedStyle, + getCssTransform: getCssTransform, + getScrollableElement: getScrollableElement, + getScrollbarWidth: getScrollbarWidth, + getScrollLeft: getScrollLeft, + getScrollTop: getScrollTop, + getStyle: getStyle, + getSelectionEndPosition: getSelectionEndPosition, + getTrimmingContainer: getTrimmingContainer, + getWindowScrollLeft: getWindowScrollLeft, + getWindowScrollTop: getWindowScrollTop, + hasCaptionProblem: hasCaptionProblem, + hasClass: hasClass, + HTML_CHARACTERS: HTML_CHARACTERS, + index: index, + innerHeight: innerHeight, + innerWidth: innerWidth, + isChildOf: isChildOf, + isChildOfWebComponentTable: isChildOfWebComponentTable, + isChrome: isChrome, + isIE8: isIE8, + isIE9: isIE9, + isSafari: isSafari, + isVisible: isVisible, + isWebComponentSupportedNatively: isWebComponentSupportedNatively, + offset: offset, + outerHeight: outerHeight, + outerWidth: outerWidth, + polymerUnwrap: polymerUnwrap, + polymerWrap: polymerWrap, + removeClass: removeClass, + removeEvent: removeEvent, + removeTextNodes: removeTextNodes, + resetCssTransform: resetCssTransform, + setCaretPosition: setCaretPosition, + setOverlayPosition: setOverlayPosition +}; + +//# +},{}],28:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + EditorManager: {get: function() { + return EditorManager; + }}, + __esModule: {value: true} +}); +var $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__, + $__helpers_46_js__, + $__dom_46_js__, + $__editors_46_js__, + $__eventManager_46_js__; +var WalkontableCellCoords = ($__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ = require("3rdparty/walkontable/src/cell/coords.js"), $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ && $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__.__esModule && $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ || {default: $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__}).WalkontableCellCoords; +var helper = ($__helpers_46_js__ = require("helpers.js"), $__helpers_46_js__ && $__helpers_46_js__.__esModule && $__helpers_46_js__ || {default: $__helpers_46_js__}); +var dom = ($__dom_46_js__ = require("dom.js"), $__dom_46_js__ && $__dom_46_js__.__esModule && $__dom_46_js__ || {default: $__dom_46_js__}); +var getEditor = ($__editors_46_js__ = require("editors.js"), $__editors_46_js__ && $__editors_46_js__.__esModule && $__editors_46_js__ || {default: $__editors_46_js__}).getEditor; +var eventManagerObject = ($__eventManager_46_js__ = require("eventManager.js"), $__eventManager_46_js__ && $__eventManager_46_js__.__esModule && $__eventManager_46_js__ || {default: $__eventManager_46_js__}).eventManager; +; +Handsontable.EditorManager = EditorManager; +function EditorManager(instance, priv, selection) { + var _this = this, + keyCodes = helper.keyCode, + destroyed = false, + eventManager, + activeEditor; + eventManager = eventManagerObject(instance); + function moveSelectionAfterEnter(shiftKey) { + var enterMoves = typeof priv.settings.enterMoves === 'function' ? priv.settings.enterMoves(event) : priv.settings.enterMoves; + if (shiftKey) { + selection.transformStart(-enterMoves.row, -enterMoves.col); + } else { + selection.transformStart(enterMoves.row, enterMoves.col, true); + } + } + function moveSelectionUp(shiftKey) { + if (shiftKey) { + selection.transformEnd(-1, 0); + } else { + selection.transformStart(-1, 0); + } + } + function moveSelectionDown(shiftKey) { + if (shiftKey) { + selection.transformEnd(1, 0); + } else { + selection.transformStart(1, 0); + } + } + function moveSelectionRight(shiftKey) { + if (shiftKey) { + selection.transformEnd(0, 1); + } else { + selection.transformStart(0, 1); + } + } + function moveSelectionLeft(shiftKey) { + if (shiftKey) { + selection.transformEnd(0, -1); + } else { + selection.transformStart(0, -1); + } + } + function onKeyDown(event) { + var ctrlDown, + rangeModifier; + if (!instance.isListening()) { + return; + } + Handsontable.hooks.run(instance, 'beforeKeyDown', event); + if (destroyed) { + return; + } + dom.enableImmediatePropagation(event); + if (event.isImmediatePropagationStopped()) { + return; + } + priv.lastKeyCode = event.keyCode; + if (!selection.isSelected()) { + return; + } + ctrlDown = (event.ctrlKey || event.metaKey) && !event.altKey; + if (activeEditor && !activeEditor.isWaiting()) { + if (!helper.isMetaKey(event.keyCode) && !helper.isCtrlKey(event.keyCode) && !ctrlDown && !_this.isEditorOpened()) { + _this.openEditor("", event); + return; + } + } + rangeModifier = event.shiftKey ? selection.setRangeEnd : selection.setRangeStart; + switch (event.keyCode) { + case keyCodes.A: + if (!_this.isEditorOpened() && ctrlDown) { + selection.selectAll(); + event.preventDefault(); + helper.stopPropagation(event); + } + break; + case keyCodes.ARROW_UP: + if (_this.isEditorOpened() && !activeEditor.isWaiting()) { + _this.closeEditorAndSaveChanges(ctrlDown); + } + moveSelectionUp(event.shiftKey); + event.preventDefault(); + helper.stopPropagation(event); + break; + case keyCodes.ARROW_DOWN: + if (_this.isEditorOpened() && !activeEditor.isWaiting()) { + _this.closeEditorAndSaveChanges(ctrlDown); + } + moveSelectionDown(event.shiftKey); + event.preventDefault(); + helper.stopPropagation(event); + break; + case keyCodes.ARROW_RIGHT: + if (_this.isEditorOpened() && !activeEditor.isWaiting()) { + _this.closeEditorAndSaveChanges(ctrlDown); + } + moveSelectionRight(event.shiftKey); + event.preventDefault(); + helper.stopPropagation(event); + break; + case keyCodes.ARROW_LEFT: + if (_this.isEditorOpened() && !activeEditor.isWaiting()) { + _this.closeEditorAndSaveChanges(ctrlDown); + } + moveSelectionLeft(event.shiftKey); + event.preventDefault(); + helper.stopPropagation(event); + break; + case keyCodes.TAB: + var tabMoves = typeof priv.settings.tabMoves === 'function' ? priv.settings.tabMoves(event) : priv.settings.tabMoves; + if (event.shiftKey) { + selection.transformStart(-tabMoves.row, -tabMoves.col); + } else { + selection.transformStart(tabMoves.row, tabMoves.col, true); + } + event.preventDefault(); + helper.stopPropagation(event); + break; + case keyCodes.BACKSPACE: + case keyCodes.DELETE: + selection.empty(event); + _this.prepareEditor(); + event.preventDefault(); + break; + case keyCodes.F2: + _this.openEditor(null, event); + if (activeEditor) { + activeEditor.enableFullEditMode(); + } + event.preventDefault(); + break; + case keyCodes.ENTER: + if (_this.isEditorOpened()) { + if (activeEditor && activeEditor.state !== Handsontable.EditorState.WAITING) { + _this.closeEditorAndSaveChanges(ctrlDown); + } + moveSelectionAfterEnter(event.shiftKey); + } else { + if (instance.getSettings().enterBeginsEditing) { + _this.openEditor(null, event); + if (activeEditor) { + activeEditor.enableFullEditMode(); + } + } else { + moveSelectionAfterEnter(event.shiftKey); + } + } + event.preventDefault(); + event.stopImmediatePropagation(); + break; + case keyCodes.ESCAPE: + if (_this.isEditorOpened()) { + _this.closeEditorAndRestoreOriginalValue(ctrlDown); + } + event.preventDefault(); + break; + case keyCodes.HOME: + if (event.ctrlKey || event.metaKey) { + rangeModifier(new WalkontableCellCoords(0, priv.selRange.from.col)); + } else { + rangeModifier(new WalkontableCellCoords(priv.selRange.from.row, 0)); + } + event.preventDefault(); + helper.stopPropagation(event); + break; + case keyCodes.END: + if (event.ctrlKey || event.metaKey) { + rangeModifier(new WalkontableCellCoords(instance.countRows() - 1, priv.selRange.from.col)); + } else { + rangeModifier(new WalkontableCellCoords(priv.selRange.from.row, instance.countCols() - 1)); + } + event.preventDefault(); + helper.stopPropagation(event); + break; + case keyCodes.PAGE_UP: + selection.transformStart(-instance.countVisibleRows(), 0); + event.preventDefault(); + helper.stopPropagation(event); + break; + case keyCodes.PAGE_DOWN: + selection.transformStart(instance.countVisibleRows(), 0); + event.preventDefault(); + helper.stopPropagation(event); + break; + } + } + function init() { + instance.addHook('afterDocumentKeyDown', onKeyDown); + eventManager.addEventListener(document.documentElement, 'keydown', function(event) { + instance.runHooks('afterDocumentKeyDown', event); + }); + function onDblClick(event, coords, elem) { + if (elem.nodeName == "TD") { + _this.openEditor(); + if (activeEditor) { + activeEditor.enableFullEditMode(); + } + } + } + instance.view.wt.update('onCellDblClick', onDblClick); + instance.addHook('afterDestroy', function() { + destroyed = true; + }); + } + this.destroyEditor = function(revertOriginal) { + this.closeEditor(revertOriginal); + }; + this.getActiveEditor = function() { + return activeEditor; + }; + this.prepareEditor = function() { + var row, + col, + prop, + td, + originalValue, + cellProperties, + editorClass; + if (activeEditor && activeEditor.isWaiting()) { + this.closeEditor(false, false, function(dataSaved) { + if (dataSaved) { + _this.prepareEditor(); + } + }); + return; + } + row = priv.selRange.highlight.row; + col = priv.selRange.highlight.col; + prop = instance.colToProp(col); + td = instance.getCell(row, col); + originalValue = instance.getDataAtCell(row, col); + cellProperties = instance.getCellMeta(row, col); + editorClass = instance.getCellEditor(cellProperties); + if (editorClass) { + activeEditor = Handsontable.editors.getEditor(editorClass, instance); + activeEditor.prepare(row, col, prop, td, originalValue, cellProperties); + } else { + activeEditor = void 0; + } + }; + this.isEditorOpened = function() { + return activeEditor && activeEditor.isOpened(); + }; + this.openEditor = function(initialValue, event) { + if (activeEditor && !activeEditor.cellProperties.readOnly) { + activeEditor.beginEditing(initialValue, event); + } else if (activeEditor && activeEditor.cellProperties.readOnly) { + if (event && event.keyCode === helper.keyCode.ENTER) { + moveSelectionAfterEnter(); + } + } + }; + this.closeEditor = function(restoreOriginalValue, ctrlDown, callback) { + if (!activeEditor) { + if (callback) { + callback(false); + } + } else { + activeEditor.finishEditing(restoreOriginalValue, ctrlDown, callback); + } + }; + this.closeEditorAndSaveChanges = function(ctrlDown) { + return this.closeEditor(false, ctrlDown); + }; + this.closeEditorAndRestoreOriginalValue = function(ctrlDown) { + return this.closeEditor(true, ctrlDown); + }; + init(); +} + +//# +},{"3rdparty/walkontable/src/cell/coords.js":5,"dom.js":27,"editors.js":29,"eventManager.js":41,"helpers.js":42}],29:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + registerEditor: {get: function() { + return registerEditor; + }}, + getEditor: {get: function() { + return getEditor; + }}, + hasEditor: {get: function() { + return hasEditor; + }}, + getEditorConstructor: {get: function() { + return getEditorConstructor; + }}, + __esModule: {value: true} +}); +var $__helpers_46_js__; +var helper = ($__helpers_46_js__ = require("helpers.js"), $__helpers_46_js__ && $__helpers_46_js__.__esModule && $__helpers_46_js__ || {default: $__helpers_46_js__}); +; +var registeredEditorNames = {}, + registeredEditorClasses = new WeakMap(); +Handsontable.editors = Handsontable.editors || {}; +Handsontable.editors.registerEditor = registerEditor; +Handsontable.editors.getEditor = getEditor; +function RegisteredEditor(editorClass) { + var Clazz, + instances; + instances = {}; + Clazz = editorClass; + this.getConstructor = function() { + return editorClass; + }; + this.getInstance = function(hotInstance) { + if (!(hotInstance.guid in instances)) { + instances[hotInstance.guid] = new Clazz(hotInstance); + } + return instances[hotInstance.guid]; + }; +} +function registerEditor(editorName, editorClass) { + var editor = new RegisteredEditor(editorClass); + if (typeof editorName === 'string') { + registeredEditorNames[editorName] = editor; + Handsontable.editors[helper.toUpperCaseFirst(editorName) + 'Editor'] = editorClass; + } + registeredEditorClasses.set(editorClass, editor); +} +function getEditor(editorName, hotInstance) { + var editor; + if (typeof editorName == 'function') { + if (!(registeredEditorClasses.get(editorName))) { + registerEditor(null, editorName); + } + editor = registeredEditorClasses.get(editorName); + } else if (typeof editorName == 'string') { + editor = registeredEditorNames[editorName]; + } else { + throw Error('Only strings and functions can be passed as "editor" parameter '); + } + if (!editor) { + throw Error('No editor registered under name "' + editorName + '"'); + } + return editor.getInstance(hotInstance); +} +function getEditorConstructor(editorName) { + var editor; + if (typeof editorName == 'string') { + editor = registeredEditorNames[editorName]; + } else { + throw Error('Only strings and functions can be passed as "editor" parameter '); + } + if (!editor) { + throw Error('No editor registered under name "' + editorName + '"'); + } + return editor.getConstructor(); +} +function hasEditor(editorName) { + return registeredEditorNames[editorName] ? true : false; +} + +//# +},{"helpers.js":42}],30:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + BaseEditor: {get: function() { + return BaseEditor; + }}, + __esModule: {value: true} +}); +var $___46__46__47_helpers_46_js__, + $___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__; +var helper = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}); +var WalkontableCellCoords = ($___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ = require("3rdparty/walkontable/src/cell/coords.js"), $___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ && $___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__.__esModule && $___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ || {default: $___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__}).WalkontableCellCoords; +; +Handsontable.editors = Handsontable.editors || {}; +Handsontable.editors.BaseEditor = BaseEditor; +Handsontable.EditorState = { + VIRGIN: 'STATE_VIRGIN', + EDITING: 'STATE_EDITING', + WAITING: 'STATE_WAITING', + FINISHED: 'STATE_FINISHED' +}; +function BaseEditor(instance) { + this.instance = instance; + this.state = Handsontable.EditorState.VIRGIN; + this._opened = false; + this._fullEditMode = false; + this._closeCallback = null; + this.init(); +} +BaseEditor.prototype._fireCallbacks = function(result) { + if (this._closeCallback) { + this._closeCallback(result); + this._closeCallback = null; + } +}; +BaseEditor.prototype.init = function() {}; +BaseEditor.prototype.getValue = function() { + throw Error('Editor getValue() method unimplemented'); +}; +BaseEditor.prototype.setValue = function(newValue) { + throw Error('Editor setValue() method unimplemented'); +}; +BaseEditor.prototype.open = function() { + throw Error('Editor open() method unimplemented'); +}; +BaseEditor.prototype.close = function() { + throw Error('Editor close() method unimplemented'); +}; +BaseEditor.prototype.prepare = function(row, col, prop, td, originalValue, cellProperties) { + this.TD = td; + this.row = row; + this.col = col; + this.prop = prop; + this.originalValue = originalValue; + this.cellProperties = cellProperties; + this.state = Handsontable.EditorState.VIRGIN; +}; +BaseEditor.prototype.extend = function() { + var baseClass = this.constructor; + function Editor() { + baseClass.apply(this, arguments); + } + function inherit(Child, Parent) { + function Bridge() {} + Bridge.prototype = Parent.prototype; + Child.prototype = new Bridge(); + Child.prototype.constructor = Child; + return Child; + } + return inherit(Editor, baseClass); +}; +BaseEditor.prototype.saveValue = function(val, ctrlDown) { + var sel, + tmp; + if (ctrlDown) { + sel = this.instance.getSelected(); + if (sel[0] > sel[2]) { + tmp = sel[0]; + sel[0] = sel[2]; + sel[2] = tmp; + } + if (sel[1] > sel[3]) { + tmp = sel[1]; + sel[1] = sel[3]; + sel[3] = tmp; + } + this.instance.populateFromArray(sel[0], sel[1], val, sel[2], sel[3], 'edit'); + } else { + this.instance.populateFromArray(this.row, this.col, val, null, null, 'edit'); + } +}; +BaseEditor.prototype.beginEditing = function(initialValue, event) { + if (this.state != Handsontable.EditorState.VIRGIN) { + return; + } + this.instance.view.scrollViewport(new WalkontableCellCoords(this.row, this.col)); + this.instance.view.render(); + this.state = Handsontable.EditorState.EDITING; + initialValue = typeof initialValue == 'string' ? initialValue : this.originalValue; + this.setValue(helper.stringify(initialValue)); + this.open(event); + this._opened = true; + this.focus(); + this.instance.view.render(); +}; +BaseEditor.prototype.finishEditing = function(restoreOriginalValue, ctrlDown, callback) { + var _this = this, + val; + if (callback) { + var previousCloseCallback = this._closeCallback; + this._closeCallback = function(result) { + if (previousCloseCallback) { + previousCloseCallback(result); + } + callback(result); + }; + } + if (this.isWaiting()) { + return; + } + if (this.state == Handsontable.EditorState.VIRGIN) { + this.instance._registerTimeout(setTimeout(function() { + _this._fireCallbacks(true); + }, 0)); + return; + } + if (this.state == Handsontable.EditorState.EDITING) { + if (restoreOriginalValue) { + this.cancelChanges(); + this.instance.view.render(); + return; + } + if (this.instance.getSettings().trimWhitespace) { + val = [[typeof this.getValue() === 'string' ? String.prototype.trim.call(this.getValue() || '') : this.getValue()]]; + } else { + val = [[this.getValue()]]; + } + this.state = Handsontable.EditorState.WAITING; + this.saveValue(val, ctrlDown); + if (this.instance.getCellValidator(this.cellProperties)) { + this.instance.addHookOnce('postAfterValidate', function(result) { + _this.state = Handsontable.EditorState.FINISHED; + _this.discardEditor(result); + }); + } else { + this.state = Handsontable.EditorState.FINISHED; + this.discardEditor(true); + } + } +}; +BaseEditor.prototype.cancelChanges = function() { + this.state = Handsontable.EditorState.FINISHED; + this.discardEditor(); +}; +BaseEditor.prototype.discardEditor = function(result) { + if (this.state !== Handsontable.EditorState.FINISHED) { + return; + } + if (result === false && this.cellProperties.allowInvalid !== true) { + this.instance.selectCell(this.row, this.col); + this.focus(); + this.state = Handsontable.EditorState.EDITING; + this._fireCallbacks(false); + } else { + this.close(); + this._opened = false; + this._fullEditMode = false; + this.state = Handsontable.EditorState.VIRGIN; + this._fireCallbacks(true); + } +}; +BaseEditor.prototype.enableFullEditMode = function() { + this._fullEditMode = true; +}; +BaseEditor.prototype.isInFullEditMode = function() { + return this._fullEditMode; +}; +BaseEditor.prototype.isOpened = function() { + return this._opened; +}; +BaseEditor.prototype.isWaiting = function() { + return this.state === Handsontable.EditorState.WAITING; +}; + +//# +},{"3rdparty/walkontable/src/cell/coords.js":5,"helpers.js":42}],31:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + AutocompleteEditor: {get: function() { + return AutocompleteEditor; + }}, + __esModule: {value: true} +}); +var $___46__46__47_helpers_46_js__, + $___46__46__47_dom_46_js__, + $___46__46__47_editors_46_js__, + $__handsontableEditor_46_js__; +var helper = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}); +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var $__0 = ($___46__46__47_editors_46_js__ = require("editors.js"), $___46__46__47_editors_46_js__ && $___46__46__47_editors_46_js__.__esModule && $___46__46__47_editors_46_js__ || {default: $___46__46__47_editors_46_js__}), + getEditorConstructor = $__0.getEditorConstructor, + registerEditor = $__0.registerEditor; +var HandsontableEditor = ($__handsontableEditor_46_js__ = require("handsontableEditor.js"), $__handsontableEditor_46_js__ && $__handsontableEditor_46_js__.__esModule && $__handsontableEditor_46_js__ || {default: $__handsontableEditor_46_js__}).HandsontableEditor; +var AutocompleteEditor = HandsontableEditor.prototype.extend(); +AutocompleteEditor.prototype.init = function() { + HandsontableEditor.prototype.init.apply(this, arguments); + this.query = null; + this.choices = []; +}; +AutocompleteEditor.prototype.createElements = function() { + HandsontableEditor.prototype.createElements.apply(this, arguments); + dom.addClass(this.htContainer, 'autocompleteEditor'); + dom.addClass(this.htContainer, window.navigator.platform.indexOf('Mac') !== -1 ? 'htMacScroll' : ''); +}; +var skipOne = false; +function onBeforeKeyDown(event) { + skipOne = false; + var editor = this.getActiveEditor(); + var keyCodes = helper.keyCode; + if (helper.isPrintableChar(event.keyCode) || event.keyCode === keyCodes.BACKSPACE || event.keyCode === keyCodes.DELETE || event.keyCode === keyCodes.INSERT) { + var timeOffset = 0; + if (event.keyCode === keyCodes.C && (event.ctrlKey || event.metaKey)) { + return; + } + if (!editor.isOpened()) { + timeOffset += 10; + } + editor.instance._registerTimeout(setTimeout(function() { + editor.queryChoices(editor.TEXTAREA.value); + skipOne = true; + }, timeOffset)); + } +} +AutocompleteEditor.prototype.prepare = function() { + this.instance.addHook('beforeKeyDown', onBeforeKeyDown); + HandsontableEditor.prototype.prepare.apply(this, arguments); +}; +AutocompleteEditor.prototype.open = function() { + HandsontableEditor.prototype.open.apply(this, arguments); + var choicesListHot = this.htEditor.getInstance(); + var that = this; + var trimDropdown = this.cellProperties.trimDropdown === void 0 ? true : this.cellProperties.trimDropdown; + this.TEXTAREA.style.visibility = 'visible'; + this.focus(); + choicesListHot.updateSettings({ + 'colWidths': trimDropdown ? [dom.outerWidth(this.TEXTAREA) - 2] : void 0, + width: trimDropdown ? dom.outerWidth(this.TEXTAREA) + dom.getScrollbarWidth() + 2 : void 0, + afterRenderer: function(TD, row, col, prop, value) { + var caseSensitive = this.getCellMeta(row, col).filteringCaseSensitive === true, + indexOfMatch, + match, + value = Handsontable.helper.stringify(value); + if (value) { + indexOfMatch = caseSensitive ? value.indexOf(this.query) : value.toLowerCase().indexOf(that.query.toLowerCase()); + if (indexOfMatch != -1) { + match = value.substr(indexOfMatch, that.query.length); + TD.innerHTML = value.replace(match, '' + match + ''); + } + } + }, + modifyColWidth: function(width, col) { + return trimDropdown ? width : width + 15; + } + }); + this.htEditor.view.wt.wtTable.holder.parentNode.style['padding-right'] = dom.getScrollbarWidth() + 2 + 'px'; + if (skipOne) { + skipOne = false; + } + that.instance._registerTimeout(setTimeout(function() { + that.queryChoices(that.TEXTAREA.value); + }, 0)); +}; +AutocompleteEditor.prototype.close = function() { + HandsontableEditor.prototype.close.apply(this, arguments); +}; +AutocompleteEditor.prototype.queryChoices = function(query) { + this.query = query; + if (typeof this.cellProperties.source == 'function') { + var that = this; + this.cellProperties.source(query, function(choices) { + that.updateChoicesList(choices); + }); + } else if (Array.isArray(this.cellProperties.source)) { + var choices; + if (!query || this.cellProperties.filter === false) { + choices = this.cellProperties.source; + } else { + var filteringCaseSensitive = this.cellProperties.filteringCaseSensitive === true; + var lowerCaseQuery = query.toLowerCase(); + choices = this.cellProperties.source.filter(function(choice) { + if (filteringCaseSensitive) { + return choice.indexOf(query) != -1; + } else { + return choice.toLowerCase().indexOf(lowerCaseQuery) != -1; + } + }); + } + this.updateChoicesList(choices); + } else { + this.updateChoicesList([]); + } +}; +AutocompleteEditor.prototype.updateChoicesList = function(choices) { + var pos = dom.getCaretPosition(this.TEXTAREA), + endPos = dom.getSelectionEndPosition(this.TEXTAREA); + var orderByRelevance = AutocompleteEditor.sortByRelevance(this.getValue(), choices, this.cellProperties.filteringCaseSensitive); + var highlightIndex; + if (this.cellProperties.filter != false) { + var sorted = []; + for (var i = 0, + choicesCount = orderByRelevance.length; i < choicesCount; i++) { + sorted.push(choices[orderByRelevance[i]]); + } + highlightIndex = 0; + choices = sorted; + } else { + highlightIndex = orderByRelevance[0]; + } + this.choices = choices; + this.htEditor.loadData(helper.pivot([choices])); + this.updateDropdownHeight(); + if (this.cellProperties.strict === true) { + this.highlightBestMatchingChoice(highlightIndex); + } + this.instance.listen(); + this.TEXTAREA.focus(); + dom.setCaretPosition(this.TEXTAREA, pos, (pos != endPos ? endPos : void 0)); +}; +AutocompleteEditor.prototype.updateDropdownHeight = function() { + var currentDropdownWidth = this.htEditor.getColWidth(0) + dom.getScrollbarWidth() + 2; + var trimDropdown = this.cellProperties.trimDropdown === void 0 ? true : this.cellProperties.trimDropdown; + this.htEditor.updateSettings({ + height: this.getDropdownHeight(), + width: trimDropdown ? void 0 : currentDropdownWidth + }); + this.htEditor.view.wt.wtTable.alignOverlaysWithTrimmingContainer(); +}; +AutocompleteEditor.prototype.finishEditing = function(restoreOriginalValue) { + if (!restoreOriginalValue) { + this.instance.removeHook('beforeKeyDown', onBeforeKeyDown); + } + HandsontableEditor.prototype.finishEditing.apply(this, arguments); +}; +AutocompleteEditor.prototype.highlightBestMatchingChoice = function(index) { + if (typeof index === "number") { + this.htEditor.selectCell(index, 0); + } else { + this.htEditor.deselectCell(); + } +}; +AutocompleteEditor.sortByRelevance = function(value, choices, caseSensitive) { + var choicesRelevance = [], + currentItem, + valueLength = value.length, + valueIndex, + charsLeft, + result = [], + i, + choicesCount; + if (valueLength === 0) { + for (i = 0, choicesCount = choices.length; i < choicesCount; i++) { + result.push(i); + } + return result; + } + for (i = 0, choicesCount = choices.length; i < choicesCount; i++) { + currentItem = Handsontable.helper.stringify(choices[i]); + if (caseSensitive) { + valueIndex = currentItem.indexOf(value); + } else { + valueIndex = currentItem.toLowerCase().indexOf(value.toLowerCase()); + } + if (valueIndex == -1) { + continue; + } + charsLeft = currentItem.length - valueIndex - valueLength; + choicesRelevance.push({ + baseIndex: i, + index: valueIndex, + charsLeft: charsLeft, + value: currentItem + }); + } + choicesRelevance.sort(function(a, b) { + if (b.index === -1) { + return -1; + } + if (a.index === -1) { + return 1; + } + if (a.index < b.index) { + return -1; + } else if (b.index < a.index) { + return 1; + } else if (a.index === b.index) { + if (a.charsLeft < b.charsLeft) { + return -1; + } else if (a.charsLeft > b.charsLeft) { + return 1; + } else { + return 0; + } + } + }); + for (i = 0, choicesCount = choicesRelevance.length; i < choicesCount; i++) { + result.push(choicesRelevance[i].baseIndex); + } + return result; +}; +AutocompleteEditor.prototype.getDropdownHeight = function() { + var firstRowHeight = this.htEditor.getInstance().getRowHeight(0) || 23; + return this.choices.length >= 10 ? 10 * firstRowHeight : this.choices.length * firstRowHeight + 8; +}; +AutocompleteEditor.prototype.allowKeyEventPropagation = function(keyCode) { + var selected = {row: this.htEditor.getSelectedRange() ? this.htEditor.getSelectedRange().from.row : -1}; + var allowed = false; + if (keyCode === helper.keyCode.ARROW_DOWN && selected.row < this.htEditor.countRows() - 1) { + allowed = true; + } + if (keyCode === helper.keyCode.ARROW_UP && selected.row > -1) { + allowed = true; + } + return allowed; +}; +; +registerEditor('autocomplete', AutocompleteEditor); + +//# +},{"dom.js":27,"editors.js":29,"handsontableEditor.js":35,"helpers.js":42}],32:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + CheckboxEditor: {get: function() { + return CheckboxEditor; + }}, + __esModule: {value: true} +}); +var $___46__46__47_editors_46_js__, + $___95_baseEditor_46_js__, + $___46__46__47_dom_46_js__; +var registerEditor = ($___46__46__47_editors_46_js__ = require("editors.js"), $___46__46__47_editors_46_js__ && $___46__46__47_editors_46_js__.__esModule && $___46__46__47_editors_46_js__ || {default: $___46__46__47_editors_46_js__}).registerEditor; +var BaseEditor = ($___95_baseEditor_46_js__ = require("_baseEditor.js"), $___95_baseEditor_46_js__ && $___95_baseEditor_46_js__.__esModule && $___95_baseEditor_46_js__ || {default: $___95_baseEditor_46_js__}).BaseEditor; +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var CheckboxEditor = function CheckboxEditor() { + $traceurRuntime.superConstructor($CheckboxEditor).apply(this, arguments); +}; +var $CheckboxEditor = CheckboxEditor; +($traceurRuntime.createClass)(CheckboxEditor, { + beginEditing: function() { + var checkbox = this.TD.querySelector('input[type="checkbox"]'); + if (!dom.hasClass(checkbox, 'htBadValue')) { + checkbox.click(); + } + }, + finishEditing: function() {}, + init: function() {}, + open: function() {}, + close: function() {}, + getValue: function() {}, + setValue: function() {}, + focus: function() {} +}, {}, BaseEditor); +; +registerEditor('checkbox', CheckboxEditor); + +//# +},{"_baseEditor.js":30,"dom.js":27,"editors.js":29}],33:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + DateEditor: {get: function() { + return DateEditor; + }}, + __esModule: {value: true} +}); +var $___46__46__47_helpers_46_js__, + $___46__46__47_dom_46_js__, + $___46__46__47_editors_46_js__, + $__textEditor_46_js__, + $___46__46__47_eventManager_46_js__, + $__moment__, + $__pikaday__; +var $__0 = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}), + deepExtend = $__0.deepExtend, + stopPropagation = $__0.stopPropagation, + isMetaKey = $__0.isMetaKey; +var $__1 = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}), + addClass = $__1.addClass, + outerHeight = $__1.outerHeight; +var $__2 = ($___46__46__47_editors_46_js__ = require("editors.js"), $___46__46__47_editors_46_js__ && $___46__46__47_editors_46_js__.__esModule && $___46__46__47_editors_46_js__ || {default: $___46__46__47_editors_46_js__}), + getEditor = $__2.getEditor, + registerEditor = $__2.registerEditor; +var TextEditor = ($__textEditor_46_js__ = require("textEditor.js"), $__textEditor_46_js__ && $__textEditor_46_js__.__esModule && $__textEditor_46_js__ || {default: $__textEditor_46_js__}).TextEditor; +var EventManager = ($___46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47_eventManager_46_js__ && $___46__46__47_eventManager_46_js__.__esModule && $___46__46__47_eventManager_46_js__ || {default: $___46__46__47_eventManager_46_js__}).EventManager; +var moment = ($__moment__ = require("moment"), $__moment__ && $__moment__.__esModule && $__moment__ || {default: $__moment__}).default; +var Pikaday = ($__pikaday__ = require("pikaday"), $__pikaday__ && $__pikaday__.__esModule && $__pikaday__ || {default: $__pikaday__}).default; +Handsontable.editors = Handsontable.editors || {}; +Handsontable.editors.DateEditor = DateEditor; +var DateEditor = function DateEditor(hotInstance) { + this.$datePicker = null; + this.datePicker = null; + this.datePickerStyle = null; + this.defaultDateFormat = 'DD/MM/YYYY'; + this.isCellEdited = false; + this.parentDestroyed = false; + $traceurRuntime.superConstructor($DateEditor).call(this, hotInstance); +}; +var $DateEditor = DateEditor; +($traceurRuntime.createClass)(DateEditor, { + init: function() { + var $__7 = this; + if (typeof moment !== 'function') { + throw new Error("You need to include moment.js to your project."); + } + if (typeof Pikaday !== 'function') { + throw new Error("You need to include Pikaday to your project."); + } + $traceurRuntime.superGet(this, $DateEditor.prototype, "init").call(this); + this.instance.addHook('afterDestroy', (function() { + $__7.parentDestroyed = true; + $__7.destroyElements(); + })); + }, + createElements: function() { + $traceurRuntime.superGet(this, $DateEditor.prototype, "createElements").call(this); + this.datePicker = document.createElement('DIV'); + this.datePickerStyle = this.datePicker.style; + this.datePickerStyle.position = 'absolute'; + this.datePickerStyle.top = 0; + this.datePickerStyle.left = 0; + this.datePickerStyle.zIndex = 9999; + addClass(this.datePicker, 'htDatepickerHolder'); + document.body.appendChild(this.datePicker); + this.$datePicker = new Pikaday(this.getDatePickerConfig()); + var eventManager = new EventManager(this); + eventManager.addEventListener(this.datePicker, 'mousedown', (function(event) { + return stopPropagation(event); + })); + this.hideDatepicker(); + }, + destroyElements: function() { + this.$datePicker.destroy(); + }, + prepare: function(row, col, prop, td, originalValue, cellProperties) { + this._opened = false; + $traceurRuntime.superGet(this, $DateEditor.prototype, "prepare").call(this, row, col, prop, td, originalValue, cellProperties); + }, + open: function() { + var event = arguments[0] !== (void 0) ? arguments[0] : null; + $traceurRuntime.superGet(this, $DateEditor.prototype, "open").call(this); + this.showDatepicker(event); + }, + close: function() { + var $__7 = this; + this._opened = false; + this.instance._registerTimeout(setTimeout((function() { + $__7.instance.selection.refreshBorders(); + }), 0)); + $traceurRuntime.superGet(this, $DateEditor.prototype, "close").call(this); + }, + finishEditing: function() { + var isCancelled = arguments[0] !== (void 0) ? arguments[0] : false; + var ctrlDown = arguments[1] !== (void 0) ? arguments[1] : false; + if (isCancelled) { + var value = this.originalValue; + if (value !== void 0) { + this.setValue(value); + } + } + this.hideDatepicker(); + $traceurRuntime.superGet(this, $DateEditor.prototype, "finishEditing").call(this, isCancelled, ctrlDown); + }, + showDatepicker: function(event) { + this.$datePicker.config(this.getDatePickerConfig()); + var offset = this.TD.getBoundingClientRect(); + var dateFormat = this.cellProperties.dateFormat || this.defaultDateFormat; + var datePickerConfig = this.$datePicker.config(); + var dateStr; + var isMouseDown = this.instance.view.isMouseDown(); + var isMeta = event ? isMetaKey(event.keyCode) : false; + this.datePickerStyle.top = (window.pageYOffset + offset.top + outerHeight(this.TD)) + 'px'; + this.datePickerStyle.left = (window.pageXOffset + offset.left) + 'px'; + this.$datePicker._onInputFocus = function() {}; + datePickerConfig.format = dateFormat; + if (this.originalValue) { + dateStr = this.originalValue; + if (moment(dateStr, dateFormat, true).isValid()) { + this.$datePicker.setMoment(moment(dateStr, dateFormat), true); + } + if (!isMeta && !isMouseDown) { + this.setValue(''); + } + } else { + if (this.cellProperties.defaultDate) { + dateStr = this.cellProperties.defaultDate; + datePickerConfig.defaultDate = dateStr; + if (moment(dateStr, dateFormat, true).isValid()) { + this.$datePicker.setMoment(moment(dateStr, dateFormat), true); + } + if (!isMeta && !isMouseDown) { + this.setValue(''); + } + } else { + this.$datePicker.gotoToday(); + } + } + this.datePickerStyle.display = 'block'; + this.$datePicker.show(); + }, + hideDatepicker: function() { + this.datePickerStyle.display = 'none'; + this.$datePicker.hide(); + }, + getDatePickerConfig: function() { + var $__7 = this; + var htInput = this.TEXTAREA; + var options = {}; + if (this.cellProperties && this.cellProperties.datePickerConfig) { + deepExtend(options, this.cellProperties.datePickerConfig); + } + var origOnSelect = options.onSelect; + var origOnClose = options.onClose; + options.field = htInput; + options.trigger = htInput; + options.container = this.datePicker; + options.bound = false; + options.format = options.format || this.defaultDateFormat; + options.reposition = options.reposition || false; + options.onSelect = (function(dateStr) { + if (!isNaN(dateStr.getTime())) { + dateStr = moment(dateStr).format($__7.cellProperties.dateFormat || $__7.defaultDateFormat); + } + $__7.setValue(dateStr); + $__7.hideDatepicker(); + if (origOnSelect) { + origOnSelect(); + } + }); + options.onClose = (function() { + if (!$__7.parentDestroyed) { + $__7.finishEditing(false); + } + if (origOnClose) { + origOnClose(); + } + }); + return options; + } +}, {}, TextEditor); +; +registerEditor('date', DateEditor); + +//# +},{"dom.js":27,"editors.js":29,"eventManager.js":41,"helpers.js":42,"moment":"moment","pikaday":"pikaday","textEditor.js":40}],34:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + DropdownEditor: {get: function() { + return DropdownEditor; + }}, + __esModule: {value: true} +}); +var $___46__46__47_editors_46_js__, + $__autocompleteEditor_46_js__; +var $__0 = ($___46__46__47_editors_46_js__ = require("editors.js"), $___46__46__47_editors_46_js__ && $___46__46__47_editors_46_js__.__esModule && $___46__46__47_editors_46_js__ || {default: $___46__46__47_editors_46_js__}), + getEditor = $__0.getEditor, + registerEditor = $__0.registerEditor; +var AutocompleteEditor = ($__autocompleteEditor_46_js__ = require("autocompleteEditor.js"), $__autocompleteEditor_46_js__ && $__autocompleteEditor_46_js__.__esModule && $__autocompleteEditor_46_js__ || {default: $__autocompleteEditor_46_js__}).AutocompleteEditor; +var DropdownEditor = function DropdownEditor() { + $traceurRuntime.superConstructor($DropdownEditor).apply(this, arguments); +}; +var $DropdownEditor = DropdownEditor; +($traceurRuntime.createClass)(DropdownEditor, {prepare: function(row, col, prop, td, originalValue, cellProperties) { + $traceurRuntime.superGet(this, $DropdownEditor.prototype, "prepare").call(this, row, col, prop, td, originalValue, cellProperties); + this.cellProperties.filter = false; + this.cellProperties.strict = true; + }}, {}, AutocompleteEditor); +; +registerEditor('dropdown', DropdownEditor); + +//# +},{"autocompleteEditor.js":31,"editors.js":29}],35:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + HandsontableEditor: {get: function() { + return HandsontableEditor; + }}, + __esModule: {value: true} +}); +var $___46__46__47_helpers_46_js__, + $___46__46__47_dom_46_js__, + $___46__46__47_editors_46_js__, + $__textEditor_46_js__; +var helper = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}); +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var $__0 = ($___46__46__47_editors_46_js__ = require("editors.js"), $___46__46__47_editors_46_js__ && $___46__46__47_editors_46_js__.__esModule && $___46__46__47_editors_46_js__ || {default: $___46__46__47_editors_46_js__}), + getEditor = $__0.getEditor, + registerEditor = $__0.registerEditor; +var TextEditor = ($__textEditor_46_js__ = require("textEditor.js"), $__textEditor_46_js__ && $__textEditor_46_js__.__esModule && $__textEditor_46_js__ || {default: $__textEditor_46_js__}).TextEditor; +var HandsontableEditor = TextEditor.prototype.extend(); +HandsontableEditor.prototype.createElements = function() { + TextEditor.prototype.createElements.apply(this, arguments); + var DIV = document.createElement('DIV'); + DIV.className = 'handsontableEditor'; + this.TEXTAREA_PARENT.appendChild(DIV); + this.htContainer = DIV; + this.htEditor = new Handsontable(DIV, { + autoColumnSize: false, + autoRowSize: false + }); + this.assignHooks(); +}; +HandsontableEditor.prototype.prepare = function(td, row, col, prop, value, cellProperties) { + TextEditor.prototype.prepare.apply(this, arguments); + var parent = this; + var options = { + startRows: 0, + startCols: 0, + minRows: 0, + minCols: 0, + className: 'listbox', + copyPaste: false, + autoColumnSize: false, + autoRowSize: false, + cells: function() { + return {readOnly: true}; + }, + fillHandle: false, + afterOnCellMouseDown: function() { + var value = this.getValue(); + if (value !== void 0) { + parent.setValue(value); + } + parent.instance.destroyEditor(); + } + }; + if (this.cellProperties.handsontable) { + helper.extend(options, cellProperties.handsontable); + } + if (this.htEditor) { + this.htEditor.destroy(); + } + this.htEditor = new Handsontable(this.htContainer, options); +}; +var onBeforeKeyDown = function(event) { + if (event != null && event.isImmediatePropagationEnabled == null) { + event.stopImmediatePropagation = function() { + this.isImmediatePropagationEnabled = false; + this.cancelBubble = true; + }; + event.isImmediatePropagationEnabled = true; + event.isImmediatePropagationStopped = function() { + return !this.isImmediatePropagationEnabled; + }; + } + if (event.isImmediatePropagationStopped()) { + return; + } + var editor = this.getActiveEditor(); + var innerHOT = editor.htEditor.getInstance(); + var rowToSelect; + if (event.keyCode == helper.keyCode.ARROW_DOWN) { + if (!innerHOT.getSelected()) { + rowToSelect = 0; + } else { + var selectedRow = innerHOT.getSelected()[0]; + var lastRow = innerHOT.countRows() - 1; + rowToSelect = Math.min(lastRow, selectedRow + 1); + } + } else if (event.keyCode == helper.keyCode.ARROW_UP) { + if (innerHOT.getSelected()) { + var selectedRow = innerHOT.getSelected()[0]; + rowToSelect = selectedRow - 1; + } + } + if (rowToSelect !== void 0) { + if (rowToSelect < 0) { + innerHOT.deselectCell(); + } else { + innerHOT.selectCell(rowToSelect, 0); + } + if (innerHOT.getData().length) { + event.preventDefault(); + event.stopImmediatePropagation(); + editor.instance.listen(); + editor.TEXTAREA.focus(); + } + } +}; +HandsontableEditor.prototype.open = function() { + this.instance.addHook('beforeKeyDown', onBeforeKeyDown); + TextEditor.prototype.open.apply(this, arguments); + this.htEditor.render(); + if (this.cellProperties.strict) { + this.htEditor.selectCell(0, 0); + this.TEXTAREA.style.visibility = 'hidden'; + } else { + this.htEditor.deselectCell(); + this.TEXTAREA.style.visibility = 'visible'; + } + dom.setCaretPosition(this.TEXTAREA, 0, this.TEXTAREA.value.length); +}; +HandsontableEditor.prototype.close = function() { + this.instance.removeHook('beforeKeyDown', onBeforeKeyDown); + this.instance.listen(); + TextEditor.prototype.close.apply(this, arguments); +}; +HandsontableEditor.prototype.focus = function() { + this.instance.listen(); + TextEditor.prototype.focus.apply(this, arguments); +}; +HandsontableEditor.prototype.beginEditing = function(initialValue) { + var onBeginEditing = this.instance.getSettings().onBeginEditing; + if (onBeginEditing && onBeginEditing() === false) { + return; + } + TextEditor.prototype.beginEditing.apply(this, arguments); +}; +HandsontableEditor.prototype.finishEditing = function(isCancelled, ctrlDown) { + if (this.htEditor.isListening()) { + this.instance.listen(); + } + if (this.htEditor.getSelected()) { + var value = this.htEditor.getInstance().getValue(); + if (value !== void 0) { + this.setValue(value); + } + } + return TextEditor.prototype.finishEditing.apply(this, arguments); +}; +HandsontableEditor.prototype.assignHooks = function() { + var _this = this; + this.instance.addHook('afterDestroy', function() { + if (_this.htEditor) { + _this.htEditor.destroy(); + } + }); +}; +; +registerEditor('handsontable', HandsontableEditor); + +//# +},{"dom.js":27,"editors.js":29,"helpers.js":42,"textEditor.js":40}],36:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + MobileTextEditor: {get: function() { + return MobileTextEditor; + }}, + __esModule: {value: true} +}); +var $___46__46__47_helpers_46_js__, + $___46__46__47_dom_46_js__, + $___46__46__47_editors_46_js__, + $___95_baseEditor_46_js__, + $___46__46__47_eventManager_46_js__; +var helper = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}); +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var $__0 = ($___46__46__47_editors_46_js__ = require("editors.js"), $___46__46__47_editors_46_js__ && $___46__46__47_editors_46_js__.__esModule && $___46__46__47_editors_46_js__ || {default: $___46__46__47_editors_46_js__}), + getEditor = $__0.getEditor, + registerEditor = $__0.registerEditor; +var BaseEditor = ($___95_baseEditor_46_js__ = require("_baseEditor.js"), $___95_baseEditor_46_js__ && $___95_baseEditor_46_js__.__esModule && $___95_baseEditor_46_js__ || {default: $___95_baseEditor_46_js__}).BaseEditor; +var eventManagerObject = ($___46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47_eventManager_46_js__ && $___46__46__47_eventManager_46_js__.__esModule && $___46__46__47_eventManager_46_js__ || {default: $___46__46__47_eventManager_46_js__}).eventManager; +var MobileTextEditor = BaseEditor.prototype.extend(), + domDimensionsCache = {}; +var createControls = function() { + this.controls = {}; + this.controls.leftButton = document.createElement('DIV'); + this.controls.leftButton.className = 'leftButton'; + this.controls.rightButton = document.createElement('DIV'); + this.controls.rightButton.className = 'rightButton'; + this.controls.upButton = document.createElement('DIV'); + this.controls.upButton.className = 'upButton'; + this.controls.downButton = document.createElement('DIV'); + this.controls.downButton.className = 'downButton'; + for (var button in this.controls) { + if (this.controls.hasOwnProperty(button)) { + this.positionControls.appendChild(this.controls[button]); + } + } +}; +MobileTextEditor.prototype.valueChanged = function() { + return this.initValue != this.getValue(); +}; +MobileTextEditor.prototype.init = function() { + var that = this; + this.eventManager = eventManagerObject(this.instance); + this.createElements(); + this.bindEvents(); + this.instance.addHook('afterDestroy', function() { + that.destroy(); + }); +}; +MobileTextEditor.prototype.getValue = function() { + return this.TEXTAREA.value; +}; +MobileTextEditor.prototype.setValue = function(newValue) { + this.initValue = newValue; + this.TEXTAREA.value = newValue; +}; +MobileTextEditor.prototype.createElements = function() { + this.editorContainer = document.createElement('DIV'); + this.editorContainer.className = "htMobileEditorContainer"; + this.cellPointer = document.createElement('DIV'); + this.cellPointer.className = "cellPointer"; + this.moveHandle = document.createElement('DIV'); + this.moveHandle.className = "moveHandle"; + this.inputPane = document.createElement('DIV'); + this.inputPane.className = "inputs"; + this.positionControls = document.createElement('DIV'); + this.positionControls.className = "positionControls"; + this.TEXTAREA = document.createElement('TEXTAREA'); + dom.addClass(this.TEXTAREA, 'handsontableInput'); + this.inputPane.appendChild(this.TEXTAREA); + this.editorContainer.appendChild(this.cellPointer); + this.editorContainer.appendChild(this.moveHandle); + this.editorContainer.appendChild(this.inputPane); + this.editorContainer.appendChild(this.positionControls); + createControls.call(this); + document.body.appendChild(this.editorContainer); +}; +MobileTextEditor.prototype.onBeforeKeyDown = function(event) { + var instance = this; + var that = instance.getActiveEditor(); + dom.enableImmediatePropagation(event); + if (event.target !== that.TEXTAREA || event.isImmediatePropagationStopped()) { + return; + } + var keyCodes = helper.keyCode; + switch (event.keyCode) { + case keyCodes.ENTER: + that.close(); + event.preventDefault(); + break; + case keyCodes.BACKSPACE: + event.stopImmediatePropagation(); + break; + } +}; +MobileTextEditor.prototype.open = function() { + this.instance.addHook('beforeKeyDown', this.onBeforeKeyDown); + dom.addClass(this.editorContainer, 'active'); + dom.removeClass(this.cellPointer, 'hidden'); + this.updateEditorPosition(); +}; +MobileTextEditor.prototype.focus = function() { + this.TEXTAREA.focus(); + dom.setCaretPosition(this.TEXTAREA, this.TEXTAREA.value.length); +}; +MobileTextEditor.prototype.close = function() { + this.TEXTAREA.blur(); + this.instance.removeHook('beforeKeyDown', this.onBeforeKeyDown); + dom.removeClass(this.editorContainer, 'active'); +}; +MobileTextEditor.prototype.scrollToView = function() { + var coords = this.instance.getSelectedRange().highlight; + this.instance.view.scrollViewport(coords); +}; +MobileTextEditor.prototype.hideCellPointer = function() { + if (!dom.hasClass(this.cellPointer, 'hidden')) { + dom.addClass(this.cellPointer, 'hidden'); + } +}; +MobileTextEditor.prototype.updateEditorPosition = function(x, y) { + if (x && y) { + x = parseInt(x, 10); + y = parseInt(y, 10); + this.editorContainer.style.top = y + "px"; + this.editorContainer.style.left = x + "px"; + } else { + var selection = this.instance.getSelected(), + selectedCell = this.instance.getCell(selection[0], selection[1]); + if (!domDimensionsCache.cellPointer) { + domDimensionsCache.cellPointer = { + height: dom.outerHeight(this.cellPointer), + width: dom.outerWidth(this.cellPointer) + }; + } + if (!domDimensionsCache.editorContainer) { + domDimensionsCache.editorContainer = {width: dom.outerWidth(this.editorContainer)}; + } + if (selectedCell !== undefined) { + var scrollLeft = this.instance.view.wt.wtOverlays.leftOverlay.trimmingContainer == window ? 0 : dom.getScrollLeft(this.instance.view.wt.wtOverlays.leftOverlay.holder); + var scrollTop = this.instance.view.wt.wtOverlays.topOverlay.trimmingContainer == window ? 0 : dom.getScrollTop(this.instance.view.wt.wtOverlays.topOverlay.holder); + var selectedCellOffset = dom.offset(selectedCell), + selectedCellWidth = dom.outerWidth(selectedCell), + currentScrollPosition = { + x: scrollLeft, + y: scrollTop + }; + this.editorContainer.style.top = parseInt(selectedCellOffset.top + dom.outerHeight(selectedCell) - currentScrollPosition.y + domDimensionsCache.cellPointer.height, 10) + "px"; + this.editorContainer.style.left = parseInt((window.innerWidth / 2) - (domDimensionsCache.editorContainer.width / 2), 10) + "px"; + if (selectedCellOffset.left + selectedCellWidth / 2 > parseInt(this.editorContainer.style.left, 10) + domDimensionsCache.editorContainer.width) { + this.editorContainer.style.left = window.innerWidth - domDimensionsCache.editorContainer.width + "px"; + } else if (selectedCellOffset.left + selectedCellWidth / 2 < parseInt(this.editorContainer.style.left, 10) + 20) { + this.editorContainer.style.left = 0 + "px"; + } + this.cellPointer.style.left = parseInt(selectedCellOffset.left - (domDimensionsCache.cellPointer.width / 2) - dom.offset(this.editorContainer).left + (selectedCellWidth / 2) - currentScrollPosition.x, 10) + "px"; + } + } +}; +MobileTextEditor.prototype.updateEditorData = function() { + var selected = this.instance.getSelected(), + selectedValue = this.instance.getDataAtCell(selected[0], selected[1]); + this.row = selected[0]; + this.col = selected[1]; + this.setValue(selectedValue); + this.updateEditorPosition(); +}; +MobileTextEditor.prototype.prepareAndSave = function() { + var val; + if (!this.valueChanged()) { + return true; + } + if (this.instance.getSettings().trimWhitespace) { + val = [[String.prototype.trim.call(this.getValue())]]; + } else { + val = [[this.getValue()]]; + } + this.saveValue(val); +}; +MobileTextEditor.prototype.bindEvents = function() { + var that = this; + this.eventManager.addEventListener(this.controls.leftButton, "touchend", function(event) { + that.prepareAndSave(); + that.instance.selection.transformStart(0, -1, null, true); + that.updateEditorData(); + event.preventDefault(); + }); + this.eventManager.addEventListener(this.controls.rightButton, "touchend", function(event) { + that.prepareAndSave(); + that.instance.selection.transformStart(0, 1, null, true); + that.updateEditorData(); + event.preventDefault(); + }); + this.eventManager.addEventListener(this.controls.upButton, "touchend", function(event) { + that.prepareAndSave(); + that.instance.selection.transformStart(-1, 0, null, true); + that.updateEditorData(); + event.preventDefault(); + }); + this.eventManager.addEventListener(this.controls.downButton, "touchend", function(event) { + that.prepareAndSave(); + that.instance.selection.transformStart(1, 0, null, true); + that.updateEditorData(); + event.preventDefault(); + }); + this.eventManager.addEventListener(this.moveHandle, "touchstart", function(event) { + if (event.touches.length == 1) { + var touch = event.touches[0], + onTouchPosition = { + x: that.editorContainer.offsetLeft, + y: that.editorContainer.offsetTop + }, + onTouchOffset = { + x: touch.pageX - onTouchPosition.x, + y: touch.pageY - onTouchPosition.y + }; + that.eventManager.addEventListener(this, "touchmove", function(event) { + var touch = event.touches[0]; + that.updateEditorPosition(touch.pageX - onTouchOffset.x, touch.pageY - onTouchOffset.y); + that.hideCellPointer(); + event.preventDefault(); + }); + } + }); + this.eventManager.addEventListener(document.body, "touchend", function(event) { + if (!dom.isChildOf(event.target, that.editorContainer) && !dom.isChildOf(event.target, that.instance.rootElement)) { + that.close(); + } + }); + this.eventManager.addEventListener(this.instance.view.wt.wtOverlays.leftOverlay.holder, "scroll", function(event) { + if (that.instance.view.wt.wtOverlays.leftOverlay.trimmingContainer != window) { + that.hideCellPointer(); + } + }); + this.eventManager.addEventListener(this.instance.view.wt.wtOverlays.topOverlay.holder, "scroll", function(event) { + if (that.instance.view.wt.wtOverlays.topOverlay.trimmingContainer != window) { + that.hideCellPointer(); + } + }); +}; +MobileTextEditor.prototype.destroy = function() { + this.eventManager.clear(); + this.editorContainer.parentNode.removeChild(this.editorContainer); +}; +; +registerEditor('mobile', MobileTextEditor); + +//# +},{"_baseEditor.js":30,"dom.js":27,"editors.js":29,"eventManager.js":41,"helpers.js":42}],37:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + NumericEditor: {get: function() { + return NumericEditor; + }}, + __esModule: {value: true} +}); +var $__numeral__, + $___46__46__47_editors_46_js__, + $__textEditor_46_js__; +var numeral = ($__numeral__ = require("numeral"), $__numeral__ && $__numeral__.__esModule && $__numeral__ || {default: $__numeral__}).default; +var $__1 = ($___46__46__47_editors_46_js__ = require("editors.js"), $___46__46__47_editors_46_js__ && $___46__46__47_editors_46_js__.__esModule && $___46__46__47_editors_46_js__ || {default: $___46__46__47_editors_46_js__}), + getEditor = $__1.getEditor, + registerEditor = $__1.registerEditor; +var TextEditor = ($__textEditor_46_js__ = require("textEditor.js"), $__textEditor_46_js__ && $__textEditor_46_js__.__esModule && $__textEditor_46_js__ || {default: $__textEditor_46_js__}).TextEditor; +var NumericEditor = function NumericEditor() { + $traceurRuntime.superConstructor($NumericEditor).apply(this, arguments); +}; +var $NumericEditor = NumericEditor; +($traceurRuntime.createClass)(NumericEditor, {beginEditing: function(initialValue) { + if (typeof(initialValue) === 'undefined' && this.originalValue) { + if (typeof this.cellProperties.language !== 'undefined') { + numeral.language(this.cellProperties.language); + } + var decimalDelimiter = numeral.languageData().delimiters.decimal; + initialValue = ('' + this.originalValue).replace('.', decimalDelimiter); + } + $traceurRuntime.superGet(this, $NumericEditor.prototype, "beginEditing").call(this, initialValue); + }}, {}, TextEditor); +; +registerEditor('numeric', NumericEditor); + +//# +},{"editors.js":29,"numeral":"numeral","textEditor.js":40}],38:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + PasswordEditor: {get: function() { + return PasswordEditor; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_editors_46_js__, + $__textEditor_46_js__; +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var $__0 = ($___46__46__47_editors_46_js__ = require("editors.js"), $___46__46__47_editors_46_js__ && $___46__46__47_editors_46_js__.__esModule && $___46__46__47_editors_46_js__ || {default: $___46__46__47_editors_46_js__}), + getEditor = $__0.getEditor, + registerEditor = $__0.registerEditor; +var TextEditor = ($__textEditor_46_js__ = require("textEditor.js"), $__textEditor_46_js__ && $__textEditor_46_js__.__esModule && $__textEditor_46_js__ || {default: $__textEditor_46_js__}).TextEditor; +var PasswordEditor = function PasswordEditor() { + $traceurRuntime.superConstructor($PasswordEditor).apply(this, arguments); +}; +var $PasswordEditor = PasswordEditor; +($traceurRuntime.createClass)(PasswordEditor, {createElements: function() { + $traceurRuntime.superGet(this, $PasswordEditor.prototype, "createElements").call(this); + this.TEXTAREA = document.createElement('input'); + this.TEXTAREA.setAttribute('type', 'password'); + this.TEXTAREA.className = 'handsontableInput'; + this.textareaStyle = this.TEXTAREA.style; + this.textareaStyle.width = 0; + this.textareaStyle.height = 0; + dom.empty(this.TEXTAREA_PARENT); + this.TEXTAREA_PARENT.appendChild(this.TEXTAREA); + }}, {}, TextEditor); +; +registerEditor('password', PasswordEditor); + +//# +},{"dom.js":27,"editors.js":29,"textEditor.js":40}],39:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + SelectEditor: {get: function() { + return SelectEditor; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_helpers_46_js__, + $___46__46__47_editors_46_js__, + $___95_baseEditor_46_js__; +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var helper = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}); +var $__0 = ($___46__46__47_editors_46_js__ = require("editors.js"), $___46__46__47_editors_46_js__ && $___46__46__47_editors_46_js__.__esModule && $___46__46__47_editors_46_js__ || {default: $___46__46__47_editors_46_js__}), + getEditor = $__0.getEditor, + registerEditor = $__0.registerEditor; +var BaseEditor = ($___95_baseEditor_46_js__ = require("_baseEditor.js"), $___95_baseEditor_46_js__ && $___95_baseEditor_46_js__.__esModule && $___95_baseEditor_46_js__ || {default: $___95_baseEditor_46_js__}).BaseEditor; +var SelectEditor = BaseEditor.prototype.extend(); +SelectEditor.prototype.init = function() { + this.select = document.createElement('SELECT'); + dom.addClass(this.select, 'htSelectEditor'); + this.select.style.display = 'none'; + this.instance.rootElement.appendChild(this.select); + this.registerHooks(); +}; +SelectEditor.prototype.registerHooks = function() { + var $__2 = this; + this.instance.addHook('afterScrollVertically', (function() { + return $__2.refreshDimensions(); + })); + this.instance.addHook('afterColumnResize', (function() { + return $__2.refreshDimensions(); + })); + this.instance.addHook('afterRowResize', (function() { + return $__2.refreshDimensions(); + })); +}; +SelectEditor.prototype.prepare = function() { + BaseEditor.prototype.prepare.apply(this, arguments); + var selectOptions = this.cellProperties.selectOptions; + var options; + if (typeof selectOptions == 'function') { + options = this.prepareOptions(selectOptions(this.row, this.col, this.prop)); + } else { + options = this.prepareOptions(selectOptions); + } + dom.empty(this.select); + for (var option in options) { + if (options.hasOwnProperty(option)) { + var optionElement = document.createElement('OPTION'); + optionElement.value = option; + dom.fastInnerHTML(optionElement, options[option]); + this.select.appendChild(optionElement); + } + } +}; +SelectEditor.prototype.prepareOptions = function(optionsToPrepare) { + var preparedOptions = {}; + if (Array.isArray(optionsToPrepare)) { + for (var i = 0, + len = optionsToPrepare.length; i < len; i++) { + preparedOptions[optionsToPrepare[i]] = optionsToPrepare[i]; + } + } else if (typeof optionsToPrepare == 'object') { + preparedOptions = optionsToPrepare; + } + return preparedOptions; +}; +SelectEditor.prototype.getValue = function() { + return this.select.value; +}; +SelectEditor.prototype.setValue = function(value) { + this.select.value = value; +}; +var onBeforeKeyDown = function(event) { + var instance = this; + var editor = instance.getActiveEditor(); + if (event != null && event.isImmediatePropagationEnabled == null) { + event.stopImmediatePropagation = function() { + this.isImmediatePropagationEnabled = false; + }; + event.isImmediatePropagationEnabled = true; + event.isImmediatePropagationStopped = function() { + return !this.isImmediatePropagationEnabled; + }; + } + switch (event.keyCode) { + case helper.keyCode.ARROW_UP: + var previousOptionIndex = editor.select.selectedIndex - 1; + if (previousOptionIndex >= 0) { + editor.select[previousOptionIndex].selected = true; + } + event.stopImmediatePropagation(); + event.preventDefault(); + break; + case helper.keyCode.ARROW_DOWN: + var nextOptionIndex = editor.select.selectedIndex + 1; + if (nextOptionIndex <= editor.select.length - 1) { + editor.select[nextOptionIndex].selected = true; + } + event.stopImmediatePropagation(); + event.preventDefault(); + break; + } +}; +SelectEditor.prototype.checkEditorSection = function() { + if (this.row < this.instance.getSettings().fixedRowsTop) { + if (this.col < this.instance.getSettings().fixedColumnsLeft) { + return 'corner'; + } else { + return 'top'; + } + } else { + if (this.col < this.instance.getSettings().fixedColumnsLeft) { + return 'left'; + } + } +}; +SelectEditor.prototype.open = function() { + this._opened = true; + this.refreshDimensions(); + this.select.style.display = ''; + this.instance.addHook('beforeKeyDown', onBeforeKeyDown); +}; +SelectEditor.prototype.close = function() { + this._opened = false; + this.select.style.display = 'none'; + this.instance.removeHook('beforeKeyDown', onBeforeKeyDown); +}; +SelectEditor.prototype.focus = function() { + this.select.focus(); +}; +SelectEditor.prototype.refreshDimensions = function() { + if (this.state !== Handsontable.EditorState.EDITING) { + return; + } + this.TD = this.getEditedCell(); + if (!this.TD) { + this.close(); + return; + } + var width = dom.outerWidth(this.TD) + 1, + height = dom.outerHeight(this.TD) + 1, + currentOffset = dom.offset(this.TD), + containerOffset = dom.offset(this.instance.rootElement), + scrollableContainer = dom.getScrollableElement(this.TD), + editTop = currentOffset.top - containerOffset.top - 1 - (scrollableContainer.scrollTop || 0), + editLeft = currentOffset.left - containerOffset.left - 1 - (scrollableContainer.scrollLeft || 0), + editorSection = this.checkEditorSection(), + cssTransformOffset; + var settings = this.instance.getSettings(); + var rowHeadersCount = settings.rowHeaders ? 1 : 0; + var colHeadersCount = settings.colHeaders ? 1 : 0; + switch (editorSection) { + case 'top': + cssTransformOffset = dom.getCssTransform(this.instance.view.wt.wtOverlays.topOverlay.clone.wtTable.holder.parentNode); + break; + case 'left': + cssTransformOffset = dom.getCssTransform(this.instance.view.wt.wtOverlays.leftOverlay.clone.wtTable.holder.parentNode); + break; + case 'corner': + cssTransformOffset = dom.getCssTransform(this.instance.view.wt.wtOverlays.topLeftCornerOverlay.clone.wtTable.holder.parentNode); + break; + } + if (this.instance.getSelected()[0] === 0) { + editTop += 1; + } + if (this.instance.getSelected()[1] === 0) { + editLeft += 1; + } + var selectStyle = this.select.style; + if (cssTransformOffset && cssTransformOffset != -1) { + selectStyle[cssTransformOffset[0]] = cssTransformOffset[1]; + } else { + dom.resetCssTransform(this.select); + } + var cellComputedStyle = dom.getComputedStyle(this.TD); + if (parseInt(cellComputedStyle.borderTopWidth, 10) > 0) { + height -= 1; + } + if (parseInt(cellComputedStyle.borderLeftWidth, 10) > 0) { + width -= 1; + } + selectStyle.height = height + 'px'; + selectStyle.minWidth = width + 'px'; + selectStyle.top = editTop + 'px'; + selectStyle.left = editLeft + 'px'; + selectStyle.margin = '0px'; +}; +SelectEditor.prototype.getEditedCell = function() { + var editorSection = this.checkEditorSection(), + editedCell; + switch (editorSection) { + case 'top': + editedCell = this.instance.view.wt.wtOverlays.topOverlay.clone.wtTable.getCell({ + row: this.row, + col: this.col + }); + this.select.style.zIndex = 101; + break; + case 'corner': + editedCell = this.instance.view.wt.wtOverlays.topLeftCornerOverlay.clone.wtTable.getCell({ + row: this.row, + col: this.col + }); + this.select.style.zIndex = 103; + break; + case 'left': + editedCell = this.instance.view.wt.wtOverlays.leftOverlay.clone.wtTable.getCell({ + row: this.row, + col: this.col + }); + this.select.style.zIndex = 102; + break; + default: + editedCell = this.instance.getCell(this.row, this.col); + this.select.style.zIndex = ''; + break; + } + return editedCell != -1 && editedCell != -2 ? editedCell : void 0; +}; +; +registerEditor('select', SelectEditor); + +//# +},{"_baseEditor.js":30,"dom.js":27,"editors.js":29,"helpers.js":42}],40:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + TextEditor: {get: function() { + return TextEditor; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_helpers_46_js__, + $__autoResize__, + $___95_baseEditor_46_js__, + $___46__46__47_eventManager_46_js__, + $___46__46__47_editors_46_js__; +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var helper = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}); +var autoResize = ($__autoResize__ = require("autoResize"), $__autoResize__ && $__autoResize__.__esModule && $__autoResize__ || {default: $__autoResize__}).default; +var BaseEditor = ($___95_baseEditor_46_js__ = require("_baseEditor.js"), $___95_baseEditor_46_js__ && $___95_baseEditor_46_js__.__esModule && $___95_baseEditor_46_js__ || {default: $___95_baseEditor_46_js__}).BaseEditor; +var eventManagerObject = ($___46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47_eventManager_46_js__ && $___46__46__47_eventManager_46_js__.__esModule && $___46__46__47_eventManager_46_js__ || {default: $___46__46__47_eventManager_46_js__}).eventManager; +var $__3 = ($___46__46__47_editors_46_js__ = require("editors.js"), $___46__46__47_editors_46_js__ && $___46__46__47_editors_46_js__.__esModule && $___46__46__47_editors_46_js__ || {default: $___46__46__47_editors_46_js__}), + getEditor = $__3.getEditor, + registerEditor = $__3.registerEditor; +var TextEditor = BaseEditor.prototype.extend(); +TextEditor.prototype.init = function() { + var that = this; + this.createElements(); + this.eventManager = eventManagerObject(this); + this.bindEvents(); + this.autoResize = autoResize(); + this.instance.addHook('afterDestroy', function() { + that.destroy(); + }); +}; +TextEditor.prototype.getValue = function() { + return this.TEXTAREA.value; +}; +TextEditor.prototype.setValue = function(newValue) { + this.TEXTAREA.value = newValue; +}; +var onBeforeKeyDown = function onBeforeKeyDown(event) { + var instance = this, + that = instance.getActiveEditor(), + keyCodes, + ctrlDown; + keyCodes = helper.keyCode; + ctrlDown = (event.ctrlKey || event.metaKey) && !event.altKey; + dom.enableImmediatePropagation(event); + if (event.target !== that.TEXTAREA || event.isImmediatePropagationStopped()) { + return; + } + if (event.keyCode === 17 || event.keyCode === 224 || event.keyCode === 91 || event.keyCode === 93) { + event.stopImmediatePropagation(); + return; + } + switch (event.keyCode) { + case keyCodes.ARROW_RIGHT: + if (that.isInFullEditMode()) { + if ((!that.isWaiting() && !that.allowKeyEventPropagation) || (!that.isWaiting() && that.allowKeyEventPropagation && !that.allowKeyEventPropagation(event.keyCode))) { + event.stopImmediatePropagation(); + } + } + break; + case keyCodes.ARROW_LEFT: + if (that.isInFullEditMode()) { + if ((!that.isWaiting() && !that.allowKeyEventPropagation) || (!that.isWaiting() && that.allowKeyEventPropagation && !that.allowKeyEventPropagation(event.keyCode))) { + event.stopImmediatePropagation(); + } + } + break; + case keyCodes.ARROW_UP: + case keyCodes.ARROW_DOWN: + if (that.isInFullEditMode()) { + if ((!that.isWaiting() && !that.allowKeyEventPropagation) || (!that.isWaiting() && that.allowKeyEventPropagation && !that.allowKeyEventPropagation(event.keyCode))) { + event.stopImmediatePropagation(); + } + } + break; + case keyCodes.ENTER: + var selected = that.instance.getSelected(); + var isMultipleSelection = !(selected[0] === selected[2] && selected[1] === selected[3]); + if ((ctrlDown && !isMultipleSelection) || event.altKey) { + if (that.isOpened()) { + var caretPosition = dom.getCaretPosition(that.TEXTAREA), + value = that.getValue(); + var newValue = value.slice(0, caretPosition) + '\n' + value.slice(caretPosition); + that.setValue(newValue); + dom.setCaretPosition(that.TEXTAREA, caretPosition + 1); + } else { + that.beginEditing(that.originalValue + '\n'); + } + event.stopImmediatePropagation(); + } + event.preventDefault(); + break; + case keyCodes.A: + case keyCodes.X: + case keyCodes.C: + case keyCodes.V: + if (ctrlDown) { + event.stopImmediatePropagation(); + } + break; + case keyCodes.BACKSPACE: + case keyCodes.DELETE: + case keyCodes.HOME: + case keyCodes.END: + event.stopImmediatePropagation(); + break; + } + if ([keyCodes.ARROW_UP, keyCodes.ARROW_RIGHT, keyCodes.ARROW_DOWN, keyCodes.ARROW_LEFT].indexOf(event.keyCode) === -1) { + that.autoResize.resize(String.fromCharCode(event.keyCode)); + } +}; +TextEditor.prototype.open = function() { + this.refreshDimensions(); + this.instance.addHook('beforeKeyDown', onBeforeKeyDown); +}; +TextEditor.prototype.close = function() { + this.textareaParentStyle.display = 'none'; + this.autoResize.unObserve(); + if (document.activeElement === this.TEXTAREA) { + this.instance.listen(); + } + this.instance.removeHook('beforeKeyDown', onBeforeKeyDown); +}; +TextEditor.prototype.focus = function() { + this.TEXTAREA.focus(); + dom.setCaretPosition(this.TEXTAREA, this.TEXTAREA.value.length); +}; +TextEditor.prototype.createElements = function() { + this.TEXTAREA = document.createElement('TEXTAREA'); + dom.addClass(this.TEXTAREA, 'handsontableInput'); + this.textareaStyle = this.TEXTAREA.style; + this.textareaStyle.width = 0; + this.textareaStyle.height = 0; + this.TEXTAREA_PARENT = document.createElement('DIV'); + dom.addClass(this.TEXTAREA_PARENT, 'handsontableInputHolder'); + this.textareaParentStyle = this.TEXTAREA_PARENT.style; + this.textareaParentStyle.top = 0; + this.textareaParentStyle.left = 0; + this.textareaParentStyle.display = 'none'; + this.TEXTAREA_PARENT.appendChild(this.TEXTAREA); + this.instance.rootElement.appendChild(this.TEXTAREA_PARENT); + var that = this; + this.instance._registerTimeout(setTimeout(function() { + that.refreshDimensions(); + }, 0)); +}; +TextEditor.prototype.checkEditorSection = function() { + if (this.row < this.instance.getSettings().fixedRowsTop) { + if (this.col < this.instance.getSettings().fixedColumnsLeft) { + return 'corner'; + } else { + return 'top'; + } + } else { + if (this.col < this.instance.getSettings().fixedColumnsLeft) { + return 'left'; + } + } +}; +TextEditor.prototype.getEditedCell = function() { + var editorSection = this.checkEditorSection(), + editedCell; + switch (editorSection) { + case 'top': + editedCell = this.instance.view.wt.wtOverlays.topOverlay.clone.wtTable.getCell({ + row: this.row, + col: this.col + }); + this.textareaParentStyle.zIndex = 101; + break; + case 'corner': + editedCell = this.instance.view.wt.wtOverlays.topLeftCornerOverlay.clone.wtTable.getCell({ + row: this.row, + col: this.col + }); + this.textareaParentStyle.zIndex = 103; + break; + case 'left': + editedCell = this.instance.view.wt.wtOverlays.leftOverlay.clone.wtTable.getCell({ + row: this.row, + col: this.col + }); + this.textareaParentStyle.zIndex = 102; + break; + default: + editedCell = this.instance.getCell(this.row, this.col); + this.textareaParentStyle.zIndex = ""; + break; + } + return editedCell != -1 && editedCell != -2 ? editedCell : void 0; +}; +TextEditor.prototype.refreshDimensions = function() { + if (this.state !== Handsontable.EditorState.EDITING) { + return; + } + this.TD = this.getEditedCell(); + if (!this.TD) { + this.close(); + return; + } + var currentOffset = dom.offset(this.TD), + containerOffset = dom.offset(this.instance.rootElement), + scrollableContainer = dom.getScrollableElement(this.TD), + editTop = currentOffset.top - containerOffset.top - 1 - (scrollableContainer.scrollTop || 0), + editLeft = currentOffset.left - containerOffset.left - 1 - (scrollableContainer.scrollLeft || 0), + settings = this.instance.getSettings(), + rowHeadersCount = settings.rowHeaders ? 1 : 0, + colHeadersCount = settings.colHeaders ? 1 : 0, + editorSection = this.checkEditorSection(), + backgroundColor = this.TD.style.backgroundColor, + cssTransformOffset; + switch (editorSection) { + case 'top': + cssTransformOffset = dom.getCssTransform(this.instance.view.wt.wtOverlays.topOverlay.clone.wtTable.holder.parentNode); + break; + case 'left': + cssTransformOffset = dom.getCssTransform(this.instance.view.wt.wtOverlays.leftOverlay.clone.wtTable.holder.parentNode); + break; + case 'corner': + cssTransformOffset = dom.getCssTransform(this.instance.view.wt.wtOverlays.topLeftCornerOverlay.clone.wtTable.holder.parentNode); + break; + } + if (this.instance.getSelected()[0] === 0) { + editTop += 1; + } + if (this.instance.getSelected()[1] === 0) { + editLeft += 1; + } + if (cssTransformOffset && cssTransformOffset != -1) { + this.textareaParentStyle[cssTransformOffset[0]] = cssTransformOffset[1]; + } else { + dom.resetCssTransform(this.textareaParentStyle); + } + this.textareaParentStyle.top = editTop + 'px'; + this.textareaParentStyle.left = editLeft + 'px'; + var cellTopOffset = this.TD.offsetTop - this.instance.view.wt.wtOverlays.topOverlay.getScrollPosition(), + cellLeftOffset = this.TD.offsetLeft - this.instance.view.wt.wtOverlays.leftOverlay.getScrollPosition(); + var width = dom.innerWidth(this.TD) - 8; + var maxWidth = this.instance.view.maximumVisibleElementWidth(cellLeftOffset) - 9; + var height = this.TD.scrollHeight + 1; + var maxHeight = Math.max(this.instance.view.maximumVisibleElementHeight(cellTopOffset) - 2, 23); + var cellComputedStyle = dom.getComputedStyle(this.TD); + this.TEXTAREA.style.fontSize = cellComputedStyle.fontSize; + this.TEXTAREA.style.fontFamily = cellComputedStyle.fontFamily; + this.TEXTAREA.style.backgroundColor = ''; + this.TEXTAREA.style.backgroundColor = backgroundColor ? backgroundColor : dom.getComputedStyle(this.TEXTAREA).backgroundColor; + this.autoResize.init(this.TEXTAREA, { + minHeight: Math.min(height, maxHeight), + maxHeight: maxHeight, + minWidth: Math.min(width, maxWidth), + maxWidth: maxWidth + }, true); + this.textareaParentStyle.display = 'block'; +}; +TextEditor.prototype.bindEvents = function() { + var editor = this; + this.eventManager.addEventListener(this.TEXTAREA, 'cut', function(event) { + helper.stopPropagation(event); + }); + this.eventManager.addEventListener(this.TEXTAREA, 'paste', function(event) { + helper.stopPropagation(event); + }); + this.instance.addHook('afterScrollVertically', function() { + editor.refreshDimensions(); + }); + this.instance.addHook('afterColumnResize', function() { + editor.refreshDimensions(); + editor.focus(); + }); + this.instance.addHook('afterRowResize', function() { + editor.refreshDimensions(); + editor.focus(); + }); + this.instance.addHook('afterDestroy', function() { + editor.eventManager.destroy(); + }); +}; +TextEditor.prototype.destroy = function() { + this.eventManager.destroy(); +}; +; +registerEditor('text', TextEditor); + +//# +},{"_baseEditor.js":30,"autoResize":"autoResize","dom.js":27,"editors.js":29,"eventManager.js":41,"helpers.js":42}],41:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + EventManager: {get: function() { + return EventManager; + }}, + eventManager: {get: function() { + return eventManager; + }}, + __esModule: {value: true} +}); +var $__dom_46_js__; +var dom = ($__dom_46_js__ = require("dom.js"), $__dom_46_js__ && $__dom_46_js__.__esModule && $__dom_46_js__ || {default: $__dom_46_js__}); +var EventManager = function EventManager() { + var context = arguments[0] !== (void 0) ? arguments[0] : null; + this.context = context || this; + if (!this.context.eventListeners) { + this.context.eventListeners = []; + } +}; +($traceurRuntime.createClass)(EventManager, { + addEventListener: function(element, eventName, callback) { + var $__0 = this; + var context = this.context; + function callbackProxy(event) { + if (event.target == void 0 && event.srcElement != void 0) { + if (event.definePoperty) { + event.definePoperty('target', {value: event.srcElement}); + } else { + event.target = event.srcElement; + } + } + if (event.preventDefault == void 0) { + if (event.definePoperty) { + event.definePoperty('preventDefault', {value: function() { + this.returnValue = false; + }}); + } else { + event.preventDefault = function() { + this.returnValue = false; + }; + } + } + event = extendEvent(context, event); + callback.call(this, event); + } + this.context.eventListeners.push({ + element: element, + event: eventName, + callback: callback, + callbackProxy: callbackProxy + }); + if (window.addEventListener) { + element.addEventListener(eventName, callbackProxy, false); + } else { + element.attachEvent('on' + eventName, callbackProxy); + } + Handsontable.countEventManagerListeners++; + return (function() { + $__0.removeEventListener(element, eventName, callback); + }); + }, + removeEventListener: function(element, eventName, callback) { + var len = this.context.eventListeners.length; + var tmpEvent; + while (len--) { + tmpEvent = this.context.eventListeners[len]; + if (tmpEvent.event == eventName && tmpEvent.element == element) { + if (callback && callback != tmpEvent.callback) { + continue; + } + this.context.eventListeners.splice(len, 1); + if (tmpEvent.element.removeEventListener) { + tmpEvent.element.removeEventListener(tmpEvent.event, tmpEvent.callbackProxy, false); + } else { + tmpEvent.element.detachEvent('on' + tmpEvent.event, tmpEvent.callbackProxy); + } + Handsontable.countEventManagerListeners--; + } + } + }, + clearEvents: function() { + if (!this.context) { + return; + } + var len = this.context.eventListeners.length; + while (len--) { + var event = this.context.eventListeners[len]; + if (event) { + this.removeEventListener(event.element, event.event, event.callback); + } + } + }, + clear: function() { + this.clearEvents(); + }, + destroy: function() { + this.clearEvents(); + this.context = null; + }, + fireEvent: function(element, eventName) { + var options = { + bubbles: true, + cancelable: (eventName !== 'mousemove'), + view: window, + detail: 0, + screenX: 0, + screenY: 0, + clientX: 1, + clientY: 1, + ctrlKey: false, + altKey: false, + shiftKey: false, + metaKey: false, + button: 0, + relatedTarget: undefined + }; + var event; + if (document.createEvent) { + event = document.createEvent('MouseEvents'); + event.initMouseEvent(eventName, options.bubbles, options.cancelable, options.view, options.detail, options.screenX, options.screenY, options.clientX, options.clientY, options.ctrlKey, options.altKey, options.shiftKey, options.metaKey, options.button, options.relatedTarget || document.body.parentNode); + } else { + event = document.createEventObject(); + } + if (element.dispatchEvent) { + element.dispatchEvent(event); + } else { + element.fireEvent('on' + eventName, event); + } + } +}, {}); +function extendEvent(context, event) { + var componentName = 'HOT-TABLE'; + var isHotTableSpotted; + var fromElement; + var realTarget; + var target; + var len; + event.isTargetWebComponent = false; + event.realTarget = event.target; + if (!Handsontable.eventManager.isHotTableEnv) { + return event; + } + event = dom.polymerWrap(event); + len = event.path ? event.path.length : 0; + while (len--) { + if (event.path[len].nodeName === componentName) { + isHotTableSpotted = true; + } else if (isHotTableSpotted && event.path[len].shadowRoot) { + target = event.path[len]; + break; + } + if (len === 0 && !target) { + target = event.path[len]; + } + } + if (!target) { + target = event.target; + } + event.isTargetWebComponent = true; + if (dom.isWebComponentSupportedNatively()) { + event.realTarget = event.srcElement || event.toElement; + } else if (context instanceof Handsontable.Core || context instanceof Walkontable) { + if (context instanceof Handsontable.Core) { + fromElement = context.view.wt.wtTable.TABLE; + } else if (context instanceof Walkontable) { + fromElement = context.wtTable.TABLE.parentNode.parentNode; + } + realTarget = dom.closest(event.target, [componentName], fromElement); + if (realTarget) { + event.realTarget = fromElement.querySelector(componentName) || event.target; + } else { + event.realTarget = event.target; + } + } + Object.defineProperty(event, 'target', { + get: function() { + return dom.polymerWrap(target); + }, + enumerable: true, + configurable: true + }); + return event; +} +; +window.Handsontable = window.Handsontable || {}; +Handsontable.countEventManagerListeners = 0; +Handsontable.eventManager = eventManager; +function eventManager(context) { + return new EventManager(context); +} + +//# +},{"dom.js":27}],42:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + isPrintableChar: {get: function() { + return isPrintableChar; + }}, + isMetaKey: {get: function() { + return isMetaKey; + }}, + isCtrlKey: {get: function() { + return isCtrlKey; + }}, + stringify: {get: function() { + return stringify; + }}, + toUpperCaseFirst: {get: function() { + return toUpperCaseFirst; + }}, + equalsIgnoreCase: {get: function() { + return equalsIgnoreCase; + }}, + duckSchema: {get: function() { + return duckSchema; + }}, + spreadsheetColumnLabel: {get: function() { + return spreadsheetColumnLabel; + }}, + createSpreadsheetData: {get: function() { + return createSpreadsheetData; + }}, + createSpreadsheetObjectData: {get: function() { + return createSpreadsheetObjectData; + }}, + isNumeric: {get: function() { + return isNumeric; + }}, + randomString: {get: function() { + return randomString; + }}, + inherit: {get: function() { + return inherit; + }}, + extend: {get: function() { + return extend; + }}, + deepExtend: {get: function() { + return deepExtend; + }}, + deepClone: {get: function() { + return deepClone; + }}, + isObjectEquals: {get: function() { + return isObjectEquals; + }}, + getPrototypeOf: {get: function() { + return getPrototypeOf; + }}, + columnFactory: {get: function() { + return columnFactory; + }}, + translateRowsToColumns: {get: function() { + return translateRowsToColumns; + }}, + to2dArray: {get: function() { + return to2dArray; + }}, + extendArray: {get: function() { + return extendArray; + }}, + isInput: {get: function() { + return isInput; + }}, + isOutsideInput: {get: function() { + return isOutsideInput; + }}, + keyCode: {get: function() { + return keyCode; + }}, + isObject: {get: function() { + return isObject; + }}, + pivot: {get: function() { + return pivot; + }}, + proxy: {get: function() { + return proxy; + }}, + cellMethodLookupFactory: {get: function() { + return cellMethodLookupFactory; + }}, + isMobileBrowser: {get: function() { + return isMobileBrowser; + }}, + isTouchSupported: {get: function() { + return isTouchSupported; + }}, + stopPropagation: {get: function() { + return stopPropagation; + }}, + pageX: {get: function() { + return pageX; + }}, + pageY: {get: function() { + return pageY; + }}, + defineGetter: {get: function() { + return defineGetter; + }}, + requestAnimationFrame: {get: function() { + return requestAnimationFrame; + }}, + cancelAnimationFrame: {get: function() { + return cancelAnimationFrame; + }}, + arrayFilter: {get: function() { + return arrayFilter; + }}, + arrayEach: {get: function() { + return arrayEach; + }}, + objectEach: {get: function() { + return objectEach; + }}, + rangeEach: {get: function() { + return rangeEach; + }}, + arraySum: {get: function() { + return arraySum; + }}, + arrayAvg: {get: function() { + return arrayAvg; + }}, + isPercentValue: {get: function() { + return isPercentValue; + }}, + valueAccordingPercent: {get: function() { + return valueAccordingPercent; + }}, + throttle: {get: function() { + return throttle; + }}, + throttleAfterHits: {get: function() { + return throttleAfterHits; + }}, + __esModule: {value: true} +}); +var $__dom_46_js__; +var dom = ($__dom_46_js__ = require("dom.js"), $__dom_46_js__ && $__dom_46_js__.__esModule && $__dom_46_js__ || {default: $__dom_46_js__}); +function isPrintableChar(keyCode) { + return ((keyCode == 32) || (keyCode >= 48 && keyCode <= 57) || (keyCode >= 96 && keyCode <= 111) || (keyCode >= 186 && keyCode <= 192) || (keyCode >= 219 && keyCode <= 222) || keyCode >= 226 || (keyCode >= 65 && keyCode <= 90)); +} +function isMetaKey(_keyCode) { + var metaKeys = [keyCode.ARROW_DOWN, keyCode.ARROW_UP, keyCode.ARROW_LEFT, keyCode.ARROW_RIGHT, keyCode.HOME, keyCode.END, keyCode.DELETE, keyCode.BACKSPACE, keyCode.F1, keyCode.F2, keyCode.F3, keyCode.F4, keyCode.F5, keyCode.F6, keyCode.F7, keyCode.F8, keyCode.F9, keyCode.F10, keyCode.F11, keyCode.F12, keyCode.TAB, keyCode.PAGE_DOWN, keyCode.PAGE_UP, keyCode.ENTER, keyCode.ESCAPE, keyCode.SHIFT, keyCode.CAPS_LOCK, keyCode.ALT]; + return metaKeys.indexOf(_keyCode) != -1; +} +function isCtrlKey(_keyCode) { + return [keyCode.CONTROL_LEFT, 224, keyCode.COMMAND_LEFT, keyCode.COMMAND_RIGHT].indexOf(_keyCode) != -1; +} +function stringify(value) { + switch (typeof value) { + case 'string': + case 'number': + return value + ''; + case 'object': + if (value === null) { + return ''; + } else { + return value.toString(); + } + break; + case 'undefined': + return ''; + default: + return value.toString(); + } +} +function toUpperCaseFirst(string) { + return string[0].toUpperCase() + string.substr(1); +} +function equalsIgnoreCase() { + for (var strings = [], + $__1 = 0; $__1 < arguments.length; $__1++) + strings[$__1] = arguments[$__1]; + var unique = []; + var length = strings.length; + while (length--) { + var string = stringify(strings[length]).toLowerCase(); + if (unique.indexOf(string) === -1) { + unique.push(string); + } + } + return unique.length === 1; +} +function duckSchema(object) { + var schema; + if (Array.isArray(object)) { + schema = []; + } else { + schema = {}; + for (var i in object) { + if (object.hasOwnProperty(i)) { + if (object[i] && typeof object[i] === 'object' && !Array.isArray(object[i])) { + schema[i] = duckSchema(object[i]); + } else if (Array.isArray(object[i])) { + if (object[i].length && typeof object[i][0] === 'object' && !Array.isArray(object[i][0])) { + schema[i] = [duckSchema(object[i][0])]; + } else { + schema[i] = []; + } + } else { + schema[i] = null; + } + } + } + } + return schema; +} +function spreadsheetColumnLabel(index) { + var dividend = index + 1; + var columnLabel = ''; + var modulo; + while (dividend > 0) { + modulo = (dividend - 1) % 26; + columnLabel = String.fromCharCode(65 + modulo) + columnLabel; + dividend = parseInt((dividend - modulo) / 26, 10); + } + return columnLabel; +} +function createSpreadsheetData(rowCount, colCount) { + rowCount = typeof rowCount === 'number' ? rowCount : 100; + colCount = typeof colCount === 'number' ? colCount : 4; + var rows = [], + i, + j; + for (i = 0; i < rowCount; i++) { + var row = []; + for (j = 0; j < colCount; j++) { + row.push(spreadsheetColumnLabel(j) + (i + 1)); + } + rows.push(row); + } + return rows; +} +function createSpreadsheetObjectData(rowCount, colCount) { + rowCount = typeof rowCount === 'number' ? rowCount : 100; + colCount = typeof colCount === 'number' ? colCount : 4; + var rows = [], + i, + j; + for (i = 0; i < rowCount; i++) { + var row = {}; + for (j = 0; j < colCount; j++) { + row['prop' + j] = spreadsheetColumnLabel(j) + (i + 1); + } + rows.push(row); + } + return rows; +} +function isNumeric(n) { + var t = typeof n; + return t == 'number' ? !isNaN(n) && isFinite(n) : t == 'string' ? !n.length ? false : n.length == 1 ? /\d/.test(n) : /^\s*[+-]?\s*(?:(?:\d+(?:\.\d+)?(?:e[+-]?\d+)?)|(?:0x[a-f\d]+))\s*$/i.test(n) : t == 'object' ? !!n && typeof n.valueOf() == "number" && !(n instanceof Date) : false; +} +function randomString() { + function s4() { + return Math.floor((1 + Math.random()) * 0x10000).toString(16).substring(1); + } + return s4() + s4() + s4() + s4(); +} +function inherit(Child, Parent) { + Parent.prototype.constructor = Parent; + Child.prototype = new Parent(); + Child.prototype.constructor = Child; + return Child; +} +function extend(target, extension) { + for (var i in extension) { + if (extension.hasOwnProperty(i)) { + target[i] = extension[i]; + } + } +} +function deepExtend(target, extension) { + for (var key in extension) { + if (extension.hasOwnProperty(key)) { + if (extension[key] && typeof extension[key] === 'object') { + if (!target[key]) { + if (Array.isArray(extension[key])) { + target[key] = []; + } else { + target[key] = {}; + } + } + deepExtend(target[key], extension[key]); + } else { + target[key] = extension[key]; + } + } + } +} +function deepClone(obj) { + if (typeof obj === "object") { + return JSON.parse(JSON.stringify(obj)); + } else { + return obj; + } +} +function isObjectEquals(object1, object2) { + return JSON.stringify(object1) === JSON.stringify(object2); +} +function getPrototypeOf(obj) { + var prototype; + if (typeof obj.__proto__ == "object") { + prototype = obj.__proto__; + } else { + var oldConstructor, + constructor = obj.constructor; + if (typeof obj.constructor == "function") { + oldConstructor = constructor; + if (delete obj.constructor) { + constructor = obj.constructor; + obj.constructor = oldConstructor; + } + } + prototype = constructor ? constructor.prototype : null; + } + return prototype; +} +function columnFactory(GridSettings, conflictList) { + function ColumnSettings() {} + inherit(ColumnSettings, GridSettings); + for (var i = 0, + len = conflictList.length; i < len; i++) { + ColumnSettings.prototype[conflictList[i]] = void 0; + } + return ColumnSettings; +} +function translateRowsToColumns(input) { + var i, + ilen, + j, + jlen, + output = [], + olen = 0; + for (i = 0, ilen = input.length; i < ilen; i++) { + for (j = 0, jlen = input[i].length; j < jlen; j++) { + if (j == olen) { + output.push([]); + olen++; + } + output[j].push(input[i][j]); + } + } + return output; +} +function to2dArray(arr) { + var i = 0, + ilen = arr.length; + while (i < ilen) { + arr[i] = [arr[i]]; + i++; + } +} +function extendArray(arr, extension) { + var i = 0, + ilen = extension.length; + while (i < ilen) { + arr.push(extension[i]); + i++; + } +} +function isInput(element) { + var inputs = ['INPUT', 'SELECT', 'TEXTAREA']; + return inputs.indexOf(element.nodeName) > -1 || element.contentEditable === 'true'; +} +function isOutsideInput(element) { + return isInput(element) && element.className.indexOf('handsontableInput') == -1 && element.className.indexOf('copyPaste') == -1; +} +var keyCode = { + MOUSE_LEFT: 1, + MOUSE_RIGHT: 3, + MOUSE_MIDDLE: 2, + BACKSPACE: 8, + COMMA: 188, + INSERT: 45, + DELETE: 46, + END: 35, + ENTER: 13, + ESCAPE: 27, + CONTROL_LEFT: 91, + COMMAND_LEFT: 17, + COMMAND_RIGHT: 93, + ALT: 18, + HOME: 36, + PAGE_DOWN: 34, + PAGE_UP: 33, + PERIOD: 190, + SPACE: 32, + SHIFT: 16, + CAPS_LOCK: 20, + TAB: 9, + ARROW_RIGHT: 39, + ARROW_LEFT: 37, + ARROW_UP: 38, + ARROW_DOWN: 40, + F1: 112, + F2: 113, + F3: 114, + F4: 115, + F5: 116, + F6: 117, + F7: 118, + F8: 119, + F9: 120, + F10: 121, + F11: 122, + F12: 123, + A: 65, + X: 88, + C: 67, + V: 86 +}; +function isObject(obj) { + return Object.prototype.toString.call(obj) == '[object Object]'; +} +function pivot(arr) { + var pivotedArr = []; + if (!arr || arr.length === 0 || !arr[0] || arr[0].length === 0) { + return pivotedArr; + } + var rowCount = arr.length; + var colCount = arr[0].length; + for (var i = 0; i < rowCount; i++) { + for (var j = 0; j < colCount; j++) { + if (!pivotedArr[j]) { + pivotedArr[j] = []; + } + pivotedArr[j][i] = arr[i][j]; + } + } + return pivotedArr; +} +function proxy(fun, context) { + return function() { + return fun.apply(context, arguments); + }; +} +function cellMethodLookupFactory(methodName, allowUndefined) { + allowUndefined = typeof allowUndefined == 'undefined' ? true : allowUndefined; + return function cellMethodLookup(row, col) { + return (function getMethodFromProperties(properties) { + if (!properties) { + return; + } else if (properties.hasOwnProperty(methodName) && properties[methodName] !== void 0) { + return properties[methodName]; + } else if (properties.hasOwnProperty('type') && properties.type) { + var type; + if (typeof properties.type != 'string') { + throw new Error('Cell type must be a string '); + } + type = translateTypeNameToObject(properties.type); + if (type.hasOwnProperty(methodName)) { + return type[methodName]; + } else if (allowUndefined) { + return; + } + } + return getMethodFromProperties(getPrototypeOf(properties)); + })(typeof row == 'number' ? this.getCellMeta(row, col) : row); + }; + function translateTypeNameToObject(typeName) { + var type = Handsontable.cellTypes[typeName]; + if (typeof type == 'undefined') { + throw new Error('You declared cell type "' + typeName + '" as a string that is not mapped to a known object. ' + 'Cell type must be an object or a string mapped to an object in Handsontable.cellTypes'); + } + return type; + } +} +function isMobileBrowser(userAgent) { + if (!userAgent) { + userAgent = navigator.userAgent; + } + return (/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(userAgent)); +} +function isTouchSupported() { + return ('ontouchstart' in window); +} +function stopPropagation(event) { + if (typeof(event.stopPropagation) === 'function') { + event.stopPropagation(); + } else { + event.cancelBubble = true; + } +} +function pageX(event) { + if (event.pageX) { + return event.pageX; + } + var scrollLeft = dom.getWindowScrollLeft(); + var cursorX = event.clientX + scrollLeft; + return cursorX; +} +function pageY(event) { + if (event.pageY) { + return event.pageY; + } + var scrollTop = dom.getWindowScrollTop(); + var cursorY = event.clientY + scrollTop; + return cursorY; +} +function defineGetter(object, property, value, options) { + options.value = value; + options.writable = options.writable === false ? false : true; + options.enumerable = options.enumerable === false ? false : true; + options.configurable = options.configurable === false ? false : true; + Object.defineProperty(object, property, options); +} +var lastTime = 0; +var vendors = ['ms', 'moz', 'webkit', 'o']; +var _requestAnimationFrame = window.requestAnimationFrame; +var _cancelAnimationFrame = window.cancelAnimationFrame; +for (var x = 0; x < vendors.length && !_requestAnimationFrame; ++x) { + _requestAnimationFrame = window[vendors[x] + 'RequestAnimationFrame']; + _cancelAnimationFrame = window[vendors[x] + 'CancelAnimationFrame'] || window[vendors[x] + 'CancelRequestAnimationFrame']; +} +if (!_requestAnimationFrame) { + _requestAnimationFrame = function(callback) { + var currTime = new Date().getTime(); + var timeToCall = Math.max(0, 16 - (currTime - lastTime)); + var id = window.setTimeout(function() { + callback(currTime + timeToCall); + }, timeToCall); + lastTime = currTime + timeToCall; + return id; + }; +} +if (!_cancelAnimationFrame) { + _cancelAnimationFrame = function(id) { + clearTimeout(id); + }; +} +function requestAnimationFrame(callback) { + return _requestAnimationFrame.call(window, callback); +} +function cancelAnimationFrame(id) { + _cancelAnimationFrame.call(window, id); +} +function arrayReduce(array, iteratee, accumulator, initFromArray) { + var index = -1, + length = array.length; + if (initFromArray && length) { + accumulator = array[++index]; + } + while (++index < length) { + accumulator = iteratee(accumulator, array[index], index, array); + } + return accumulator; +} +function arrayFilter(array, predicate) { + var index = -1, + length = array.length, + resIndex = -1, + result = []; + while (++index < length) { + var value = array[index]; + if (predicate(value, index, array)) { + result[++resIndex] = value; + } + } + return result; +} +function arrayEach(array, iteratee) { + var index = -1, + length = array.length; + while (++index < length) { + if (iteratee(array[index], index, array) === false) { + break; + } + } + return array; +} +function objectEach(object, iteratee) { + for (var key in object) { + if (!object.hasOwnProperty || (object.hasOwnProperty && object.hasOwnProperty(key))) { + if (iteratee(object[key], key, object) === false) { + break; + } + } + } + return object; +} +function rangeEach(rangeFrom, rangeTo, iteratee) { + var index = -1; + if (typeof rangeTo === 'function') { + iteratee = rangeTo; + rangeTo = rangeFrom; + } else { + index = rangeFrom - 1; + } + while (++index <= rangeTo) { + if (iteratee(index) === false) { + break; + } + } +} +function arraySum(array) { + return arrayReduce(array, (function(a, b) { + return (a + b); + }), 0); +} +function arrayAvg(array) { + if (!array.length) { + return 0; + } + return arraySum(array) / array.length; +} +function isPercentValue(value) { + return /^([0-9][0-9]?\%$)|(^100\%$)/.test(value); +} +function valueAccordingPercent(value, percent) { + percent = parseInt(percent.toString().replace('%', ''), 10); + percent = parseInt(value * percent / 100); + return percent; +} +function throttle(func) { + var wait = arguments[1] !== (void 0) ? arguments[1] : 200; + var lastCalled = 0; + var result = {lastCallThrottled: true}; + var lastTimer = null; + function _throttle() { + var $__0 = this; + var args = arguments; + var stamp = Date.now(); + var needCall = false; + result.lastCallThrottled = true; + if (!lastCalled) { + lastCalled = stamp; + needCall = true; + } + var remaining = wait - (stamp - lastCalled); + if (needCall) { + result.lastCallThrottled = false; + func.apply(this, args); + } else { + if (lastTimer) { + clearTimeout(lastTimer); + } + lastTimer = setTimeout((function() { + result.lastCallThrottled = false; + func.apply($__0, args); + lastCalled = 0; + lastTimer = void 0; + }), remaining); + } + return result; + } + return _throttle; +} +function throttleAfterHits(func) { + var wait = arguments[1] !== (void 0) ? arguments[1] : 200; + var hits = arguments[2] !== (void 0) ? arguments[2] : 10; + var funcThrottle = throttle(func, wait); + var remainHits = hits; + function _clearHits() { + remainHits = hits; + } + function _throttleAfterHits() { + if (remainHits) { + remainHits--; + return func.apply(this, arguments); + } + return funcThrottle.apply(this, arguments); + } + _throttleAfterHits.clearHits = _clearHits; + return _throttleAfterHits; +} +window.Handsontable = window.Handsontable || {}; +Handsontable.helper = { + arrayAvg: arrayAvg, + arrayEach: arrayEach, + arrayFilter: arrayFilter, + arrayReduce: arrayReduce, + arraySum: arraySum, + cancelAnimationFrame: cancelAnimationFrame, + cellMethodLookupFactory: cellMethodLookupFactory, + columnFactory: columnFactory, + createSpreadsheetData: createSpreadsheetData, + createSpreadsheetObjectData: createSpreadsheetObjectData, + deepClone: deepClone, + deepExtend: deepExtend, + defineGetter: defineGetter, + duckSchema: duckSchema, + equalsIgnoreCase: equalsIgnoreCase, + extend: extend, + extendArray: extendArray, + getPrototypeOf: getPrototypeOf, + inherit: inherit, + isCtrlKey: isCtrlKey, + isInput: isInput, + isMetaKey: isMetaKey, + isMobileBrowser: isMobileBrowser, + isNumeric: isNumeric, + isObject: isObject, + isObjectEquals: isObjectEquals, + isOutsideInput: isOutsideInput, + isPercentValue: isPercentValue, + isPrintableChar: isPrintableChar, + isTouchSupported: isTouchSupported, + keyCode: keyCode, + objectEach: objectEach, + pageX: pageX, + pageY: pageY, + pivot: pivot, + proxy: proxy, + randomString: randomString, + rangeEach: rangeEach, + requestAnimationFrame: requestAnimationFrame, + spreadsheetColumnLabel: spreadsheetColumnLabel, + stopPropagation: stopPropagation, + stringify: stringify, + throttle: throttle, + throttleAfterHits: throttleAfterHits, + to2dArray: to2dArray, + toUpperCaseFirst: toUpperCaseFirst, + translateRowsToColumns: translateRowsToColumns, + valueAccordingPercent: valueAccordingPercent +}; + +//# +},{"dom.js":27}],43:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + MultiMap: {get: function() { + return MultiMap; + }}, + __esModule: {value: true} +}); +; +window.MultiMap = MultiMap; +function MultiMap() { + var map = { + arrayMap: [], + weakMap: new WeakMap() + }; + return { + 'get': function(key) { + if (canBeAnArrayMapKey(key)) { + return map.arrayMap[key]; + } else if (canBeAWeakMapKey(key)) { + return map.weakMap.get(key); + } + }, + 'set': function(key, value) { + if (canBeAnArrayMapKey(key)) { + map.arrayMap[key] = value; + } else if (canBeAWeakMapKey(key)) { + map.weakMap.set(key, value); + } else { + throw new Error('Invalid key type'); + } + }, + 'delete': function(key) { + if (canBeAnArrayMapKey(key)) { + delete map.arrayMap[key]; + } else if (canBeAWeakMapKey(key)) { + map.weakMap['delete'](key); + } + } + }; + function canBeAnArrayMapKey(obj) { + return obj !== null && !isNaNSymbol(obj) && (typeof obj == 'string' || typeof obj == 'number'); + } + function canBeAWeakMapKey(obj) { + return obj !== null && (typeof obj == 'object' || typeof obj == 'function'); + } + function isNaNSymbol(obj) { + return obj !== obj; + } +} + +//# +},{}],44:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + Hooks: {get: function() { + return Hooks; + }}, + __esModule: {value: true} +}); +var $__eventManager_46_js__, + $__helpers_46_js__; +var REGISTERED_HOOKS = ["afterCellMetaReset", "afterChange", "afterChangesObserved", "afterColumnMove", "afterColumnResize", "afterContextMenuDefaultOptions", "afterContextMenuHide", "afterContextMenuShow", "afterCopyLimit", "afterCreateCol", "afterCreateRow", "afterDeselect", "afterDestroy", "afterDocumentKeyDown", "afterGetCellMeta", "afterGetColHeader", "afterGetRowHeader", "afterInit", "afterIsMultipleSelectionCheck", "afterLoadData", "afterMomentumScroll", "afterOnCellCornerMouseDown", "afterOnCellMouseDown", "afterOnCellMouseOver", "afterRemoveCol", "afterRemoveRow", "afterRender", "afterRenderer", "afterRowMove", "afterRowResize", "afterScrollHorizontally", "afterScrollVertically", "afterSelection", "afterSelectionByProp", "afterSelectionEnd", "afterSelectionEndByProp", "afterSetCellMeta", "afterUpdateSettings", "afterValidate", "beforeAutofill", "beforeCellAlignment", "beforeChange", "beforeChangeRender", "beforeDrawBorders", "beforeGetCellMeta", "beforeInit", "beforeInitWalkontable", "beforeKeyDown", "beforeOnCellMouseDown", "beforeRemoveCol", "beforeRemoveRow", "beforeRender", "beforeSetRangeEnd", "beforeTouchScroll", "beforeValidate", "construct", "init", "modifyCol", "modifyColWidth", "modifyRow", "modifyRowHeight", "persistentStateLoad", "persistentStateReset", "persistentStateSave"]; +var EventManager = ($__eventManager_46_js__ = require("eventManager.js"), $__eventManager_46_js__ && $__eventManager_46_js__.__esModule && $__eventManager_46_js__ || {default: $__eventManager_46_js__}).EventManager; +var $__1 = ($__helpers_46_js__ = require("helpers.js"), $__helpers_46_js__ && $__helpers_46_js__.__esModule && $__helpers_46_js__ || {default: $__helpers_46_js__}), + arrayEach = $__1.arrayEach, + objectEach = $__1.objectEach; +var Hooks = function Hooks() { + this.globalBucket = this.createEmptyBucket(); +}; +($traceurRuntime.createClass)(Hooks, { + createEmptyBucket: function() { + var bucket = Object.create(null); + arrayEach(REGISTERED_HOOKS, (function(hook) { + return (bucket[hook] = []); + })); + return bucket; + }, + getBucket: function() { + var context = arguments[0] !== (void 0) ? arguments[0] : null; + if (context) { + if (!context.pluginHookBucket) { + context.pluginHookBucket = this.createEmptyBucket(); + } + return context.pluginHookBucket; + } + return this.globalBucket; + }, + add: function(key, callback) { + var context = arguments[2] !== (void 0) ? arguments[2] : null; + var $__2 = this; + if (Array.isArray(callback)) { + arrayEach(callback, (function(c) { + return ($__2.add(key, c, context)); + })); + } else { + var bucket = this.getBucket(context); + if (typeof bucket[key] === 'undefined') { + this.register(key); + bucket[key] = []; + } + callback.skip = false; + if (bucket[key].indexOf(callback) === -1) { + bucket[key].push(callback); + } + } + return this; + }, + once: function(key, callback) { + var context = arguments[2] !== (void 0) ? arguments[2] : null; + var $__2 = this; + if (Array.isArray(callback)) { + arrayEach(callback, (function(c) { + return ($__2.once(key, c, context)); + })); + } else { + callback.runOnce = true; + this.add(key, callback, context); + } + }, + remove: function(key, callback) { + var context = arguments[2] !== (void 0) ? arguments[2] : null; + var bucket = this.getBucket(context); + if (typeof bucket[key] !== 'undefined') { + if (bucket[key].indexOf(callback) >= 0) { + callback.skip = true; + return true; + } + } + return false; + }, + run: function(context, key, p1, p2, p3, p4, p5, p6) { + var $__2 = this; + { + var globalHandlers = this.globalBucket[key]; + if (globalHandlers && globalHandlers.length) { + arrayEach(globalHandlers, (function(handler) { + if (!handler || handler.skip) { + return; + } + var res = handler.call(context, p1, p2, p3, p4, p5, p6); + if (res !== void 0) { + p1 = res; + } + if (handler.runOnce) { + $__2.remove(key, handler); + } + })); + } + } + { + var localHandlers = this.getBucket(context)[key]; + if (localHandlers && localHandlers.length) { + arrayEach(localHandlers, (function(handler) { + if (!handler || handler.skip) { + return; + } + var res = handler.call(context, p1, p2, p3, p4, p5, p6); + if (res !== void 0) { + p1 = res; + } + if (handler.runOnce) { + $__2.remove(key, handler, context); + } + })); + } + } + return p1; + }, + destroy: function() { + var context = arguments[0] !== (void 0) ? arguments[0] : null; + objectEach(this.getBucket(context), (function(value, key, bucket) { + return (bucket[key].length = 0); + })); + }, + register: function(key) { + if (!this.isRegistered(key)) { + REGISTERED_HOOKS.push(key); + } + }, + deregister: function(key) { + if (this.isRegistered(key)) { + REGISTERED_HOOKS.splice(REGISTERED_HOOKS.indexOf(key), 1); + } + }, + isRegistered: function(key) { + return REGISTERED_HOOKS.indexOf(key) >= 0; + }, + getRegistered: function() { + return REGISTERED_HOOKS; + } +}, {}); +; +Handsontable.utils = Handsontable.utils || {}; +Handsontable.utils.Hooks = Hooks; + +//# +},{"eventManager.js":41,"helpers.js":42}],45:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + registerPlugin: {get: function() { + return registerPlugin; + }}, + getPlugin: {get: function() { + return getPlugin; + }}, + __esModule: {value: true} +}); +; +var registeredPlugins = new WeakMap(); +function registerPlugin(pluginName, PluginClass) { + Handsontable.hooks.add('construct', function() { + var holder; + pluginName = pluginName.toLowerCase(); + if (!registeredPlugins.has(this)) { + registeredPlugins.set(this, {}); + } + holder = registeredPlugins.get(this); + if (!holder[pluginName]) { + holder[pluginName] = new PluginClass(this); + } + }); + Handsontable.hooks.add('afterDestroy', function() { + var i, + pluginsHolder; + if (registeredPlugins.has(this)) { + pluginsHolder = registeredPlugins.get(this); + for (i in pluginsHolder) { + if (pluginsHolder.hasOwnProperty(i)) { + pluginsHolder[i].destroy(); + } + } + registeredPlugins.delete(this); + } + }); +} +function getPlugin(instance, pluginName) { + if (typeof pluginName != 'string') { + throw Error('Only strings can be passed as "plugin" parameter'); + } + var _pluginName = pluginName.toLowerCase(); + if (!registeredPlugins.has(instance) || !registeredPlugins.get(instance)[_pluginName]) { + return void 0; + } + return registeredPlugins.get(instance)[_pluginName]; +} + +//# +},{}],46:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + default: {get: function() { + return $__default; + }}, + __esModule: {value: true} +}); +var $___46__46__47_helpers_46_js__; +var $__0 = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}), + defineGetter = $__0.defineGetter, + objectEach = $__0.objectEach, + arrayEach = $__0.arrayEach; +var privatePool = new WeakMap(); +var BasePlugin = function BasePlugin(hotInstance) { + var $__1 = this; + defineGetter(this, 'hot', hotInstance, {writable: false}); + privatePool.set(this, {hooks: {}}); + this.enabled = false; + this.hot.addHook('afterUpdateSettings', (function() { + return $__1.onUpdateSettings(); + })); + this.hot.addHook('beforeInit', (function() { + return $__1.init(); + })); +}; +($traceurRuntime.createClass)(BasePlugin, { + init: function() { + if (this.isEnabled) { + this[(this.isEnabled() ? 'enable' : 'disable') + 'Plugin'](); + this.enabled = this.isEnabled(); + } + }, + enablePlugin: function() { + this.enabled = true; + }, + disablePlugin: function() { + if (this.eventManager) { + this.eventManager.clear(); + } + this.clearHooks(); + this.enabled = false; + }, + addHook: function(name, callback) { + var hooks = privatePool.get(this).hooks[name] = (privatePool.get(this).hooks[name] || []); + this.hot.addHook(name, callback); + hooks.push(callback); + privatePool.get(this).hooks[name] = hooks; + }, + removeHooks: function(name) { + var $__1 = this; + arrayEach(privatePool.get(this).hooks[name] || [], (function(callback) { + $__1.hot.removeHook(name, callback); + })); + }, + clearHooks: function() { + var $__1 = this; + var hooks = privatePool.get(this).hooks; + objectEach(hooks, (function(callbacks, name) { + return $__1.removeHooks(name); + })); + hooks.length = 0; + }, + onUpdateSettings: function() { + if (this.isEnabled) { + if (this.enabled && !this.isEnabled()) { + this.disablePlugin(); + } + if (!this.enabled && this.isEnabled()) { + this.enablePlugin(); + } + } + }, + destroy: function() { + if (this.eventManager) { + this.eventManager.destroy(); + } + this.clearHooks(); + delete this.hot; + } +}, {}); +var $__default = BasePlugin; + +//# +},{"helpers.js":42}],47:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + AutoColumnSize: {get: function() { + return AutoColumnSize; + }}, + __esModule: {value: true} +}); +var $___46__46__47__95_base_46_js__, + $___46__46__47__46__46__47_helpers_46_js__, + $___46__46__47__46__46__47_utils_47_ghostTable_46_js__, + $___46__46__47__46__46__47_plugins_46_js__, + $___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__, + $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__; +var BasePlugin = ($___46__46__47__95_base_46_js__ = require("_base.js"), $___46__46__47__95_base_46_js__ && $___46__46__47__95_base_46_js__.__esModule && $___46__46__47__95_base_46_js__ || {default: $___46__46__47__95_base_46_js__}).default; +var $__1 = ($___46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47_helpers_46_js__}), + arrayEach = $__1.arrayEach, + arrayFilter = $__1.arrayFilter, + objectEach = $__1.objectEach, + rangeEach = $__1.rangeEach, + requestAnimationFrame = $__1.requestAnimationFrame, + cancelAnimationFrame = $__1.cancelAnimationFrame, + isObject = $__1.isObject, + isPercentValue = $__1.isPercentValue, + valueAccordingPercent = $__1.valueAccordingPercent; +var GhostTable = ($___46__46__47__46__46__47_utils_47_ghostTable_46_js__ = require("utils/ghostTable.js"), $___46__46__47__46__46__47_utils_47_ghostTable_46_js__ && $___46__46__47__46__46__47_utils_47_ghostTable_46_js__.__esModule && $___46__46__47__46__46__47_utils_47_ghostTable_46_js__ || {default: $___46__46__47__46__46__47_utils_47_ghostTable_46_js__}).GhostTable; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +var SamplesGenerator = ($___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__ = require("utils/samplesGenerator.js"), $___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__ && $___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__.__esModule && $___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__ || {default: $___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__}).SamplesGenerator; +var WalkontableViewportColumnsCalculator = ($___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__ = require("3rdparty/walkontable/src/calculator/viewportColumns.js"), $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__ && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__.__esModule && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__ || {default: $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_calculator_47_viewportColumns_46_js__}).WalkontableViewportColumnsCalculator; +var AutoColumnSize = function AutoColumnSize(hotInstance) { + var $__6 = this; + $traceurRuntime.superConstructor($AutoColumnSize).call(this, hotInstance); + this.widths = []; + this.ghostTable = new GhostTable(this.hot); + this.samplesGenerator = new SamplesGenerator((function(row, col) { + return $__6.hot.getDataAtCell(row, col); + })); + this.firstCalculation = true; + this.inProgress = false; +}; +var $AutoColumnSize = AutoColumnSize; +($traceurRuntime.createClass)(AutoColumnSize, { + isEnabled: function() { + return this.hot.getSettings().autoColumnSize !== false && !this.hot.getSettings().colWidths; + }, + enablePlugin: function() { + var $__6 = this; + if (this.enabled) { + return; + } + this.addHook('afterLoadData', (function() { + return $__6.onAfterLoadData(); + })); + this.addHook('beforeChange', (function(changes) { + return $__6.onBeforeChange(changes); + })); + this.addHook('beforeColumnResize', (function(col, size, isDblClick) { + return $__6.onBeforeColumnResize(col, size, isDblClick); + })); + this.addHook('beforeRender', (function(force) { + return $__6.onBeforeRender(force); + })); + this.addHook('modifyColWidth', (function(width, col) { + return $__6.getColumnWidth(col, width); + })); + $traceurRuntime.superGet(this, $AutoColumnSize.prototype, "enablePlugin").call(this); + }, + calculateColumnsWidth: function() { + var colRange = arguments[0] !== (void 0) ? arguments[0] : { + from: 0, + to: this.hot.countCols() - 1 + }; + var rowRange = arguments[1] !== (void 0) ? arguments[1] : { + from: 0, + to: this.hot.countRows() - 1 + }; + var force = arguments[2] !== (void 0) ? arguments[2] : false; + var $__6 = this; + if (typeof colRange === 'number') { + colRange = { + from: colRange, + to: colRange + }; + } + if (typeof rowRange === 'number') { + rowRange = { + from: rowRange, + to: rowRange + }; + } + rangeEach(colRange.from, colRange.to, (function(col) { + if (force || ($__6.widths[col] === void 0 && !$__6.hot._getColWidthFromSettings(col))) { + var samples = $__6.samplesGenerator.generateColumnSamples(col, rowRange); + samples.forEach((function(sample, col) { + return $__6.ghostTable.addColumn(col, sample); + })); + } + })); + if (this.ghostTable.columns.length) { + this.ghostTable.getWidths((function(col, width) { + return $__6.widths[col] = width; + })); + this.ghostTable.clean(); + } + }, + calculateAllColumnsWidth: function() { + var rowRange = arguments[0] !== (void 0) ? arguments[0] : { + from: 0, + to: this.hot.countRows() - 1 + }; + var $__6 = this; + var current = 0; + var length = this.hot.countCols() - 1; + var timer = null; + this.inProgress = true; + var loop = (function() { + if (!$__6.hot) { + cancelAnimationFrame(timer); + $__6.inProgress = false; + return; + } + $__6.calculateColumnsWidth({ + from: current, + to: Math.min(current + $AutoColumnSize.CALCULATION_STEP, length) + }, rowRange); + current = current + $AutoColumnSize.CALCULATION_STEP + 1; + if (current < length) { + timer = requestAnimationFrame(loop); + } else { + cancelAnimationFrame(timer); + $__6.inProgress = false; + $__6.hot.view.wt.wtOverlays.adjustElementsSize(true); + if ($__6.hot.view.wt.wtOverlays.leftOverlay.needFullRender) { + $__6.hot.view.wt.wtOverlays.leftOverlay.clone.draw(); + } + } + }); + if (this.firstCalculation && this.getSyncCalculationLimit()) { + this.calculateColumnsWidth({ + from: 0, + to: this.getSyncCalculationLimit() + }, rowRange); + this.firstCalculation = false; + current = this.getSyncCalculationLimit() + 1; + } + if (current < length) { + loop(); + } else { + this.inProgress = false; + } + }, + recalculateAllColumnsWidth: function() { + this.clearCache(); + this.calculateAllColumnsWidth(); + }, + getSyncCalculationLimit: function() { + var limit = $AutoColumnSize.SYNC_CALCULATION_LIMIT; + var colsLimit = this.hot.countCols() - 1; + if (isObject(this.hot.getSettings().autoColumnSize)) { + limit = this.hot.getSettings().autoColumnSize.syncLimit; + if (isPercentValue(limit)) { + limit = valueAccordingPercent(colsLimit, limit); + } else { + limit = limit >> 0; + } + } + return Math.min(limit, colsLimit); + }, + getColumnWidth: function(col) { + var defaultWidth = arguments[1]; + var keepMinimum = arguments[2] !== (void 0) ? arguments[2] : true; + var width = defaultWidth; + if (width === void 0) { + width = this.widths[col]; + if (keepMinimum && typeof width === 'number') { + width = Math.max(width, WalkontableViewportColumnsCalculator.DEFAULT_WIDTH); + } + } + return width; + }, + getFirstVisibleColumn: function() { + var wot = this.hot.view.wt; + if (wot.wtViewport.columnsVisibleCalculator) { + return wot.wtTable.getFirstVisibleColumn(); + } + if (wot.wtViewport.columnsRenderCalculator) { + return wot.wtTable.getFirstRenderedColumn(); + } + return -1; + }, + getLastVisibleColumn: function() { + var wot = this.hot.view.wt; + if (wot.wtViewport.columnsVisibleCalculator) { + return wot.wtTable.getLastVisibleColumn(); + } + if (wot.wtViewport.columnsRenderCalculator) { + return wot.wtTable.getLastRenderedColumn(); + } + return -1; + }, + clearCache: function() { + this.widths.length = 0; + }, + isNeedRecalculate: function() { + return arrayFilter(this.widths, (function(item) { + return (item === void 0); + })).length ? true : false; + }, + onBeforeRender: function() { + var force = this.hot.renderCall; + this.calculateColumnsWidth({ + from: this.getFirstVisibleColumn(), + to: this.getLastVisibleColumn() + }, void 0, force); + if (this.isNeedRecalculate() && !this.inProgress) { + this.calculateAllColumnsWidth(); + } + }, + onAfterLoadData: function() { + var $__6 = this; + if (this.hot.view) { + this.recalculateAllColumnsWidth(); + } else { + setTimeout((function() { + if ($__6.hot) { + $__6.recalculateAllColumnsWidth(); + } + }), 0); + } + }, + onBeforeChange: function(changes) { + var $__6 = this; + arrayEach(changes, (function(data) { + return $__6.widths[data[1]] = void 0; + })); + }, + onBeforeColumnResize: function(col, size, isDblClick) { + if (isDblClick) { + this.calculateColumnsWidth(col, void 0, true); + size = this.getColumnWidth(col, void 0, false); + } + return size; + }, + destroy: function() { + this.ghostTable.clean(); + $traceurRuntime.superGet(this, $AutoColumnSize.prototype, "destroy").call(this); + } +}, { + get CALCULATION_STEP() { + return 50; + }, + get SYNC_CALCULATION_LIMIT() { + return 50; + } +}, BasePlugin); +; +registerPlugin('autoColumnSize', AutoColumnSize); + +//# +},{"3rdparty/walkontable/src/calculator/viewportColumns.js":3,"_base.js":46,"helpers.js":42,"plugins.js":45,"utils/ghostTable.js":81,"utils/samplesGenerator.js":82}],48:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + AutoRowSize: {get: function() { + return AutoRowSize; + }}, + __esModule: {value: true} +}); +var $___46__46__47__95_base_46_js__, + $___46__46__47__46__46__47_helpers_46_js__, + $___46__46__47__46__46__47_utils_47_ghostTable_46_js__, + $___46__46__47__46__46__47_plugins_46_js__, + $___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__; +var BasePlugin = ($___46__46__47__95_base_46_js__ = require("_base.js"), $___46__46__47__95_base_46_js__ && $___46__46__47__95_base_46_js__.__esModule && $___46__46__47__95_base_46_js__ || {default: $___46__46__47__95_base_46_js__}).default; +var $__1 = ($___46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47_helpers_46_js__}), + arrayEach = $__1.arrayEach, + arrayFilter = $__1.arrayFilter, + objectEach = $__1.objectEach, + rangeEach = $__1.rangeEach, + requestAnimationFrame = $__1.requestAnimationFrame, + cancelAnimationFrame = $__1.cancelAnimationFrame, + isObject = $__1.isObject, + isPercentValue = $__1.isPercentValue, + valueAccordingPercent = $__1.valueAccordingPercent; +var GhostTable = ($___46__46__47__46__46__47_utils_47_ghostTable_46_js__ = require("utils/ghostTable.js"), $___46__46__47__46__46__47_utils_47_ghostTable_46_js__ && $___46__46__47__46__46__47_utils_47_ghostTable_46_js__.__esModule && $___46__46__47__46__46__47_utils_47_ghostTable_46_js__ || {default: $___46__46__47__46__46__47_utils_47_ghostTable_46_js__}).GhostTable; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +var SamplesGenerator = ($___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__ = require("utils/samplesGenerator.js"), $___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__ && $___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__.__esModule && $___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__ || {default: $___46__46__47__46__46__47_utils_47_samplesGenerator_46_js__}).SamplesGenerator; +var AutoRowSize = function AutoRowSize(hotInstance) { + var $__5 = this; + $traceurRuntime.superConstructor($AutoRowSize).call(this, hotInstance); + this.heights = []; + this.ghostTable = new GhostTable(this.hot); + this.samplesGenerator = new SamplesGenerator((function(row, col) { + return $__5.hot.getDataAtCell(row, col); + })); + this.firstCalculation = true; + this.inProgress = false; +}; +var $AutoRowSize = AutoRowSize; +($traceurRuntime.createClass)(AutoRowSize, { + isEnabled: function() { + return this.hot.getSettings().autoRowSize === true || isObject(this.hot.getSettings().autoRowSize); + }, + enablePlugin: function() { + var $__5 = this; + if (this.enabled) { + return; + } + this.addHook('afterLoadData', (function() { + return $__5.onAfterLoadData(); + })); + this.addHook('beforeChange', (function(changes) { + return $__5.onBeforeChange(changes); + })); + this.addHook('beforeColumnMove', (function() { + return $__5.recalculateAllRowsHeight(); + })); + this.addHook('beforeColumnResize', (function() { + return $__5.recalculateAllRowsHeight(); + })); + this.addHook('beforeColumnSort', (function() { + return $__5.clearCache(); + })); + this.addHook('beforeRender', (function(force) { + return $__5.onBeforeRender(force); + })); + this.addHook('beforeRowMove', (function(rowStart, rowEnd) { + return $__5.onBeforeRowMove(rowStart, rowEnd); + })); + this.addHook('beforeRowResize', (function(row, size, isDblClick) { + return $__5.onBeforeRowResize(row, size, isDblClick); + })); + this.addHook('modifyRowHeight', (function(height, row) { + return $__5.getRowHeight(row, height); + })); + $traceurRuntime.superGet(this, $AutoRowSize.prototype, "enablePlugin").call(this); + }, + disablePlugin: function() { + $traceurRuntime.superGet(this, $AutoRowSize.prototype, "disablePlugin").call(this); + }, + calculateRowsHeight: function() { + var rowRange = arguments[0] !== (void 0) ? arguments[0] : { + from: 0, + to: this.hot.countRows() - 1 + }; + var colRange = arguments[1] !== (void 0) ? arguments[1] : { + from: 0, + to: this.hot.countCols() - 1 + }; + var force = arguments[2] !== (void 0) ? arguments[2] : false; + var $__5 = this; + if (typeof rowRange === 'number') { + rowRange = { + from: rowRange, + to: rowRange + }; + } + if (typeof colRange === 'number') { + colRange = { + from: colRange, + to: colRange + }; + } + rangeEach(rowRange.from, rowRange.to, (function(row) { + if (force || $__5.heights[row] === void 0) { + var samples = $__5.samplesGenerator.generateRowSamples(row, colRange); + samples.forEach((function(sample, row) { + return $__5.ghostTable.addRow(row, sample); + })); + } + })); + if (this.ghostTable.rows.length) { + this.ghostTable.getHeights((function(row, height) { + return $__5.heights[row] = height; + })); + this.ghostTable.clean(); + } + }, + calculateAllRowsHeight: function() { + var colRange = arguments[0] !== (void 0) ? arguments[0] : { + from: 0, + to: this.hot.countCols() - 1 + }; + var $__5 = this; + var current = 0; + var length = this.hot.countRows() - 1; + var timer = null; + this.inProgress = true; + var loop = (function() { + if (!$__5.hot) { + cancelAnimationFrame(timer); + $__5.inProgress = false; + return; + } + $__5.calculateRowsHeight({ + from: current, + to: Math.min(current + $AutoRowSize.CALCULATION_STEP, length) + }, colRange); + current = current + $AutoRowSize.CALCULATION_STEP + 1; + if (current < length) { + timer = requestAnimationFrame(loop); + } else { + cancelAnimationFrame(timer); + $__5.inProgress = false; + $__5.hot.view.wt.wtOverlays.adjustElementsSize(true); + if ($__5.hot.view.wt.wtOverlays.leftOverlay.needFullRender) { + $__5.hot.view.wt.wtOverlays.leftOverlay.clone.draw(); + } + } + }); + if (this.firstCalculation && this.getSyncCalculationLimit()) { + this.calculateRowsHeight({ + from: 0, + to: this.getSyncCalculationLimit() + }, colRange); + this.firstCalculation = false; + current = this.getSyncCalculationLimit() + 1; + } + if (current < length) { + loop(); + } else { + this.inProgress = false; + } + }, + recalculateAllRowsHeight: function() { + this.clearCache(); + this.calculateAllRowsHeight(); + }, + getSyncCalculationLimit: function() { + var limit = $AutoRowSize.SYNC_CALCULATION_LIMIT; + var rowsLimit = this.hot.countRows() - 1; + if (isObject(this.hot.getSettings().autoRowSize)) { + limit = this.hot.getSettings().autoRowSize.syncLimit; + if (isPercentValue(limit)) { + limit = valueAccordingPercent(rowsLimit, limit); + } else { + limit = limit >> 0; + } + } + return Math.min(limit, rowsLimit); + }, + getRowHeight: function(row) { + var defaultHeight = arguments[1]; + var height = defaultHeight; + if (this.heights[row] !== void 0 && this.heights[row] > (defaultHeight || 0)) { + height = this.heights[row]; + } + return height; + }, + getFirstVisibleRow: function() { + var wot = this.hot.view.wt; + if (wot.wtViewport.rowsVisibleCalculator) { + return wot.wtTable.getFirstVisibleRow(); + } + if (wot.wtViewport.rowsRenderCalculator) { + return wot.wtTable.getFirstRenderedRow(); + } + return -1; + }, + getLastVisibleRow: function() { + var wot = this.hot.view.wt; + if (wot.wtViewport.rowsVisibleCalculator) { + return wot.wtTable.getLastVisibleRow(); + } + if (wot.wtViewport.rowsRenderCalculator) { + return wot.wtTable.getLastRenderedRow(); + } + return -1; + }, + clearCache: function() { + this.heights.length = 0; + }, + clearCacheByRange: function(range) { + var $__5 = this; + if (typeof range === 'number') { + range = { + from: range, + to: range + }; + } + rangeEach(Math.min(range.from, range.to), Math.max(range.from, range.to), (function(row) { + return $__5.heights[row] = void 0; + })); + }, + isNeedRecalculate: function() { + return arrayFilter(this.heights, (function(item) { + return (item === void 0); + })).length ? true : false; + }, + onBeforeRender: function() { + var force = this.hot.renderCall; + this.calculateRowsHeight({ + from: this.getFirstVisibleRow(), + to: this.getLastVisibleRow() + }, void 0, force); + if (this.isNeedRecalculate() && !this.inProgress) { + this.calculateAllRowsHeight(); + } + }, + onBeforeRowMove: function(from, to) { + this.clearCacheByRange({ + from: from, + to: to + }); + this.calculateAllRowsHeight(); + }, + onBeforeRowResize: function(row, size, isDblClick) { + if (isDblClick) { + this.calculateRowsHeight(row, void 0, true); + size = this.getRowHeight(row); + } + return size; + }, + onAfterLoadData: function() { + var $__5 = this; + if (this.hot.view) { + this.recalculateAllRowsHeight(); + } else { + setTimeout((function() { + if ($__5.hot) { + $__5.recalculateAllRowsHeight(); + } + }), 0); + } + }, + onBeforeChange: function(changes) { + var range = null; + if (changes.length === 1) { + range = changes[0][0]; + } else if (changes.length > 1) { + range = { + from: changes[0][0], + to: changes[changes.length - 1][0] + }; + } + if (range !== null) { + this.clearCacheByRange(range); + } + }, + destroy: function() { + this.ghostTable.clean(); + $traceurRuntime.superGet(this, $AutoRowSize.prototype, "destroy").call(this); + } +}, { + get CALCULATION_STEP() { + return 50; + }, + get SYNC_CALCULATION_LIMIT() { + return 500; + } +}, BasePlugin); +; +registerPlugin('autoRowSize', AutoRowSize); + +//# +},{"_base.js":46,"helpers.js":42,"plugins.js":45,"utils/ghostTable.js":81,"utils/samplesGenerator.js":82}],49:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + Autofill: {get: function() { + return Autofill; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47_eventManager_46_js__, + $___46__46__47__46__46__47_plugins_46_js__, + $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__; +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var eventManagerObject = ($___46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47_eventManager_46_js__}).eventManager; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +var WalkontableCellCoords = ($___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ = require("3rdparty/walkontable/src/cell/coords.js"), $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__.__esModule && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ || {default: $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__}).WalkontableCellCoords; +; +function getDeltas(start, end, data, direction) { + var rlength = data.length, + clength = data ? data[0].length : 0, + deltas = [], + arr = [], + diffRow, + diffCol, + startValue, + endValue, + delta; + diffRow = end.row - start.row; + diffCol = end.col - start.col; + if (['down', 'up'].indexOf(direction) !== -1) { + for (var col = 0; col <= diffCol; col++) { + startValue = parseInt(data[0][col], 10); + endValue = parseInt(data[rlength - 1][col], 10); + delta = (direction === 'down' ? (endValue - startValue) : (startValue - endValue)) / (rlength - 1) || 0; + arr.push(delta); + } + deltas.push(arr); + } + if (['right', 'left'].indexOf(direction) !== -1) { + for (var row = 0; row <= diffRow; row++) { + startValue = parseInt(data[row][0], 10); + endValue = parseInt(data[row][clength - 1], 10); + delta = (direction === 'right' ? (endValue - startValue) : (startValue - endValue)) / (clength - 1) || 0; + arr = []; + arr.push(delta); + deltas.push(arr); + } + } + return deltas; +} +function Autofill(instance) { + var _this = this, + mouseDownOnCellCorner = false, + wtOnCellCornerMouseDown, + wtOnCellMouseOver, + eventManager; + this.instance = instance; + this.addingStarted = false; + eventManager = eventManagerObject(instance); + function mouseUpCallback(event) { + if (!instance.autofill) { + return true; + } + if (instance.autofill.handle && instance.autofill.handle.isDragged) { + if (instance.autofill.handle.isDragged > 1) { + instance.autofill.apply(); + } + instance.autofill.handle.isDragged = 0; + mouseDownOnCellCorner = false; + } + } + function mouseMoveCallback(event) { + var tableBottom, + tableRight; + if (!_this.instance.autofill) { + return false; + } + tableBottom = dom.offset(_this.instance.table).top - (window.pageYOffset || document.documentElement.scrollTop) + dom.outerHeight(_this.instance.table); + tableRight = dom.offset(_this.instance.table).left - (window.pageXOffset || document.documentElement.scrollLeft) + dom.outerWidth(_this.instance.table); + if (_this.addingStarted === false && _this.instance.autofill.handle.isDragged > 0 && event.clientY > tableBottom && event.clientX <= tableRight) { + _this.instance.mouseDragOutsideBottom = true; + _this.addingStarted = true; + } else { + _this.instance.mouseDragOutsideBottom = false; + } + if (_this.addingStarted === false && _this.instance.autofill.handle.isDragged > 0 && event.clientY <= tableBottom && event.clientX > tableRight) { + _this.instance.mouseDragOutsideRight = true; + _this.addingStarted = true; + } else { + _this.instance.mouseDragOutsideRight = false; + } + if (_this.instance.mouseDragOutsideBottom) { + setTimeout(function() { + _this.addingStarted = false; + _this.instance.alter('insert_row'); + }, 200); + } + if (_this.instance.mouseDragOutsideRight) { + setTimeout(function() { + _this.addingStarted = false; + _this.instance.alter('insert_col', _this.instance.countCols()); + }, 200); + } + } + eventManager.addEventListener(document, 'mouseup', mouseUpCallback); + eventManager.addEventListener(document, 'mousemove', mouseMoveCallback); + wtOnCellCornerMouseDown = this.instance.view.wt.wtSettings.settings.onCellCornerMouseDown; + this.instance.view.wt.wtSettings.settings.onCellCornerMouseDown = function(event) { + instance.autofill.handle.isDragged = 1; + mouseDownOnCellCorner = true; + wtOnCellCornerMouseDown(event); + }; + wtOnCellMouseOver = this.instance.view.wt.wtSettings.settings.onCellMouseOver; + this.instance.view.wt.wtSettings.settings.onCellMouseOver = function(event, coords, TD, wt) { + if (instance.autofill && mouseDownOnCellCorner && !instance.view.isMouseDown() && instance.autofill.handle && instance.autofill.handle.isDragged) { + instance.autofill.handle.isDragged++; + instance.autofill.showBorder(coords); + instance.autofill.checkIfNewRowNeeded(); + } + wtOnCellMouseOver(event, coords, TD, wt); + }; + this.instance.view.wt.wtSettings.settings.onCellCornerDblClick = function() { + instance.autofill.selectAdjacent(); + }; +} +Autofill.prototype.init = function() { + this.handle = {}; +}; +Autofill.prototype.disable = function() { + this.handle.disabled = true; +}; +Autofill.prototype.selectAdjacent = function() { + var select, + data, + r, + maxR, + c; + if (this.instance.selection.isMultiple()) { + select = this.instance.view.wt.selections.area.getCorners(); + } else { + select = this.instance.view.wt.selections.current.getCorners(); + } + data = this.instance.getData(); + rows: for (r = select[2] + 1; r < this.instance.countRows(); r++) { + for (c = select[1]; c <= select[3]; c++) { + if (data[r][c]) { + break rows; + } + } + if (!!data[r][select[1] - 1] || !!data[r][select[3] + 1]) { + maxR = r; + } + } + if (maxR) { + this.instance.view.wt.selections.fill.clear(); + this.instance.view.wt.selections.fill.add(new WalkontableCellCoords(select[0], select[1])); + this.instance.view.wt.selections.fill.add(new WalkontableCellCoords(maxR, select[3])); + this.apply(); + } +}; +Autofill.prototype.apply = function() { + var drag, + select, + start, + end, + _data, + direction, + deltas, + selRange; + this.handle.isDragged = 0; + drag = this.instance.view.wt.selections.fill.getCorners(); + if (!drag) { + return; + } + this.instance.view.wt.selections.fill.clear(); + if (this.instance.selection.isMultiple()) { + select = this.instance.view.wt.selections.area.getCorners(); + } else { + select = this.instance.view.wt.selections.current.getCorners(); + } + Handsontable.hooks.run(this.instance, 'afterAutofillApplyValues', select, drag); + if (drag[0] === select[0] && drag[1] < select[1]) { + direction = 'left'; + start = new WalkontableCellCoords(drag[0], drag[1]); + end = new WalkontableCellCoords(drag[2], select[1] - 1); + } else if (drag[0] === select[0] && drag[3] > select[3]) { + direction = 'right'; + start = new WalkontableCellCoords(drag[0], select[3] + 1); + end = new WalkontableCellCoords(drag[2], drag[3]); + } else if (drag[0] < select[0] && drag[1] === select[1]) { + direction = 'up'; + start = new WalkontableCellCoords(drag[0], drag[1]); + end = new WalkontableCellCoords(select[0] - 1, drag[3]); + } else if (drag[2] > select[2] && drag[1] === select[1]) { + direction = 'down'; + start = new WalkontableCellCoords(select[2] + 1, drag[1]); + end = new WalkontableCellCoords(drag[2], drag[3]); + } + if (start && start.row > -1 && start.col > -1) { + selRange = { + from: this.instance.getSelectedRange().from, + to: this.instance.getSelectedRange().to + }; + _data = this.instance.getData(selRange.from.row, selRange.from.col, selRange.to.row, selRange.to.col); + deltas = getDeltas(start, end, _data, direction); + Handsontable.hooks.run(this.instance, 'beforeAutofill', start, end, _data); + this.instance.populateFromArray(start.row, start.col, _data, end.row, end.col, 'autofill', null, direction, deltas); + this.instance.selection.setRangeStart(new WalkontableCellCoords(drag[0], drag[1])); + this.instance.selection.setRangeEnd(new WalkontableCellCoords(drag[2], drag[3])); + } else { + this.instance.selection.refreshBorders(); + } +}; +Autofill.prototype.showBorder = function(coords) { + var topLeft = this.instance.getSelectedRange().getTopLeftCorner(), + bottomRight = this.instance.getSelectedRange().getBottomRightCorner(); + if (this.instance.getSettings().fillHandle !== 'horizontal' && (bottomRight.row < coords.row || topLeft.row > coords.row)) { + coords = new WalkontableCellCoords(coords.row, bottomRight.col); + } else if (this.instance.getSettings().fillHandle !== 'vertical') { + coords = new WalkontableCellCoords(bottomRight.row, coords.col); + } else { + return; + } + this.instance.view.wt.selections.fill.clear(); + this.instance.view.wt.selections.fill.add(this.instance.getSelectedRange().from); + this.instance.view.wt.selections.fill.add(this.instance.getSelectedRange().to); + this.instance.view.wt.selections.fill.add(coords); + this.instance.view.render(); +}; +Autofill.prototype.checkIfNewRowNeeded = function() { + var fillCorners, + selection, + tableRows = this.instance.countRows(), + that = this; + if (this.instance.view.wt.selections.fill.cellRange && this.addingStarted === false) { + selection = this.instance.getSelected(); + fillCorners = this.instance.view.wt.selections.fill.getCorners(); + if (selection[2] < tableRows - 1 && fillCorners[2] === tableRows - 1) { + this.addingStarted = true; + this.instance._registerTimeout(setTimeout(function() { + that.instance.alter('insert_row'); + that.addingStarted = false; + }, 200)); + } + } +}; +Handsontable.hooks.add('afterInit', function() { + var autofill = new Autofill(this); + if (typeof this.getSettings().fillHandle !== 'undefined') { + if (autofill.handle && this.getSettings().fillHandle === false) { + autofill.disable(); + } else if (!autofill.handle && this.getSettings().fillHandle !== false) { + this.autofill = autofill; + this.autofill.init(); + } + } +}); +Handsontable.Autofill = Autofill; + +//# +},{"3rdparty/walkontable/src/cell/coords.js":5,"dom.js":27,"eventManager.js":41,"plugins.js":45}],50:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + default: {get: function() { + return $__default; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47_eventManager_46_js__, + $___46__46__47__95_base_46_js__, + $___46__46__47__46__46__47_plugins_46_js__; +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var eventManagerObject = ($___46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47_eventManager_46_js__}).eventManager; +var BasePlugin = ($___46__46__47__95_base_46_js__ = require("_base.js"), $___46__46__47__95_base_46_js__ && $___46__46__47__95_base_46_js__.__esModule && $___46__46__47__95_base_46_js__ || {default: $___46__46__47__95_base_46_js__}).default; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +Handsontable.hooks.register('beforeColumnSort'); +Handsontable.hooks.register('afterColumnSort'); +var ColumnSorting = function ColumnSorting(hotInstance) { + $traceurRuntime.superConstructor($ColumnSorting).call(this, hotInstance); + this.sortIndicators = []; +}; +var $ColumnSorting = ColumnSorting; +($traceurRuntime.createClass)(ColumnSorting, { + isEnabled: function() { + return !!(this.hot.getSettings().columnSorting); + }, + enablePlugin: function() { + var $__3 = this; + if (this.enabled) { + return; + } + var _this = this; + this.hot.sortIndex = []; + this.hot.sort = function() { + var args = Array.prototype.slice.call(arguments); + return _this.sortByColumn.apply(_this, args); + }; + if (typeof this.hot.getSettings().observeChanges === 'undefined') { + this.enableObserveChangesPlugin(); + } + this.bindColumnSortingAfterClick(); + this.addHook('modifyRow', (function(row) { + return $__3.translateRow(row); + })); + this.addHook('afterUpdateSettings', (function() { + return $__3.onAfterUpdateSettings(); + })); + this.addHook('afterGetColHeader', (function(col, TH) { + return $__3.getColHeader(col, TH); + })); + this.addHook('afterCreateRow', function() { + _this.afterCreateRow.apply(_this, arguments); + }); + this.addHook('afterRemoveRow', function() { + _this.afterRemoveRow.apply(_this, arguments); + }); + this.addHook('afterInit', (function() { + return $__3.sortBySettings(); + })); + this.addHook('afterLoadData', (function() { + $__3.hot.sortIndex = []; + if ($__3.hot.view) { + $__3.sortBySettings(); + } + })); + if (this.hot.view) { + this.sortBySettings(); + } + $traceurRuntime.superGet(this, $ColumnSorting.prototype, "enablePlugin").call(this); + }, + disablePlugin: function() { + this.hot.sort = void 0; + $traceurRuntime.superGet(this, $ColumnSorting.prototype, "disablePlugin").call(this); + }, + onAfterUpdateSettings: function() { + this.sortBySettings(); + }, + sortBySettings: function() { + var sortingSettings = this.hot.getSettings().columnSorting; + var loadedSortingState = this.loadSortingState(); + var sortingColumn; + var sortingOrder; + if (typeof loadedSortingState !== 'undefined') { + sortingColumn = loadedSortingState.sortColumn; + sortingOrder = loadedSortingState.sortOrder; + } else { + sortingColumn = sortingSettings.column; + sortingOrder = sortingSettings.sortOrder; + } + this.sortByColumn(sortingColumn, sortingOrder); + }, + setSortingColumn: function(col, order) { + if (typeof col == 'undefined') { + this.hot.sortColumn = void 0; + this.hot.sortOrder = void 0; + return; + } else if (this.hot.sortColumn === col && typeof order == 'undefined') { + if (this.hot.sortOrder === false) { + this.hot.sortOrder = void 0; + } else { + this.hot.sortOrder = !this.hot.sortOrder; + } + } else { + this.hot.sortOrder = typeof order != 'undefined' ? order : true; + } + this.hot.sortColumn = col; + }, + sortByColumn: function(col, order) { + this.setSortingColumn(col, order); + if (typeof this.hot.sortColumn == 'undefined') { + return; + } + Handsontable.hooks.run(this.hot, 'beforeColumnSort', this.hot.sortColumn, this.hot.sortOrder); + this.sort(); + this.hot.render(); + this.saveSortingState(); + Handsontable.hooks.run(this.hot, 'afterColumnSort', this.hot.sortColumn, this.hot.sortOrder); + }, + saveSortingState: function() { + var sortingState = {}; + if (typeof this.hot.sortColumn != 'undefined') { + sortingState.sortColumn = this.hot.sortColumn; + } + if (typeof this.hot.sortOrder != 'undefined') { + sortingState.sortOrder = this.hot.sortOrder; + } + if (sortingState.hasOwnProperty('sortColumn') || sortingState.hasOwnProperty('sortOrder')) { + Handsontable.hooks.run(this.hot, 'persistentStateSave', 'columnSorting', sortingState); + } + }, + loadSortingState: function() { + var storedState = {}; + Handsontable.hooks.run(this.hot, 'persistentStateLoad', 'columnSorting', storedState); + return storedState.value; + }, + bindColumnSortingAfterClick: function() { + if (this.bindedSortEvent) { + return; + } + var eventManager = eventManagerObject(this.hot), + _this = this; + this.bindedSortEvent = true; + eventManager.addEventListener(this.hot.rootElement, 'click', function(e) { + if (dom.hasClass(e.target, 'columnSorting')) { + var col = getColumn(e.target); + if (col !== this.lastSortedColumn) { + _this.sortOrderClass = 'ascending'; + } else { + switch (_this.hot.sortOrder) { + case void 0: + _this.sortOrderClass = 'ascending'; + break; + case true: + _this.sortOrderClass = 'descending'; + break; + case false: + _this.sortOrderClass = void 0; + } + } + this.lastSortedColumn = col; + _this.sortByColumn(col); + } + }); + function countRowHeaders() { + var THs = _this.hot.view.TBODY.querySelector('tr').querySelectorAll('th'); + return THs.length; + } + function getColumn(target) { + var TH = dom.closest(target, 'TH'); + return dom.index(TH) - countRowHeaders(); + } + }, + enableObserveChangesPlugin: function() { + var _this = this; + this.hot._registerTimeout(setTimeout(function() { + _this.hot.updateSettings({observeChanges: true}); + }, 0)); + }, + defaultSort: function(sortOrder) { + return function(a, b) { + if (typeof a[1] == "string") { + a[1] = a[1].toLowerCase(); + } + if (typeof b[1] == "string") { + b[1] = b[1].toLowerCase(); + } + if (a[1] === b[1]) { + return 0; + } + if (a[1] === null || a[1] === "") { + return 1; + } + if (b[1] === null || b[1] === "") { + return -1; + } + if (a[1] < b[1]) { + return sortOrder ? -1 : 1; + } + if (a[1] > b[1]) { + return sortOrder ? 1 : -1; + } + return 0; + }; + }, + dateSort: function(sortOrder) { + return function(a, b) { + if (a[1] === b[1]) { + return 0; + } + if (a[1] === null) { + return 1; + } + if (b[1] === null) { + return -1; + } + var aDate = new Date(a[1]); + var bDate = new Date(b[1]); + if (aDate < bDate) { + return sortOrder ? -1 : 1; + } + if (aDate > bDate) { + return sortOrder ? 1 : -1; + } + return 0; + }; + }, + sort: function() { + if (typeof this.hot.sortOrder == 'undefined') { + return; + } + var colMeta, + sortFunction; + this.hot.sortingEnabled = false; + this.hot.sortIndex.length = 0; + var colOffset = this.hot.colOffset(); + for (var i = 0, + ilen = this.hot.countRows() - this.hot.getSettings().minSpareRows; i < ilen; i++) { + this.hot.sortIndex.push([i, this.hot.getDataAtCell(i, this.hot.sortColumn + colOffset)]); + } + colMeta = this.hot.getCellMeta(0, this.hot.sortColumn); + this.sortIndicators[this.hot.sortColumn] = colMeta.sortIndicator; + switch (colMeta.type) { + case 'date': + sortFunction = this.dateSort; + break; + default: + sortFunction = this.defaultSort; + } + this.hot.sortIndex.sort(sortFunction(this.hot.sortOrder)); + for (var i = this.hot.sortIndex.length; i < this.hot.countRows(); i++) { + this.hot.sortIndex.push([i, this.hot.getDataAtCell(i, this.hot.sortColumn + colOffset)]); + } + this.hot.sortingEnabled = true; + }, + translateRow: function(row) { + if (this.hot.sortingEnabled && (typeof this.hot.sortOrder !== 'undefined') && this.hot.sortIndex && this.hot.sortIndex.length && this.hot.sortIndex[row]) { + return this.hot.sortIndex[row][0]; + } + return row; + }, + untranslateRow: function(row) { + if (this.hot.sortingEnabled && this.hot.sortIndex && this.hot.sortIndex.length) { + for (var i = 0; i < this.hot.sortIndex.length; i++) { + if (this.hot.sortIndex[i][0] == row) { + return i; + } + } + } + }, + getColHeader: function(col, TH) { + var headerLink = TH.querySelector('.colHeader'); + if (this.hot.getSettings().columnSorting && col >= 0) { + dom.addClass(headerLink, 'columnSorting'); + } + dom.removeClass(headerLink, 'descending'); + dom.removeClass(headerLink, 'ascending'); + if (this.sortIndicators[col]) { + if (col === this.hot.sortColumn) { + if (this.sortOrderClass === 'ascending') { + dom.addClass(headerLink, 'ascending'); + } else if (this.sortOrderClass === 'descending') { + dom.addClass(headerLink, 'descending'); + } + } + } + }, + isSorted: function() { + return typeof this.hot.sortColumn != 'undefined'; + }, + afterCreateRow: function(index, amount) { + if (!this.isSorted()) { + return; + } + for (var i = 0; i < this.hot.sortIndex.length; i++) { + if (this.hot.sortIndex[i][0] >= index) { + this.hot.sortIndex[i][0] += amount; + } + } + for (var i = 0; i < amount; i++) { + this.hot.sortIndex.splice(index + i, 0, [index + i, this.hot.getData()[index + i][this.hot.sortColumn + this.hot.colOffset()]]); + } + this.saveSortingState(); + }, + afterRemoveRow: function(index, amount) { + if (!this.isSorted()) { + return; + } + var physicalRemovedIndex = this.translateRow(index); + this.hot.sortIndex.splice(index, amount); + for (var i = 0; i < this.hot.sortIndex.length; i++) { + if (this.hot.sortIndex[i][0] > physicalRemovedIndex) { + this.hot.sortIndex[i][0] -= amount; + } + } + this.saveSortingState(); + } +}, {}, BasePlugin); +var $__default = ColumnSorting; +registerPlugin('columnSorting', ColumnSorting); + +//# +},{"_base.js":46,"dom.js":27,"eventManager.js":41,"plugins.js":45}],51:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + CommentEditor: {get: function() { + return CommentEditor; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_dom_46_js__; +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var CommentEditor = function CommentEditor() { + this.editor = this.createEditor(); + this.editorStyle = this.editor.style; + this.editorStyle.position = 'absolute'; + this.editorStyle.zIndex = 100; + this.hide(); +}; +var $CommentEditor = CommentEditor; +($traceurRuntime.createClass)(CommentEditor, { + setPosition: function(x, y) { + this.editorStyle.left = x + 'px'; + this.editorStyle.top = y + 'px'; + }, + show: function() { + this.editorStyle.display = 'block'; + }, + hide: function() { + this.editorStyle.display = 'none'; + }, + isVisible: function() { + return this.editorStyle.display === 'block'; + }, + setValue: function() { + var value = arguments[0] !== (void 0) ? arguments[0] : ''; + value = value || ''; + this.getInputElement().value = value; + }, + getValue: function() { + return this.getInputElement().value; + }, + isFocused: function() { + return document.activeElement === this.getInputElement(); + }, + focus: function() { + this.getInputElement().focus(); + }, + createEditor: function() { + var container = document.querySelector('.' + $CommentEditor.CLASS_EDITOR_CONTAINER); + var editor; + var textArea; + if (!container) { + container = document.createElement('div'); + dom.addClass(container, $CommentEditor.CLASS_EDITOR_CONTAINER); + document.body.appendChild(container); + } + editor = document.createElement('div'); + dom.addClass(editor, $CommentEditor.CLASS_EDITOR); + textArea = document.createElement('textarea'); + dom.addClass(textArea, $CommentEditor.CLASS_INPUT); + editor.appendChild(textArea); + container.appendChild(editor); + return editor; + }, + getInputElement: function() { + return this.editor.querySelector('.' + $CommentEditor.CLASS_INPUT); + }, + destroy: function() { + this.editor.parentNode.removeChild(this.editor); + this.editor = null; + this.editorStyle = null; + } +}, { + get CLASS_EDITOR_CONTAINER() { + return 'htCommentsContainer'; + }, + get CLASS_EDITOR() { + return 'htComments'; + }, + get CLASS_INPUT() { + return 'htCommentTextArea'; + }, + get CLASS_CELL() { + return 'htCommentCell'; + } +}); +; + +//# +},{"dom.js":27}],52:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + Comments: {get: function() { + return Comments; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47_eventManager_46_js__, + $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__, + $___46__46__47__46__46__47_plugins_46_js__, + $___46__46__47__95_base_46_js__, + $__commentEditor_46_js__; +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var EventManager = ($___46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47_eventManager_46_js__}).EventManager; +var WalkontableCellCoords = ($___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ = require("3rdparty/walkontable/src/cell/coords.js"), $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__.__esModule && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ || {default: $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__}).WalkontableCellCoords; +var $__2 = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}), + registerPlugin = $__2.registerPlugin, + getPlugin = $__2.getPlugin; +var BasePlugin = ($___46__46__47__95_base_46_js__ = require("_base.js"), $___46__46__47__95_base_46_js__ && $___46__46__47__95_base_46_js__.__esModule && $___46__46__47__95_base_46_js__ || {default: $___46__46__47__95_base_46_js__}).default; +var CommentEditor = ($__commentEditor_46_js__ = require("commentEditor.js"), $__commentEditor_46_js__ && $__commentEditor_46_js__.__esModule && $__commentEditor_46_js__ || {default: $__commentEditor_46_js__}).CommentEditor; +var Comments = function Comments(hotInstance) { + $traceurRuntime.superConstructor($Comments).call(this, hotInstance); + this.editor = null; + this.eventManager = null; + this.range = {}; + this.mouseDown = false; + this.contextMenuEvent = false; + this.timer = null; +}; +var $Comments = Comments; +($traceurRuntime.createClass)(Comments, { + isEnabled: function() { + return this.hot.getSettings().comments; + }, + enablePlugin: function() { + var $__5 = this; + if (this.enabled) { + return; + } + if (!this.editor) { + this.editor = new CommentEditor(); + } + if (!this.eventManager) { + this.eventManager = new EventManager(this); + } + this.addHook('afterContextMenuDefaultOptions', (function(options) { + return $__5.addToContextMenu(options); + })); + this.addHook('afterRenderer', (function(TD, row, col, prop, value, cellProperties) { + return $__5.onAfterRenderer(TD, cellProperties); + })); + this.addHook('afterScrollVertically', (function() { + return $__5.refreshEditorPosition(); + })); + this.addHook('afterColumnResize', (function() { + return $__5.refreshEditorPosition(); + })); + this.addHook('afterRowResize', (function() { + return $__5.refreshEditorPosition(); + })); + this.registerListeners(); + $traceurRuntime.superGet(this, $Comments.prototype, "enablePlugin").call(this); + }, + registerListeners: function() { + var $__5 = this; + this.eventManager.addEventListener(document, 'mouseover', (function(event) { + return $__5.onMouseOver(event); + })); + this.eventManager.addEventListener(document, 'mousedown', (function(event) { + return $__5.onMouseDown(event); + })); + this.eventManager.addEventListener(document, 'mousemove', (function(event) { + return $__5.onMouseMove(event); + })); + this.eventManager.addEventListener(document, 'mouseup', (function(event) { + return $__5.onMouseUp(event); + })); + this.eventManager.addEventListener(this.editor.getInputElement(), 'blur', (function(event) { + return $__5.onEditorBlur(event); + })); + }, + setRange: function(range) { + this.range = range; + }, + clearRange: function() { + this.range = {}; + }, + targetIsCellWithComment: function(event) { + return dom.hasClass(event.target, 'htCommentCell') && dom.closest(event.target, [this.hot.rootElement]) ? true : false; + }, + targetIsCommentTextArea: function(event) { + return this.editor.getInputElement() === event.target; + }, + saveComment: function() { + if (!this.range.from) { + throw new Error('Before using this method, first set cell range (hot.getPlugin("comment").setRange())'); + } + var comment = this.editor.getValue(); + var row = this.range.from.row; + var col = this.range.from.col; + this.hot.setCellMeta(row, col, 'comment', comment); + this.hot.render(); + }, + saveCommentAtCell: function(row, col) { + this.setRange({from: new WalkontableCellCoords(row, col)}); + this.saveComment(); + }, + removeComment: function() { + if (!this.range.from) { + throw new Error('Before using this method, first set cell range (hot.getPlugin("comment").setRange())'); + } + this.hot.removeCellMeta(this.range.from.row, this.range.from.col, 'comment'); + this.hot.render(); + this.hide(); + }, + removeCommentAtCell: function(row, col) { + this.setRange({from: new WalkontableCellCoords(row, col)}); + this.removeComment(); + }, + show: function() { + if (!this.range.from) { + throw new Error('Before using this method, first set cell range (hot.getPlugin("comment").setRange())'); + } + var meta = this.hot.getCellMeta(this.range.from.row, this.range.from.col); + this.refreshEditorPosition(true); + this.editor.setValue(meta.comment || ''); + this.editor.show(); + return true; + }, + showAtCell: function(row, col) { + this.setRange({from: new WalkontableCellCoords(row, col)}); + return this.show(); + }, + hide: function() { + this.editor.hide(); + }, + refreshEditorPosition: function() { + var force = arguments[0] !== (void 0) ? arguments[0] : false; + if (!force && (!this.range.from || !this.editor.isVisible())) { + return; + } + var TD = this.hot.view.wt.wtTable.getCell(this.range.from); + var offset = dom.offset(TD); + var lastColWidth = this.hot.getColWidth(this.range.from.col); + var cellTopOffset = offset.top; + var cellLeftOffset = offset.left; + var verticalCompensation = 0; + var horizontalCompensation = 0; + if (this.hot.view.wt.wtViewport.hasVerticalScroll()) { + cellTopOffset = cellTopOffset - this.hot.view.wt.wtOverlays.topOverlay.getScrollPosition(); + verticalCompensation = 20; + } + if (this.hot.view.wt.wtViewport.hasHorizontalScroll()) { + cellLeftOffset = cellLeftOffset - this.hot.view.wt.wtOverlays.leftOverlay.getScrollPosition(); + horizontalCompensation = 20; + } + var x = cellLeftOffset + lastColWidth; + var y = cellTopOffset; + var rect = this.hot.view.wt.wtTable.holder.getBoundingClientRect(); + var holderPos = { + left: rect.left + dom.getWindowScrollLeft() + horizontalCompensation, + right: rect.right + dom.getWindowScrollLeft() - 15, + top: rect.top + dom.getWindowScrollTop() + verticalCompensation, + bottom: rect.bottom + dom.getWindowScrollTop() + }; + if (x <= holderPos.left || x > holderPos.right || y <= holderPos.top || y > holderPos.bottom) { + this.hide(); + } else { + this.editor.setPosition(x, y); + } + }, + onMouseDown: function(event) { + this.mouseDown = true; + if (!this.hot.view || !this.hot.view.wt) { + return; + } + if (!this.contextMenuEvent && !this.targetIsCommentTextArea(event) && !this.targetIsCellWithComment(event)) { + this.hide(); + } + this.contextMenuEvent = false; + }, + onMouseOver: function(event) { + if (this.mouseDown || this.editor.isFocused()) { + return; + } + if (this.targetIsCellWithComment(event)) { + var coordinates = this.hot.view.wt.wtTable.getCoords(event.target); + var range = {from: new WalkontableCellCoords(coordinates.row, coordinates.col)}; + this.setRange(range); + this.show(); + } else if (!this.targetIsCommentTextArea(event) && !this.editor.isFocused()) { + this.hide(); + } + }, + onMouseMove: function(event) { + var $__5 = this; + if (this.targetIsCommentTextArea(event)) { + this.mouseDown = true; + clearTimeout(this.timer); + this.timer = setTimeout((function() { + $__5.mouseDown = false; + }), 200); + } + }, + onMouseUp: function(event) { + this.mouseDown = false; + }, + onAfterRenderer: function(TD, cellProperties) { + if (cellProperties.comment) { + dom.addClass(TD, cellProperties.commentedCellClassName); + } + }, + onEditorBlur: function(event) { + this.saveComment(); + }, + checkSelectionCommentsConsistency: function() { + var hasComment = false; + var cell = this.hot.getSelectedRange().from; + if (this.hot.getCellMeta(cell.row, cell.col).comment) { + hasComment = true; + } + return hasComment; + }, + onContextMenuAddComment: function() { + var $__5 = this; + var coords = this.hot.getSelectedRange(); + this.contextMenuEvent = true; + this.setRange({from: coords.from}); + this.show(); + setTimeout((function() { + if ($__5.hot) { + $__5.hot.deselectCell(); + $__5.editor.focus(); + } + }), 10); + }, + onContextMenuRemoveComment: function(key, selection) { + this.contextMenuEvent = true; + this.removeCommentAtCell(selection.start.row, selection.start.col); + }, + addToContextMenu: function(defaultOptions) { + var $__5 = this; + defaultOptions.items.push(Handsontable.ContextMenu.SEPARATOR, { + key: 'commentsAddEdit', + name: (function() { + return $__5.checkSelectionCommentsConsistency() ? 'Edit Comment' : 'Add Comment'; + }), + callback: (function() { + return $__5.onContextMenuAddComment(); + }), + disabled: function() { + return false; + } + }, { + key: 'commentsRemove', + name: function() { + return 'Delete Comment'; + }, + callback: (function(key, selection) { + return $__5.onContextMenuRemoveComment(key, selection); + }), + disabled: (function() { + return !$__5.checkSelectionCommentsConsistency(); + }) + }); + }, + destroy: function() { + if (this.editor) { + this.editor.destroy(); + } + $traceurRuntime.superGet(this, $Comments.prototype, "destroy").call(this); + } +}, {}, BasePlugin); +; +registerPlugin('comments', Comments); + +//# +},{"3rdparty/walkontable/src/cell/coords.js":5,"_base.js":46,"commentEditor.js":51,"dom.js":27,"eventManager.js":41,"plugins.js":45}],53:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + ContextMenu: {get: function() { + return ContextMenu; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_helpers_46_js__, + $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47_eventManager_46_js__, + $___46__46__47__46__46__47_plugins_46_js__; +var helper = ($___46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47_helpers_46_js__}); +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var eventManagerObject = ($___46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47_eventManager_46_js__}).eventManager; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +; +function ContextMenu(instance, customOptions) { + this.instance = instance; + var contextMenu = this; + contextMenu.menus = []; + contextMenu.htMenus = {}; + contextMenu.triggerRows = []; + contextMenu.eventManager = eventManagerObject(contextMenu); + this.enabled = true; + this.instance.addHook('afterDestroy', function() { + contextMenu.destroy(); + }); + function getValidSelection() { + var selected = instance.getSelected(); + if (!selected) { + return null; + } + if (selected[0] < 0) { + return null; + } + if (instance.countRows() >= instance.getSettings().maxRows) { + return null; + } + return selected; + } + this.defaultOptions = {items: [{ + key: 'row_above', + name: 'Insert row above', + callback: function(key, selection) { + this.alter("insert_row", selection.start.row); + }, + disabled: function() { + var selected = getValidSelection(); + if (!selected) { + return true; + } + var entireColumnSelection = [0, selected[1], this.countRows() - 1, selected[1]]; + return entireColumnSelection.join(',') === selected.join(','); + } + }, { + key: 'row_below', + name: 'Insert row below', + callback: function(key, selection) { + this.alter("insert_row", selection.end.row + 1); + }, + disabled: function() { + var selected = getValidSelection(); + if (!selected) { + return true; + } + var entireColumnSelection = [0, selected[1], this.countRows() - 1, selected[1]]; + return entireColumnSelection.join(',') === selected.join(','); + } + }, ContextMenu.SEPARATOR, { + key: 'col_left', + name: 'Insert column on the left', + callback: function(key, selection) { + this.alter("insert_col", selection.start.col); + }, + disabled: function() { + if (!this.isColumnModificationAllowed()) { + return true; + } + var selected = this.getSelected(), + entireRowSelection = [selected[0], 0, selected[0], this.countCols() - 1], + rowSelected = entireRowSelection.join(',') == selected.join(','); + return this.getSelected()[1] < 0 || this.countCols() >= this.getSettings().maxCols || rowSelected; + } + }, { + key: 'col_right', + name: 'Insert column on the right', + callback: function(key, selection) { + this.alter("insert_col", selection.end.col + 1); + }, + disabled: function() { + if (!this.isColumnModificationAllowed()) { + return true; + } + var selected = this.getSelected(), + entireRowSelection = [selected[0], 0, selected[0], this.countCols() - 1], + rowSelected = entireRowSelection.join(',') == selected.join(','); + return selected[1] < 0 || this.countCols() >= this.getSettings().maxCols || rowSelected; + } + }, ContextMenu.SEPARATOR, { + key: 'remove_row', + name: 'Remove row', + callback: function(key, selection) { + var amount = selection.end.row - selection.start.row + 1; + this.alter("remove_row", selection.start.row, amount); + }, + disabled: function() { + var selected = getValidSelection(); + if (!selected) { + return true; + } + var entireColumnSelection = [0, selected[1], this.countRows() - 1, selected[1]]; + return entireColumnSelection.join(',') === selected.join(','); + } + }, { + key: 'remove_col', + name: 'Remove column', + callback: function(key, selection) { + var amount = selection.end.col - selection.start.col + 1; + this.alter("remove_col", selection.start.col, amount); + }, + disabled: function() { + if (!this.isColumnModificationAllowed()) { + return true; + } + var selected = this.getSelected(), + entireRowSelection = [selected[0], 0, selected[0], this.countCols() - 1], + rowSelected = entireRowSelection.join(',') == selected.join(','); + return (selected[1] < 0 || rowSelected); + } + }, ContextMenu.SEPARATOR, { + key: 'undo', + name: 'Undo', + callback: function() { + this.undo(); + }, + disabled: function() { + return this.undoRedo && !this.undoRedo.isUndoAvailable(); + } + }, { + key: 'redo', + name: 'Redo', + callback: function() { + this.redo(); + }, + disabled: function() { + return this.undoRedo && !this.undoRedo.isRedoAvailable(); + } + }, ContextMenu.SEPARATOR, { + key: 'make_read_only', + name: function() { + var label = "Read only"; + var atLeastOneReadOnly = contextMenu.checkSelectionReadOnlyConsistency(this); + if (atLeastOneReadOnly) { + label = contextMenu.markSelected(label); + } + return label; + }, + callback: function() { + var atLeastOneReadOnly = contextMenu.checkSelectionReadOnlyConsistency(this); + var that = this; + this.getSelectedRange().forAll(function(r, c) { + that.getCellMeta(r, c).readOnly = atLeastOneReadOnly ? false : true; + }); + this.render(); + } + }, ContextMenu.SEPARATOR, { + key: 'alignment', + name: 'Alignment', + submenu: {items: [{ + name: function() { + var label = "Left"; + var hasClass = contextMenu.checkSelectionAlignment(this, 'htLeft'); + if (hasClass) { + label = contextMenu.markSelected(label); + } + return label; + }, + callback: function() { + align.call(this, this.getSelectedRange(), 'horizontal', 'htLeft'); + }, + disabled: false + }, { + name: function() { + var label = "Center"; + var hasClass = contextMenu.checkSelectionAlignment(this, 'htCenter'); + if (hasClass) { + label = contextMenu.markSelected(label); + } + return label; + }, + callback: function() { + align.call(this, this.getSelectedRange(), 'horizontal', 'htCenter'); + }, + disabled: false + }, { + name: function() { + var label = "Right"; + var hasClass = contextMenu.checkSelectionAlignment(this, 'htRight'); + if (hasClass) { + label = contextMenu.markSelected(label); + } + return label; + }, + callback: function() { + align.call(this, this.getSelectedRange(), 'horizontal', 'htRight'); + }, + disabled: false + }, { + name: function() { + var label = "Justify"; + var hasClass = contextMenu.checkSelectionAlignment(this, 'htJustify'); + if (hasClass) { + label = contextMenu.markSelected(label); + } + return label; + }, + callback: function() { + align.call(this, this.getSelectedRange(), 'horizontal', 'htJustify'); + }, + disabled: false + }, ContextMenu.SEPARATOR, { + name: function() { + var label = "Top"; + var hasClass = contextMenu.checkSelectionAlignment(this, 'htTop'); + if (hasClass) { + label = contextMenu.markSelected(label); + } + return label; + }, + callback: function() { + align.call(this, this.getSelectedRange(), 'vertical', 'htTop'); + }, + disabled: false + }, { + name: function() { + var label = "Middle"; + var hasClass = contextMenu.checkSelectionAlignment(this, 'htMiddle'); + if (hasClass) { + label = contextMenu.markSelected(label); + } + return label; + }, + callback: function() { + align.call(this, this.getSelectedRange(), 'vertical', 'htMiddle'); + }, + disabled: false + }, { + name: function() { + var label = "Bottom"; + var hasClass = contextMenu.checkSelectionAlignment(this, 'htBottom'); + if (hasClass) { + label = contextMenu.markSelected(label); + } + return label; + }, + callback: function() { + align.call(this, this.getSelectedRange(), 'vertical', 'htBottom'); + }, + disabled: false + }]} + }]}; + contextMenu.options = {}; + helper.extend(contextMenu.options, this.options); + this.bindMouseEvents(); + this.markSelected = function(label) { + return "" + String.fromCharCode(10003) + "" + label; + }; + this.checkSelectionAlignment = function(hot, className) { + var hasAlignment = false; + if (hot.getSelectedRange()) { + hot.getSelectedRange().forAll(function(r, c) { + var metaClassName = hot.getCellMeta(r, c).className; + if (metaClassName && metaClassName.indexOf(className) != -1) { + hasAlignment = true; + return false; + } + }); + } + return hasAlignment; + }; + if (!this.instance.getSettings().allowInsertRow) { + var rowAboveIndex = findIndexByKey(this.defaultOptions.items, 'row_above'); + this.defaultOptions.items.splice(rowAboveIndex, 1); + var rowBelowIndex = findIndexByKey(this.defaultOptions.items, 'row_above'); + this.defaultOptions.items.splice(rowBelowIndex, 1); + this.defaultOptions.items.splice(rowBelowIndex, 1); + } + if (!this.instance.getSettings().allowInsertColumn) { + var colLeftIndex = findIndexByKey(this.defaultOptions.items, 'col_left'); + this.defaultOptions.items.splice(colLeftIndex, 1); + var colRightIndex = findIndexByKey(this.defaultOptions.items, 'col_right'); + this.defaultOptions.items.splice(colRightIndex, 1); + this.defaultOptions.items.splice(colRightIndex, 1); + } + var removeRow = false; + var removeCol = false; + var removeRowIndex, + removeColumnIndex; + if (!this.instance.getSettings().allowRemoveRow) { + removeRowIndex = findIndexByKey(this.defaultOptions.items, 'remove_row'); + this.defaultOptions.items.splice(removeRowIndex, 1); + removeRow = true; + } + if (!this.instance.getSettings().allowRemoveColumn) { + removeColumnIndex = findIndexByKey(this.defaultOptions.items, 'remove_col'); + this.defaultOptions.items.splice(removeColumnIndex, 1); + removeCol = true; + } + if (removeRow && removeCol) { + this.defaultOptions.items.splice(removeColumnIndex, 1); + } + this.checkSelectionReadOnlyConsistency = function(hot) { + var atLeastOneReadOnly = false; + if (hot.getSelectedRange()) { + hot.getSelectedRange().forAll(function(r, c) { + if (hot.getCellMeta(r, c).readOnly) { + atLeastOneReadOnly = true; + return false; + } + }); + } + return atLeastOneReadOnly; + }; + Handsontable.hooks.run(instance, 'afterContextMenuDefaultOptions', this.defaultOptions); +} +ContextMenu.prototype.createMenu = function(menuName, row) { + if (menuName) { + menuName = menuName.replace(/ /g, '_'); + menuName = 'htContextSubMenu_' + menuName; + } + var menu; + if (menuName) { + menu = document.querySelector('.htContextMenu.' + menuName); + } else { + menu = document.querySelector('.htContextMenu'); + } + if (!menu) { + menu = document.createElement('DIV'); + dom.addClass(menu, 'htContextMenu'); + if (menuName) { + dom.addClass(menu, menuName); + } + document.getElementsByTagName('body')[0].appendChild(menu); + } + if (this.menus.indexOf(menu) < 0) { + this.menus.push(menu); + row = row || 0; + this.triggerRows.push(row); + } + return menu; +}; +ContextMenu.prototype.bindMouseEvents = function() { + function contextMenuOpenListener(event) { + var settings = this.instance.getSettings(), + showRowHeaders = this.instance.getSettings().rowHeaders, + showColHeaders = this.instance.getSettings().colHeaders, + containsCornerHeader, + element, + items, + menu; + function isValidElement(element) { + return element.nodeName === 'TD' || element.parentNode.nodeName === 'TD'; + } + element = event.realTarget; + this.closeAll(); + event.preventDefault(); + helper.stopPropagation(event); + if (!(showRowHeaders || showColHeaders)) { + if (!isValidElement(element) && !(dom.hasClass(element, 'current') && dom.hasClass(element, 'wtBorder'))) { + return; + } + } else if (showRowHeaders && showColHeaders) { + containsCornerHeader = element.parentNode.querySelectorAll('.cornerHeader').length > 0; + if (containsCornerHeader) { + return; + } + } + menu = this.createMenu(); + items = this.getItems(settings.contextMenu); + this.show(menu, items); + this.setMenuPosition(event, menu); + this.eventManager.addEventListener(document.documentElement, 'mousedown', helper.proxy(ContextMenu.prototype.closeAll, this)); + } + var eventManager = eventManagerObject(this.instance); + eventManager.addEventListener(this.instance.rootElement, 'contextmenu', helper.proxy(contextMenuOpenListener, this)); +}; +ContextMenu.prototype.bindTableEvents = function() { + this._afterScrollCallback = function() {}; + this.instance.addHook('afterScrollVertically', this._afterScrollCallback); + this.instance.addHook('afterScrollHorizontally', this._afterScrollCallback); +}; +ContextMenu.prototype.unbindTableEvents = function() { + if (this._afterScrollCallback) { + this.instance.removeHook('afterScrollVertically', this._afterScrollCallback); + this.instance.removeHook('afterScrollHorizontally', this._afterScrollCallback); + this._afterScrollCallback = null; + } +}; +ContextMenu.prototype.performAction = function(event, hot) { + var contextMenu = this; + var selectedItemIndex = hot.getSelected()[0]; + var selectedItem = hot.getData()[selectedItemIndex]; + if (selectedItem.disabled === true || (typeof selectedItem.disabled == 'function' && selectedItem.disabled.call(this.instance) === true)) { + return; + } + if (!selectedItem.hasOwnProperty('submenu')) { + if (typeof selectedItem.callback != 'function') { + return; + } + var selRange = this.instance.getSelectedRange(); + if (selRange) { + var normalizedSelection = ContextMenu.utils.normalizeSelection(selRange); + selectedItem.callback.call(this.instance, selectedItem.key, normalizedSelection, event); + contextMenu.closeAll(); + } + } +}; +ContextMenu.prototype.unbindMouseEvents = function() { + this.eventManager.clear(); + var eventManager = eventManagerObject(this.instance); + eventManager.removeEventListener(this.instance.rootElement, 'contextmenu'); +}; +ContextMenu.prototype.show = function(menu, items) { + var that = this; + menu.removeAttribute('style'); + menu.style.display = 'block'; + var settings = { + data: items, + colHeaders: false, + colWidths: [200], + autoRowSize: false, + readOnly: true, + copyPaste: false, + columns: [{ + data: 'name', + renderer: helper.proxy(this.renderer, this) + }], + renderAllRows: true, + beforeKeyDown: function(event) { + that.onBeforeKeyDown(event, htContextMenu); + }, + afterOnCellMouseOver: function(event, coords, TD) { + that.onCellMouseOver(event, coords, TD, htContextMenu); + } + }; + var htContextMenu = new Handsontable(menu, settings); + htContextMenu.isHotTableEnv = this.instance.isHotTableEnv; + Handsontable.eventManager.isHotTableEnv = this.instance.isHotTableEnv; + this.eventManager.removeEventListener(menu, 'mousedown'); + this.eventManager.addEventListener(menu, 'mousedown', function(event) { + that.performAction(event, htContextMenu); + }); + this.bindTableEvents(); + htContextMenu.listen(); + this.htMenus[htContextMenu.guid] = htContextMenu; + Handsontable.hooks.run(this.instance, 'afterContextMenuShow', htContextMenu); +}; +ContextMenu.prototype.close = function(menu) { + this.hide(menu); + this.eventManager.clear(); + this.unbindTableEvents(); + this.instance.listen(); +}; +ContextMenu.prototype.closeAll = function() { + while (this.menus.length > 0) { + var menu = this.menus.pop(); + if (menu) { + this.close(menu); + } + } + this.triggerRows = []; +}; +ContextMenu.prototype.closeLastOpenedSubMenu = function() { + var menu = this.menus.pop(); + if (menu) { + this.hide(menu); + } +}; +ContextMenu.prototype.hide = function(menu) { + menu.style.display = 'none'; + var instance = this.htMenus[menu.id]; + Handsontable.hooks.run(this.instance, 'afterContextMenuHide', instance); + instance.destroy(); + delete this.htMenus[menu.id]; +}; +ContextMenu.prototype.renderer = function(instance, TD, row, col, prop, value) { + var contextMenu = this; + var item = instance.getData()[row]; + var wrapper = document.createElement('DIV'); + if (typeof value === 'function') { + value = value.call(this.instance); + } + dom.empty(TD); + TD.appendChild(wrapper); + Handsontable.Dom.addClass(wrapper, item.key); + if (itemIsSeparator(item)) { + dom.addClass(TD, 'htSeparator'); + } else { + dom.fastInnerHTML(wrapper, value); + } + if (itemIsDisabled(item)) { + dom.addClass(TD, 'htDisabled'); + this.eventManager.addEventListener(wrapper, 'mouseenter', function() { + instance.deselectCell(); + }); + } else { + if (isSubMenu(item)) { + dom.addClass(TD, 'htSubmenu'); + this.eventManager.addEventListener(wrapper, 'mouseenter', function() { + instance.selectCell(row, col); + }); + } else { + dom.removeClass(TD, 'htSubmenu'); + dom.removeClass(TD, 'htDisabled'); + this.eventManager.addEventListener(wrapper, 'mouseenter', function() { + instance.selectCell(row, col); + }); + } + } + function isSubMenu(item) { + return item.hasOwnProperty('submenu'); + } + function itemIsSeparator(item) { + return new RegExp(ContextMenu.SEPARATOR.name, 'i').test(item.name); + } + function itemIsDisabled(item) { + return item.disabled === true || (typeof item.disabled == 'function' && item.disabled.call(contextMenu.instance) === true); + } +}; +ContextMenu.prototype.onCellMouseOver = function(event, coords, TD, hot) { + var menusLength = this.menus.length; + if (menusLength > 0) { + var lastMenu = this.menus[menusLength - 1]; + if (lastMenu.id != hot.guid) { + this.closeLastOpenedSubMenu(); + } + } else { + this.closeLastOpenedSubMenu(); + } + if (TD.className.indexOf('htSubmenu') != -1) { + var selectedItem = hot.getData()[coords.row]; + var items = this.getItems(selectedItem.submenu); + var subMenu = this.createMenu(selectedItem.name, coords.row); + var tdCoords = TD.getBoundingClientRect(); + this.show(subMenu, items); + this.setSubMenuPosition(tdCoords, subMenu); + } +}; +ContextMenu.prototype.onBeforeKeyDown = function(event, instance) { + dom.enableImmediatePropagation(event); + var contextMenu = this; + var selection = instance.getSelected(); + switch (event.keyCode) { + case helper.keyCode.ESCAPE: + contextMenu.closeAll(); + event.preventDefault(); + event.stopImmediatePropagation(); + break; + case helper.keyCode.ENTER: + if (selection) { + contextMenu.performAction(event, instance); + } + break; + case helper.keyCode.ARROW_DOWN: + if (!selection) { + selectFirstCell(instance, contextMenu); + } else { + selectNextCell(selection[0], selection[1], instance, contextMenu); + } + event.preventDefault(); + event.stopImmediatePropagation(); + break; + case helper.keyCode.ARROW_UP: + if (!selection) { + selectLastCell(instance, contextMenu); + } else { + selectPrevCell(selection[0], selection[1], instance, contextMenu); + } + event.preventDefault(); + event.stopImmediatePropagation(); + break; + case helper.keyCode.ARROW_RIGHT: + if (selection) { + var row = selection[0]; + var cell = instance.getCell(selection[0], 0); + if (ContextMenu.utils.hasSubMenu(cell)) { + openSubMenu(instance, contextMenu, cell, row); + } + } + event.preventDefault(); + event.stopImmediatePropagation(); + break; + case helper.keyCode.ARROW_LEFT: + if (selection) { + if (instance.rootElement.className.indexOf('htContextSubMenu_') != -1) { + contextMenu.closeLastOpenedSubMenu(); + var index = contextMenu.menus.length; + if (index > 0) { + var menu = contextMenu.menus[index - 1]; + var triggerRow = contextMenu.triggerRows.pop(); + instance = this.htMenus[menu.id]; + instance.selectCell(triggerRow, 0); + } + } + event.preventDefault(); + event.stopImmediatePropagation(); + } + break; + } + function selectFirstCell(instance) { + var firstCell = instance.getCell(0, 0); + if (ContextMenu.utils.isSeparator(firstCell) || ContextMenu.utils.isDisabled(firstCell)) { + selectNextCell(0, 0, instance); + } else { + instance.selectCell(0, 0); + } + } + function selectLastCell(instance) { + var lastRow = instance.countRows() - 1; + var lastCell = instance.getCell(lastRow, 0); + if (ContextMenu.utils.isSeparator(lastCell) || ContextMenu.utils.isDisabled(lastCell)) { + selectPrevCell(lastRow, 0, instance); + } else { + instance.selectCell(lastRow, 0); + } + } + function selectNextCell(row, col, instance) { + var nextRow = row + 1; + var nextCell = nextRow < instance.countRows() ? instance.getCell(nextRow, col) : null; + if (!nextCell) { + return; + } + if (ContextMenu.utils.isSeparator(nextCell) || ContextMenu.utils.isDisabled(nextCell)) { + selectNextCell(nextRow, col, instance); + } else { + instance.selectCell(nextRow, col); + } + } + function selectPrevCell(row, col, instance) { + var prevRow = row - 1; + var prevCell = prevRow >= 0 ? instance.getCell(prevRow, col) : null; + if (!prevCell) { + return; + } + if (ContextMenu.utils.isSeparator(prevCell) || ContextMenu.utils.isDisabled(prevCell)) { + selectPrevCell(prevRow, col, instance); + } else { + instance.selectCell(prevRow, col); + } + } + function openSubMenu(instance, contextMenu, cell, row) { + var selectedItem = instance.getData()[row]; + var items = contextMenu.getItems(selectedItem.submenu); + var subMenu = contextMenu.createMenu(selectedItem.name, row); + var coords = cell.getBoundingClientRect(); + var subMenuInstance = contextMenu.show(subMenu, items); + contextMenu.setSubMenuPosition(coords, subMenu); + subMenuInstance.selectCell(0, 0); + } +}; +function findByKey(items, key) { + for (var i = 0, + ilen = items.length; i < ilen; i++) { + if (items[i].key === key) { + return items[i]; + } + } +} +function findIndexByKey(items, key) { + for (var i = 0, + ilen = items.length; i < ilen; i++) { + if (items[i].key === key) { + return i; + } + } +} +ContextMenu.prototype.getItems = function(items) { + var menu, + item; + function ContextMenuItem(rawItem) { + if (typeof rawItem == 'string') { + this.name = rawItem; + } else { + helper.extend(this, rawItem); + } + } + ContextMenuItem.prototype = items; + if (items && items.items) { + items = items.items; + } + if (items === true) { + items = this.defaultOptions.items; + } + if (1 == 1) { + menu = []; + for (var key in items) { + if (items.hasOwnProperty(key)) { + if (typeof items[key] === 'string') { + item = findByKey(this.defaultOptions.items, items[key]); + } else { + item = findByKey(this.defaultOptions.items, key); + } + if (!item) { + item = items[key]; + } + item = new ContextMenuItem(item); + if (typeof items[key] === 'object') { + helper.extend(item, items[key]); + } + if (!item.key) { + item.key = key; + } + menu.push(item); + } + } + } + return menu; +}; +ContextMenu.prototype.setSubMenuPosition = function(coords, menu) { + var scrollTop = dom.getWindowScrollTop(); + var scrollLeft = dom.getWindowScrollLeft(); + var cursor = { + top: scrollTop + coords.top, + topRelative: coords.top, + left: coords.left, + leftRelative: coords.left - scrollLeft, + scrollTop: scrollTop, + scrollLeft: scrollLeft, + cellHeight: coords.height, + cellWidth: coords.width + }; + if (this.menuFitsBelowCursor(cursor, menu, document.body.clientWidth)) { + this.positionMenuBelowCursor(cursor, menu, true); + } else { + if (this.menuFitsAboveCursor(cursor, menu)) { + this.positionMenuAboveCursor(cursor, menu, true); + } else { + this.positionMenuBelowCursor(cursor, menu, true); + } + } + if (this.menuFitsOnRightOfCursor(cursor, menu, document.body.clientWidth)) { + this.positionMenuOnRightOfCursor(cursor, menu, true); + } else { + this.positionMenuOnLeftOfCursor(cursor, menu, true); + } +}; +ContextMenu.prototype.setMenuPosition = function(event, menu) { + var scrollTop = dom.getWindowScrollTop(); + var scrollLeft = dom.getWindowScrollLeft(); + var cursorY = event.pageY || (event.clientY + scrollTop); + var cursorX = event.pageX || (event.clientX + scrollLeft); + var cursor = { + top: cursorY, + topRelative: cursorY - scrollTop, + left: cursorX, + leftRelative: cursorX - scrollLeft, + scrollTop: scrollTop, + scrollLeft: scrollLeft, + cellHeight: event.target.clientHeight, + cellWidth: event.target.clientWidth + }; + if (this.menuFitsBelowCursor(cursor, menu, document.body.clientHeight)) { + this.positionMenuBelowCursor(cursor, menu); + } else { + if (this.menuFitsAboveCursor(cursor, menu)) { + this.positionMenuAboveCursor(cursor, menu); + } else { + this.positionMenuBelowCursor(cursor, menu); + } + } + if (this.menuFitsOnRightOfCursor(cursor, menu, document.body.clientWidth)) { + this.positionMenuOnRightOfCursor(cursor, menu); + } else { + this.positionMenuOnLeftOfCursor(cursor, menu); + } +}; +ContextMenu.prototype.menuFitsAboveCursor = function(cursor, menu) { + return cursor.topRelative >= menu.offsetHeight; +}; +ContextMenu.prototype.menuFitsBelowCursor = function(cursor, menu, viewportHeight) { + return cursor.topRelative + menu.offsetHeight <= viewportHeight; +}; +ContextMenu.prototype.menuFitsOnRightOfCursor = function(cursor, menu, viewportHeight) { + return cursor.leftRelative + menu.offsetWidth <= viewportHeight; +}; +ContextMenu.prototype.positionMenuBelowCursor = function(cursor, menu) { + menu.style.top = cursor.top + 'px'; +}; +ContextMenu.prototype.positionMenuAboveCursor = function(cursor, menu, subMenu) { + if (subMenu) { + menu.style.top = (cursor.top + cursor.cellHeight - menu.offsetHeight) + 'px'; + } else { + menu.style.top = (cursor.top - menu.offsetHeight) + 'px'; + } +}; +ContextMenu.prototype.positionMenuOnRightOfCursor = function(cursor, menu, subMenu) { + if (subMenu) { + menu.style.left = 1 + cursor.left + cursor.cellWidth + 'px'; + } else { + menu.style.left = 1 + cursor.left + 'px'; + } +}; +ContextMenu.prototype.positionMenuOnLeftOfCursor = function(cursor, menu, subMenu) { + if (subMenu) { + menu.style.left = (cursor.left - menu.offsetWidth) + 'px'; + } else { + menu.style.left = (cursor.left - menu.offsetWidth) + 'px'; + } +}; +ContextMenu.utils = {}; +ContextMenu.utils.normalizeSelection = function(selRange) { + return { + start: selRange.getTopLeftCorner(), + end: selRange.getBottomRightCorner() + }; +}; +ContextMenu.utils.isSeparator = function(cell) { + return dom.hasClass(cell, 'htSeparator'); +}; +ContextMenu.utils.hasSubMenu = function(cell) { + return dom.hasClass(cell, 'htSubmenu'); +}; +ContextMenu.utils.isDisabled = function(cell) { + return dom.hasClass(cell, 'htDisabled'); +}; +ContextMenu.prototype.enable = function() { + if (!this.enabled) { + this.enabled = true; + this.bindMouseEvents(); + } +}; +ContextMenu.prototype.disable = function() { + if (this.enabled) { + this.enabled = false; + this.closeAll(); + this.unbindMouseEvents(); + this.unbindTableEvents(); + } +}; +ContextMenu.prototype.destroy = function() { + this.closeAll(); + while (this.menus.length > 0) { + var menu = this.menus.pop(); + this.triggerRows.pop(); + if (menu) { + this.close(menu); + if (!this.isMenuEnabledByOtherHotInstance()) { + this.removeMenu(menu); + } + } + } + this.unbindMouseEvents(); + this.unbindTableEvents(); +}; +ContextMenu.prototype.isMenuEnabledByOtherHotInstance = function() { + var hotContainers = document.querySelectorAll('.handsontable'); + var menuEnabled = false; + for (var i = 0, + len = hotContainers.length; i < len; i++) { + var instance = this.htMenus[hotContainers[i].id]; + if (instance && instance.getSettings().contextMenu) { + menuEnabled = true; + break; + } + } + return menuEnabled; +}; +ContextMenu.prototype.removeMenu = function(menu) { + if (menu.parentNode) { + this.menu.parentNode.removeChild(menu); + } +}; +ContextMenu.prototype.align = function(range, type, alignment) { + align.call(this, range, type, alignment); +}; +ContextMenu.SEPARATOR = {name: "---------"}; +function updateHeight() { + if (this.rootElement.className.indexOf('htContextMenu')) { + return; + } + var realSeparatorHeight = 0, + realEntrySize = 0, + dataSize = this.getSettings().data.length, + currentHiderWidth = parseInt(this.view.wt.wtTable.hider.style.width, 10); + for (var i = 0; i < dataSize; i++) { + if (this.getSettings().data[i].name == ContextMenu.SEPARATOR.name) { + realSeparatorHeight += 1; + } else { + realEntrySize += 26; + } + } + this.view.wt.wtTable.holder.style.width = currentHiderWidth + 22 + "px"; + this.view.wt.wtTable.holder.style.height = realEntrySize + realSeparatorHeight + 4 + "px"; +} +function prepareVerticalAlignClass(className, alignment) { + if (className.indexOf(alignment) != -1) { + return className; + } + className = className.replace('htTop', '').replace('htMiddle', '').replace('htBottom', '').replace(' ', ''); + className += " " + alignment; + return className; +} +function prepareHorizontalAlignClass(className, alignment) { + if (className.indexOf(alignment) != -1) { + return className; + } + className = className.replace('htLeft', '').replace('htCenter', '').replace('htRight', '').replace('htJustify', '').replace(' ', ''); + className += " " + alignment; + return className; +} +function getAlignmentClasses(range) { + var classesArray = {}; + for (var row = range.from.row; row <= range.to.row; row++) { + for (var col = range.from.col; col <= range.to.col; col++) { + if (!classesArray[row]) { + classesArray[row] = []; + } + classesArray[row][col] = this.getCellMeta(row, col).className; + } + } + return classesArray; +} +function doAlign(row, col, type, alignment) { + var cellMeta = this.getCellMeta(row, col), + className = alignment; + if (cellMeta.className) { + if (type === 'vertical') { + className = prepareVerticalAlignClass(cellMeta.className, alignment); + } else { + className = prepareHorizontalAlignClass(cellMeta.className, alignment); + } + } + this.setCellMeta(row, col, 'className', className); +} +function align(range, type, alignment) { + var stateBefore = getAlignmentClasses.call(this, range); + this.runHooks('beforeCellAlignment', stateBefore, range, type, alignment); + if (range.from.row == range.to.row && range.from.col == range.to.col) { + doAlign.call(this, range.from.row, range.from.col, type, alignment); + } else { + for (var row = range.from.row; row <= range.to.row; row++) { + for (var col = range.from.col; col <= range.to.col; col++) { + doAlign.call(this, row, col, type, alignment); + } + } + } + this.render(); +} +function init() { + var instance = this; + var contextMenuSetting = instance.getSettings().contextMenu; + var customOptions = helper.isObject(contextMenuSetting) ? contextMenuSetting : {}; + if (contextMenuSetting) { + if (!instance.contextMenu) { + instance.contextMenu = new ContextMenu(instance, customOptions); + } + instance.contextMenu.enable(); + } else if (instance.contextMenu) { + instance.contextMenu.destroy(); + delete instance.contextMenu; + } +} +Handsontable.hooks.add('afterInit', init); +Handsontable.hooks.add('afterUpdateSettings', init); +Handsontable.hooks.add('afterInit', updateHeight); +Handsontable.hooks.register('afterContextMenuDefaultOptions'); +Handsontable.hooks.register('afterContextMenuShow'); +Handsontable.hooks.register('afterContextMenuHide'); +Handsontable.ContextMenu = ContextMenu; + +//# +},{"dom.js":27,"eventManager.js":41,"helpers.js":42,"plugins.js":45}],54:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + ContextMenuCopyPaste: {get: function() { + return ContextMenuCopyPaste; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47_eventManager_46_js__, + $___46__46__47__46__46__47_plugins_46_js__, + $___46__46__47__95_base_46_js__, + $__zeroclipboard__; +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var eventManagerObject = ($___46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47_eventManager_46_js__}).eventManager; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +var BasePlugin = ($___46__46__47__95_base_46_js__ = require("_base.js"), $___46__46__47__95_base_46_js__ && $___46__46__47__95_base_46_js__.__esModule && $___46__46__47__95_base_46_js__ || {default: $___46__46__47__95_base_46_js__}).default; +var ZeroClipboard = ($__zeroclipboard__ = require("zeroclipboard"), $__zeroclipboard__ && $__zeroclipboard__.__esModule && $__zeroclipboard__ || {default: $__zeroclipboard__}).default; +var ContextMenuCopyPaste = function ContextMenuCopyPaste(hotInstance) { + var $__4 = this; + $traceurRuntime.superConstructor($ContextMenuCopyPaste).call(this, hotInstance); + this.swfPath = null; + this.hotContextMenu = null; + this.outsideClickDeselectsCache = null; + this.hot.addHook('afterContextMenuShow', (function(htContextMenu) { + return $__4.setupZeroClipboard(htContextMenu); + })); + this.hot.addHook('afterInit', (function() { + return $__4.afterInit(); + })); + this.hot.addHook('afterContextMenuDefaultOptions', (function(options) { + return $__4.addToContextMenu(options); + })); +}; +var $ContextMenuCopyPaste = ContextMenuCopyPaste; +($traceurRuntime.createClass)(ContextMenuCopyPaste, { + afterInit: function() { + if (!this.hot.getSettings().contextMenuCopyPaste) { + return; + } else if (typeof this.hot.getSettings().contextMenuCopyPaste == 'object') { + this.swfPath = this.hot.getSettings().contextMenuCopyPaste.swfPath; + } + if (typeof ZeroClipboard === 'undefined') { + console.error('To be able to use the Copy/Paste feature from the context menu, you need to manualy include ZeroClipboard.js file to your website.'); + } + try { + new ActiveXObject('ShockwaveFlash.ShockwaveFlash'); + } catch (exception) { + if ('undefined' == typeof navigator.mimeTypes['application/x-shockwave-flash']) { + console.error('To be able to use the Copy/Paste feature from the context menu, your browser needs to have Flash Plugin installed.'); + } + } + this.prepareZeroClipboard(); + }, + prepareZeroClipboard: function() { + if (this.swfPath) { + ZeroClipboard.config({swfPath: this.swfPath}); + } + }, + getCopyValue: function() { + this.hot.copyPaste.setCopyableText(); + return this.hot.copyPaste.copyPasteInstance.elTextarea.value; + }, + addToContextMenu: function(defaultOptions) { + if (!this.hot.getSettings().contextMenuCopyPaste) { + return; + } + defaultOptions.items.unshift({ + key: 'copy', + name: 'Copy' + }, { + key: 'paste', + name: 'Paste', + callback: function() { + this.copyPaste.triggerPaste(); + } + }, Handsontable.ContextMenu.SEPARATOR); + }, + setupZeroClipboard: function(hotContextMenu) { + var $__4 = this; + var data, + zeroClipboardInstance; + if (!this.hot.getSettings().contextMenuCopyPaste) { + return; + } + this.hotContextMenu = hotContextMenu; + data = this.hotContextMenu.getData(); + for (var i = 0, + ilen = data.length; i < ilen; i++) { + if (data[i].key === 'copy') { + zeroClipboardInstance = new ZeroClipboard(this.hotContextMenu.getCell(i, 0)); + zeroClipboardInstance.off(); + zeroClipboardInstance.on('copy', (function(event) { + var clipboard = event.clipboardData; + clipboard.setData('text/plain', $__4.getCopyValue()); + $__4.hot.getSettings().outsideClickDeselects = $__4.outsideClickDeselectsCache; + })); + this.bindEvents(); + break; + } + } + }, + removeCurrentClass: function() { + if (this.hotContextMenu.rootElement) { + var element = this.hotContextMenu.rootElement.querySelector('td.current'); + if (element) { + dom.removeClass(element, 'current'); + } + } + this.outsideClickDeselectsCache = this.hot.getSettings().outsideClickDeselects; + this.hot.getSettings().outsideClickDeselects = false; + }, + removeZeroClipboardClass: function() { + if (this.hotContextMenu.rootElement) { + var element = this.hotContextMenu.rootElement.querySelector('td.zeroclipboard-is-hover'); + if (element) { + dom.removeClass(element, 'zeroclipboard-is-hover'); + } + } + this.hot.getSettings().outsideClickDeselects = this.outsideClickDeselectsCache; + }, + bindEvents: function() { + var $__4 = this; + var eventManager = eventManagerObject(this.hotContextMenu); + eventManager.addEventListener(document, 'mouseenter', (function() { + return $__4.removeCurrentClass(); + })); + eventManager.addEventListener(document, 'mouseleave', (function() { + return $__4.removeZeroClipboardClass(); + })); + } +}, {}, BasePlugin); +; +registerPlugin('contextMenuCopyPaste', ContextMenuCopyPaste); + +//# +},{"_base.js":46,"dom.js":27,"eventManager.js":41,"plugins.js":45,"zeroclipboard":"zeroclipboard"}],55:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + CopyPastePlugin: {get: function() { + return CopyPastePlugin; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_helpers_46_js__, + $__copyPaste__, + $__SheetClip__, + $___46__46__47__46__46__47_plugins_46_js__, + $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__, + $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__; +var helper = ($___46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47_helpers_46_js__}); +var copyPaste = ($__copyPaste__ = require("copyPaste"), $__copyPaste__ && $__copyPaste__.__esModule && $__copyPaste__ || {default: $__copyPaste__}).default; +var SheetClip = ($__SheetClip__ = require("SheetClip"), $__SheetClip__ && $__SheetClip__.__esModule && $__SheetClip__ || {default: $__SheetClip__}).default; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +var WalkontableCellCoords = ($___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ = require("3rdparty/walkontable/src/cell/coords.js"), $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__.__esModule && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ || {default: $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__}).WalkontableCellCoords; +var WalkontableCellRange = ($___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ = require("3rdparty/walkontable/src/cell/range.js"), $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__.__esModule && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ || {default: $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__}).WalkontableCellRange; +function CopyPastePlugin(instance) { + var _this = this; + this.copyPasteInstance = copyPaste(); + this.copyPasteInstance.onCut(onCut); + this.copyPasteInstance.onPaste(onPaste); + instance.addHook('beforeKeyDown', onBeforeKeyDown); + function onCut() { + if (!instance.isListening()) { + return; + } + instance.selection.empty(); + } + function onPaste(str) { + var input, + inputArray, + selected, + coordsFrom, + coordsTo, + cellRange, + topLeftCorner, + bottomRightCorner, + areaStart, + areaEnd; + if (!instance.isListening() || !instance.selection.isSelected()) { + return; + } + input = str; + inputArray = SheetClip.parse(input); + selected = instance.getSelected(); + coordsFrom = new WalkontableCellCoords(selected[0], selected[1]); + coordsTo = new WalkontableCellCoords(selected[2], selected[3]); + cellRange = new WalkontableCellRange(coordsFrom, coordsFrom, coordsTo); + topLeftCorner = cellRange.getTopLeftCorner(); + bottomRightCorner = cellRange.getBottomRightCorner(); + areaStart = topLeftCorner; + areaEnd = new WalkontableCellCoords(Math.max(bottomRightCorner.row, inputArray.length - 1 + topLeftCorner.row), Math.max(bottomRightCorner.col, inputArray[0].length - 1 + topLeftCorner.col)); + instance.addHookOnce('afterChange', function(changes, source) { + if (changes && changes.length) { + this.selectCell(areaStart.row, areaStart.col, areaEnd.row, areaEnd.col); + } + }); + instance.populateFromArray(areaStart.row, areaStart.col, inputArray, areaEnd.row, areaEnd.col, 'paste', instance.getSettings().pasteMode); + } + function onBeforeKeyDown(event) { + if (!instance.getSelected()) { + return; + } + if (instance.getActiveEditor() && instance.getActiveEditor().isOpened()) { + return; + } + if (helper.isCtrlKey(event.keyCode)) { + _this.setCopyableText(); + event.stopImmediatePropagation(); + return; + } + var ctrlDown = (event.ctrlKey || event.metaKey) && !event.altKey; + if (event.keyCode == helper.keyCode.A && ctrlDown) { + instance._registerTimeout(setTimeout(helper.proxy(_this.setCopyableText, _this), 0)); + } + } + this.destroy = function() { + if (this.copyPasteInstance) { + this.copyPasteInstance.removeCallback(onCut); + this.copyPasteInstance.removeCallback(onPaste); + this.copyPasteInstance.destroy(); + this.copyPasteInstance = null; + } + instance.removeHook('beforeKeyDown', onBeforeKeyDown); + }; + instance.addHook('afterDestroy', helper.proxy(this.destroy, this)); + this.triggerPaste = helper.proxy(this.copyPasteInstance.triggerPaste, this.copyPasteInstance); + this.triggerCut = helper.proxy(this.copyPasteInstance.triggerCut, this.copyPasteInstance); + this.setCopyableText = function() { + var settings = instance.getSettings(); + var copyRowsLimit = settings.copyRowsLimit; + var copyColsLimit = settings.copyColsLimit; + var selRange = instance.getSelectedRange(); + var topLeft = selRange.getTopLeftCorner(); + var bottomRight = selRange.getBottomRightCorner(); + var startRow = topLeft.row; + var startCol = topLeft.col; + var endRow = bottomRight.row; + var endCol = bottomRight.col; + var finalEndRow = Math.min(endRow, startRow + copyRowsLimit - 1); + var finalEndCol = Math.min(endCol, startCol + copyColsLimit - 1); + instance.copyPaste.copyPasteInstance.copyable(instance.getCopyableData(startRow, startCol, finalEndRow, finalEndCol)); + if (endRow !== finalEndRow || endCol !== finalEndCol) { + Handsontable.hooks.run(instance, "afterCopyLimit", endRow - startRow + 1, endCol - startCol + 1, copyRowsLimit, copyColsLimit); + } + }; +} +function init() { + var instance = this, + pluginEnabled = instance.getSettings().copyPaste !== false; + if (pluginEnabled && !instance.copyPaste) { + instance.copyPaste = new CopyPastePlugin(instance); + } else if (!pluginEnabled && instance.copyPaste) { + instance.copyPaste.destroy(); + instance.copyPaste = null; + } +} +Handsontable.hooks.add('afterInit', init); +Handsontable.hooks.add('afterUpdateSettings', init); +Handsontable.hooks.register('afterCopyLimit'); +; + +//# +},{"3rdparty/walkontable/src/cell/coords.js":5,"3rdparty/walkontable/src/cell/range.js":6,"SheetClip":"SheetClip","copyPaste":"copyPaste","helpers.js":42,"plugins.js":45}],56:[function(require,module,exports){ +"use strict"; +var $___46__46__47__46__46__47_plugins_46_js__, + $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__, + $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_selection_46_js__; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +var WalkontableCellRange = ($___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ = require("3rdparty/walkontable/src/cell/range.js"), $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__.__esModule && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ || {default: $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__}).WalkontableCellRange; +var WalkontableSelection = ($___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_selection_46_js__ = require("3rdparty/walkontable/src/selection.js"), $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_selection_46_js__ && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_selection_46_js__.__esModule && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_selection_46_js__ || {default: $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_selection_46_js__}).WalkontableSelection; +function CustomBorders() {} +var instance; +var checkEnable = function(customBorders) { + if (typeof customBorders === "boolean") { + if (customBorders === true) { + return true; + } + } + if (typeof customBorders === "object") { + if (customBorders.length > 0) { + return true; + } + } + return false; +}; +var init = function() { + if (checkEnable(this.getSettings().customBorders)) { + if (!this.customBorders) { + instance = this; + this.customBorders = new CustomBorders(); + } + } +}; +var getSettingIndex = function(className) { + for (var i = 0; i < instance.view.wt.selections.length; i++) { + if (instance.view.wt.selections[i].settings.className == className) { + return i; + } + } + return -1; +}; +var insertBorderIntoSettings = function(border) { + var coordinates = { + row: border.row, + col: border.col + }; + var selection = new WalkontableSelection(border, new WalkontableCellRange(coordinates, coordinates, coordinates)); + var index = getSettingIndex(border.className); + if (index >= 0) { + instance.view.wt.selections[index] = selection; + } else { + instance.view.wt.selections.push(selection); + } +}; +var prepareBorderFromCustomAdded = function(row, col, borderObj) { + var border = createEmptyBorders(row, col); + border = extendDefaultBorder(border, borderObj); + this.setCellMeta(row, col, 'borders', border); + insertBorderIntoSettings(border); +}; +var prepareBorderFromCustomAddedRange = function(rowObj) { + var range = rowObj.range; + for (var row = range.from.row; row <= range.to.row; row++) { + for (var col = range.from.col; col <= range.to.col; col++) { + var border = createEmptyBorders(row, col); + var add = 0; + if (row == range.from.row) { + add++; + if (rowObj.hasOwnProperty('top')) { + border.top = rowObj.top; + } + } + if (row == range.to.row) { + add++; + if (rowObj.hasOwnProperty('bottom')) { + border.bottom = rowObj.bottom; + } + } + if (col == range.from.col) { + add++; + if (rowObj.hasOwnProperty('left')) { + border.left = rowObj.left; + } + } + if (col == range.to.col) { + add++; + if (rowObj.hasOwnProperty('right')) { + border.right = rowObj.right; + } + } + if (add > 0) { + this.setCellMeta(row, col, 'borders', border); + insertBorderIntoSettings(border); + } + } + } +}; +var createClassName = function(row, col) { + return "border_row" + row + "col" + col; +}; +var createDefaultCustomBorder = function() { + return { + width: 1, + color: '#000' + }; +}; +var createSingleEmptyBorder = function() { + return {hide: true}; +}; +var createDefaultHtBorder = function() { + return { + width: 1, + color: '#000', + cornerVisible: false + }; +}; +var createEmptyBorders = function(row, col) { + return { + className: createClassName(row, col), + border: createDefaultHtBorder(), + row: row, + col: col, + top: createSingleEmptyBorder(), + right: createSingleEmptyBorder(), + bottom: createSingleEmptyBorder(), + left: createSingleEmptyBorder() + }; +}; +var extendDefaultBorder = function(defaultBorder, customBorder) { + if (customBorder.hasOwnProperty('border')) { + defaultBorder.border = customBorder.border; + } + if (customBorder.hasOwnProperty('top')) { + defaultBorder.top = customBorder.top; + } + if (customBorder.hasOwnProperty('right')) { + defaultBorder.right = customBorder.right; + } + if (customBorder.hasOwnProperty('bottom')) { + defaultBorder.bottom = customBorder.bottom; + } + if (customBorder.hasOwnProperty('left')) { + defaultBorder.left = customBorder.left; + } + return defaultBorder; +}; +var removeBordersFromDom = function(borderClassName) { + var borders = document.querySelectorAll("." + borderClassName); + for (var i = 0; i < borders.length; i++) { + if (borders[i]) { + if (borders[i].nodeName != 'TD') { + var parent = borders[i].parentNode; + if (parent.parentNode) { + parent.parentNode.removeChild(parent); + } + } + } + } +}; +var removeAllBorders = function(row, col) { + var borderClassName = createClassName(row, col); + removeBordersFromDom(borderClassName); + this.removeCellMeta(row, col, 'borders'); +}; +var setBorder = function(row, col, place, remove) { + var bordersMeta = this.getCellMeta(row, col).borders; + if (!bordersMeta || bordersMeta.border == undefined) { + bordersMeta = createEmptyBorders(row, col); + } + if (remove) { + bordersMeta[place] = createSingleEmptyBorder(); + } else { + bordersMeta[place] = createDefaultCustomBorder(); + } + this.setCellMeta(row, col, 'borders', bordersMeta); + var borderClassName = createClassName(row, col); + removeBordersFromDom(borderClassName); + insertBorderIntoSettings(bordersMeta); + this.render(); +}; +var prepareBorder = function(range, place, remove) { + if (range.from.row == range.to.row && range.from.col == range.to.col) { + if (place == "noBorders") { + removeAllBorders.call(this, range.from.row, range.from.col); + } else { + setBorder.call(this, range.from.row, range.from.col, place, remove); + } + } else { + switch (place) { + case "noBorders": + for (var column = range.from.col; column <= range.to.col; column++) { + for (var row = range.from.row; row <= range.to.row; row++) { + removeAllBorders.call(this, row, column); + } + } + break; + case "top": + for (var topCol = range.from.col; topCol <= range.to.col; topCol++) { + setBorder.call(this, range.from.row, topCol, place, remove); + } + break; + case "right": + for (var rowRight = range.from.row; rowRight <= range.to.row; rowRight++) { + setBorder.call(this, rowRight, range.to.col, place); + } + break; + case "bottom": + for (var bottomCol = range.from.col; bottomCol <= range.to.col; bottomCol++) { + setBorder.call(this, range.to.row, bottomCol, place); + } + break; + case "left": + for (var rowLeft = range.from.row; rowLeft <= range.to.row; rowLeft++) { + setBorder.call(this, rowLeft, range.from.col, place); + } + break; + } + } +}; +var checkSelectionBorders = function(hot, direction) { + var atLeastOneHasBorder = false; + hot.getSelectedRange().forAll(function(r, c) { + var metaBorders = hot.getCellMeta(r, c).borders; + if (metaBorders) { + if (direction) { + if (!metaBorders[direction].hasOwnProperty('hide')) { + atLeastOneHasBorder = true; + return false; + } + } else { + atLeastOneHasBorder = true; + return false; + } + } + }); + return atLeastOneHasBorder; +}; +var markSelected = function(label) { + return "" + String.fromCharCode(10003) + "" + label; +}; +var addBordersOptionsToContextMenu = function(defaultOptions) { + if (!this.getSettings().customBorders) { + return; + } + defaultOptions.items.push(Handsontable.ContextMenu.SEPARATOR); + defaultOptions.items.push({ + key: 'borders', + name: 'Borders', + submenu: {items: { + top: { + name: function() { + var label = "Top"; + var hasBorder = checkSelectionBorders(this, 'top'); + if (hasBorder) { + label = markSelected(label); + } + return label; + }, + callback: function() { + var hasBorder = checkSelectionBorders(this, 'top'); + prepareBorder.call(this, this.getSelectedRange(), 'top', hasBorder); + }, + disabled: false + }, + right: { + name: function() { + var label = 'Right'; + var hasBorder = checkSelectionBorders(this, 'right'); + if (hasBorder) { + label = markSelected(label); + } + return label; + }, + callback: function() { + var hasBorder = checkSelectionBorders(this, 'right'); + prepareBorder.call(this, this.getSelectedRange(), 'right', hasBorder); + }, + disabled: false + }, + bottom: { + name: function() { + var label = 'Bottom'; + var hasBorder = checkSelectionBorders(this, 'bottom'); + if (hasBorder) { + label = markSelected(label); + } + return label; + }, + callback: function() { + var hasBorder = checkSelectionBorders(this, 'bottom'); + prepareBorder.call(this, this.getSelectedRange(), 'bottom', hasBorder); + }, + disabled: false + }, + left: { + name: function() { + var label = 'Left'; + var hasBorder = checkSelectionBorders(this, 'left'); + if (hasBorder) { + label = markSelected(label); + } + return label; + }, + callback: function() { + var hasBorder = checkSelectionBorders(this, 'left'); + prepareBorder.call(this, this.getSelectedRange(), 'left', hasBorder); + }, + disabled: false + }, + remove: { + name: 'Remove border(s)', + callback: function() { + prepareBorder.call(this, this.getSelectedRange(), 'noBorders'); + }, + disabled: function() { + return !checkSelectionBorders(this); + } + } + }} + }); +}; +Handsontable.hooks.add('beforeInit', init); +Handsontable.hooks.add('afterContextMenuDefaultOptions', addBordersOptionsToContextMenu); +Handsontable.hooks.add('afterInit', function() { + var customBorders = this.getSettings().customBorders; + if (customBorders) { + for (var i = 0; i < customBorders.length; i++) { + if (customBorders[i].range) { + prepareBorderFromCustomAddedRange.call(this, customBorders[i]); + } else { + prepareBorderFromCustomAdded.call(this, customBorders[i].row, customBorders[i].col, customBorders[i]); + } + } + this.render(); + this.view.wt.draw(true); + } +}); +Handsontable.CustomBorders = CustomBorders; + +//# +},{"3rdparty/walkontable/src/cell/range.js":6,"3rdparty/walkontable/src/selection.js":18,"plugins.js":45}],57:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + DragToScroll: {get: function() { + return DragToScroll; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_eventManager_46_js__, + $___46__46__47__46__46__47_plugins_46_js__; +var eventManagerObject = ($___46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47_eventManager_46_js__}).eventManager; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +; +Handsontable.plugins.DragToScroll = DragToScroll; +function DragToScroll() { + this.boundaries = null; + this.callback = null; +} +DragToScroll.prototype.setBoundaries = function(boundaries) { + this.boundaries = boundaries; +}; +DragToScroll.prototype.setCallback = function(callback) { + this.callback = callback; +}; +DragToScroll.prototype.check = function(x, y) { + var diffX = 0; + var diffY = 0; + if (y < this.boundaries.top) { + diffY = y - this.boundaries.top; + } else if (y > this.boundaries.bottom) { + diffY = y - this.boundaries.bottom; + } + if (x < this.boundaries.left) { + diffX = x - this.boundaries.left; + } else if (x > this.boundaries.right) { + diffX = x - this.boundaries.right; + } + this.callback(diffX, diffY); +}; +var dragToScroll; +var instance; +var setupListening = function(instance) { + instance.dragToScrollListening = false; + var scrollHandler = instance.view.wt.wtTable.holder; + dragToScroll = new DragToScroll(); + if (scrollHandler === window) { + return; + } else { + dragToScroll.setBoundaries(scrollHandler.getBoundingClientRect()); + } + dragToScroll.setCallback(function(scrollX, scrollY) { + if (scrollX < 0) { + scrollHandler.scrollLeft -= 50; + } else if (scrollX > 0) { + scrollHandler.scrollLeft += 50; + } + if (scrollY < 0) { + scrollHandler.scrollTop -= 20; + } else if (scrollY > 0) { + scrollHandler.scrollTop += 20; + } + }); + instance.dragToScrollListening = true; +}; +Handsontable.hooks.add('afterInit', function() { + var instance = this; + var eventManager = eventManagerObject(this); + eventManager.addEventListener(document, 'mouseup', function() { + instance.dragToScrollListening = false; + }); + eventManager.addEventListener(document, 'mousemove', function(event) { + if (instance.dragToScrollListening) { + dragToScroll.check(event.clientX, event.clientY); + } + }); +}); +Handsontable.hooks.add('afterDestroy', function() { + eventManagerObject(this).clear(); +}); +Handsontable.hooks.add('afterOnCellMouseDown', function() { + setupListening(this); +}); +Handsontable.hooks.add('afterOnCellCornerMouseDown', function() { + setupListening(this); +}); +Handsontable.plugins.DragToScroll = DragToScroll; + +//# +},{"eventManager.js":41,"plugins.js":45}],58:[function(require,module,exports){ +"use strict"; +var $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47_plugins_46_js__; +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +function Grouping(instance) { + var groups = []; + var item = { + id: '', + level: 0, + hidden: 0, + rows: [], + cols: [] + }; + var counters = { + rows: 0, + cols: 0 + }; + var levels = { + rows: 0, + cols: 0 + }; + var hiddenRows = []; + var hiddenCols = []; + var classes = { + 'groupIndicatorContainer': 'htGroupIndicatorContainer', + 'groupIndicator': function(direction) { + return 'ht' + direction + 'Group'; + }, + 'groupStart': 'htGroupStart', + 'collapseButton': 'htCollapseButton', + 'expandButton': 'htExpandButton', + 'collapseGroupId': function(id) { + return 'htCollapse-' + id; + }, + 'collapseFromLevel': function(direction, level) { + return 'htCollapse' + direction + 'FromLevel-' + level; + }, + 'clickable': 'clickable', + 'levelTrigger': 'htGroupLevelTrigger' + }; + var compare = function(property, orderDirection) { + return function(item1, item2) { + return typeof(orderDirection) === 'undefined' || orderDirection === 'asc' ? item1[property] - item2[property] : item2[property] - item1[property]; + }; + }; + var range = function(from, to) { + var arr = []; + while (from <= to) { + arr.push(from++); + } + return arr; + }; + var getRangeGroups = function(dataType, from, to) { + var cells = [], + cell = { + row: null, + col: null + }; + if (dataType == "cols") { + while (from <= to) { + cell = { + row: -1, + col: from++ + }; + cells.push(cell); + } + } else { + while (from <= to) { + cell = { + row: from++, + col: -1 + }; + cells.push(cell); + } + } + var cellsGroups = getCellsGroups(cells), + totalRows = 0, + totalCols = 0; + for (var i = 0; i < cellsGroups.length; i++) { + totalRows += cellsGroups[i].filter(function(item) { + return item['rows']; + }).length; + totalCols += cellsGroups[i].filter(function(item) { + return item['cols']; + }).length; + } + return { + total: { + rows: totalRows, + cols: totalCols + }, + groups: cellsGroups + }; + }; + var getCellsGroups = function(cells) { + var _groups = []; + for (var i = 0; i < cells.length; i++) { + _groups.push(getCellGroups(cells[i])); + } + return _groups; + }; + var getCellGroups = function(coords, groupLevel, groupType) { + var row = coords.row, + col = coords.col; + var tmpRow = (row === -1 ? 0 : row), + tmpCol = (col === -1 ? 0 : col); + var _groups = []; + for (var i = 0; i < groups.length; i++) { + var group = groups[i], + id = group['id'], + level = group['level'], + rows = group['rows'] || [], + cols = group['cols'] || []; + if (_groups.indexOf(id) === -1) { + if (rows.indexOf(tmpRow) !== -1 || cols.indexOf(tmpCol) !== -1) { + _groups.push(group); + } + } + } + if (col === -1) { + _groups = _groups.concat(getColGroups()); + } else if (row === -1) { + _groups = _groups.concat(getRowGroups()); + } + if (groupLevel) { + _groups = _groups.filter(function(item) { + return item['level'] === groupLevel; + }); + } + if (groupType) { + if (groupType === 'cols') { + _groups = _groups.filter(function(item) { + return item['cols']; + }); + } else if (groupType === 'rows') { + _groups = _groups.filter(function(item) { + return item['rows']; + }); + } + } + var tmp = []; + return _groups.filter(function(item) { + if (tmp.indexOf(item.id) === -1) { + tmp.push(item.id); + return item; + } + }); + }; + var getGroupById = function(id) { + for (var i = 0, + groupsLength = groups.length; i < groupsLength; i++) { + if (groups[i].id == id) { + return groups[i]; + } + } + return false; + }; + var getGroupByRowAndLevel = function(row, level) { + for (var i = 0, + groupsLength = groups.length; i < groupsLength; i++) { + if (groups[i].level == level && groups[i].rows && groups[i].rows.indexOf(row) > -1) { + return groups[i]; + } + } + return false; + }; + var getGroupByColAndLevel = function(col, level) { + for (var i = 0, + groupsLength = groups.length; i < groupsLength; i++) { + if (groups[i].level == level && groups[i].cols && groups[i].cols.indexOf(col) > -1) { + return groups[i]; + } + } + return false; + }; + var getColGroups = function() { + var result = []; + for (var i = 0, + groupsLength = groups.length; i < groupsLength; i++) { + if (Array.isArray(groups[i]['cols'])) { + result.push(groups[i]); + } + } + return result; + }; + var getColGroupsByLevel = function(level) { + var result = []; + for (var i = 0, + groupsLength = groups.length; i < groupsLength; i++) { + if (groups[i]['cols'] && groups[i]['level'] === level) { + result.push(groups[i]); + } + } + return result; + }; + var getRowGroups = function() { + var result = []; + for (var i = 0, + groupsLength = groups.length; i < groupsLength; i++) { + if (Array.isArray(groups[i]['rows'])) { + result.push(groups[i]); + } + } + return result; + }; + var getRowGroupsByLevel = function(level) { + var result = []; + for (var i = 0, + groupsLength = groups.length; i < groupsLength; i++) { + if (groups[i]['rows'] && groups[i]['level'] === level) { + result.push(groups[i]); + } + } + return result; + }; + var getLastLevelColsInRange = function(rangeGroups) { + var level = 0; + if (rangeGroups.length) { + rangeGroups.forEach(function(items) { + items = items.filter(function(item) { + return item['cols']; + }); + if (items.length) { + var sortedGroup = items.sort(compare('level', 'desc')), + lastLevel = sortedGroup[0].level; + if (level < lastLevel) { + level = lastLevel; + } + } + }); + } + return level; + }; + var getLastLevelRowsInRange = function(rangeGroups) { + var level = 0; + if (rangeGroups.length) { + rangeGroups.forEach(function(items) { + items = items.filter(function(item) { + return item['rows']; + }); + if (items.length) { + var sortedGroup = items.sort(compare('level', 'desc')), + lastLevel = sortedGroup[0].level; + if (level < lastLevel) { + level = lastLevel; + } + } + }); + } + return level; + }; + var groupCols = function(from, to) { + var rangeGroups = getRangeGroups("cols", from, to), + lastLevel = getLastLevelColsInRange(rangeGroups.groups); + if (lastLevel === levels.cols) { + levels.cols++; + } else if (lastLevel > levels.cols) { + levels.cols = lastLevel + 1; + } + if (!counters.cols) { + counters.cols = getColGroups().length; + } + counters.cols++; + groups.push({ + id: 'c' + counters.cols, + level: lastLevel + 1, + cols: range(from, to), + hidden: 0 + }); + }; + var groupRows = function(from, to) { + var rangeGroups = getRangeGroups("rows", from, to), + lastLevel = getLastLevelRowsInRange(rangeGroups.groups); + levels.rows = Math.max(levels.rows, lastLevel + 1); + if (!counters.rows) { + counters.rows = getRowGroups().length; + } + counters.rows++; + groups.push({ + id: 'r' + counters.rows, + level: lastLevel + 1, + rows: range(from, to), + hidden: 0 + }); + }; + var showHideGroups = function(hidden, groups) { + var level; + for (var i = 0, + groupsLength = groups.length; i < groupsLength; i++) { + groups[i].hidden = hidden; + level = groups[i].level; + if (!hiddenRows[level]) { + hiddenRows[level] = []; + } + if (!hiddenCols[level]) { + hiddenCols[level] = []; + } + if (groups[i].rows) { + for (var j = 0, + rowsLength = groups[i].rows.length; j < rowsLength; j++) { + if (hidden > 0) { + hiddenRows[level][groups[i].rows[j]] = true; + } else { + hiddenRows[level][groups[i].rows[j]] = void 0; + } + } + } else if (groups[i].cols) { + for (var j = 0, + colsLength = groups[i].cols.length; j < colsLength; j++) { + if (hidden > 0) { + hiddenCols[level][groups[i].cols[j]] = true; + } else { + hiddenCols[level][groups[i].cols[j]] = void 0; + } + } + } + } + }; + var nextIndexSharesLevel = function(dimension, currentPosition, level, currentGroupId) { + var nextCellGroupId, + levelsByOrder; + switch (dimension) { + case 'rows': + nextCellGroupId = getGroupByRowAndLevel(currentPosition + 1, level).id; + levelsByOrder = Handsontable.Grouping.getGroupLevelsByRows(); + break; + case 'cols': + nextCellGroupId = getGroupByColAndLevel(currentPosition + 1, level).id; + levelsByOrder = Handsontable.Grouping.getGroupLevelsByCols(); + break; + } + return !!(levelsByOrder[currentPosition + 1] && levelsByOrder[currentPosition + 1].indexOf(level) > -1 && currentGroupId == nextCellGroupId); + }; + var previousIndexSharesLevel = function(dimension, currentPosition, level, currentGroupId) { + var previousCellGroupId, + levelsByOrder; + switch (dimension) { + case 'rows': + previousCellGroupId = getGroupByRowAndLevel(currentPosition - 1, level).id; + levelsByOrder = Handsontable.Grouping.getGroupLevelsByRows(); + break; + case 'cols': + previousCellGroupId = getGroupByColAndLevel(currentPosition - 1, level).id; + levelsByOrder = Handsontable.Grouping.getGroupLevelsByCols(); + break; + } + return !!(levelsByOrder[currentPosition - 1] && levelsByOrder[currentPosition - 1].indexOf(level) > -1 && currentGroupId == previousCellGroupId); + }; + var isLastIndexOfTheLine = function(dimension, index, level, currentGroupId) { + if (index === 0) { + return false; + } + var levelsByOrder, + entriesLength, + previousSharesLevel = previousIndexSharesLevel(dimension, index, level, currentGroupId), + nextSharesLevel = nextIndexSharesLevel(dimension, index, level, currentGroupId), + nextIsHidden = false; + switch (dimension) { + case 'rows': + levelsByOrder = Handsontable.Grouping.getGroupLevelsByRows(); + entriesLength = instance.countRows(); + for (var i = 0; i <= levels.rows; i++) { + if (hiddenRows[i] && hiddenRows[i][index + 1]) { + nextIsHidden = true; + break; + } + } + break; + case 'cols': + levelsByOrder = Handsontable.Grouping.getGroupLevelsByCols(); + entriesLength = instance.countCols(); + for (var i = 0; i <= levels.cols; i++) { + if (hiddenCols[i] && hiddenCols[i][index + 1]) { + nextIsHidden = true; + break; + } + } + break; + } + if (previousSharesLevel) { + if (index == entriesLength - 1) { + return true; + } else if (!nextSharesLevel || (nextSharesLevel && nextIsHidden)) { + return true; + } else if (!levelsByOrder[index + 1]) { + return true; + } + } + return false; + }; + var isLastHidden = function(dataType) { + var levelAmount; + switch (dataType) { + case 'rows': + levelAmount = levels.rows; + for (var j = 0; j <= levelAmount; j++) { + if (hiddenRows[j] && hiddenRows[j][instance.countRows() - 1]) { + return true; + } + } + break; + case 'cols': + levelAmount = levels.cols; + for (var j = 0; j <= levelAmount; j++) { + if (hiddenCols[j] && hiddenCols[j][instance.countCols() - 1]) { + return true; + } + } + break; + } + return false; + }; + var isFirstIndexOfTheLine = function(dimension, index, level, currentGroupId) { + var levelsByOrder, + entriesLength, + currentGroup = getGroupById(currentGroupId), + previousAreHidden = false, + arePreviousHidden = function(dimension) { + var hidden = false, + hiddenArr = dimension == 'rows' ? hiddenRows : hiddenCols; + for (var i = 0; i <= levels[dimension]; i++) { + tempInd = index; + while (currentGroup[dimension].indexOf(tempInd) > -1) { + hidden = !!(hiddenArr[i] && hiddenArr[i][tempInd]); + tempInd--; + } + if (hidden) { + break; + } + } + return hidden; + }, + previousSharesLevel = previousIndexSharesLevel(dimension, index, level, currentGroupId), + nextSharesLevel = nextIndexSharesLevel(dimension, index, level, currentGroupId), + tempInd; + switch (dimension) { + case 'rows': + levelsByOrder = Handsontable.Grouping.getGroupLevelsByRows(); + entriesLength = instance.countRows(); + previousAreHidden = arePreviousHidden(dimension); + break; + case 'cols': + levelsByOrder = Handsontable.Grouping.getGroupLevelsByCols(); + entriesLength = instance.countCols(); + previousAreHidden = arePreviousHidden(dimension); + break; + } + if (index == entriesLength - 1) { + return false; + } else if (index === 0) { + if (nextSharesLevel) { + return true; + } + } else if (!previousSharesLevel || (previousSharesLevel && previousAreHidden)) { + if (nextSharesLevel) { + return true; + } + } else if (!levelsByOrder[index - 1]) { + if (nextSharesLevel) { + return true; + } + } + return false; + }; + var addGroupExpander = function(dataType, index, level, id, elem) { + var previousIndexGroupId; + switch (dataType) { + case 'rows': + previousIndexGroupId = getGroupByRowAndLevel(index - 1, level).id; + break; + case 'cols': + previousIndexGroupId = getGroupByColAndLevel(index - 1, level).id; + break; + } + if (!previousIndexGroupId) { + return null; + } + if (index > 0) { + if (previousIndexSharesLevel(dataType, index - 1, level, previousIndexGroupId) && previousIndexGroupId != id) { + var expanderButton = document.createElement('DIV'); + dom.addClass(expanderButton, classes.expandButton); + expanderButton.id = 'htExpand-' + previousIndexGroupId; + expanderButton.appendChild(document.createTextNode('+')); + expanderButton.setAttribute('data-level', level); + expanderButton.setAttribute('data-type', dataType); + expanderButton.setAttribute('data-hidden', "1"); + elem.appendChild(expanderButton); + return expanderButton; + } + } + return null; + }; + var isCollapsed = function(currentPosition) { + var rowGroups = getRowGroups(), + colGroups = getColGroups(); + for (var i = 0, + rowGroupsCount = rowGroups.length; i < rowGroupsCount; i++) { + if (rowGroups[i].rows.indexOf(currentPosition.row) > -1 && rowGroups[i].hidden) { + return true; + } + } + if (currentPosition.col === null) { + return false; + } + for (var i = 0, + colGroupsCount = colGroups.length; i < colGroupsCount; i++) { + if (colGroups[i].cols.indexOf(currentPosition.col) > -1 && colGroups[i].hidden) { + return true; + } + } + return false; + }; + return { + getGroups: function() { + return groups; + }, + getLevels: function() { + return levels; + }, + instance: instance, + baseSpareRows: instance.getSettings().minSpareRows, + baseSpareCols: instance.getSettings().minSpareCols, + getRowGroups: getRowGroups, + getColGroups: getColGroups, + init: function() { + var groupsSetting = instance.getSettings().groups; + if (groupsSetting) { + if (Array.isArray(groupsSetting)) { + Handsontable.Grouping.initGroups(groupsSetting); + } + } + }, + initGroups: function(initialGroups) { + var that = this; + groups = []; + initialGroups.forEach(function(item) { + var _group = [], + isRow = false, + isCol = false; + if (Array.isArray(item.rows)) { + _group = item.rows; + isRow = true; + } else if (Array.isArray(item.cols)) { + _group = item.cols; + isCol = true; + } + var from = _group[0], + to = _group[_group.length - 1]; + if (isRow) { + groupRows(from, to); + } else if (isCol) { + groupCols(from, to); + } + }); + }, + resetGroups: function() { + groups = []; + counters = { + rows: 0, + cols: 0 + }; + levels = { + rows: 0, + cols: 0 + }; + var allOccurrences; + for (var i in classes) { + if (typeof classes[i] != 'function') { + allOccurrences = document.querySelectorAll('.' + classes[i]); + for (var j = 0, + occurrencesLength = allOccurrences.length; j < occurrencesLength; j++) { + dom.removeClass(allOccurrences[j], classes[i]); + } + } + } + var otherClasses = ['htGroupColClosest', 'htGroupCol']; + for (var i = 0, + otherClassesLength = otherClasses.length; i < otherClassesLength; i++) { + allOccurrences = document.querySelectorAll('.' + otherClasses[i]); + for (var j = 0, + occurrencesLength = allOccurrences.length; j < occurrencesLength; j++) { + dom.removeClass(allOccurrences[j], otherClasses[i]); + } + } + }, + updateGroups: function() { + var groupSettings = this.getSettings().groups; + Handsontable.Grouping.resetGroups(); + Handsontable.Grouping.initGroups(groupSettings); + }, + afterGetRowHeader: function(row, TH) { + if (!TH.parentNode) { + return; + } + var currentRowHidden = false; + for (var i = 0, + levels = hiddenRows.length; i < levels; i++) { + if (hiddenRows[i] && hiddenRows[i][row] === true) { + currentRowHidden = true; + } + } + if (currentRowHidden) { + dom.addClass(TH.parentNode, 'hidden'); + } else if (!currentRowHidden && dom.hasClass(TH.parentNode, 'hidden')) { + dom.removeClass(TH.parentNode, 'hidden'); + } + }, + afterGetColHeader: function(col, TH) { + var rowHeaders = this.view.wt.wtSettings.getSetting('rowHeaders').length, + thisColgroup = instance.rootElement.querySelectorAll('colgroup col:nth-child(' + parseInt(col + rowHeaders + 1, 10) + ')'); + if (thisColgroup.length === 0) { + return; + } + var currentColHidden = false; + for (var i = 0, + levels = hiddenCols.length; i < levels; i++) { + if (hiddenCols[i] && hiddenCols[i][col] === true) { + currentColHidden = true; + } + } + if (currentColHidden) { + for (var i = 0, + colsAmount = thisColgroup.length; i < colsAmount; i++) { + dom.addClass(thisColgroup[i], 'hidden'); + } + } else if (!currentColHidden && dom.hasClass(thisColgroup[0], 'hidden')) { + for (var i = 0, + colsAmount = thisColgroup.length; i < colsAmount; i++) { + dom.removeClass(thisColgroup[i], 'hidden'); + } + } + }, + groupIndicatorsFactory: function(renderersArr, direction) { + var groupsLevelsList, + getCurrentLevel, + getCurrentGroupId, + dataType, + getGroupByIndexAndLevel, + headersType, + currentHeaderModifier, + createLevelTriggers; + switch (direction) { + case 'horizontal': + groupsLevelsList = Handsontable.Grouping.getGroupLevelsByCols(); + getCurrentLevel = function(elem) { + return Array.prototype.indexOf.call(elem.parentNode.parentNode.childNodes, elem.parentNode) + 1; + }; + getCurrentGroupId = function(col, level) { + return getGroupByColAndLevel(col, level).id; + }; + dataType = 'cols'; + getGroupByIndexAndLevel = function(col, level) { + return getGroupByColAndLevel(col - 1, level); + }; + headersType = "columnHeaders"; + currentHeaderModifier = function(headerRenderers) { + if (headerRenderers.length === 1) { + var oldFn = headerRenderers[0]; + headerRenderers[0] = function(index, elem, level) { + if (index < -1) { + makeGroupIndicatorsForLevel()(index, elem, level); + } else { + dom.removeClass(elem, classes.groupIndicatorContainer); + oldFn(index, elem, level); + } + }; + } + return function() { + return headerRenderers; + }; + }; + createLevelTriggers = true; + break; + case 'vertical': + groupsLevelsList = Handsontable.Grouping.getGroupLevelsByRows(); + getCurrentLevel = function(elem) { + return dom.index(elem) + 1; + }; + getCurrentGroupId = function(row, level) { + return getGroupByRowAndLevel(row, level).id; + }; + dataType = 'rows'; + getGroupByIndexAndLevel = function(row, level) { + return getGroupByRowAndLevel(row - 1, level); + }; + headersType = "rowHeaders"; + currentHeaderModifier = function(headerRenderers) { + return headerRenderers; + }; + break; + } + var createButton = function(parent) { + var button = document.createElement('div'); + parent.appendChild(button); + return { + button: button, + addClass: function(className) { + dom.addClass(button, className); + } + }; + }; + var makeGroupIndicatorsForLevel = function() { + var directionClassname = direction.charAt(0).toUpperCase() + direction.slice(1); + return function(index, elem, level) { + level++; + var child, + collapseButton; + while (child = elem.lastChild) { + elem.removeChild(child); + } + dom.addClass(elem, classes.groupIndicatorContainer); + var currentGroupId = getCurrentGroupId(index, level); + if (index > -1 && (groupsLevelsList[index] && groupsLevelsList[index].indexOf(level) > -1)) { + collapseButton = createButton(elem); + collapseButton.addClass(classes.groupIndicator(directionClassname)); + if (isFirstIndexOfTheLine(dataType, index, level, currentGroupId)) { + collapseButton.addClass(classes.groupStart); + } + if (isLastIndexOfTheLine(dataType, index, level, currentGroupId)) { + collapseButton.button.appendChild(document.createTextNode('-')); + collapseButton.addClass(classes.collapseButton); + collapseButton.button.id = classes.collapseGroupId(currentGroupId); + collapseButton.button.setAttribute('data-level', level); + collapseButton.button.setAttribute('data-type', dataType); + } + } + if (createLevelTriggers) { + var rowInd = dom.index(elem.parentNode); + if (index === -1 || (index < -1 && rowInd === Handsontable.Grouping.getLevels().cols + 1) || (rowInd === 0 && Handsontable.Grouping.getLevels().cols === 0)) { + collapseButton = createButton(elem); + collapseButton.addClass(classes.levelTrigger); + if (index === -1) { + collapseButton.button.id = classes.collapseFromLevel("Cols", level); + collapseButton.button.appendChild(document.createTextNode(level)); + } else if (index < -1 && rowInd === Handsontable.Grouping.getLevels().cols + 1 || (rowInd === 0 && Handsontable.Grouping.getLevels().cols === 0)) { + var colInd = dom.index(elem) + 1; + collapseButton.button.id = classes.collapseFromLevel("Rows", colInd); + collapseButton.button.appendChild(document.createTextNode(colInd)); + } + } + } + var expanderButton = addGroupExpander(dataType, index, level, currentGroupId, elem); + if (index > 0) { + var previousGroupObj = getGroupByIndexAndLevel(index - 1, level); + if (expanderButton && previousGroupObj.hidden) { + dom.addClass(expanderButton, classes.clickable); + } + } + updateHeaderWidths(); + }; + }; + renderersArr = currentHeaderModifier(renderersArr); + if (counters[dataType] > 0) { + for (var i = 0; i < levels[dataType] + 1; i++) { + if (!Array.isArray(renderersArr)) { + renderersArr = typeof renderersArr === 'function' ? renderersArr() : new Array(renderersArr); + } + renderersArr.unshift(makeGroupIndicatorsForLevel()); + } + } + }, + getGroupLevelsByRows: function() { + var rowGroups = getRowGroups(), + result = []; + for (var i = 0, + groupsLength = rowGroups.length; i < groupsLength; i++) { + if (rowGroups[i].rows) { + for (var j = 0, + groupRowsLength = rowGroups[i].rows.length; j < groupRowsLength; j++) { + if (!result[rowGroups[i].rows[j]]) { + result[rowGroups[i].rows[j]] = []; + } + result[rowGroups[i].rows[j]].push(rowGroups[i].level); + } + } + } + return result; + }, + getGroupLevelsByCols: function() { + var colGroups = getColGroups(), + result = []; + for (var i = 0, + groupsLength = colGroups.length; i < groupsLength; i++) { + if (colGroups[i].cols) { + for (var j = 0, + groupColsLength = colGroups[i].cols.length; j < groupColsLength; j++) { + if (!result[colGroups[i].cols[j]]) { + result[colGroups[i].cols[j]] = []; + } + result[colGroups[i].cols[j]].push(colGroups[i].level); + } + } + } + return result; + }, + toggleGroupVisibility: function(event, coords, TD) { + if (dom.hasClass(event.target, classes.expandButton) || dom.hasClass(event.target, classes.collapseButton) || dom.hasClass(event.target, classes.levelTrigger)) { + var element = event.target, + elemIdSplit = element.id.split('-'); + var groups = [], + id, + level, + type, + hidden; + var prepareGroupData = function(componentElement) { + if (componentElement) { + element = componentElement; + } + elemIdSplit = element.id.split('-'); + id = elemIdSplit[1]; + level = parseInt(element.getAttribute('data-level'), 10); + type = element.getAttribute('data-type'); + hidden = parseInt(element.getAttribute('data-hidden')); + if (isNaN(hidden)) { + hidden = 1; + } else { + hidden = (hidden ? 0 : 1); + } + element.setAttribute('data-hidden', hidden.toString()); + groups.push(getGroupById(id)); + }; + if (element.className.indexOf(classes.levelTrigger) > -1) { + var groupsInLevel, + groupsToExpand = [], + groupsToCollapse = [], + levelType = element.id.indexOf("Rows") > -1 ? "rows" : "cols"; + for (var i = 1, + levelsCount = levels[levelType]; i <= levelsCount; i++) { + groupsInLevel = levelType == "rows" ? getRowGroupsByLevel(i) : getColGroupsByLevel(i); + if (i >= parseInt(elemIdSplit[1], 10)) { + for (var j = 0, + groupCount = groupsInLevel.length; j < groupCount; j++) { + groupsToCollapse.push(groupsInLevel[j]); + } + } else { + for (var j = 0, + groupCount = groupsInLevel.length; j < groupCount; j++) { + groupsToExpand.push(groupsInLevel[j]); + } + } + } + showHideGroups(true, groupsToCollapse); + showHideGroups(false, groupsToExpand); + } else { + prepareGroupData(); + showHideGroups(hidden, groups); + } + type = type || levelType; + var lastHidden = isLastHidden(type), + typeUppercase = type.charAt(0).toUpperCase() + type.slice(1), + spareElements = Handsontable.Grouping['baseSpare' + typeUppercase]; + if (lastHidden) { + if (spareElements == 0) { + instance.alter('insert_' + type.slice(0, -1), instance['count' + typeUppercase]()); + Handsontable.Grouping["dummy" + type.slice(0, -1)] = true; + } + } else { + if (spareElements == 0) { + if (Handsontable.Grouping["dummy" + type.slice(0, -1)]) { + instance.alter('remove_' + type.slice(0, -1), instance['count' + typeUppercase]() - 1); + Handsontable.Grouping["dummy" + type.slice(0, -1)] = false; + } + } + } + instance.render(); + event.stopImmediatePropagation(); + } + }, + modifySelectionFactory: function(position) { + var instance = this.instance; + var currentlySelected, + nextPosition = new WalkontableCellCoords(0, 0), + nextVisible = function(direction, currentPosition) { + var updateDelta = 0; + switch (direction) { + case 'down': + while (isCollapsed(currentPosition)) { + updateDelta++; + currentPosition.row += 1; + } + break; + case 'up': + while (isCollapsed(currentPosition)) { + updateDelta--; + currentPosition.row -= 1; + } + break; + case 'right': + while (isCollapsed(currentPosition)) { + updateDelta++; + currentPosition.col += 1; + } + break; + case 'left': + while (isCollapsed(currentPosition)) { + updateDelta--; + currentPosition.col -= 1; + } + break; + } + return updateDelta; + }, + updateDelta = function(delta, nextPosition) { + if (delta.row > 0) { + if (isCollapsed(nextPosition)) { + delta.row += nextVisible('down', nextPosition); + } + } else if (delta.row < 0) { + if (isCollapsed(nextPosition)) { + delta.row += nextVisible('up', nextPosition); + } + } + if (delta.col > 0) { + if (isCollapsed(nextPosition)) { + delta.col += nextVisible('right', nextPosition); + } + } else if (delta.col < 0) { + if (isCollapsed(nextPosition)) { + delta.col += nextVisible('left', nextPosition); + } + } + }; + switch (position) { + case 'start': + return function(delta) { + currentlySelected = instance.getSelected(); + nextPosition.row = currentlySelected[0] + delta.row; + nextPosition.col = currentlySelected[1] + delta.col; + updateDelta(delta, nextPosition); + }; + break; + case 'end': + return function(delta) { + currentlySelected = instance.getSelected(); + nextPosition.row = currentlySelected[2] + delta.row; + nextPosition.col = currentlySelected[3] + delta.col; + updateDelta(delta, nextPosition); + }; + break; + } + }, + modifyRowHeight: function(height, row) { + if (instance.view.wt.wtTable.rowFilter && isCollapsed({ + row: row, + col: null + })) { + return 0; + } + }, + validateGroups: function() { + var areRangesOverlapping = function(a, b) { + if ((a[0] < b[0] && a[1] < b[1] && b[0] <= a[1]) || (a[0] > b[0] && b[1] < a[1] && a[0] <= b[1])) { + return true; + } + }; + var configGroups = instance.getSettings().groups, + cols = [], + rows = []; + for (var i = 0, + groupsLength = configGroups.length; i < groupsLength; i++) { + if (configGroups[i].rows) { + if (configGroups[i].rows.length === 1) { + throw new Error("Grouping error: Group {" + configGroups[i].rows[0] + "} is invalid. Cannot define single-entry groups."); + return false; + } else if (configGroups[i].rows.length === 0) { + throw new Error("Grouping error: Cannot define empty groups."); + return false; + } + rows.push(configGroups[i].rows); + for (var j = 0, + rowsLength = rows.length; j < rowsLength; j++) { + if (areRangesOverlapping(configGroups[i].rows, rows[j])) { + throw new Error("Grouping error: ranges {" + configGroups[i].rows[0] + ", " + configGroups[i].rows[1] + "} and {" + rows[j][0] + ", " + rows[j][1] + "} are overlapping."); + return false; + } + } + } else if (configGroups[i].cols) { + if (configGroups[i].cols.length === 1) { + throw new Error("Grouping error: Group {" + configGroups[i].cols[0] + "} is invalid. Cannot define single-entry groups."); + return false; + } else if (configGroups[i].cols.length === 0) { + throw new Error("Grouping error: Cannot define empty groups."); + return false; + } + cols.push(configGroups[i].cols); + for (var j = 0, + colsLength = cols.length; j < colsLength; j++) { + if (areRangesOverlapping(configGroups[i].cols, cols[j])) { + throw new Error("Grouping error: ranges {" + configGroups[i].cols[0] + ", " + configGroups[i].cols[1] + "} and {" + cols[j][0] + ", " + cols[j][1] + "} are overlapping."); + return false; + } + } + } + } + return true; + }, + afterGetRowHeaderRenderers: function(arr) { + Handsontable.Grouping.groupIndicatorsFactory(arr, 'vertical'); + }, + afterGetColumnHeaderRenderers: function(arr) { + Handsontable.Grouping.groupIndicatorsFactory(arr, 'horizontal'); + }, + hookProxy: function(fn, arg) { + return function() { + if (instance.getSettings().groups) { + return arg ? Handsontable.Grouping[fn](arg).apply(this, arguments) : Handsontable.Grouping[fn].apply(this, arguments); + } else { + return void 0; + } + }; + } + }; +} +Grouping.prototype.beforeInit = function() {}; +var init = function() { + var instance = this, + groupingSetting = !!(instance.getSettings().groups); + if (groupingSetting) { + var headerUpdates = {}; + Handsontable.Grouping = new Grouping(instance); + if (!instance.getSettings().rowHeaders) { + headerUpdates.rowHeaders = true; + } + if (!instance.getSettings().colHeaders) { + headerUpdates.colHeaders = true; + } + if (headerUpdates.colHeaders || headerUpdates.rowHeaders) { + instance.updateSettings(headerUpdates); + } + var groupConfigValid = Handsontable.Grouping.validateGroups(); + if (!groupConfigValid) { + return; + } + instance.addHook('beforeInit', Handsontable.Grouping.hookProxy('init')); + instance.addHook('afterUpdateSettings', Handsontable.Grouping.hookProxy('updateGroups')); + instance.addHook('afterGetColumnHeaderRenderers', Handsontable.Grouping.hookProxy('afterGetColumnHeaderRenderers')); + instance.addHook('afterGetRowHeaderRenderers', Handsontable.Grouping.hookProxy('afterGetRowHeaderRenderers')); + instance.addHook('afterGetRowHeader', Handsontable.Grouping.hookProxy('afterGetRowHeader')); + instance.addHook('afterGetColHeader', Handsontable.Grouping.hookProxy('afterGetColHeader')); + instance.addHook('beforeOnCellMouseDown', Handsontable.Grouping.hookProxy('toggleGroupVisibility')); + instance.addHook('modifyTransformStart', Handsontable.Grouping.hookProxy('modifySelectionFactory', 'start')); + instance.addHook('modifyTransformEnd', Handsontable.Grouping.hookProxy('modifySelectionFactory', 'end')); + instance.addHook('modifyRowHeight', Handsontable.Grouping.hookProxy('modifyRowHeight')); + } +}; +var updateHeaderWidths = function() { + var colgroups = document.querySelectorAll('colgroup'); + for (var i = 0, + colgroupsLength = colgroups.length; i < colgroupsLength; i++) { + var rowHeaders = colgroups[i].querySelectorAll('col.rowHeader'); + if (rowHeaders.length === 0) { + return; + } + for (var j = 0, + rowHeadersLength = rowHeaders.length + 1; j < rowHeadersLength; j++) { + if (rowHeadersLength == 2) { + return; + } + if (j < Handsontable.Grouping.getLevels().rows + 1) { + if (j == Handsontable.Grouping.getLevels().rows) { + dom.addClass(rowHeaders[j], 'htGroupColClosest'); + } else { + dom.addClass(rowHeaders[j], 'htGroupCol'); + } + } + } + } +}; +Handsontable.hooks.add('beforeInit', init); +Handsontable.hooks.add('afterUpdateSettings', function() { + if (this.getSettings().groups && !Handsontable.Grouping) { + init.call(this, arguments); + } else if (!this.getSettings().groups && Handsontable.Grouping) { + Handsontable.Grouping.resetGroups(); + Handsontable.Grouping = void 0; + } +}); +Handsontable.plugins.Grouping = Grouping; + +//# +},{"dom.js":27,"plugins.js":45}],59:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + ManualColumnFreeze: {get: function() { + return ManualColumnFreeze; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_plugins_46_js__; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +; +function ManualColumnFreeze(instance) { + var fixedColumnsCount = instance.getSettings().fixedColumnsLeft; + var init = function() { + if (typeof instance.manualColumnPositionsPluginUsages !== 'undefined') { + instance.manualColumnPositionsPluginUsages.push('manualColumnFreeze'); + } else { + instance.manualColumnPositionsPluginUsages = ['manualColumnFreeze']; + } + bindHooks(); + }; + function addContextMenuEntry(defaultOptions) { + defaultOptions.items.push(Handsontable.ContextMenu.SEPARATOR, { + key: 'freeze_column', + name: function() { + var selectedColumn = instance.getSelected()[1]; + if (selectedColumn > fixedColumnsCount - 1) { + return 'Freeze this column'; + } else { + return 'Unfreeze this column'; + } + }, + disabled: function() { + var selection = instance.getSelected(); + return selection[1] !== selection[3]; + }, + callback: function() { + var selectedColumn = instance.getSelected()[1]; + if (selectedColumn > fixedColumnsCount - 1) { + freezeColumn(selectedColumn); + } else { + unfreezeColumn(selectedColumn); + } + } + }); + } + function addFixedColumn() { + instance.updateSettings({fixedColumnsLeft: fixedColumnsCount + 1}); + fixedColumnsCount++; + } + function removeFixedColumn() { + instance.updateSettings({fixedColumnsLeft: fixedColumnsCount - 1}); + fixedColumnsCount--; + } + function checkPositionData(col) { + if (!instance.manualColumnPositions || instance.manualColumnPositions.length === 0) { + if (!instance.manualColumnPositions) { + instance.manualColumnPositions = []; + } + } + if (col) { + if (!instance.manualColumnPositions[col]) { + createPositionData(col + 1); + } + } else { + createPositionData(instance.countCols()); + } + } + function createPositionData(len) { + if (instance.manualColumnPositions.length < len) { + for (var i = instance.manualColumnPositions.length; i < len; i++) { + instance.manualColumnPositions[i] = i; + } + } + } + function modifyColumnOrder(col, actualCol, returnCol, action) { + if (returnCol == null) { + returnCol = col; + } + if (action === 'freeze') { + instance.manualColumnPositions.splice(fixedColumnsCount, 0, instance.manualColumnPositions.splice(actualCol, 1)[0]); + } else if (action === 'unfreeze') { + instance.manualColumnPositions.splice(returnCol, 0, instance.manualColumnPositions.splice(actualCol, 1)[0]); + } + } + function getBestColumnReturnPosition(col) { + var i = fixedColumnsCount, + j = getModifiedColumnIndex(i), + initialCol = getModifiedColumnIndex(col); + while (j < initialCol) { + i++; + j = getModifiedColumnIndex(i); + } + return i - 1; + } + function freezeColumn(col) { + if (col <= fixedColumnsCount - 1) { + return; + } + var modifiedColumn = getModifiedColumnIndex(col) || col; + checkPositionData(modifiedColumn); + modifyColumnOrder(modifiedColumn, col, null, 'freeze'); + addFixedColumn(); + instance.view.wt.wtOverlays.leftOverlay.refresh(); + instance.view.wt.wtOverlays.adjustElementsSize(); + } + function unfreezeColumn(col) { + if (col > fixedColumnsCount - 1) { + return; + } + var returnCol = getBestColumnReturnPosition(col); + var modifiedColumn = getModifiedColumnIndex(col) || col; + checkPositionData(modifiedColumn); + modifyColumnOrder(modifiedColumn, col, returnCol, 'unfreeze'); + removeFixedColumn(); + instance.view.wt.wtOverlays.leftOverlay.refresh(); + } + function getModifiedColumnIndex(col) { + return instance.manualColumnPositions[col]; + } + function onModifyCol(col) { + if (this.manualColumnPositionsPluginUsages.length > 1) { + return col; + } + return getModifiedColumnIndex(col); + } + function bindHooks() { + instance.addHook('modifyCol', onModifyCol); + instance.addHook('afterContextMenuDefaultOptions', addContextMenuEntry); + } + return { + init: init, + freezeColumn: freezeColumn, + unfreezeColumn: unfreezeColumn, + helpers: { + addFixedColumn: addFixedColumn, + removeFixedColumn: removeFixedColumn, + checkPositionData: checkPositionData, + modifyColumnOrder: modifyColumnOrder, + getBestColumnReturnPosition: getBestColumnReturnPosition + } + }; +} +var init = function init() { + if (!this.getSettings().manualColumnFreeze) { + return; + } + var mcfPlugin; + Handsontable.plugins.manualColumnFreeze = ManualColumnFreeze; + this.manualColumnFreeze = new ManualColumnFreeze(this); + mcfPlugin = this.manualColumnFreeze; + mcfPlugin.init.call(this); +}; +Handsontable.hooks.add('beforeInit', init); + +//# +},{"plugins.js":45}],60:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + ManualColumnMove: {get: function() { + return ManualColumnMove; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_helpers_46_js__, + $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47_eventManager_46_js__, + $___46__46__47__46__46__47_plugins_46_js__; +var helper = ($___46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47_helpers_46_js__}); +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var eventManagerObject = ($___46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47_eventManager_46_js__}).eventManager; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +; +function ManualColumnMove() { + var startCol, + endCol, + startX, + startOffset, + currentCol, + instance, + currentTH, + handle = document.createElement('DIV'), + guide = document.createElement('DIV'), + eventManager = eventManagerObject(this); + handle.className = 'manualColumnMover'; + guide.className = 'manualColumnMoverGuide'; + var saveManualColumnPositions = function() { + var instance = this; + Handsontable.hooks.run(instance, 'persistentStateSave', 'manualColumnPositions', instance.manualColumnPositions); + }; + var loadManualColumnPositions = function() { + var instance = this; + var storedState = {}; + Handsontable.hooks.run(instance, 'persistentStateLoad', 'manualColumnPositions', storedState); + return storedState.value; + }; + function setupHandlePosition(TH) { + instance = this; + currentTH = TH; + var col = this.view.wt.wtTable.getCoords(TH).col; + if (col >= 0 && this.disabledColumns.indexOf(col) === -1) { + currentCol = col; + var box = currentTH.getBoundingClientRect(); + startOffset = box.left; + handle.style.top = box.top + 'px'; + handle.style.left = startOffset + 'px'; + instance.rootElement.appendChild(handle); + } + } + function refreshHandlePosition(TH, delta) { + var box = TH.getBoundingClientRect(); + var handleWidth = 6; + if (delta > 0) { + handle.style.left = (box.left + box.width - handleWidth) + 'px'; + } else { + handle.style.left = box.left + 'px'; + } + } + function setupGuidePosition() { + var instance = this; + dom.addClass(handle, 'active'); + dom.addClass(guide, 'active'); + var box = currentTH.getBoundingClientRect(); + guide.style.width = box.width + 'px'; + guide.style.height = instance.view.maximumVisibleElementHeight(0) + 'px'; + guide.style.top = handle.style.top; + guide.style.left = startOffset + 'px'; + instance.rootElement.appendChild(guide); + } + function refreshGuidePosition(diff) { + guide.style.left = startOffset + diff + 'px'; + } + function hideHandleAndGuide() { + dom.removeClass(handle, 'active'); + dom.removeClass(guide, 'active'); + } + var checkColumnHeader = function(element) { + if (element.tagName != 'BODY') { + if (element.parentNode.tagName == 'THEAD') { + return true; + } else { + element = element.parentNode; + return checkColumnHeader(element); + } + } + return false; + }; + var getTHFromTargetElement = function(element) { + if (element.tagName != 'TABLE') { + if (element.tagName == 'TH') { + return element; + } else { + return getTHFromTargetElement(element.parentNode); + } + } + return null; + }; + var bindEvents = function() { + var instance = this; + var pressed; + eventManager.addEventListener(instance.rootElement, 'mouseover', function(e) { + if (checkColumnHeader(e.target)) { + var th = getTHFromTargetElement(e.target); + if (th) { + if (pressed) { + var col = instance.view.wt.wtTable.getCoords(th).col; + if (col >= 0) { + if (instance.disabledColumns.indexOf(col) === -1 || col == startCol || col < startCol && instance.disabledColumns.indexOf(col - 1) === -1 || col > startCol && instance.disabledColumns.indexOf(col + 1) === -1) { + endCol = col; + refreshHandlePosition(e.target, endCol - startCol); + } + } + } else { + setupHandlePosition.call(instance, th); + } + } + } + }); + eventManager.addEventListener(instance.rootElement, 'mousedown', function(e) { + if (dom.hasClass(e.target, 'manualColumnMover')) { + startX = helper.pageX(e); + setupGuidePosition.call(instance); + pressed = instance; + startCol = currentCol; + endCol = currentCol; + } + }); + eventManager.addEventListener(window, 'mousemove', function(e) { + if (pressed) { + refreshGuidePosition(helper.pageX(e) - startX); + } + }); + eventManager.addEventListener(window, 'mouseup', function(e) { + if (pressed) { + hideHandleAndGuide(); + pressed = false; + createPositionData(instance.manualColumnPositions, instance.countCols()); + instance.manualColumnPositions.splice(endCol, 0, instance.manualColumnPositions.splice(startCol, 1)[0]); + Handsontable.hooks.run(instance, 'beforeColumnMove', startCol, endCol); + instance.forceFullRender = true; + instance.view.render(); + saveManualColumnPositions.call(instance); + Handsontable.hooks.run(instance, 'afterColumnMove', startCol, endCol); + setupHandlePosition.call(instance, currentTH); + } + }); + instance.addHook('afterDestroy', unbindEvents); + }; + var unbindEvents = function() { + eventManager.clear(); + }; + var createPositionData = function(positionArr, len) { + if (positionArr.length < len) { + for (var i = positionArr.length; i < len; i++) { + positionArr[i] = i; + } + } + }; + this.beforeInit = function() { + this.manualColumnPositions = []; + }; + this.init = function(source) { + var instance = this; + var manualColMoveEnabled = !!(this.getSettings().manualColumnMove); + if (manualColMoveEnabled) { + var initialManualColumnPositions = this.getSettings().manualColumnMove; + this.disabledColumns = instance.getSettings().manualColumnMoveDisable; + if (!Array.isArray(this.disabledColumns)) { + this.disabledColumns = []; + } + var loadedManualColumnPositions = loadManualColumnPositions.call(instance); + if (typeof loadedManualColumnPositions != 'undefined') { + this.manualColumnPositions = loadedManualColumnPositions; + } else if (Array.isArray(initialManualColumnPositions)) { + this.manualColumnPositions = initialManualColumnPositions; + } else { + this.manualColumnPositions = []; + } + if (source == 'afterInit') { + if (typeof instance.manualColumnPositionsPluginUsages != 'undefined') { + instance.manualColumnPositionsPluginUsages.push('manualColumnMove'); + } else { + instance.manualColumnPositionsPluginUsages = ['manualColumnMove']; + } + bindEvents.call(this); + if (this.manualColumnPositions.length > 0) { + this.forceFullRender = true; + this.render(); + } + } + } else { + var pluginUsagesIndex = instance.manualColumnPositionsPluginUsages ? instance.manualColumnPositionsPluginUsages.indexOf('manualColumnMove') : -1; + if (pluginUsagesIndex > -1) { + unbindEvents.call(this); + this.manualColumnPositions = []; + instance.manualColumnPositionsPluginUsages[pluginUsagesIndex] = void 0; + } + } + }; + this.modifyCol = function(col) { + if (this.getSettings().manualColumnMove) { + if (typeof this.manualColumnPositions[col] === 'undefined') { + createPositionData(this.manualColumnPositions, col + 1); + } + return this.manualColumnPositions[col]; + } + return col; + }; + this.afterRemoveCol = function(index, amount) { + if (!this.getSettings().manualColumnMove) { + return; + } + var rmindx, + colpos = this.manualColumnPositions; + rmindx = colpos.splice(index, amount); + colpos = colpos.map(function(colpos) { + var i, + newpos = colpos; + for (i = 0; i < rmindx.length; i++) { + if (colpos > rmindx[i]) { + newpos--; + } + } + return newpos; + }); + this.manualColumnPositions = colpos; + }; + this.afterCreateCol = function(index, amount) { + if (!this.getSettings().manualColumnMove) { + return; + } + var colpos = this.manualColumnPositions; + if (!colpos.length) { + return; + } + var addindx = []; + for (var i = 0; i < amount; i++) { + addindx.push(index + i); + } + if (index >= colpos.length) { + colpos.concat(addindx); + } else { + colpos = colpos.map(function(colpos) { + return (colpos >= index) ? (colpos + amount) : colpos; + }); + colpos.splice.apply(colpos, [index, 0].concat(addindx)); + } + this.manualColumnPositions = colpos; + }; +} +var htManualColumnMove = new ManualColumnMove(); +Handsontable.hooks.add('beforeInit', htManualColumnMove.beforeInit); +Handsontable.hooks.add('afterInit', function() { + htManualColumnMove.init.call(this, 'afterInit'); +}); +Handsontable.hooks.add('afterUpdateSettings', function() { + htManualColumnMove.init.call(this, 'afterUpdateSettings'); +}); +Handsontable.hooks.add('modifyCol', htManualColumnMove.modifyCol); +Handsontable.hooks.add('afterRemoveCol', htManualColumnMove.afterRemoveCol); +Handsontable.hooks.add('afterCreateCol', htManualColumnMove.afterCreateCol); +Handsontable.hooks.register('beforeColumnMove'); +Handsontable.hooks.register('afterColumnMove'); + +//# +},{"dom.js":27,"eventManager.js":41,"helpers.js":42,"plugins.js":45}],61:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + ManualColumnResize: {get: function() { + return ManualColumnResize; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_helpers_46_js__, + $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47_eventManager_46_js__, + $___46__46__47__46__46__47_plugins_46_js__; +var helper = ($___46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47_helpers_46_js__}); +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var eventManagerObject = ($___46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47_eventManager_46_js__}).eventManager; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +; +function ManualColumnResize() { + var currentTH, + currentCol, + currentWidth, + instance, + newSize, + startX, + startWidth, + startOffset, + handle = document.createElement('DIV'), + guide = document.createElement('DIV'), + eventManager = eventManagerObject(this); + handle.className = 'manualColumnResizer'; + guide.className = 'manualColumnResizerGuide'; + var saveManualColumnWidths = function() { + var instance = this; + Handsontable.hooks.run(instance, 'persistentStateSave', 'manualColumnWidths', instance.manualColumnWidths); + }; + var loadManualColumnWidths = function() { + var instance = this; + var storedState = {}; + Handsontable.hooks.run(instance, 'persistentStateLoad', 'manualColumnWidths', storedState); + return storedState.value; + }; + function setupHandlePosition(TH) { + instance = this; + currentTH = TH; + var col = this.view.wt.wtTable.getCoords(TH).col; + if (col >= 0) { + currentCol = col; + var box = currentTH.getBoundingClientRect(); + startOffset = box.left - 6; + startWidth = parseInt(box.width, 10); + handle.style.top = box.top + 'px'; + handle.style.left = startOffset + startWidth + 'px'; + instance.rootElement.appendChild(handle); + } + } + function refreshHandlePosition() { + handle.style.left = startOffset + currentWidth + 'px'; + } + function setupGuidePosition() { + var instance = this; + dom.addClass(handle, 'active'); + dom.addClass(guide, 'active'); + guide.style.top = handle.style.top; + guide.style.left = handle.style.left; + guide.style.height = instance.view.maximumVisibleElementHeight(0) + 'px'; + instance.rootElement.appendChild(guide); + } + function refreshGuidePosition() { + guide.style.left = handle.style.left; + } + function hideHandleAndGuide() { + dom.removeClass(handle, 'active'); + dom.removeClass(guide, 'active'); + } + var checkColumnHeader = function(element) { + if (element.tagName != 'BODY') { + if (element.parentNode.tagName == 'THEAD') { + return true; + } else { + element = element.parentNode; + return checkColumnHeader(element); + } + } + return false; + }; + var getTHFromTargetElement = function(element) { + if (element.tagName != 'TABLE') { + if (element.tagName == 'TH') { + return element; + } else { + return getTHFromTargetElement(element.parentNode); + } + } + return null; + }; + var bindEvents = function() { + var instance = this; + var pressed; + var dblclick = 0; + var autoresizeTimeout = null; + eventManager.addEventListener(instance.rootElement, 'mouseover', function(e) { + if (checkColumnHeader(e.target)) { + var th = getTHFromTargetElement(e.target); + if (th) { + if (!pressed) { + setupHandlePosition.call(instance, th); + } + } + } + }); + eventManager.addEventListener(instance.rootElement, 'mousedown', function(e) { + if (dom.hasClass(e.target, 'manualColumnResizer')) { + setupGuidePosition.call(instance); + pressed = instance; + if (autoresizeTimeout == null) { + autoresizeTimeout = setTimeout(function() { + if (dblclick >= 2) { + var hookNewSize = Handsontable.hooks.run(instance, 'beforeColumnResize', currentCol, newSize, true); + if (hookNewSize !== void 0) { + newSize = hookNewSize; + } + setManualSize(currentCol, newSize); + instance.forceFullRender = true; + instance.view.render(); + instance.view.wt.wtOverlays.adjustElementsSize(true); + Handsontable.hooks.run(instance, 'afterColumnResize', currentCol, newSize, true); + } + dblclick = 0; + autoresizeTimeout = null; + }, 500); + instance._registerTimeout(autoresizeTimeout); + } + dblclick++; + startX = helper.pageX(e); + newSize = startWidth; + } + }); + eventManager.addEventListener(window, 'mousemove', function(e) { + if (pressed) { + currentWidth = startWidth + (helper.pageX(e) - startX); + newSize = setManualSize(currentCol, currentWidth); + refreshHandlePosition(); + refreshGuidePosition(); + } + }); + eventManager.addEventListener(window, 'mouseup', function() { + if (pressed) { + hideHandleAndGuide(); + pressed = false; + if (newSize != startWidth) { + Handsontable.hooks.run(instance, 'beforeColumnResize', currentCol, newSize); + instance.forceFullRender = true; + instance.view.render(); + instance.view.wt.wtOverlays.adjustElementsSize(true); + saveManualColumnWidths.call(instance); + Handsontable.hooks.run(instance, 'afterColumnResize', currentCol, newSize); + } + setupHandlePosition.call(instance, currentTH); + } + }); + instance.addHook('afterDestroy', unbindEvents); + }; + var unbindEvents = function() { + eventManager.clear(); + }; + this.init = function(source) { + this.manualColumnWidths = []; + var instance = this; + var manualColumnWidthEnabled = !!(this.getSettings().manualColumnResize); + if (manualColumnWidthEnabled) { + var initialColumnWidths = this.getSettings().manualColumnResize; + var loadedManualColumnWidths = loadManualColumnWidths.call(instance); + if (typeof instance.manualColumnWidthsPluginUsages != 'undefined') { + instance.manualColumnWidthsPluginUsages.push('manualColumnResize'); + } else { + instance.manualColumnWidthsPluginUsages = ['manualColumnResize']; + } + if (typeof loadedManualColumnWidths != 'undefined') { + this.manualColumnWidths = loadedManualColumnWidths; + } else if (Array.isArray(initialColumnWidths)) { + this.manualColumnWidths = initialColumnWidths; + } else { + this.manualColumnWidths = []; + } + if (!source) { + bindEvents.call(this); + } + } else { + var pluginUsagesIndex = instance.manualColumnWidthsPluginUsages ? instance.manualColumnWidthsPluginUsages.indexOf('manualColumnResize') : -1; + if (pluginUsagesIndex > -1) { + unbindEvents.call(this); + this.manualColumnWidths = []; + } + } + }; + var setManualSize = function(col, width) { + width = Math.max(width, 20); + col = Handsontable.hooks.run(instance, 'modifyCol', col); + instance.manualColumnWidths[col] = width; + return width; + }; + this.modifyColWidth = function(width, col) { + col = this.runHooks('modifyCol', col); + if (this.getSettings().manualColumnResize && this.manualColumnWidths[col]) { + return this.manualColumnWidths[col]; + } + return width; + }; +} +var htManualColumnResize = new ManualColumnResize(); +Handsontable.hooks.add('init', htManualColumnResize.init); +Handsontable.hooks.add('afterUpdateSettings', function() { + htManualColumnResize.init.call(this, 'afterUpdateSettings'); +}); +Handsontable.hooks.add('modifyColWidth', htManualColumnResize.modifyColWidth); +Handsontable.hooks.register('afterColumnResize'); +Handsontable.hooks.register('beforeColumnResize'); + +//# +},{"dom.js":27,"eventManager.js":41,"helpers.js":42,"plugins.js":45}],62:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + ManualRowMove: {get: function() { + return ManualRowMove; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_helpers_46_js__, + $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47_eventManager_46_js__, + $___46__46__47__46__46__47_plugins_46_js__; +var helper = ($___46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47_helpers_46_js__}); +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var eventManagerObject = ($___46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47_eventManager_46_js__}).eventManager; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +; +function ManualRowMove() { + var startRow, + endRow, + startY, + startOffset, + currentRow, + currentTH, + handle = document.createElement('DIV'), + guide = document.createElement('DIV'), + eventManager = eventManagerObject(this); + handle.className = 'manualRowMover'; + guide.className = 'manualRowMoverGuide'; + var saveManualRowPositions = function() { + var instance = this; + Handsontable.hooks.run(instance, 'persistentStateSave', 'manualRowPositions', instance.manualRowPositions); + }; + var loadManualRowPositions = function() { + var instance = this, + storedState = {}; + Handsontable.hooks.run(instance, 'persistentStateLoad', 'manualRowPositions', storedState); + return storedState.value; + }; + function setupHandlePosition(TH) { + var instance = this; + currentTH = TH; + var row = this.view.wt.wtTable.getCoords(TH).row; + if (row >= 0 && this.disabledRows.indexOf(row) === -1) { + currentRow = row; + var box = currentTH.getBoundingClientRect(); + startOffset = box.top; + handle.style.top = startOffset + 'px'; + handle.style.left = box.left + 'px'; + instance.rootElement.appendChild(handle); + } + } + function refreshHandlePosition(TH, delta) { + var box = TH.getBoundingClientRect(); + var handleHeight = 6; + if (delta > 0) { + handle.style.top = (box.top + box.height - handleHeight) + 'px'; + } else { + handle.style.top = box.top + 'px'; + } + } + function setupGuidePosition() { + var instance = this; + dom.addClass(handle, 'active'); + dom.addClass(guide, 'active'); + var box = currentTH.getBoundingClientRect(); + guide.style.width = instance.view.maximumVisibleElementWidth(0) + 'px'; + guide.style.height = box.height + 'px'; + guide.style.top = startOffset + 'px'; + guide.style.left = handle.style.left; + instance.rootElement.appendChild(guide); + } + function refreshGuidePosition(diff) { + guide.style.top = startOffset + diff + 'px'; + } + function hideHandleAndGuide() { + dom.removeClass(handle, 'active'); + dom.removeClass(guide, 'active'); + } + var checkRowHeader = function(element) { + if (element.tagName != 'BODY') { + if (element.parentNode.tagName == 'TBODY') { + return true; + } else { + element = element.parentNode; + return checkRowHeader(element); + } + } + return false; + }; + var getTHFromTargetElement = function(element) { + if (element.tagName != 'TABLE') { + if (element.tagName == 'TH') { + return element; + } else { + return getTHFromTargetElement(element.parentNode); + } + } + return null; + }; + var bindEvents = function() { + var instance = this; + var pressed; + eventManager.addEventListener(instance.rootElement, 'mouseover', function(e) { + if (checkRowHeader(e.target)) { + var th = getTHFromTargetElement(e.target); + if (th) { + if (pressed) { + var currentRow = instance.view.wt.wtTable.getCoords(th).row; + if (instance.disabledRows.indexOf(currentRow) === -1 || currentRow == startRow || currentRow < startRow && instance.disabledRows.indexOf(currentRow - 1) === -1 || currentRow > startRow && instance.disabledRows.indexOf(currentRow + 1) === -1) { + refreshHandlePosition(th, currentRow - startRow); + endRow = currentRow; + } + } else { + setupHandlePosition.call(instance, th); + } + } + } + }); + eventManager.addEventListener(instance.rootElement, 'mousedown', function(e) { + if (dom.hasClass(e.target, 'manualRowMover')) { + startY = helper.pageY(e); + setupGuidePosition.call(instance); + pressed = instance; + startRow = currentRow; + endRow = currentRow; + } + }); + eventManager.addEventListener(window, 'mousemove', function(e) { + if (pressed) { + refreshGuidePosition(helper.pageY(e) - startY); + } + }); + eventManager.addEventListener(window, 'mouseup', function(e) { + if (pressed) { + hideHandleAndGuide(); + pressed = false; + createPositionData(instance.manualRowPositions, instance.countRows()); + instance.manualRowPositions.splice(endRow, 0, instance.manualRowPositions.splice(startRow, 1)[0]); + Handsontable.hooks.run(instance, 'beforeRowMove', startRow, endRow); + instance.forceFullRender = true; + instance.view.render(); + saveManualRowPositions.call(instance); + Handsontable.hooks.run(instance, 'afterRowMove', startRow, endRow); + setupHandlePosition.call(instance, currentTH); + } + }); + instance.addHook('afterDestroy', unbindEvents); + }; + var unbindEvents = function() { + eventManager.clear(); + }; + var createPositionData = function(positionArr, len) { + if (positionArr.length < len) { + for (var i = positionArr.length; i < len; i++) { + positionArr[i] = i; + } + } + }; + this.beforeInit = function() { + this.manualRowPositions = []; + }; + this.init = function(source) { + var instance = this; + var manualRowMoveEnabled = !!(instance.getSettings().manualRowMove); + if (manualRowMoveEnabled) { + var initialManualRowPositions = instance.getSettings().manualRowMove; + this.disabledRows = instance.getSettings().manualRowMoveDisable; + if (!Array.isArray(this.disabledRows)) { + this.disabledRows = []; + } + var loadedManualRowPostions = loadManualRowPositions.call(instance); + if (typeof instance.manualRowPositionsPluginUsages != 'undefined') { + instance.manualRowPositionsPluginUsages.push('manualColumnMove'); + } else { + instance.manualRowPositionsPluginUsages = ['manualColumnMove']; + } + if (typeof loadedManualRowPostions != 'undefined') { + this.manualRowPositions = loadedManualRowPostions; + } else if (Array.isArray(initialManualRowPositions)) { + this.manualRowPositions = initialManualRowPositions; + } else { + this.manualRowPositions = []; + } + if (source === 'afterInit') { + bindEvents.call(this); + if (this.manualRowPositions.length > 0) { + instance.forceFullRender = true; + instance.render(); + } + } + } else { + var pluginUsagesIndex = instance.manualRowPositionsPluginUsages ? instance.manualRowPositionsPluginUsages.indexOf('manualColumnMove') : -1; + if (pluginUsagesIndex > -1) { + unbindEvents.call(this); + instance.manualRowPositions = []; + instance.manualRowPositionsPluginUsages[pluginUsagesIndex] = void 0; + } + } + }; + this.modifyRow = function(row) { + var instance = this; + if (instance.getSettings().manualRowMove) { + if (typeof instance.manualRowPositions[row] === 'undefined') { + createPositionData(this.manualRowPositions, row + 1); + } + return instance.manualRowPositions[row]; + } + return row; + }; +} +var htManualRowMove = new ManualRowMove(); +Handsontable.hooks.add('beforeInit', htManualRowMove.beforeInit); +Handsontable.hooks.add('afterInit', function() { + htManualRowMove.init.call(this, 'afterInit'); +}); +Handsontable.hooks.add('afterUpdateSettings', function() { + htManualRowMove.init.call(this, 'afterUpdateSettings'); +}); +Handsontable.hooks.add('modifyRow', htManualRowMove.modifyRow); +Handsontable.hooks.register('beforeRowMove'); +Handsontable.hooks.register('afterRowMove'); + +//# +},{"dom.js":27,"eventManager.js":41,"helpers.js":42,"plugins.js":45}],63:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + ManualRowResize: {get: function() { + return ManualRowResize; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_helpers_46_js__, + $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47_eventManager_46_js__, + $___46__46__47__46__46__47_plugins_46_js__; +var helper = ($___46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47_helpers_46_js__}); +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var eventManagerObject = ($___46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47_eventManager_46_js__}).eventManager; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +; +function ManualRowResize() { + var currentTH, + currentRow, + currentHeight, + instance, + newSize, + startY, + startHeight, + startOffset, + handle = document.createElement('DIV'), + guide = document.createElement('DIV'), + eventManager = eventManagerObject(this); + handle.className = 'manualRowResizer'; + guide.className = 'manualRowResizerGuide'; + var saveManualRowHeights = function() { + var instance = this; + Handsontable.hooks.run(instance, 'persistentStateSave', 'manualRowHeights', instance.manualRowHeights); + }; + var loadManualRowHeights = function() { + var instance = this, + storedState = {}; + Handsontable.hooks.run(instance, 'persistentStateLoad', 'manualRowHeights', storedState); + return storedState.value; + }; + function setupHandlePosition(TH) { + instance = this; + currentTH = TH; + var row = this.view.wt.wtTable.getCoords(TH).row; + if (row >= 0) { + currentRow = row; + var box = currentTH.getBoundingClientRect(); + startOffset = box.top - 6; + startHeight = parseInt(box.height, 10); + handle.style.left = box.left + 'px'; + handle.style.top = startOffset + startHeight + 'px'; + instance.rootElement.appendChild(handle); + } + } + function refreshHandlePosition() { + handle.style.top = startOffset + currentHeight + 'px'; + } + function setupGuidePosition() { + var instance = this; + dom.addClass(handle, 'active'); + dom.addClass(guide, 'active'); + guide.style.top = handle.style.top; + guide.style.left = handle.style.left; + guide.style.width = instance.view.maximumVisibleElementWidth(0) + 'px'; + instance.rootElement.appendChild(guide); + } + function refreshGuidePosition() { + guide.style.top = handle.style.top; + } + function hideHandleAndGuide() { + dom.removeClass(handle, 'active'); + dom.removeClass(guide, 'active'); + } + var checkRowHeader = function(element) { + if (element.tagName != 'BODY') { + if (element.parentNode.tagName == 'TBODY') { + return true; + } else { + element = element.parentNode; + return checkRowHeader(element); + } + } + return false; + }; + var getTHFromTargetElement = function(element) { + if (element.tagName != 'TABLE') { + if (element.tagName == 'TH') { + return element; + } else { + return getTHFromTargetElement(element.parentNode); + } + } + return null; + }; + var bindEvents = function() { + var instance = this; + var pressed; + var dblclick = 0; + var autoresizeTimeout = null; + eventManager.addEventListener(instance.rootElement, 'mouseover', function(e) { + if (checkRowHeader(e.target)) { + var th = getTHFromTargetElement(e.target); + if (th) { + if (!pressed) { + setupHandlePosition.call(instance, th); + } + } + } + }); + eventManager.addEventListener(instance.rootElement, 'mousedown', function(e) { + if (dom.hasClass(e.target, 'manualRowResizer')) { + setupGuidePosition.call(instance); + pressed = instance; + if (autoresizeTimeout == null) { + autoresizeTimeout = setTimeout(function() { + if (dblclick >= 2) { + var hookNewSize = Handsontable.hooks.run(instance, 'beforeRowResize', currentRow, newSize, true); + if (hookNewSize !== void 0) { + newSize = hookNewSize; + } + setManualSize(currentRow, newSize); + instance.forceFullRender = true; + instance.view.render(); + Handsontable.hooks.run(instance, 'afterRowResize', currentRow, newSize, true); + } + dblclick = 0; + autoresizeTimeout = null; + }, 500); + instance._registerTimeout(autoresizeTimeout); + } + dblclick++; + startY = helper.pageY(e); + newSize = startHeight; + } + }); + eventManager.addEventListener(window, 'mousemove', function(e) { + if (pressed) { + currentHeight = startHeight + (helper.pageY(e) - startY); + newSize = setManualSize(currentRow, currentHeight); + refreshHandlePosition(); + refreshGuidePosition(); + } + }); + eventManager.addEventListener(window, 'mouseup', function(e) { + if (pressed) { + hideHandleAndGuide(); + pressed = false; + if (newSize != startHeight) { + Handsontable.hooks.run(instance, 'beforeRowResize', currentRow, newSize); + instance.forceFullRender = true; + instance.view.render(); + saveManualRowHeights.call(instance); + Handsontable.hooks.run(instance, 'afterRowResize', currentRow, newSize); + } + setupHandlePosition.call(instance, currentTH); + } + }); + instance.addHook('afterDestroy', unbindEvents); + }; + var unbindEvents = function() { + eventManager.clear(); + }; + this.init = function(source) { + this.manualRowHeights = []; + var instance = this; + var manualColumnHeightEnabled = !!(this.getSettings().manualRowResize); + if (manualColumnHeightEnabled) { + var initialRowHeights = this.getSettings().manualRowResize; + var loadedManualRowHeights = loadManualRowHeights.call(instance); + if (typeof instance.manualRowHeightsPluginUsages != 'undefined') { + instance.manualRowHeightsPluginUsages.push('manualRowResize'); + } else { + instance.manualRowHeightsPluginUsages = ['manualRowResize']; + } + if (typeof loadedManualRowHeights != 'undefined') { + this.manualRowHeights = loadedManualRowHeights; + } else if (Array.isArray(initialRowHeights)) { + this.manualRowHeights = initialRowHeights; + } else { + this.manualRowHeights = []; + } + if (source === void 0) { + bindEvents.call(this); + } + } else { + var pluginUsagesIndex = instance.manualRowHeightsPluginUsages ? instance.manualRowHeightsPluginUsages.indexOf('manualRowResize') : -1; + if (pluginUsagesIndex > -1) { + unbindEvents.call(this); + this.manualRowHeights = []; + instance.manualRowHeightsPluginUsages[pluginUsagesIndex] = void 0; + } + } + }; + var setManualSize = function(row, height) { + row = Handsontable.hooks.run(instance, 'modifyRow', row); + instance.manualRowHeights[row] = height; + return height; + }; + this.modifyRowHeight = function(height, row) { + if (this.getSettings().manualRowResize) { + row = this.runHooks('modifyRow', row); + if (this.manualRowHeights[row] !== void 0) { + return this.manualRowHeights[row]; + } + } + return height; + }; +} +var htManualRowResize = new ManualRowResize(); +Handsontable.hooks.add('init', htManualRowResize.init); +Handsontable.hooks.add('afterUpdateSettings', function() { + htManualRowResize.init.call(this, 'afterUpdateSettings'); +}); +Handsontable.hooks.add('modifyRowHeight', htManualRowResize.modifyRowHeight); +Handsontable.hooks.register('beforeRowResize'); +Handsontable.hooks.register('afterRowResize'); + +//# +},{"dom.js":27,"eventManager.js":41,"helpers.js":42,"plugins.js":45}],64:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + MergeCells: {get: function() { + return MergeCells; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_plugins_46_js__, + $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__, + $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__, + $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_table_46_js__; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +var WalkontableCellCoords = ($___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ = require("3rdparty/walkontable/src/cell/coords.js"), $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__.__esModule && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ || {default: $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__}).WalkontableCellCoords; +var WalkontableCellRange = ($___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ = require("3rdparty/walkontable/src/cell/range.js"), $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__.__esModule && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__ || {default: $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_range_46_js__}).WalkontableCellRange; +var WalkontableTable = ($___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_table_46_js__ = require("3rdparty/walkontable/src/table.js"), $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_table_46_js__ && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_table_46_js__.__esModule && $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_table_46_js__ || {default: $___46__46__47__46__46__47_3rdparty_47_walkontable_47_src_47_table_46_js__}).WalkontableTable; +; +function CellInfoCollection() { + var collection = []; + collection.getInfo = function(row, col) { + for (var i = 0, + ilen = this.length; i < ilen; i++) { + if (this[i].row <= row && this[i].row + this[i].rowspan - 1 >= row && this[i].col <= col && this[i].col + this[i].colspan - 1 >= col) { + return this[i]; + } + } + }; + collection.setInfo = function(info) { + for (var i = 0, + ilen = this.length; i < ilen; i++) { + if (this[i].row === info.row && this[i].col === info.col) { + this[i] = info; + return; + } + } + this.push(info); + }; + collection.removeInfo = function(row, col) { + for (var i = 0, + ilen = this.length; i < ilen; i++) { + if (this[i].row === row && this[i].col === col) { + this.splice(i, 1); + break; + } + } + }; + return collection; +} +function MergeCells(mergeCellsSetting) { + this.mergedCellInfoCollection = new CellInfoCollection(); + if (Array.isArray(mergeCellsSetting)) { + for (var i = 0, + ilen = mergeCellsSetting.length; i < ilen; i++) { + this.mergedCellInfoCollection.setInfo(mergeCellsSetting[i]); + } + } +} +MergeCells.prototype.canMergeRange = function(cellRange) { + return !cellRange.isSingle(); +}; +MergeCells.prototype.mergeRange = function(cellRange) { + if (!this.canMergeRange(cellRange)) { + return; + } + var topLeft = cellRange.getTopLeftCorner(); + var bottomRight = cellRange.getBottomRightCorner(); + var mergeParent = {}; + mergeParent.row = topLeft.row; + mergeParent.col = topLeft.col; + mergeParent.rowspan = bottomRight.row - topLeft.row + 1; + mergeParent.colspan = bottomRight.col - topLeft.col + 1; + this.mergedCellInfoCollection.setInfo(mergeParent); +}; +MergeCells.prototype.mergeOrUnmergeSelection = function(cellRange) { + var info = this.mergedCellInfoCollection.getInfo(cellRange.from.row, cellRange.from.col); + if (info) { + this.unmergeSelection(cellRange.from); + } else { + this.mergeSelection(cellRange); + } +}; +MergeCells.prototype.mergeSelection = function(cellRange) { + this.mergeRange(cellRange); +}; +MergeCells.prototype.unmergeSelection = function(cellRange) { + var info = this.mergedCellInfoCollection.getInfo(cellRange.row, cellRange.col); + this.mergedCellInfoCollection.removeInfo(info.row, info.col); +}; +MergeCells.prototype.applySpanProperties = function(TD, row, col) { + var info = this.mergedCellInfoCollection.getInfo(row, col); + if (info) { + if (info.row === row && info.col === col) { + TD.setAttribute('rowspan', info.rowspan); + TD.setAttribute('colspan', info.colspan); + } else { + TD.removeAttribute('rowspan'); + TD.removeAttribute('colspan'); + TD.style.display = "none"; + } + } else { + TD.removeAttribute('rowspan'); + TD.removeAttribute('colspan'); + } +}; +MergeCells.prototype.modifyTransform = function(hook, currentSelectedRange, delta) { + var sameRowspan = function(merged, coords) { + if (coords.row >= merged.row && coords.row <= (merged.row + merged.rowspan - 1)) { + return true; + } + return false; + }, + sameColspan = function(merged, coords) { + if (coords.col >= merged.col && coords.col <= (merged.col + merged.colspan - 1)) { + return true; + } + return false; + }, + getNextPosition = function(newDelta) { + return new WalkontableCellCoords(currentSelectedRange.to.row + newDelta.row, currentSelectedRange.to.col + newDelta.col); + }; + var newDelta = { + row: delta.row, + col: delta.col + }; + if (hook == 'modifyTransformStart') { + if (!this.lastDesiredCoords) { + this.lastDesiredCoords = new WalkontableCellCoords(null, null); + } + var currentPosition = new WalkontableCellCoords(currentSelectedRange.highlight.row, currentSelectedRange.highlight.col), + mergedParent = this.mergedCellInfoCollection.getInfo(currentPosition.row, currentPosition.col), + currentRangeContainsMerge; + for (var i = 0, + mergesLength = this.mergedCellInfoCollection.length; i < mergesLength; i++) { + var range = this.mergedCellInfoCollection[i]; + range = new WalkontableCellCoords(range.row + range.rowspan - 1, range.col + range.colspan - 1); + if (currentSelectedRange.includes(range)) { + currentRangeContainsMerge = true; + break; + } + } + if (mergedParent) { + var mergeTopLeft = new WalkontableCellCoords(mergedParent.row, mergedParent.col), + mergeBottomRight = new WalkontableCellCoords(mergedParent.row + mergedParent.rowspan - 1, mergedParent.col + mergedParent.colspan - 1), + mergeRange = new WalkontableCellRange(mergeTopLeft, mergeTopLeft, mergeBottomRight); + if (!mergeRange.includes(this.lastDesiredCoords)) { + this.lastDesiredCoords = new WalkontableCellCoords(null, null); + } + newDelta.row = this.lastDesiredCoords.row ? this.lastDesiredCoords.row - currentPosition.row : newDelta.row; + newDelta.col = this.lastDesiredCoords.col ? this.lastDesiredCoords.col - currentPosition.col : newDelta.col; + if (delta.row > 0) { + newDelta.row = mergedParent.row + mergedParent.rowspan - 1 - currentPosition.row + delta.row; + } else if (delta.row < 0) { + newDelta.row = currentPosition.row - mergedParent.row + delta.row; + } + if (delta.col > 0) { + newDelta.col = mergedParent.col + mergedParent.colspan - 1 - currentPosition.col + delta.col; + } else if (delta.col < 0) { + newDelta.col = currentPosition.col - mergedParent.col + delta.col; + } + } + var nextPosition = new WalkontableCellCoords(currentSelectedRange.highlight.row + newDelta.row, currentSelectedRange.highlight.col + newDelta.col), + nextParentIsMerged = this.mergedCellInfoCollection.getInfo(nextPosition.row, nextPosition.col); + if (nextParentIsMerged) { + this.lastDesiredCoords = nextPosition; + newDelta = { + row: nextParentIsMerged.row - currentPosition.row, + col: nextParentIsMerged.col - currentPosition.col + }; + } + } else if (hook == 'modifyTransformEnd') { + for (var i = 0, + mergesLength = this.mergedCellInfoCollection.length; i < mergesLength; i++) { + var currentMerge = this.mergedCellInfoCollection[i], + mergeTopLeft = new WalkontableCellCoords(currentMerge.row, currentMerge.col), + mergeBottomRight = new WalkontableCellCoords(currentMerge.row + currentMerge.rowspan - 1, currentMerge.col + currentMerge.colspan - 1), + mergedRange = new WalkontableCellRange(mergeTopLeft, mergeTopLeft, mergeBottomRight), + sharedBorders = currentSelectedRange.getBordersSharedWith(mergedRange); + if (mergedRange.isEqual(currentSelectedRange)) { + currentSelectedRange.setDirection("NW-SE"); + } else if (sharedBorders.length > 0) { + var mergeHighlighted = (currentSelectedRange.highlight.isEqual(mergedRange.from)); + if (sharedBorders.indexOf('top') > -1) { + if (currentSelectedRange.to.isSouthEastOf(mergedRange.from) && mergeHighlighted) { + currentSelectedRange.setDirection("NW-SE"); + } else if (currentSelectedRange.to.isSouthWestOf(mergedRange.from) && mergeHighlighted) { + currentSelectedRange.setDirection("NE-SW"); + } + } else if (sharedBorders.indexOf('bottom') > -1) { + if (currentSelectedRange.to.isNorthEastOf(mergedRange.from) && mergeHighlighted) { + currentSelectedRange.setDirection("SW-NE"); + } else if (currentSelectedRange.to.isNorthWestOf(mergedRange.from) && mergeHighlighted) { + currentSelectedRange.setDirection("SE-NW"); + } + } + } + var nextPosition = getNextPosition(newDelta), + withinRowspan = sameRowspan(currentMerge, nextPosition), + withinColspan = sameColspan(currentMerge, nextPosition); + if (currentSelectedRange.includesRange(mergedRange) && (mergedRange.includes(nextPosition) || withinRowspan || withinColspan)) { + if (withinRowspan) { + if (newDelta.row < 0) { + newDelta.row -= currentMerge.rowspan - 1; + } else if (newDelta.row > 0) { + newDelta.row += currentMerge.rowspan - 1; + } + } + if (withinColspan) { + if (newDelta.col < 0) { + newDelta.col -= currentMerge.colspan - 1; + } else if (newDelta.col > 0) { + newDelta.col += currentMerge.colspan - 1; + } + } + } + } + } + if (newDelta.row !== 0) { + delta.row = newDelta.row; + } + if (newDelta.col !== 0) { + delta.col = newDelta.col; + } +}; +var beforeInit = function() { + var instance = this; + var mergeCellsSetting = instance.getSettings().mergeCells; + if (mergeCellsSetting) { + if (!instance.mergeCells) { + instance.mergeCells = new MergeCells(mergeCellsSetting); + } + } +}; +var afterInit = function() { + var instance = this; + if (instance.mergeCells) { + instance.view.wt.wtTable.getCell = function(coords) { + if (instance.getSettings().mergeCells) { + var mergeParent = instance.mergeCells.mergedCellInfoCollection.getInfo(coords.row, coords.col); + if (mergeParent) { + coords = mergeParent; + } + } + return WalkontableTable.prototype.getCell.call(this, coords); + }; + } +}; +var onBeforeKeyDown = function(event) { + if (!this.mergeCells) { + return; + } + var ctrlDown = (event.ctrlKey || event.metaKey) && !event.altKey; + if (ctrlDown) { + if (event.keyCode === 77) { + this.mergeCells.mergeOrUnmergeSelection(this.getSelectedRange()); + this.render(); + event.stopImmediatePropagation(); + } + } +}; +var addMergeActionsToContextMenu = function(defaultOptions) { + if (!this.getSettings().mergeCells) { + return; + } + defaultOptions.items.push(Handsontable.ContextMenu.SEPARATOR); + defaultOptions.items.push({ + key: 'mergeCells', + name: function() { + var sel = this.getSelected(); + var info = this.mergeCells.mergedCellInfoCollection.getInfo(sel[0], sel[1]); + if (info) { + return 'Unmerge cells'; + } else { + return 'Merge cells'; + } + }, + callback: function() { + this.mergeCells.mergeOrUnmergeSelection(this.getSelectedRange()); + this.render(); + }, + disabled: function() { + return false; + } + }); +}; +var afterRenderer = function(TD, row, col, prop, value, cellProperties) { + if (this.mergeCells) { + this.mergeCells.applySpanProperties(TD, row, col); + } +}; +var modifyTransformFactory = function(hook) { + return function(delta) { + var mergeCellsSetting = this.getSettings().mergeCells; + if (mergeCellsSetting) { + var currentSelectedRange = this.getSelectedRange(); + this.mergeCells.modifyTransform(hook, currentSelectedRange, delta); + if (hook === "modifyTransformEnd") { + var totalRows = this.countRows(); + var totalCols = this.countCols(); + if (currentSelectedRange.from.row < 0) { + currentSelectedRange.from.row = 0; + } else if (currentSelectedRange.from.row > 0 && currentSelectedRange.from.row >= totalRows) { + currentSelectedRange.from.row = currentSelectedRange.from - 1; + } + if (currentSelectedRange.from.col < 0) { + currentSelectedRange.from.col = 0; + } else if (currentSelectedRange.from.col > 0 && currentSelectedRange.from.col >= totalCols) { + currentSelectedRange.from.col = totalCols - 1; + } + } + } + }; +}; +var beforeSetRangeEnd = function(coords) { + this.lastDesiredCoords = null; + var mergeCellsSetting = this.getSettings().mergeCells; + if (mergeCellsSetting) { + var selRange = this.getSelectedRange(); + selRange.highlight = new WalkontableCellCoords(selRange.highlight.row, selRange.highlight.col); + selRange.to = coords; + var rangeExpanded = false; + do { + rangeExpanded = false; + for (var i = 0, + ilen = this.mergeCells.mergedCellInfoCollection.length; i < ilen; i++) { + var cellInfo = this.mergeCells.mergedCellInfoCollection[i]; + var mergedCellTopLeft = new WalkontableCellCoords(cellInfo.row, cellInfo.col); + var mergedCellBottomRight = new WalkontableCellCoords(cellInfo.row + cellInfo.rowspan - 1, cellInfo.col + cellInfo.colspan - 1); + var mergedCellRange = new WalkontableCellRange(mergedCellTopLeft, mergedCellTopLeft, mergedCellBottomRight); + if (selRange.expandByRange(mergedCellRange)) { + coords.row = selRange.to.row; + coords.col = selRange.to.col; + rangeExpanded = true; + } + } + } while (rangeExpanded); + } +}; +var beforeDrawAreaBorders = function(corners, className) { + if (className && className == 'area') { + var mergeCellsSetting = this.getSettings().mergeCells; + if (mergeCellsSetting) { + var selRange = this.getSelectedRange(); + var startRange = new WalkontableCellRange(selRange.from, selRange.from, selRange.from); + var stopRange = new WalkontableCellRange(selRange.to, selRange.to, selRange.to); + for (var i = 0, + ilen = this.mergeCells.mergedCellInfoCollection.length; i < ilen; i++) { + var cellInfo = this.mergeCells.mergedCellInfoCollection[i]; + var mergedCellTopLeft = new WalkontableCellCoords(cellInfo.row, cellInfo.col); + var mergedCellBottomRight = new WalkontableCellCoords(cellInfo.row + cellInfo.rowspan - 1, cellInfo.col + cellInfo.colspan - 1); + var mergedCellRange = new WalkontableCellRange(mergedCellTopLeft, mergedCellTopLeft, mergedCellBottomRight); + if (startRange.expandByRange(mergedCellRange)) { + corners[0] = startRange.from.row; + corners[1] = startRange.from.col; + } + if (stopRange.expandByRange(mergedCellRange)) { + corners[2] = stopRange.from.row; + corners[3] = stopRange.from.col; + } + } + } + } +}; +var afterGetCellMeta = function(row, col, cellProperties) { + var mergeCellsSetting = this.getSettings().mergeCells; + if (mergeCellsSetting) { + var mergeParent = this.mergeCells.mergedCellInfoCollection.getInfo(row, col); + if (mergeParent && (mergeParent.row != row || mergeParent.col != col)) { + cellProperties.copyable = false; + } + } +}; +var afterViewportRowCalculatorOverride = function(calc) { + var mergeCellsSetting = this.getSettings().mergeCells; + if (mergeCellsSetting) { + var colCount = this.countCols(); + var mergeParent; + for (var c = 0; c < colCount; c++) { + mergeParent = this.mergeCells.mergedCellInfoCollection.getInfo(calc.startRow, c); + if (mergeParent) { + if (mergeParent.row < calc.startRow) { + calc.startRow = mergeParent.row; + return afterViewportRowCalculatorOverride.call(this, calc); + } + } + mergeParent = this.mergeCells.mergedCellInfoCollection.getInfo(calc.endRow, c); + if (mergeParent) { + var mergeEnd = mergeParent.row + mergeParent.rowspan - 1; + if (mergeEnd > calc.endRow) { + calc.endRow = mergeEnd; + return afterViewportRowCalculatorOverride.call(this, calc); + } + } + } + } +}; +var afterViewportColumnCalculatorOverride = function(calc) { + var mergeCellsSetting = this.getSettings().mergeCells; + if (mergeCellsSetting) { + var rowCount = this.countRows(); + var mergeParent; + for (var r = 0; r < rowCount; r++) { + mergeParent = this.mergeCells.mergedCellInfoCollection.getInfo(r, calc.startColumn); + if (mergeParent) { + if (mergeParent.col < calc.startColumn) { + calc.startColumn = mergeParent.col; + return afterViewportColumnCalculatorOverride.call(this, calc); + } + } + mergeParent = this.mergeCells.mergedCellInfoCollection.getInfo(r, calc.endColumn); + if (mergeParent) { + var mergeEnd = mergeParent.col + mergeParent.colspan - 1; + if (mergeEnd > calc.endColumn) { + calc.endColumn = mergeEnd; + return afterViewportColumnCalculatorOverride.call(this, calc); + } + } + } + } +}; +var isMultipleSelection = function(isMultiple) { + if (isMultiple && this.mergeCells) { + var mergedCells = this.mergeCells.mergedCellInfoCollection, + selectionRange = this.getSelectedRange(); + for (var group in mergedCells) { + if (selectionRange.highlight.row == mergedCells[group].row && selectionRange.highlight.col == mergedCells[group].col && selectionRange.to.row == mergedCells[group].row + mergedCells[group].rowspan - 1 && selectionRange.to.col == mergedCells[group].col + mergedCells[group].colspan - 1) { + return false; + } + } + } + return isMultiple; +}; +function afterAutofillApplyValues(select, drag) { + var mergeCellsSetting = this.getSettings().mergeCells; + if (!mergeCellsSetting || this.selection.isMultiple()) { + return; + } + var info = this.mergeCells.mergedCellInfoCollection.getInfo(select[0], select[1]); + if (info) { + select[0] = info.row; + select[1] = info.col; + select[2] = info.row + info.rowspan - 1; + select[3] = info.col + info.colspan - 1; + } +} +Handsontable.hooks.add('beforeInit', beforeInit); +Handsontable.hooks.add('afterInit', afterInit); +Handsontable.hooks.add('beforeKeyDown', onBeforeKeyDown); +Handsontable.hooks.add('modifyTransformStart', modifyTransformFactory('modifyTransformStart')); +Handsontable.hooks.add('modifyTransformEnd', modifyTransformFactory('modifyTransformEnd')); +Handsontable.hooks.add('beforeSetRangeEnd', beforeSetRangeEnd); +Handsontable.hooks.add('beforeDrawBorders', beforeDrawAreaBorders); +Handsontable.hooks.add('afterIsMultipleSelection', isMultipleSelection); +Handsontable.hooks.add('afterRenderer', afterRenderer); +Handsontable.hooks.add('afterContextMenuDefaultOptions', addMergeActionsToContextMenu); +Handsontable.hooks.add('afterGetCellMeta', afterGetCellMeta); +Handsontable.hooks.add('afterViewportRowCalculatorOverride', afterViewportRowCalculatorOverride); +Handsontable.hooks.add('afterViewportColumnCalculatorOverride', afterViewportColumnCalculatorOverride); +Handsontable.hooks.add('afterAutofillApplyValues', afterAutofillApplyValues); +Handsontable.MergeCells = MergeCells; + +//# +},{"3rdparty/walkontable/src/cell/coords.js":5,"3rdparty/walkontable/src/cell/range.js":6,"3rdparty/walkontable/src/table.js":20,"plugins.js":45}],65:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + MultipleSelectionHandles: {get: function() { + return MultipleSelectionHandles; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__95_base_46_js__, + $___46__46__47__46__46__47_eventManager_46_js__, + $___46__46__47__46__46__47_plugins_46_js__; +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var BasePlugin = ($___46__46__47__95_base_46_js__ = require("_base.js"), $___46__46__47__95_base_46_js__ && $___46__46__47__95_base_46_js__.__esModule && $___46__46__47__95_base_46_js__ || {default: $___46__46__47__95_base_46_js__}).default; +var EventManager = ($___46__46__47__46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47__46__46__47_eventManager_46_js__ && $___46__46__47__46__46__47_eventManager_46_js__.__esModule && $___46__46__47__46__46__47_eventManager_46_js__ || {default: $___46__46__47__46__46__47_eventManager_46_js__}).EventManager; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +var MultipleSelectionHandles = function MultipleSelectionHandles(hotInstance) { + $traceurRuntime.superConstructor($MultipleSelectionHandles).call(this, hotInstance); + this.dragged = []; + this.eventManager = null; + this.lastSetCell = null; +}; +var $MultipleSelectionHandles = MultipleSelectionHandles; +($traceurRuntime.createClass)(MultipleSelectionHandles, { + isEnabled: function() { + return Handsontable.mobileBrowser; + }, + enablePlugin: function() { + if (this.enabled) { + return; + } + if (!this.eventManager) { + this.eventManager = new EventManager(this); + } + this.registerListeners(); + $traceurRuntime.superGet(this, $MultipleSelectionHandles.prototype, "enablePlugin").call(this); + }, + registerListeners: function() { + var _this = this; + function removeFromDragged(query) { + if (_this.dragged.length === 1) { + _this.dragged.splice(0, _this.dragged.length); + return true; + } + var entryPosition = _this.dragged.indexOf(query); + if (entryPosition == -1) { + return false; + } else if (entryPosition === 0) { + _this.dragged = _this.dragged.slice(0, 1); + } else if (entryPosition == 1) { + _this.dragged = _this.dragged.slice(-1); + } + } + this.eventManager.addEventListener(this.hot.rootElement, 'touchstart', function(event) { + var selectedRange; + if (dom.hasClass(event.target, "topLeftSelectionHandle-HitArea")) { + selectedRange = _this.hot.getSelectedRange(); + _this.dragged.push("topLeft"); + _this.touchStartRange = { + width: selectedRange.getWidth(), + height: selectedRange.getHeight(), + direction: selectedRange.getDirection() + }; + event.preventDefault(); + return false; + } else if (dom.hasClass(event.target, "bottomRightSelectionHandle-HitArea")) { + selectedRange = _this.hot.getSelectedRange(); + _this.dragged.push("bottomRight"); + _this.touchStartRange = { + width: selectedRange.getWidth(), + height: selectedRange.getHeight(), + direction: selectedRange.getDirection() + }; + event.preventDefault(); + return false; + } + }); + this.eventManager.addEventListener(this.hot.rootElement, 'touchend', function(event) { + if (dom.hasClass(event.target, "topLeftSelectionHandle-HitArea")) { + removeFromDragged.call(_this, "topLeft"); + _this.touchStartRange = void 0; + event.preventDefault(); + return false; + } else if (dom.hasClass(event.target, "bottomRightSelectionHandle-HitArea")) { + removeFromDragged.call(_this, "bottomRight"); + _this.touchStartRange = void 0; + event.preventDefault(); + return false; + } + }); + this.eventManager.addEventListener(this.hot.rootElement, 'touchmove', function(event) { + var scrollTop = dom.getWindowScrollTop(), + scrollLeft = dom.getWindowScrollLeft(), + endTarget, + targetCoords, + selectedRange, + rangeWidth, + rangeHeight, + rangeDirection, + newRangeCoords; + if (_this.dragged.length === 0) { + return; + } + endTarget = document.elementFromPoint(event.touches[0].screenX - scrollLeft, event.touches[0].screenY - scrollTop); + if (!endTarget || endTarget === _this.lastSetCell) { + return; + } + if (endTarget.nodeName == "TD" || endTarget.nodeName == "TH") { + targetCoords = _this.hot.getCoords(endTarget); + if (targetCoords.col == -1) { + targetCoords.col = 0; + } + selectedRange = _this.hot.getSelectedRange(); + rangeWidth = selectedRange.getWidth(); + rangeHeight = selectedRange.getHeight(); + rangeDirection = selectedRange.getDirection(); + if (rangeWidth == 1 && rangeHeight == 1) { + _this.hot.selection.setRangeEnd(targetCoords); + } + newRangeCoords = _this.getCurrentRangeCoords(selectedRange, targetCoords, _this.touchStartRange.direction, rangeDirection, _this.dragged[0]); + if (newRangeCoords.start !== null) { + _this.hot.selection.setRangeStart(newRangeCoords.start); + } + _this.hot.selection.setRangeEnd(newRangeCoords.end); + _this.lastSetCell = endTarget; + } + event.preventDefault(); + }); + }, + getCurrentRangeCoords: function(selectedRange, currentTouch, touchStartDirection, currentDirection, draggedHandle) { + var topLeftCorner = selectedRange.getTopLeftCorner(), + bottomRightCorner = selectedRange.getBottomRightCorner(), + bottomLeftCorner = selectedRange.getBottomLeftCorner(), + topRightCorner = selectedRange.getTopRightCorner(); + var newCoords = { + start: null, + end: null + }; + switch (touchStartDirection) { + case "NE-SW": + switch (currentDirection) { + case "NE-SW": + case "NW-SE": + if (draggedHandle == "topLeft") { + newCoords = { + start: new WalkontableCellCoords(currentTouch.row, selectedRange.highlight.col), + end: new WalkontableCellCoords(bottomLeftCorner.row, currentTouch.col) + }; + } else { + newCoords = { + start: new WalkontableCellCoords(selectedRange.highlight.row, currentTouch.col), + end: new WalkontableCellCoords(currentTouch.row, topLeftCorner.col) + }; + } + break; + case "SE-NW": + if (draggedHandle == "bottomRight") { + newCoords = { + start: new WalkontableCellCoords(bottomRightCorner.row, currentTouch.col), + end: new WalkontableCellCoords(currentTouch.row, topLeftCorner.col) + }; + } + break; + } + break; + case "NW-SE": + switch (currentDirection) { + case "NE-SW": + if (draggedHandle == "topLeft") { + newCoords = { + start: currentTouch, + end: bottomLeftCorner + }; + } else { + newCoords.end = currentTouch; + } + break; + case "NW-SE": + if (draggedHandle == "topLeft") { + newCoords = { + start: currentTouch, + end: bottomRightCorner + }; + } else { + newCoords.end = currentTouch; + } + break; + case "SE-NW": + if (draggedHandle == "topLeft") { + newCoords = { + start: currentTouch, + end: topLeftCorner + }; + } else { + newCoords.end = currentTouch; + } + break; + case "SW-NE": + if (draggedHandle == "topLeft") { + newCoords = { + start: currentTouch, + end: topRightCorner + }; + } else { + newCoords.end = currentTouch; + } + break; + } + break; + case "SW-NE": + switch (currentDirection) { + case "NW-SE": + if (draggedHandle == "bottomRight") { + newCoords = { + start: new WalkontableCellCoords(currentTouch.row, topLeftCorner.col), + end: new WalkontableCellCoords(bottomLeftCorner.row, currentTouch.col) + }; + } else { + newCoords = { + start: new WalkontableCellCoords(topLeftCorner.row, currentTouch.col), + end: new WalkontableCellCoords(currentTouch.row, bottomRightCorner.col) + }; + } + break; + case "SW-NE": + if (draggedHandle == "topLeft") { + newCoords = { + start: new WalkontableCellCoords(selectedRange.highlight.row, currentTouch.col), + end: new WalkontableCellCoords(currentTouch.row, bottomRightCorner.col) + }; + } else { + newCoords = { + start: new WalkontableCellCoords(currentTouch.row, topLeftCorner.col), + end: new WalkontableCellCoords(topLeftCorner.row, currentTouch.col) + }; + } + break; + case "SE-NW": + if (draggedHandle == "bottomRight") { + newCoords = { + start: new WalkontableCellCoords(currentTouch.row, topRightCorner.col), + end: new WalkontableCellCoords(topLeftCorner.row, currentTouch.col) + }; + } else if (draggedHandle == "topLeft") { + newCoords = { + start: bottomLeftCorner, + end: currentTouch + }; + } + break; + } + break; + case "SE-NW": + switch (currentDirection) { + case "NW-SE": + case "NE-SW": + case "SW-NE": + if (draggedHandle == "topLeft") { + newCoords.end = currentTouch; + } + break; + case "SE-NW": + if (draggedHandle == "topLeft") { + newCoords.end = currentTouch; + } else { + newCoords = { + start: currentTouch, + end: topLeftCorner + }; + } + break; + } + break; + } + return newCoords; + }, + isDragged: function() { + return this.dragged.length > 0; + } +}, {}, BasePlugin); +; +registerPlugin('multipleSelectionHandles', MultipleSelectionHandles); + +//# +},{"_base.js":46,"dom.js":27,"eventManager.js":41,"plugins.js":45}],66:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + ObserveChanges: {get: function() { + return ObserveChanges; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_plugins_46_js__, + $__jsonpatch__; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +var jsonpatch = ($__jsonpatch__ = require("jsonpatch"), $__jsonpatch__ && $__jsonpatch__.__esModule && $__jsonpatch__ || {default: $__jsonpatch__}).default; +; +function ObserveChanges() {} +Handsontable.hooks.add('afterLoadData', init); +Handsontable.hooks.add('afterUpdateSettings', init); +Handsontable.hooks.register('afterChangesObserved'); +function init() { + var instance = this; + var pluginEnabled = instance.getSettings().observeChanges; + if (pluginEnabled) { + if (instance.observer) { + destroy.call(instance); + } + createObserver.call(instance); + bindEvents.call(instance); + } else if (!pluginEnabled) { + destroy.call(instance); + } +} +function createObserver() { + var instance = this; + instance.observeChangesActive = true; + instance.pauseObservingChanges = function() { + instance.observeChangesActive = false; + }; + instance.resumeObservingChanges = function() { + instance.observeChangesActive = true; + }; + instance.observedData = instance.getData(); + instance.observer = jsonpatch.observe(instance.observedData, function(patches) { + if (instance.observeChangesActive) { + runHookForOperation.call(instance, patches); + instance.render(); + } + instance.runHooks('afterChangesObserved'); + }); +} +function runHookForOperation(rawPatches) { + var instance = this; + var patches = cleanPatches(rawPatches); + for (var i = 0, + len = patches.length; i < len; i++) { + var patch = patches[i]; + var parsedPath = parsePath(patch.path); + switch (patch.op) { + case 'add': + if (isNaN(parsedPath.col)) { + instance.runHooks('afterCreateRow', parsedPath.row); + } else { + instance.runHooks('afterCreateCol', parsedPath.col); + } + break; + case 'remove': + if (isNaN(parsedPath.col)) { + instance.runHooks('afterRemoveRow', parsedPath.row, 1); + } else { + instance.runHooks('afterRemoveCol', parsedPath.col, 1); + } + break; + case 'replace': + instance.runHooks('afterChange', [parsedPath.row, parsedPath.col, null, patch.value], 'external'); + break; + } + } + function cleanPatches(rawPatches) { + var patches; + patches = removeLengthRelatedPatches(rawPatches); + patches = removeMultipleAddOrRemoveColPatches(patches); + return patches; + } + function removeMultipleAddOrRemoveColPatches(rawPatches) { + var newOrRemovedColumns = []; + return rawPatches.filter(function(patch) { + var parsedPath = parsePath(patch.path); + if (['add', 'remove'].indexOf(patch.op) != -1 && !isNaN(parsedPath.col)) { + if (newOrRemovedColumns.indexOf(parsedPath.col) != -1) { + return false; + } else { + newOrRemovedColumns.push(parsedPath.col); + } + } + return true; + }); + } + function removeLengthRelatedPatches(rawPatches) { + return rawPatches.filter(function(patch) { + return !/[/]length/ig.test(patch.path); + }); + } + function parsePath(path) { + var match = path.match(/^\/(\d+)\/?(.*)?$/); + return { + row: parseInt(match[1], 10), + col: /^\d*$/.test(match[2]) ? parseInt(match[2], 10) : match[2] + }; + } +} +function destroy() { + var instance = this; + if (instance.observer) { + destroyObserver.call(instance); + unbindEvents.call(instance); + } +} +function destroyObserver() { + var instance = this; + jsonpatch.unobserve(instance.observedData, instance.observer); + delete instance.observedData; + delete instance.observeChangesActive; + delete instance.pauseObservingChanges; + delete instance.resumeObservingChanges; +} +function bindEvents() { + var instance = this; + instance.addHook('afterDestroy', destroy); + instance.addHook('afterCreateRow', afterTableAlter); + instance.addHook('afterRemoveRow', afterTableAlter); + instance.addHook('afterCreateCol', afterTableAlter); + instance.addHook('afterRemoveCol', afterTableAlter); + instance.addHook('afterChange', function(changes, source) { + if (source != 'loadData') { + afterTableAlter.call(this); + } + }); +} +function unbindEvents() { + var instance = this; + instance.removeHook('afterDestroy', destroy); + instance.removeHook('afterCreateRow', afterTableAlter); + instance.removeHook('afterRemoveRow', afterTableAlter); + instance.removeHook('afterCreateCol', afterTableAlter); + instance.removeHook('afterRemoveCol', afterTableAlter); + instance.removeHook('afterChange', afterTableAlter); +} +function afterTableAlter() { + var instance = this; + instance.pauseObservingChanges(); + instance.addHookOnce('afterChangesObserved', function() { + instance.resumeObservingChanges(); + }); +} + +//# +},{"jsonpatch":"jsonpatch","plugins.js":45}],67:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + HandsontablePersistentState: {get: function() { + return HandsontablePersistentState; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_plugins_46_js__; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +; +function Storage(prefix) { + var savedKeys; + var saveSavedKeys = function() { + window.localStorage[prefix + '__' + 'persistentStateKeys'] = JSON.stringify(savedKeys); + }; + var loadSavedKeys = function() { + var keysJSON = window.localStorage[prefix + '__' + 'persistentStateKeys']; + var keys = typeof keysJSON == 'string' ? JSON.parse(keysJSON) : void 0; + savedKeys = keys ? keys : []; + }; + var clearSavedKeys = function() { + savedKeys = []; + saveSavedKeys(); + }; + loadSavedKeys(); + this.saveValue = function(key, value) { + window.localStorage[prefix + '_' + key] = JSON.stringify(value); + if (savedKeys.indexOf(key) == -1) { + savedKeys.push(key); + saveSavedKeys(); + } + }; + this.loadValue = function(key, defaultValue) { + key = typeof key != 'undefined' ? key : defaultValue; + var value = window.localStorage[prefix + '_' + key]; + return typeof value == "undefined" ? void 0 : JSON.parse(value); + }; + this.reset = function(key) { + window.localStorage.removeItem(prefix + '_' + key); + }; + this.resetAll = function() { + for (var index = 0; index < savedKeys.length; index++) { + window.localStorage.removeItem(prefix + '_' + savedKeys[index]); + } + clearSavedKeys(); + }; +} +function HandsontablePersistentState() { + var plugin = this; + this.init = function() { + var instance = this, + pluginSettings = instance.getSettings().persistentState; + plugin.enabled = !!(pluginSettings); + if (!plugin.enabled) { + removeHooks.call(instance); + return; + } + if (!instance.storage) { + instance.storage = new Storage(instance.rootElement.id); + } + instance.resetState = plugin.resetValue; + addHooks.call(instance); + }; + this.saveValue = function(key, value) { + var instance = this; + instance.storage.saveValue(key, value); + }; + this.loadValue = function(key, saveTo) { + var instance = this; + saveTo.value = instance.storage.loadValue(key); + }; + this.resetValue = function(key) { + var instance = this; + if (typeof key != 'undefined') { + instance.storage.reset(key); + } else { + instance.storage.resetAll(); + } + }; + var hooks = { + 'persistentStateSave': plugin.saveValue, + 'persistentStateLoad': plugin.loadValue, + 'persistentStateReset': plugin.resetValue + }; + for (var hookName in hooks) { + if (hooks.hasOwnProperty(hookName)) { + Handsontable.hooks.register(hookName); + } + } + function addHooks() { + var instance = this; + for (var hookName in hooks) { + if (hooks.hasOwnProperty(hookName)) { + instance.addHook(hookName, hooks[hookName]); + } + } + } + function removeHooks() { + var instance = this; + for (var hookName in hooks) { + if (hooks.hasOwnProperty(hookName)) { + instance.removeHook(hookName, hooks[hookName]); + } + } + } +} +var htPersistentState = new HandsontablePersistentState(); +Handsontable.hooks.add('beforeInit', htPersistentState.init); +Handsontable.hooks.add('afterUpdateSettings', htPersistentState.init); + +//# +},{"plugins.js":45}],68:[function(require,module,exports){ +"use strict"; +var $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__46__46__47_renderers_46_js__; +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var $__0 = ($___46__46__47__46__46__47_renderers_46_js__ = require("renderers.js"), $___46__46__47__46__46__47_renderers_46_js__ && $___46__46__47__46__46__47_renderers_46_js__.__esModule && $___46__46__47__46__46__47_renderers_46_js__ || {default: $___46__46__47__46__46__47_renderers_46_js__}), + registerRenderer = $__0.registerRenderer, + getRenderer = $__0.getRenderer; +Handsontable.Search = function Search(instance) { + this.query = function(queryStr, callback, queryMethod) { + var rowCount = instance.countRows(); + var colCount = instance.countCols(); + var queryResult = []; + if (!callback) { + callback = Handsontable.Search.global.getDefaultCallback(); + } + if (!queryMethod) { + queryMethod = Handsontable.Search.global.getDefaultQueryMethod(); + } + for (var rowIndex = 0; rowIndex < rowCount; rowIndex++) { + for (var colIndex = 0; colIndex < colCount; colIndex++) { + var cellData = instance.getDataAtCell(rowIndex, colIndex); + var cellProperties = instance.getCellMeta(rowIndex, colIndex); + var cellCallback = cellProperties.search.callback || callback; + var cellQueryMethod = cellProperties.search.queryMethod || queryMethod; + var testResult = cellQueryMethod(queryStr, cellData); + if (testResult) { + var singleResult = { + row: rowIndex, + col: colIndex, + data: cellData + }; + queryResult.push(singleResult); + } + if (cellCallback) { + cellCallback(instance, rowIndex, colIndex, cellData, testResult); + } + } + } + return queryResult; + }; +}; +Handsontable.Search.DEFAULT_CALLBACK = function(instance, row, col, data, testResult) { + instance.getCellMeta(row, col).isSearchResult = testResult; +}; +Handsontable.Search.DEFAULT_QUERY_METHOD = function(query, value) { + if (typeof query == 'undefined' || query == null || !query.toLowerCase || query.length === 0) { + return false; + } + if (typeof value == 'undefined' || value == null) { + return false; + } + return value.toString().toLowerCase().indexOf(query.toLowerCase()) != -1; +}; +Handsontable.Search.DEFAULT_SEARCH_RESULT_CLASS = 'htSearchResult'; +Handsontable.Search.global = (function() { + var defaultCallback = Handsontable.Search.DEFAULT_CALLBACK; + var defaultQueryMethod = Handsontable.Search.DEFAULT_QUERY_METHOD; + var defaultSearchResultClass = Handsontable.Search.DEFAULT_SEARCH_RESULT_CLASS; + return { + getDefaultCallback: function() { + return defaultCallback; + }, + setDefaultCallback: function(newDefaultCallback) { + defaultCallback = newDefaultCallback; + }, + getDefaultQueryMethod: function() { + return defaultQueryMethod; + }, + setDefaultQueryMethod: function(newDefaultQueryMethod) { + defaultQueryMethod = newDefaultQueryMethod; + }, + getDefaultSearchResultClass: function() { + return defaultSearchResultClass; + }, + setDefaultSearchResultClass: function(newSearchResultClass) { + defaultSearchResultClass = newSearchResultClass; + } + }; +})(); +Handsontable.SearchCellDecorator = function(instance, TD, row, col, prop, value, cellProperties) { + var searchResultClass = (cellProperties.search !== null && typeof cellProperties.search == 'object' && cellProperties.search.searchResultClass) || Handsontable.Search.global.getDefaultSearchResultClass(); + if (cellProperties.isSearchResult) { + dom.addClass(TD, searchResultClass); + } else { + dom.removeClass(TD, searchResultClass); + } +}; +var originalBaseRenderer = getRenderer('base'); +registerRenderer('base', function(instance, TD, row, col, prop, value, cellProperties) { + originalBaseRenderer.apply(this, arguments); + Handsontable.SearchCellDecorator.apply(this, arguments); +}); +function init() { + var instance = this; + var pluginEnabled = !!instance.getSettings().search; + if (pluginEnabled) { + instance.search = new Handsontable.Search(instance); + } else { + delete instance.search; + } +} +Handsontable.hooks.add('afterInit', init); +Handsontable.hooks.add('afterUpdateSettings', init); + +//# +},{"dom.js":27,"renderers.js":71}],69:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + TouchScroll: {get: function() { + return TouchScroll; + }}, + __esModule: {value: true} +}); +var $___46__46__47__46__46__47_dom_46_js__, + $___46__46__47__95_base_46_js__, + $___46__46__47__46__46__47_plugins_46_js__; +var dom = ($___46__46__47__46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47__46__46__47_dom_46_js__ && $___46__46__47__46__46__47_dom_46_js__.__esModule && $___46__46__47__46__46__47_dom_46_js__ || {default: $___46__46__47__46__46__47_dom_46_js__}); +var BasePlugin = ($___46__46__47__95_base_46_js__ = require("_base.js"), $___46__46__47__95_base_46_js__ && $___46__46__47__95_base_46_js__.__esModule && $___46__46__47__95_base_46_js__ || {default: $___46__46__47__95_base_46_js__}).default; +var registerPlugin = ($___46__46__47__46__46__47_plugins_46_js__ = require("plugins.js"), $___46__46__47__46__46__47_plugins_46_js__ && $___46__46__47__46__46__47_plugins_46_js__.__esModule && $___46__46__47__46__46__47_plugins_46_js__ || {default: $___46__46__47__46__46__47_plugins_46_js__}).registerPlugin; +var TouchScroll = function TouchScroll(hotInstance) { + var $__2 = this; + $traceurRuntime.superConstructor($TouchScroll).call(this, hotInstance); + this.hot.addHook('afterInit', (function() { + return $__2.init(); + })); + this.hot.addHook('afterUpdateSettings', (function() { + return $__2.onAfterUpdateSettings(); + })); + this.scrollbars = []; + this.clones = []; +}; +var $TouchScroll = TouchScroll; +($traceurRuntime.createClass)(TouchScroll, { + init: function() { + this.registerEvents(); + this.onAfterUpdateSettings(); + }, + onAfterUpdateSettings: function() { + var _this = this; + this.hot.addHookOnce('afterRender', function() { + var wtOverlays = _this.hot.view.wt.wtOverlays; + _this.scrollbars = []; + _this.scrollbars.push(wtOverlays.topOverlay); + _this.scrollbars.push(wtOverlays.leftOverlay); + if (wtOverlays.topLeftCornerOverlay) { + _this.scrollbars.push(wtOverlays.topLeftCornerOverlay); + } + _this.clones = []; + if (wtOverlays.topOverlay.needFullRender) { + _this.clones.push(wtOverlays.topOverlay.clone.wtTable.holder.parentNode); + } + if (wtOverlays.leftOverlay.needFullRender) { + _this.clones.push(wtOverlays.leftOverlay.clone.wtTable.holder.parentNode); + } + if (wtOverlays.topLeftCornerOverlay) { + _this.clones.push(wtOverlays.topLeftCornerOverlay.clone.wtTable.holder.parentNode); + } + }); + }, + registerEvents: function() { + var $__2 = this; + this.hot.addHook('beforeTouchScroll', (function() { + return $__2.onBeforeTouchScroll(); + })); + this.hot.addHook('afterMomentumScroll', (function() { + return $__2.onAfterMomentumScroll(); + })); + }, + onBeforeTouchScroll: function() { + Handsontable.freezeOverlays = true; + for (var i = 0, + cloneCount = this.clones.length; i < cloneCount; i++) { + dom.addClass(this.clones[i], 'hide-tween'); + } + }, + onAfterMomentumScroll: function() { + Handsontable.freezeOverlays = false; + var _that = this; + for (var i = 0, + cloneCount = this.clones.length; i < cloneCount; i++) { + dom.removeClass(this.clones[i], 'hide-tween'); + } + for (var i$__4 = 0, + cloneCount$__5 = this.clones.length; i$__4 < cloneCount$__5; i$__4++) { + dom.addClass(this.clones[i$__4], 'show-tween'); + } + setTimeout(function() { + for (var i = 0, + cloneCount = _that.clones.length; i < cloneCount; i++) { + dom.removeClass(_that.clones[i], 'show-tween'); + } + }, 400); + for (var i$__6 = 0, + cloneCount$__7 = this.scrollbars.length; i$__6 < cloneCount$__7; i$__6++) { + this.scrollbars[i$__6].refresh(); + this.scrollbars[i$__6].resetFixedPosition(); + } + this.hot.view.wt.wtOverlays.syncScrollWithMaster(); + } +}, {}, BasePlugin); +; +registerPlugin('touchScroll', TouchScroll); + +//# +},{"_base.js":46,"dom.js":27,"plugins.js":45}],70:[function(require,module,exports){ +"use strict"; +var $___46__46__47__46__46__47_helpers_46_js__; +var helper = ($___46__46__47__46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47__46__46__47_helpers_46_js__ && $___46__46__47__46__46__47_helpers_46_js__.__esModule && $___46__46__47__46__46__47_helpers_46_js__ || {default: $___46__46__47__46__46__47_helpers_46_js__}); +Handsontable.UndoRedo = function(instance) { + var plugin = this; + this.instance = instance; + this.doneActions = []; + this.undoneActions = []; + this.ignoreNewActions = false; + instance.addHook("afterChange", function(changes, origin) { + if (changes) { + var action = new Handsontable.UndoRedo.ChangeAction(changes); + plugin.done(action); + } + }); + instance.addHook("afterCreateRow", function(index, amount, createdAutomatically) { + if (createdAutomatically) { + return; + } + var action = new Handsontable.UndoRedo.CreateRowAction(index, amount); + plugin.done(action); + }); + instance.addHook("beforeRemoveRow", function(index, amount) { + var originalData = plugin.instance.getData(); + index = (originalData.length + index) % originalData.length; + var removedData = originalData.slice(index, index + amount); + var action = new Handsontable.UndoRedo.RemoveRowAction(index, removedData); + plugin.done(action); + }); + instance.addHook("afterCreateCol", function(index, amount, createdAutomatically) { + if (createdAutomatically) { + return; + } + var action = new Handsontable.UndoRedo.CreateColumnAction(index, amount); + plugin.done(action); + }); + instance.addHook("beforeRemoveCol", function(index, amount) { + var originalData = plugin.instance.getData(); + index = (plugin.instance.countCols() + index) % plugin.instance.countCols(); + var removedData = []; + for (var i = 0, + len = originalData.length; i < len; i++) { + removedData[i] = originalData[i].slice(index, index + amount); + } + var headers; + if (Array.isArray(instance.getSettings().colHeaders)) { + headers = instance.getSettings().colHeaders.slice(index, index + removedData.length); + } + var action = new Handsontable.UndoRedo.RemoveColumnAction(index, removedData, headers); + plugin.done(action); + }); + instance.addHook("beforeCellAlignment", function(stateBefore, range, type, alignment) { + var action = new Handsontable.UndoRedo.CellAlignmentAction(stateBefore, range, type, alignment); + plugin.done(action); + }); +}; +Handsontable.UndoRedo.prototype.done = function(action) { + if (!this.ignoreNewActions) { + this.doneActions.push(action); + this.undoneActions.length = 0; + } +}; +Handsontable.UndoRedo.prototype.undo = function() { + if (this.isUndoAvailable()) { + var action = this.doneActions.pop(); + this.ignoreNewActions = true; + var that = this; + action.undo(this.instance, function() { + that.ignoreNewActions = false; + that.undoneActions.push(action); + }); + } +}; +Handsontable.UndoRedo.prototype.redo = function() { + if (this.isRedoAvailable()) { + var action = this.undoneActions.pop(); + this.ignoreNewActions = true; + var that = this; + action.redo(this.instance, function() { + that.ignoreNewActions = false; + that.doneActions.push(action); + }); + } +}; +Handsontable.UndoRedo.prototype.isUndoAvailable = function() { + return this.doneActions.length > 0; +}; +Handsontable.UndoRedo.prototype.isRedoAvailable = function() { + return this.undoneActions.length > 0; +}; +Handsontable.UndoRedo.prototype.clear = function() { + this.doneActions.length = 0; + this.undoneActions.length = 0; +}; +Handsontable.UndoRedo.Action = function() {}; +Handsontable.UndoRedo.Action.prototype.undo = function() {}; +Handsontable.UndoRedo.Action.prototype.redo = function() {}; +Handsontable.UndoRedo.ChangeAction = function(changes) { + this.changes = changes; +}; +helper.inherit(Handsontable.UndoRedo.ChangeAction, Handsontable.UndoRedo.Action); +Handsontable.UndoRedo.ChangeAction.prototype.undo = function(instance, undoneCallback) { + var data = helper.deepClone(this.changes), + emptyRowsAtTheEnd = instance.countEmptyRows(true), + emptyColsAtTheEnd = instance.countEmptyCols(true); + for (var i = 0, + len = data.length; i < len; i++) { + data[i].splice(3, 1); + } + instance.addHookOnce('afterChange', undoneCallback); + instance.setDataAtRowProp(data, null, null, 'undo'); + for (var i = 0, + len = data.length; i < len; i++) { + if (instance.getSettings().minSpareRows && data[i][0] + 1 + instance.getSettings().minSpareRows === instance.countRows() && emptyRowsAtTheEnd == instance.getSettings().minSpareRows) { + instance.alter('remove_row', parseInt(data[i][0] + 1, 10), instance.getSettings().minSpareRows); + instance.undoRedo.doneActions.pop(); + } + if (instance.getSettings().minSpareCols && data[i][1] + 1 + instance.getSettings().minSpareCols === instance.countCols() && emptyColsAtTheEnd == instance.getSettings().minSpareCols) { + instance.alter('remove_col', parseInt(data[i][1] + 1, 10), instance.getSettings().minSpareCols); + instance.undoRedo.doneActions.pop(); + } + } +}; +Handsontable.UndoRedo.ChangeAction.prototype.redo = function(instance, onFinishCallback) { + var data = helper.deepClone(this.changes); + for (var i = 0, + len = data.length; i < len; i++) { + data[i].splice(2, 1); + } + instance.addHookOnce('afterChange', onFinishCallback); + instance.setDataAtRowProp(data, null, null, 'redo'); +}; +Handsontable.UndoRedo.CreateRowAction = function(index, amount) { + this.index = index; + this.amount = amount; +}; +helper.inherit(Handsontable.UndoRedo.CreateRowAction, Handsontable.UndoRedo.Action); +Handsontable.UndoRedo.CreateRowAction.prototype.undo = function(instance, undoneCallback) { + var rowCount = instance.countRows(), + minSpareRows = instance.getSettings().minSpareRows; + if (this.index >= rowCount && this.index - minSpareRows < rowCount) { + this.index -= minSpareRows; + } + instance.addHookOnce('afterRemoveRow', undoneCallback); + instance.alter('remove_row', this.index, this.amount); +}; +Handsontable.UndoRedo.CreateRowAction.prototype.redo = function(instance, redoneCallback) { + instance.addHookOnce('afterCreateRow', redoneCallback); + instance.alter('insert_row', this.index + 1, this.amount); +}; +Handsontable.UndoRedo.RemoveRowAction = function(index, data) { + this.index = index; + this.data = data; +}; +helper.inherit(Handsontable.UndoRedo.RemoveRowAction, Handsontable.UndoRedo.Action); +Handsontable.UndoRedo.RemoveRowAction.prototype.undo = function(instance, undoneCallback) { + var spliceArgs = [this.index, 0]; + Array.prototype.push.apply(spliceArgs, this.data); + Array.prototype.splice.apply(instance.getData(), spliceArgs); + instance.addHookOnce('afterRender', undoneCallback); + instance.render(); +}; +Handsontable.UndoRedo.RemoveRowAction.prototype.redo = function(instance, redoneCallback) { + instance.addHookOnce('afterRemoveRow', redoneCallback); + instance.alter('remove_row', this.index, this.data.length); +}; +Handsontable.UndoRedo.CreateColumnAction = function(index, amount) { + this.index = index; + this.amount = amount; +}; +helper.inherit(Handsontable.UndoRedo.CreateColumnAction, Handsontable.UndoRedo.Action); +Handsontable.UndoRedo.CreateColumnAction.prototype.undo = function(instance, undoneCallback) { + instance.addHookOnce('afterRemoveCol', undoneCallback); + instance.alter('remove_col', this.index, this.amount); +}; +Handsontable.UndoRedo.CreateColumnAction.prototype.redo = function(instance, redoneCallback) { + instance.addHookOnce('afterCreateCol', redoneCallback); + instance.alter('insert_col', this.index + 1, this.amount); +}; +Handsontable.UndoRedo.CellAlignmentAction = function(stateBefore, range, type, alignment) { + this.stateBefore = stateBefore; + this.range = range; + this.type = type; + this.alignment = alignment; +}; +Handsontable.UndoRedo.CellAlignmentAction.prototype.undo = function(instance, undoneCallback) { + if (!instance.contextMenu) { + return; + } + for (var row = this.range.from.row; row <= this.range.to.row; row++) { + for (var col = this.range.from.col; col <= this.range.to.col; col++) { + instance.setCellMeta(row, col, 'className', this.stateBefore[row][col] || ' htLeft'); + } + } + instance.addHookOnce('afterRender', undoneCallback); + instance.render(); +}; +Handsontable.UndoRedo.CellAlignmentAction.prototype.redo = function(instance, undoneCallback) { + if (!instance.contextMenu) { + return; + } + for (var row = this.range.from.row; row <= this.range.to.row; row++) { + for (var col = this.range.from.col; col <= this.range.to.col; col++) { + instance.contextMenu.align.call(instance, this.range, this.type, this.alignment); + } + } + instance.addHookOnce('afterRender', undoneCallback); + instance.render(); +}; +Handsontable.UndoRedo.RemoveColumnAction = function(index, data, headers) { + this.index = index; + this.data = data; + this.amount = this.data[0].length; + this.headers = headers; +}; +helper.inherit(Handsontable.UndoRedo.RemoveColumnAction, Handsontable.UndoRedo.Action); +Handsontable.UndoRedo.RemoveColumnAction.prototype.undo = function(instance, undoneCallback) { + var row, + spliceArgs; + for (var i = 0, + len = instance.getData().length; i < len; i++) { + row = instance.getSourceDataAtRow(i); + spliceArgs = [this.index, 0]; + Array.prototype.push.apply(spliceArgs, this.data[i]); + Array.prototype.splice.apply(row, spliceArgs); + } + if (typeof this.headers != 'undefined') { + spliceArgs = [this.index, 0]; + Array.prototype.push.apply(spliceArgs, this.headers); + Array.prototype.splice.apply(instance.getSettings().colHeaders, spliceArgs); + } + instance.addHookOnce('afterRender', undoneCallback); + instance.render(); +}; +Handsontable.UndoRedo.RemoveColumnAction.prototype.redo = function(instance, redoneCallback) { + instance.addHookOnce('afterRemoveCol', redoneCallback); + instance.alter('remove_col', this.index, this.amount); +}; +function init() { + var instance = this; + var pluginEnabled = typeof instance.getSettings().undo == 'undefined' || instance.getSettings().undo; + if (pluginEnabled) { + if (!instance.undoRedo) { + instance.undoRedo = new Handsontable.UndoRedo(instance); + exposeUndoRedoMethods(instance); + instance.addHook('beforeKeyDown', onBeforeKeyDown); + instance.addHook('afterChange', onAfterChange); + } + } else { + if (instance.undoRedo) { + delete instance.undoRedo; + removeExposedUndoRedoMethods(instance); + instance.removeHook('beforeKeyDown', onBeforeKeyDown); + instance.removeHook('afterChange', onAfterChange); + } + } +} +function onBeforeKeyDown(event) { + var instance = this; + var ctrlDown = (event.ctrlKey || event.metaKey) && !event.altKey; + if (ctrlDown) { + if (event.keyCode === 89 || (event.shiftKey && event.keyCode === 90)) { + instance.undoRedo.redo(); + event.stopImmediatePropagation(); + } else if (event.keyCode === 90) { + instance.undoRedo.undo(); + event.stopImmediatePropagation(); + } + } +} +function onAfterChange(changes, source) { + var instance = this; + if (source == 'loadData') { + return instance.undoRedo.clear(); + } +} +function exposeUndoRedoMethods(instance) { + instance.undo = function() { + return instance.undoRedo.undo(); + }; + instance.redo = function() { + return instance.undoRedo.redo(); + }; + instance.isUndoAvailable = function() { + return instance.undoRedo.isUndoAvailable(); + }; + instance.isRedoAvailable = function() { + return instance.undoRedo.isRedoAvailable(); + }; + instance.clearUndo = function() { + return instance.undoRedo.clear(); + }; +} +function removeExposedUndoRedoMethods(instance) { + delete instance.undo; + delete instance.redo; + delete instance.isUndoAvailable; + delete instance.isRedoAvailable; + delete instance.clearUndo; +} +Handsontable.hooks.add('afterInit', init); +Handsontable.hooks.add('afterUpdateSettings', init); + +//# +},{"helpers.js":42}],71:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + registerRenderer: {get: function() { + return registerRenderer; + }}, + getRenderer: {get: function() { + return getRenderer; + }}, + hasRenderer: {get: function() { + return hasRenderer; + }}, + __esModule: {value: true} +}); +var $__helpers_46_js__; +var helper = ($__helpers_46_js__ = require("helpers.js"), $__helpers_46_js__ && $__helpers_46_js__.__esModule && $__helpers_46_js__ || {default: $__helpers_46_js__}); +; +var registeredRenderers = {}; +Handsontable.renderers = Handsontable.renderers || {}; +Handsontable.renderers.registerRenderer = registerRenderer; +Handsontable.renderers.getRenderer = getRenderer; +function registerRenderer(rendererName, rendererFunction) { + var registerName; + registeredRenderers[rendererName] = rendererFunction; + registerName = helper.toUpperCaseFirst(rendererName) + 'Renderer'; + Handsontable.renderers[registerName] = rendererFunction; + Handsontable[registerName] = rendererFunction; +} +function getRenderer(rendererName) { + if (typeof rendererName == 'function') { + return rendererName; + } + if (typeof rendererName != 'string') { + throw Error('Only strings and functions can be passed as "renderer" parameter'); + } + if (!(rendererName in registeredRenderers)) { + throw Error('No editor registered under name "' + rendererName + '"'); + } + return registeredRenderers[rendererName]; +} +function hasRenderer(rendererName) { + return rendererName in registeredRenderers; +} + +//# +},{"helpers.js":42}],72:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + cellDecorator: {get: function() { + return cellDecorator; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_renderers_46_js__; +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var registerRenderer = ($___46__46__47_renderers_46_js__ = require("renderers.js"), $___46__46__47_renderers_46_js__ && $___46__46__47_renderers_46_js__.__esModule && $___46__46__47_renderers_46_js__ || {default: $___46__46__47_renderers_46_js__}).registerRenderer; +; +registerRenderer('base', cellDecorator); +Handsontable.renderers.cellDecorator = cellDecorator; +function cellDecorator(instance, TD, row, col, prop, value, cellProperties) { + if (cellProperties.className) { + if (TD.className) { + TD.className = TD.className + " " + cellProperties.className; + } else { + TD.className = cellProperties.className; + } + } + if (cellProperties.readOnly) { + dom.addClass(TD, cellProperties.readOnlyCellClassName); + } + if (cellProperties.valid === false && cellProperties.invalidCellClassName) { + dom.addClass(TD, cellProperties.invalidCellClassName); + } else { + dom.removeClass(TD, cellProperties.invalidCellClassName); + } + if (cellProperties.wordWrap === false && cellProperties.noWordWrapClassName) { + dom.addClass(TD, cellProperties.noWordWrapClassName); + } + if (!value && cellProperties.placeholder) { + dom.addClass(TD, cellProperties.placeholderCellClassName); + } +} + +//# +},{"dom.js":27,"renderers.js":71}],73:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + autocompleteRenderer: {get: function() { + return autocompleteRenderer; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_eventManager_46_js__, + $___46__46__47_renderers_46_js__, + $___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__; +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var eventManagerObject = ($___46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47_eventManager_46_js__ && $___46__46__47_eventManager_46_js__.__esModule && $___46__46__47_eventManager_46_js__ || {default: $___46__46__47_eventManager_46_js__}).eventManager; +var $__1 = ($___46__46__47_renderers_46_js__ = require("renderers.js"), $___46__46__47_renderers_46_js__ && $___46__46__47_renderers_46_js__.__esModule && $___46__46__47_renderers_46_js__ || {default: $___46__46__47_renderers_46_js__}), + getRenderer = $__1.getRenderer, + registerRenderer = $__1.registerRenderer; +var WalkontableCellCoords = ($___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ = require("3rdparty/walkontable/src/cell/coords.js"), $___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ && $___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__.__esModule && $___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ || {default: $___46__46__47_3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__}).WalkontableCellCoords; +; +var clonableWRAPPER = document.createElement('DIV'); +clonableWRAPPER.className = 'htAutocompleteWrapper'; +var clonableARROW = document.createElement('DIV'); +clonableARROW.className = 'htAutocompleteArrow'; +clonableARROW.appendChild(document.createTextNode(String.fromCharCode(9660))); +var wrapTdContentWithWrapper = function(TD, WRAPPER) { + WRAPPER.innerHTML = TD.innerHTML; + dom.empty(TD); + TD.appendChild(WRAPPER); +}; +registerRenderer('autocomplete', autocompleteRenderer); +function autocompleteRenderer(instance, TD, row, col, prop, value, cellProperties) { + var WRAPPER = clonableWRAPPER.cloneNode(true); + var ARROW = clonableARROW.cloneNode(true); + getRenderer('text')(instance, TD, row, col, prop, value, cellProperties); + TD.appendChild(ARROW); + dom.addClass(TD, 'htAutocomplete'); + if (!TD.firstChild) { + TD.appendChild(document.createTextNode(String.fromCharCode(160))); + } + if (!instance.acArrowListener) { + var eventManager = eventManagerObject(instance); + instance.acArrowListener = function(event) { + if (dom.hasClass(event.target, 'htAutocompleteArrow')) { + instance.view.wt.getSetting('onCellDblClick', null, new WalkontableCellCoords(row, col), TD); + } + }; + eventManager.addEventListener(instance.rootElement, 'mousedown', instance.acArrowListener); + instance.addHookOnce('afterDestroy', function() { + eventManager.destroy(); + }); + } +} + +//# +},{"3rdparty/walkontable/src/cell/coords.js":5,"dom.js":27,"eventManager.js":41,"renderers.js":71}],74:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + checkboxRenderer: {get: function() { + return checkboxRenderer; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_helpers_46_js__, + $___46__46__47_eventManager_46_js__, + $___46__46__47_renderers_46_js__; +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var helper = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}); +var EventManager = ($___46__46__47_eventManager_46_js__ = require("eventManager.js"), $___46__46__47_eventManager_46_js__ && $___46__46__47_eventManager_46_js__.__esModule && $___46__46__47_eventManager_46_js__ || {default: $___46__46__47_eventManager_46_js__}).EventManager; +var $__1 = ($___46__46__47_renderers_46_js__ = require("renderers.js"), $___46__46__47_renderers_46_js__ && $___46__46__47_renderers_46_js__.__esModule && $___46__46__47_renderers_46_js__ || {default: $___46__46__47_renderers_46_js__}), + getRenderer = $__1.getRenderer, + registerRenderer = $__1.registerRenderer; +var isListeningKeyDownEvent = new WeakMap(); +var BAD_VALUE_CLASS = 'htBadValue'; +function checkboxRenderer(instance, TD, row, col, prop, value, cellProperties) { + var eventManager = new EventManager(instance); + var input = createInput(); + if (typeof cellProperties.checkedTemplate === 'undefined') { + cellProperties.checkedTemplate = true; + } + if (typeof cellProperties.uncheckedTemplate === 'undefined') { + cellProperties.uncheckedTemplate = false; + } + dom.empty(TD); + if (value === cellProperties.checkedTemplate || helper.equalsIgnoreCase(value, cellProperties.checkedTemplate)) { + input.checked = true; + TD.appendChild(input); + } else if (value === cellProperties.uncheckedTemplate || helper.equalsIgnoreCase(value, cellProperties.uncheckedTemplate)) { + TD.appendChild(input); + } else if (value === null) { + dom.addClass(input, 'noValue'); + TD.appendChild(input); + } else { + input.style.display = 'none'; + dom.addClass(input, BAD_VALUE_CLASS); + TD.appendChild(input); + TD.appendChild(document.createTextNode('#bad-value#')); + } + if (cellProperties.readOnly) { + eventManager.addEventListener(input, 'click', preventDefault); + } else { + eventManager.addEventListener(input, 'mousedown', stopPropagation); + eventManager.addEventListener(input, 'mouseup', stopPropagation); + eventManager.addEventListener(input, 'change', (function(event) { + instance.setDataAtRowProp(row, prop, event.target.checked ? cellProperties.checkedTemplate : cellProperties.uncheckedTemplate); + })); + } + if (!isListeningKeyDownEvent.has(instance)) { + isListeningKeyDownEvent.set(instance, true); + instance.addHook('beforeKeyDown', onBeforeKeyDown); + } + function onBeforeKeyDown(event) { + var allowedKeys = [helper.keyCode.SPACE, helper.keyCode.ENTER, helper.keyCode.DELETE, helper.keyCode.BACKSPACE]; + dom.enableImmediatePropagation(event); + if (allowedKeys.indexOf(event.keyCode) !== -1 && !event.isImmediatePropagationStopped()) { + eachSelectedCheckboxCell(function() { + event.stopImmediatePropagation(); + event.preventDefault(); + }); + } + if (event.keyCode == helper.keyCode.SPACE || event.keyCode == helper.keyCode.ENTER) { + toggleSelected(); + } + if (event.keyCode == helper.keyCode.DELETE || event.keyCode == helper.keyCode.BACKSPACE) { + toggleSelected(false); + } + } + function toggleSelected() { + var checked = arguments[0] !== (void 0) ? arguments[0] : null; + eachSelectedCheckboxCell(function(checkboxes) { + for (var i = 0, + len = checkboxes.length; i < len; i++) { + if (dom.hasClass(checkboxes[i], BAD_VALUE_CLASS) && checked === null) { + return; + } + toggleCheckbox(checkboxes[i], checked); + } + }); + } + function toggleCheckbox(checkbox) { + var checked = arguments[1] !== (void 0) ? arguments[1] : null; + if (checked === null) { + checkbox.checked = !checkbox.checked; + } else { + checkbox.checked = checked; + } + eventManager.fireEvent(checkbox, 'change'); + } + function eachSelectedCheckboxCell(callback) { + var selRange = instance.getSelectedRange(); + var topLeft = selRange.getTopLeftCorner(); + var bottomRight = selRange.getBottomRightCorner(); + for (var row = topLeft.row; row <= bottomRight.row; row++) { + for (var col = topLeft.col; col <= bottomRight.col; col++) { + var cell = instance.getCell(row, col); + var cellProperties$__2 = instance.getCellMeta(row, col); + var checkboxes = cell.querySelectorAll('input[type=checkbox]'); + if (checkboxes.length > 0 && !cellProperties$__2.readOnly) { + callback(checkboxes); + } + } + } + } +} +; +registerRenderer('checkbox', checkboxRenderer); +function createInput() { + var input = document.createElement('INPUT'); + input.className = 'htCheckboxRendererInput'; + input.type = 'checkbox'; + input.setAttribute('autocomplete', 'off'); + return input.cloneNode(false); +} +function preventDefault(event) { + event.preventDefault(); +} +function stopPropagation(event) { + helper.stopPropagation(event); +} + +//# +},{"dom.js":27,"eventManager.js":41,"helpers.js":42,"renderers.js":71}],75:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + htmlRenderer: {get: function() { + return htmlRenderer; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_renderers_46_js__; +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var $__0 = ($___46__46__47_renderers_46_js__ = require("renderers.js"), $___46__46__47_renderers_46_js__ && $___46__46__47_renderers_46_js__.__esModule && $___46__46__47_renderers_46_js__ || {default: $___46__46__47_renderers_46_js__}), + getRenderer = $__0.getRenderer, + registerRenderer = $__0.registerRenderer; +; +registerRenderer('html', htmlRenderer); +function htmlRenderer(instance, TD, row, col, prop, value, cellProperties) { + getRenderer('base').apply(this, arguments); + dom.fastInnerHTML(TD, value); +} + +//# +},{"dom.js":27,"renderers.js":71}],76:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + numericRenderer: {get: function() { + return numericRenderer; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_helpers_46_js__, + $__numeral__, + $___46__46__47_renderers_46_js__; +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var helper = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}); +var numeral = ($__numeral__ = require("numeral"), $__numeral__ && $__numeral__.__esModule && $__numeral__ || {default: $__numeral__}).default; +var $__1 = ($___46__46__47_renderers_46_js__ = require("renderers.js"), $___46__46__47_renderers_46_js__ && $___46__46__47_renderers_46_js__.__esModule && $___46__46__47_renderers_46_js__ || {default: $___46__46__47_renderers_46_js__}), + getRenderer = $__1.getRenderer, + registerRenderer = $__1.registerRenderer; +; +registerRenderer('numeric', numericRenderer); +function numericRenderer(instance, TD, row, col, prop, value, cellProperties) { + if (helper.isNumeric(value)) { + if (typeof cellProperties.language !== 'undefined') { + numeral.language(cellProperties.language); + } + value = numeral(value).format(cellProperties.format || '0'); + dom.addClass(TD, 'htNumeric'); + } + getRenderer('text')(instance, TD, row, col, prop, value, cellProperties); +} + +//# +},{"dom.js":27,"helpers.js":42,"numeral":"numeral","renderers.js":71}],77:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + passwordRenderer: {get: function() { + return passwordRenderer; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_renderers_46_js__; +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var $__0 = ($___46__46__47_renderers_46_js__ = require("renderers.js"), $___46__46__47_renderers_46_js__ && $___46__46__47_renderers_46_js__.__esModule && $___46__46__47_renderers_46_js__ || {default: $___46__46__47_renderers_46_js__}), + getRenderer = $__0.getRenderer, + registerRenderer = $__0.registerRenderer; +; +registerRenderer('password', passwordRenderer); +function passwordRenderer(instance, TD, row, col, prop, value, cellProperties) { + getRenderer('text').apply(this, arguments); + value = TD.innerHTML; + var hash; + var hashLength = cellProperties.hashLength || value.length; + var hashSymbol = cellProperties.hashSymbol || '*'; + for (hash = ''; hash.split(hashSymbol).length - 1 < hashLength; hash += hashSymbol) {} + dom.fastInnerHTML(TD, hash); +} + +//# +},{"dom.js":27,"renderers.js":71}],78:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + textRenderer: {get: function() { + return textRenderer; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_helpers_46_js__, + $___46__46__47_renderers_46_js__; +var dom = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}); +var helper = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}); +var $__0 = ($___46__46__47_renderers_46_js__ = require("renderers.js"), $___46__46__47_renderers_46_js__ && $___46__46__47_renderers_46_js__.__esModule && $___46__46__47_renderers_46_js__ || {default: $___46__46__47_renderers_46_js__}), + getRenderer = $__0.getRenderer, + registerRenderer = $__0.registerRenderer; +; +registerRenderer('text', textRenderer); +function textRenderer(instance, TD, row, col, prop, value, cellProperties) { + getRenderer('base').apply(this, arguments); + if (!value && cellProperties.placeholder) { + value = cellProperties.placeholder; + } + var escaped = helper.stringify(value); + if (!instance.getSettings().trimWhitespace) { + escaped = escaped.replace(/ /g, String.fromCharCode(160)); + } + if (cellProperties.rendererTemplate) { + dom.empty(TD); + var TEMPLATE = document.createElement('TEMPLATE'); + TEMPLATE.setAttribute('bind', '{{}}'); + TEMPLATE.innerHTML = cellProperties.rendererTemplate; + HTMLTemplateElement.decorate(TEMPLATE); + TEMPLATE.model = instance.getSourceDataAtRow(row); + TD.appendChild(TEMPLATE); + } else { + dom.fastInnerText(TD, escaped); + } +} + +//# +},{"dom.js":27,"helpers.js":42,"renderers.js":71}],79:[function(require,module,exports){ +"use strict"; +(function(global) { + 'use strict'; + if (global.$traceurRuntime) { + return; + } + var $Object = Object; + var $TypeError = TypeError; + var $create = $Object.create; + var $defineProperties = $Object.defineProperties; + var $defineProperty = $Object.defineProperty; + var $freeze = $Object.freeze; + var $getOwnPropertyDescriptor = $Object.getOwnPropertyDescriptor; + var $getOwnPropertyNames = $Object.getOwnPropertyNames; + var $keys = $Object.keys; + var $hasOwnProperty = $Object.prototype.hasOwnProperty; + var $toString = $Object.prototype.toString; + var $preventExtensions = Object.preventExtensions; + var $seal = Object.seal; + var $isExtensible = Object.isExtensible; + function nonEnum(value) { + return { + configurable: true, + enumerable: false, + value: value, + writable: true + }; + } + var method = nonEnum; + var counter = 0; + function newUniqueString() { + return '__$' + Math.floor(Math.random() * 1e9) + '$' + ++counter + '$__'; + } + var symbolInternalProperty = newUniqueString(); + var symbolDescriptionProperty = newUniqueString(); + var symbolDataProperty = newUniqueString(); + var symbolValues = $create(null); + var privateNames = $create(null); + function isPrivateName(s) { + return privateNames[s]; + } + function createPrivateName() { + var s = newUniqueString(); + privateNames[s] = true; + return s; + } + function isShimSymbol(symbol) { + return typeof symbol === 'object' && symbol instanceof SymbolValue; + } + function typeOf(v) { + if (isShimSymbol(v)) + return 'symbol'; + return typeof v; + } + function Symbol(description) { + var value = new SymbolValue(description); + if (!(this instanceof Symbol)) + return value; + throw new TypeError('Symbol cannot be new\'ed'); + } + $defineProperty(Symbol.prototype, 'constructor', nonEnum(Symbol)); + $defineProperty(Symbol.prototype, 'toString', method(function() { + var symbolValue = this[symbolDataProperty]; + if (!getOption('symbols')) + return symbolValue[symbolInternalProperty]; + if (!symbolValue) + throw TypeError('Conversion from symbol to string'); + var desc = symbolValue[symbolDescriptionProperty]; + if (desc === undefined) + desc = ''; + return 'Symbol(' + desc + ')'; + })); + $defineProperty(Symbol.prototype, 'valueOf', method(function() { + var symbolValue = this[symbolDataProperty]; + if (!symbolValue) + throw TypeError('Conversion from symbol to string'); + if (!getOption('symbols')) + return symbolValue[symbolInternalProperty]; + return symbolValue; + })); + function SymbolValue(description) { + var key = newUniqueString(); + $defineProperty(this, symbolDataProperty, {value: this}); + $defineProperty(this, symbolInternalProperty, {value: key}); + $defineProperty(this, symbolDescriptionProperty, {value: description}); + freeze(this); + symbolValues[key] = this; + } + $defineProperty(SymbolValue.prototype, 'constructor', nonEnum(Symbol)); + $defineProperty(SymbolValue.prototype, 'toString', { + value: Symbol.prototype.toString, + enumerable: false + }); + $defineProperty(SymbolValue.prototype, 'valueOf', { + value: Symbol.prototype.valueOf, + enumerable: false + }); + var hashProperty = createPrivateName(); + var hashPropertyDescriptor = {value: undefined}; + var hashObjectProperties = { + hash: {value: undefined}, + self: {value: undefined} + }; + var hashCounter = 0; + function getOwnHashObject(object) { + var hashObject = object[hashProperty]; + if (hashObject && hashObject.self === object) + return hashObject; + if ($isExtensible(object)) { + hashObjectProperties.hash.value = hashCounter++; + hashObjectProperties.self.value = object; + hashPropertyDescriptor.value = $create(null, hashObjectProperties); + $defineProperty(object, hashProperty, hashPropertyDescriptor); + return hashPropertyDescriptor.value; + } + return undefined; + } + function freeze(object) { + getOwnHashObject(object); + return $freeze.apply(this, arguments); + } + function preventExtensions(object) { + getOwnHashObject(object); + return $preventExtensions.apply(this, arguments); + } + function seal(object) { + getOwnHashObject(object); + return $seal.apply(this, arguments); + } + freeze(SymbolValue.prototype); + function isSymbolString(s) { + return symbolValues[s] || privateNames[s]; + } + function toProperty(name) { + if (isShimSymbol(name)) + return name[symbolInternalProperty]; + return name; + } + function removeSymbolKeys(array) { + var rv = []; + for (var i = 0; i < array.length; i++) { + if (!isSymbolString(array[i])) { + rv.push(array[i]); + } + } + return rv; + } + function getOwnPropertyNames(object) { + return removeSymbolKeys($getOwnPropertyNames(object)); + } + function keys(object) { + return removeSymbolKeys($keys(object)); + } + function getOwnPropertySymbols(object) { + var rv = []; + var names = $getOwnPropertyNames(object); + for (var i = 0; i < names.length; i++) { + var symbol = symbolValues[names[i]]; + if (symbol) { + rv.push(symbol); + } + } + return rv; + } + function getOwnPropertyDescriptor(object, name) { + return $getOwnPropertyDescriptor(object, toProperty(name)); + } + function hasOwnProperty(name) { + return $hasOwnProperty.call(this, toProperty(name)); + } + function getOption(name) { + return global.traceur && global.traceur.options[name]; + } + function defineProperty(object, name, descriptor) { + if (isShimSymbol(name)) { + name = name[symbolInternalProperty]; + } + $defineProperty(object, name, descriptor); + return object; + } + function polyfillObject(Object) { + $defineProperty(Object, 'defineProperty', {value: defineProperty}); + $defineProperty(Object, 'getOwnPropertyNames', {value: getOwnPropertyNames}); + $defineProperty(Object, 'getOwnPropertyDescriptor', {value: getOwnPropertyDescriptor}); + $defineProperty(Object.prototype, 'hasOwnProperty', {value: hasOwnProperty}); + $defineProperty(Object, 'freeze', {value: freeze}); + $defineProperty(Object, 'preventExtensions', {value: preventExtensions}); + $defineProperty(Object, 'seal', {value: seal}); + $defineProperty(Object, 'keys', {value: keys}); + } + function exportStar(object) { + for (var i = 1; i < arguments.length; i++) { + var names = $getOwnPropertyNames(arguments[i]); + for (var j = 0; j < names.length; j++) { + var name = names[j]; + if (isSymbolString(name)) + continue; + (function(mod, name) { + $defineProperty(object, name, { + get: function() { + return mod[name]; + }, + enumerable: true + }); + })(arguments[i], names[j]); + } + } + return object; + } + function isObject(x) { + return x != null && (typeof x === 'object' || typeof x === 'function'); + } + function toObject(x) { + if (x == null) + throw $TypeError(); + return $Object(x); + } + function checkObjectCoercible(argument) { + if (argument == null) { + throw new TypeError('Value cannot be converted to an Object'); + } + return argument; + } + function polyfillSymbol(global, Symbol) { + if (!global.Symbol) { + global.Symbol = Symbol; + Object.getOwnPropertySymbols = getOwnPropertySymbols; + } + if (!global.Symbol.iterator) { + global.Symbol.iterator = Symbol('Symbol.iterator'); + } + } + function setupGlobals(global) { + polyfillSymbol(global, Symbol); + global.Reflect = global.Reflect || {}; + global.Reflect.global = global.Reflect.global || global; + polyfillObject(global.Object); + } + setupGlobals(global); + global.$traceurRuntime = { + checkObjectCoercible: checkObjectCoercible, + createPrivateName: createPrivateName, + defineProperties: $defineProperties, + defineProperty: $defineProperty, + exportStar: exportStar, + getOwnHashObject: getOwnHashObject, + getOwnPropertyDescriptor: $getOwnPropertyDescriptor, + getOwnPropertyNames: $getOwnPropertyNames, + isObject: isObject, + isPrivateName: isPrivateName, + isSymbolString: isSymbolString, + keys: $keys, + setupGlobals: setupGlobals, + toObject: toObject, + toProperty: toProperty, + typeof: typeOf + }; +})(window); +(function() { + 'use strict'; + var path; + function relativeRequire(callerPath, requiredPath) { + path = path || typeof require !== 'undefined' && require('path'); + function isDirectory(path) { + return path.slice(-1) === '/'; + } + function isAbsolute(path) { + return path[0] === '/'; + } + function isRelative(path) { + return path[0] === '.'; + } + if (isDirectory(requiredPath) || isAbsolute(requiredPath)) + return; + return isRelative(requiredPath) ? require(path.resolve(path.dirname(callerPath), requiredPath)) : require(requiredPath); + } + $traceurRuntime.require = relativeRequire; +})(); +(function() { + 'use strict'; + function spread() { + var rv = [], + j = 0, + iterResult; + for (var i = 0; i < arguments.length; i++) { + var valueToSpread = $traceurRuntime.checkObjectCoercible(arguments[i]); + if (typeof valueToSpread[$traceurRuntime.toProperty(Symbol.iterator)] !== 'function') { + throw new TypeError('Cannot spread non-iterable object.'); + } + var iter = valueToSpread[$traceurRuntime.toProperty(Symbol.iterator)](); + while (!(iterResult = iter.next()).done) { + rv[j++] = iterResult.value; + } + } + return rv; + } + $traceurRuntime.spread = spread; +})(); +(function() { + 'use strict'; + var $Object = Object; + var $TypeError = TypeError; + var $create = $Object.create; + var $defineProperties = $traceurRuntime.defineProperties; + var $defineProperty = $traceurRuntime.defineProperty; + var $getOwnPropertyDescriptor = $traceurRuntime.getOwnPropertyDescriptor; + var $getOwnPropertyNames = $traceurRuntime.getOwnPropertyNames; + var $getPrototypeOf = Object.getPrototypeOf; + var $__0 = Object, + getOwnPropertyNames = $__0.getOwnPropertyNames, + getOwnPropertySymbols = $__0.getOwnPropertySymbols; + function superDescriptor(homeObject, name) { + var proto = $getPrototypeOf(homeObject); + do { + var result = $getOwnPropertyDescriptor(proto, name); + if (result) + return result; + proto = $getPrototypeOf(proto); + } while (proto); + return undefined; + } + function superConstructor(ctor) { + return ctor.__proto__; + } + function superCall(self, homeObject, name, args) { + return superGet(self, homeObject, name).apply(self, args); + } + function superGet(self, homeObject, name) { + var descriptor = superDescriptor(homeObject, name); + if (descriptor) { + if (!descriptor.get) + return descriptor.value; + return descriptor.get.call(self); + } + return undefined; + } + function superSet(self, homeObject, name, value) { + var descriptor = superDescriptor(homeObject, name); + if (descriptor && descriptor.set) { + descriptor.set.call(self, value); + return value; + } + throw $TypeError(("super has no setter '" + name + "'.")); + } + function getDescriptors(object) { + var descriptors = {}; + var names = getOwnPropertyNames(object); + for (var i = 0; i < names.length; i++) { + var name = names[i]; + descriptors[name] = $getOwnPropertyDescriptor(object, name); + } + var symbols = getOwnPropertySymbols(object); + for (var i = 0; i < symbols.length; i++) { + var symbol = symbols[i]; + descriptors[$traceurRuntime.toProperty(symbol)] = $getOwnPropertyDescriptor(object, $traceurRuntime.toProperty(symbol)); + } + return descriptors; + } + function createClass(ctor, object, staticObject, superClass) { + $defineProperty(object, 'constructor', { + value: ctor, + configurable: true, + enumerable: false, + writable: true + }); + if (arguments.length > 3) { + if (typeof superClass === 'function') + ctor.__proto__ = superClass; + ctor.prototype = $create(getProtoParent(superClass), getDescriptors(object)); + } else { + ctor.prototype = object; + } + $defineProperty(ctor, 'prototype', { + configurable: false, + writable: false + }); + return $defineProperties(ctor, getDescriptors(staticObject)); + } + function getProtoParent(superClass) { + if (typeof superClass === 'function') { + var prototype = superClass.prototype; + if ($Object(prototype) === prototype || prototype === null) + return superClass.prototype; + throw new $TypeError('super prototype must be an Object or null'); + } + if (superClass === null) + return null; + throw new $TypeError(("Super expression must either be null or a function, not " + typeof superClass + ".")); + } + function defaultSuperCall(self, homeObject, args) { + if ($getPrototypeOf(homeObject) !== null) + superCall(self, homeObject, 'constructor', args); + } + $traceurRuntime.createClass = createClass; + $traceurRuntime.defaultSuperCall = defaultSuperCall; + $traceurRuntime.superCall = superCall; + $traceurRuntime.superConstructor = superConstructor; + $traceurRuntime.superGet = superGet; + $traceurRuntime.superSet = superSet; +})(); + +//# +},{"path":undefined}],80:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + TableView: {get: function() { + return TableView; + }}, + __esModule: {value: true} +}); +var $__dom_46_js__, + $__helpers_46_js__, + $__eventManager_46_js__, + $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__, + $__3rdparty_47_walkontable_47_src_47_selection_46_js__, + $__3rdparty_47_walkontable_47_src_47_core_46_js__; +var dom = ($__dom_46_js__ = require("dom.js"), $__dom_46_js__ && $__dom_46_js__.__esModule && $__dom_46_js__ || {default: $__dom_46_js__}); +var helper = ($__helpers_46_js__ = require("helpers.js"), $__helpers_46_js__ && $__helpers_46_js__.__esModule && $__helpers_46_js__ || {default: $__helpers_46_js__}); +var eventManagerObject = ($__eventManager_46_js__ = require("eventManager.js"), $__eventManager_46_js__ && $__eventManager_46_js__.__esModule && $__eventManager_46_js__ || {default: $__eventManager_46_js__}).eventManager; +var WalkontableCellCoords = ($__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ = require("3rdparty/walkontable/src/cell/coords.js"), $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ && $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__.__esModule && $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__ || {default: $__3rdparty_47_walkontable_47_src_47_cell_47_coords_46_js__}).WalkontableCellCoords; +var WalkontableSelection = ($__3rdparty_47_walkontable_47_src_47_selection_46_js__ = require("3rdparty/walkontable/src/selection.js"), $__3rdparty_47_walkontable_47_src_47_selection_46_js__ && $__3rdparty_47_walkontable_47_src_47_selection_46_js__.__esModule && $__3rdparty_47_walkontable_47_src_47_selection_46_js__ || {default: $__3rdparty_47_walkontable_47_src_47_selection_46_js__}).WalkontableSelection; +var Walkontable = ($__3rdparty_47_walkontable_47_src_47_core_46_js__ = require("3rdparty/walkontable/src/core.js"), $__3rdparty_47_walkontable_47_src_47_core_46_js__ && $__3rdparty_47_walkontable_47_src_47_core_46_js__.__esModule && $__3rdparty_47_walkontable_47_src_47_core_46_js__ || {default: $__3rdparty_47_walkontable_47_src_47_core_46_js__}).Walkontable; +Handsontable.TableView = TableView; +function TableView(instance) { + var that = this; + this.eventManager = eventManagerObject(instance); + this.instance = instance; + this.settings = instance.getSettings(); + var originalStyle = instance.rootElement.getAttribute('style'); + if (originalStyle) { + instance.rootElement.setAttribute('data-originalstyle', originalStyle); + } + dom.addClass(instance.rootElement, 'handsontable'); + var table = document.createElement('TABLE'); + table.className = 'htCore'; + this.THEAD = document.createElement('THEAD'); + table.appendChild(this.THEAD); + this.TBODY = document.createElement('TBODY'); + table.appendChild(this.TBODY); + instance.table = table; + instance.container.insertBefore(table, instance.container.firstChild); + this.eventManager.addEventListener(instance.rootElement, 'mousedown', function(event) { + if (!that.isTextSelectionAllowed(event.target)) { + clearTextSelection(); + event.preventDefault(); + window.focus(); + } + }); + this.eventManager.addEventListener(document.documentElement, 'keyup', function(event) { + if (instance.selection.isInProgress() && !event.shiftKey) { + instance.selection.finish(); + } + }); + var isMouseDown; + this.isMouseDown = function() { + return isMouseDown; + }; + this.eventManager.addEventListener(document.documentElement, 'mouseup', function(event) { + if (instance.selection.isInProgress() && event.which === 1) { + instance.selection.finish(); + } + isMouseDown = false; + if (helper.isOutsideInput(document.activeElement)) { + instance.unlisten(); + } + }); + this.eventManager.addEventListener(document.documentElement, 'mousedown', function(event) { + var next = event.target; + var eventX = event.x || event.clientX; + var eventY = event.y || event.clientY; + if (isMouseDown || !instance.rootElement) { + return; + } + if (next !== instance.view.wt.wtTable.holder) { + while (next !== document.documentElement) { + if (next === null) { + if (event.isTargetWebComponent) { + break; + } + return; + } + if (next === instance.rootElement) { + return; + } + next = next.parentNode; + } + } else { + var scrollbarWidth = Handsontable.Dom.getScrollbarWidth(); + if (document.elementFromPoint(eventX + scrollbarWidth, eventY) !== instance.view.wt.wtTable.holder || document.elementFromPoint(eventX, eventY + scrollbarWidth) !== instance.view.wt.wtTable.holder) { + return; + } + } + if (that.settings.outsideClickDeselects) { + instance.deselectCell(); + } else { + instance.destroyEditor(); + } + }); + this.eventManager.addEventListener(table, 'selectstart', function(event) { + if (that.settings.fragmentSelection) { + return; + } + event.preventDefault(); + }); + var clearTextSelection = function() { + if (window.getSelection) { + if (window.getSelection().empty) { + window.getSelection().empty(); + } else if (window.getSelection().removeAllRanges) { + window.getSelection().removeAllRanges(); + } + } else if (document.selection) { + document.selection.empty(); + } + }; + var selections = [new WalkontableSelection({ + className: 'current', + border: { + width: 2, + color: '#5292F7', + cornerVisible: function() { + return that.settings.fillHandle && !that.isCellEdited() && !instance.selection.isMultiple(); + }, + multipleSelectionHandlesVisible: function() { + return !that.isCellEdited() && !instance.selection.isMultiple(); + } + } + }), new WalkontableSelection({ + className: 'area', + border: { + width: 1, + color: '#89AFF9', + cornerVisible: function() { + return that.settings.fillHandle && !that.isCellEdited() && instance.selection.isMultiple(); + }, + multipleSelectionHandlesVisible: function() { + return !that.isCellEdited() && instance.selection.isMultiple(); + } + } + }), new WalkontableSelection({ + className: 'highlight', + highlightRowClassName: that.settings.currentRowClassName, + highlightColumnClassName: that.settings.currentColClassName + }), new WalkontableSelection({ + className: 'fill', + border: { + width: 1, + color: 'red' + } + })]; + selections.current = selections[0]; + selections.area = selections[1]; + selections.highlight = selections[2]; + selections.fill = selections[3]; + var walkontableConfig = { + debug: function() { + return that.settings.debug; + }, + externalRowCalculator: this.instance.getPlugin('autoRowSize') && this.instance.getPlugin('autoRowSize').isEnabled(), + table: table, + stretchH: this.settings.stretchH, + data: instance.getDataAtCell, + totalRows: instance.countRows, + totalColumns: instance.countCols, + fixedColumnsLeft: function() { + return that.settings.fixedColumnsLeft; + }, + fixedRowsTop: function() { + return that.settings.fixedRowsTop; + }, + renderAllRows: that.settings.renderAllRows, + rowHeaders: function() { + var arr = []; + if (instance.hasRowHeaders()) { + arr.push(function(index, TH) { + that.appendRowHeader(index, TH); + }); + } + Handsontable.hooks.run(instance, 'afterGetRowHeaderRenderers', arr); + return arr; + }, + columnHeaders: function() { + var arr = []; + if (instance.hasColHeaders()) { + arr.push(function(index, TH) { + that.appendColHeader(index, TH); + }); + } + Handsontable.hooks.run(instance, 'afterGetColumnHeaderRenderers', arr); + return arr; + }, + columnWidth: instance.getColWidth, + rowHeight: instance.getRowHeight, + cellRenderer: function(row, col, TD) { + var prop = that.instance.colToProp(col), + cellProperties = that.instance.getCellMeta(row, col), + renderer = that.instance.getCellRenderer(cellProperties); + var value = that.instance.getDataAtRowProp(row, prop); + renderer(that.instance, TD, row, col, prop, value, cellProperties); + Handsontable.hooks.run(that.instance, 'afterRenderer', TD, row, col, prop, value, cellProperties); + }, + selections: selections, + hideBorderOnMouseDownOver: function() { + return that.settings.fragmentSelection; + }, + onCellMouseDown: function(event, coords, TD, wt) { + instance.listen(); + that.activeWt = wt; + isMouseDown = true; + dom.enableImmediatePropagation(event); + Handsontable.hooks.run(instance, 'beforeOnCellMouseDown', event, coords, TD); + if (!event.isImmediatePropagationStopped()) { + if (event.button === 2 && instance.selection.inInSelection(coords)) {} else if (event.shiftKey) { + if (coords.row >= 0 && coords.col >= 0) { + instance.selection.setRangeEnd(coords); + } + } else { + if ((coords.row < 0 || coords.col < 0) && (coords.row >= 0 || coords.col >= 0)) { + if (coords.row < 0) { + instance.selectCell(0, coords.col, instance.countRows() - 1, coords.col); + instance.selection.setSelectedHeaders(false, true); + } + if (coords.col < 0) { + instance.selectCell(coords.row, 0, coords.row, instance.countCols() - 1); + instance.selection.setSelectedHeaders(true, false); + } + } else { + coords.row = coords.row < 0 ? 0 : coords.row; + coords.col = coords.col < 0 ? 0 : coords.col; + instance.selection.setRangeStart(coords); + } + } + Handsontable.hooks.run(instance, 'afterOnCellMouseDown', event, coords, TD); + that.activeWt = that.wt; + } + }, + onCellMouseOver: function(event, coords, TD, wt) { + that.activeWt = wt; + if (coords.row >= 0 && coords.col >= 0) { + if (isMouseDown) { + instance.selection.setRangeEnd(coords); + } + } else { + if (isMouseDown) { + if (coords.row < 0) { + instance.selection.setRangeEnd(new WalkontableCellCoords(instance.countRows() - 1, coords.col)); + instance.selection.setSelectedHeaders(false, true); + } + if (coords.col < 0) { + instance.selection.setRangeEnd(new WalkontableCellCoords(coords.row, instance.countCols() - 1)); + instance.selection.setSelectedHeaders(true, false); + } + } + } + Handsontable.hooks.run(instance, 'afterOnCellMouseOver', event, coords, TD); + that.activeWt = that.wt; + }, + onCellCornerMouseDown: function(event) { + event.preventDefault(); + Handsontable.hooks.run(instance, 'afterOnCellCornerMouseDown', event); + }, + beforeDraw: function(force) { + that.beforeRender(force); + }, + onDraw: function(force) { + that.onDraw(force); + }, + onScrollVertically: function() { + instance.runHooks('afterScrollVertically'); + }, + onScrollHorizontally: function() { + instance.runHooks('afterScrollHorizontally'); + }, + onBeforeDrawBorders: function(corners, borderClassName) { + instance.runHooks('beforeDrawBorders', corners, borderClassName); + }, + onBeforeTouchScroll: function() { + instance.runHooks('beforeTouchScroll'); + }, + onAfterMomentumScroll: function() { + instance.runHooks('afterMomentumScroll'); + }, + viewportRowCalculatorOverride: function(calc) { + var rows = instance.countRows(); + var viewportOffset = that.settings.viewportRowRenderingOffset; + if (viewportOffset === 'auto' && that.settings.fixedRowsTop) { + viewportOffset = 10; + } + if (typeof viewportOffset === 'number') { + calc.startRow = Math.max(calc.startRow - viewportOffset, 0); + calc.endRow = Math.min(calc.endRow + viewportOffset, rows - 1); + } + if (viewportOffset === 'auto') { + var center = calc.startRow + calc.endRow - calc.startRow; + var offset = Math.ceil(center / rows * 12); + calc.startRow = Math.max(calc.startRow - offset, 0); + calc.endRow = Math.min(calc.endRow + offset, rows - 1); + } + instance.runHooks('afterViewportRowCalculatorOverride', calc); + }, + viewportColumnCalculatorOverride: function(calc) { + var cols = instance.countCols(); + var viewportOffset = that.settings.viewportColumnRenderingOffset; + if (viewportOffset === 'auto' && that.settings.fixedColumnsLeft) { + viewportOffset = 10; + } + if (typeof viewportOffset === 'number') { + calc.startColumn = Math.max(calc.startColumn - viewportOffset, 0); + calc.endColumn = Math.min(calc.endColumn + viewportOffset, cols - 1); + } + if (viewportOffset === 'auto') { + var center = calc.startColumn + calc.endColumn - calc.startColumn; + var offset = Math.ceil(center / cols * 12); + calc.startRow = Math.max(calc.startColumn - offset, 0); + calc.endColumn = Math.min(calc.endColumn + offset, cols - 1); + } + instance.runHooks('afterViewportColumnCalculatorOverride', calc); + } + }; + Handsontable.hooks.run(instance, 'beforeInitWalkontable', walkontableConfig); + this.wt = new Walkontable(walkontableConfig); + this.activeWt = this.wt; + this.eventManager.addEventListener(that.wt.wtTable.spreader, 'mousedown', function(event) { + if (event.target === that.wt.wtTable.spreader && event.which === 3) { + helper.stopPropagation(event); + } + }); + this.eventManager.addEventListener(that.wt.wtTable.spreader, 'contextmenu', function(event) { + if (event.target === that.wt.wtTable.spreader && event.which === 3) { + helper.stopPropagation(event); + } + }); + this.eventManager.addEventListener(document.documentElement, 'click', function() { + if (that.settings.observeDOMVisibility) { + if (that.wt.drawInterrupted) { + that.instance.forceFullRender = true; + that.render(); + } + } + }); +} +TableView.prototype.isTextSelectionAllowed = function(el) { + if (helper.isInput(el)) { + return true; + } + if (this.settings.fragmentSelection && dom.isChildOf(el, this.TBODY)) { + return true; + } + return false; +}; +TableView.prototype.isCellEdited = function() { + var activeEditor = this.instance.getActiveEditor(); + return activeEditor && activeEditor.isOpened(); +}; +TableView.prototype.beforeRender = function(force) { + if (force) { + Handsontable.hooks.run(this.instance, 'beforeRender', this.instance.forceFullRender); + } +}; +TableView.prototype.onDraw = function(force) { + if (force) { + Handsontable.hooks.run(this.instance, 'afterRender', this.instance.forceFullRender); + } +}; +TableView.prototype.render = function() { + this.wt.draw(!this.instance.forceFullRender); + this.instance.forceFullRender = false; + this.instance.renderCall = false; +}; +TableView.prototype.getCellAtCoords = function(coords, topmost) { + var td = this.wt.getCell(coords, topmost); + if (td < 0) { + return null; + } else { + return td; + } +}; +TableView.prototype.scrollViewport = function(coords) { + this.wt.scrollViewport(coords); +}; +TableView.prototype.appendRowHeader = function(row, TH) { + if (TH.firstChild) { + var container = TH.firstChild; + if (!dom.hasClass(container, 'relative')) { + dom.empty(TH); + this.appendRowHeader(row, TH); + return; + } + this.updateCellHeader(container.firstChild, row, this.instance.getRowHeader); + } else { + var div = document.createElement('div'); + var span = document.createElement('span'); + div.className = 'relative'; + span.className = 'colHeader'; + this.updateCellHeader(span, row, this.instance.getRowHeader); + div.appendChild(span); + TH.appendChild(div); + } + Handsontable.hooks.run(this.instance, 'afterGetRowHeader', row, TH); +}; +TableView.prototype.appendColHeader = function(col, TH) { + if (TH.firstChild) { + var container = TH.firstChild; + if (!dom.hasClass(container, 'relative')) { + dom.empty(TH); + this.appendRowHeader(col, TH); + return; + } + this.updateCellHeader(container.firstChild, col, this.instance.getColHeader); + } else { + var div = document.createElement('div'); + var span = document.createElement('span'); + div.className = 'relative'; + span.className = 'colHeader'; + this.updateCellHeader(span, col, this.instance.getColHeader); + div.appendChild(span); + TH.appendChild(div); + } + Handsontable.hooks.run(this.instance, 'afterGetColHeader', col, TH); +}; +TableView.prototype.updateCellHeader = function(element, index, content) { + if (index > -1) { + dom.fastInnerHTML(element, content(index)); + } else { + dom.fastInnerText(element, String.fromCharCode(160)); + dom.addClass(element, 'cornerHeader'); + } +}; +TableView.prototype.maximumVisibleElementWidth = function(leftOffset) { + var workspaceWidth = this.wt.wtViewport.getWorkspaceWidth(); + var maxWidth = workspaceWidth - leftOffset; + return maxWidth > 0 ? maxWidth : 0; +}; +TableView.prototype.maximumVisibleElementHeight = function(topOffset) { + var workspaceHeight = this.wt.wtViewport.getWorkspaceHeight(); + var maxHeight = workspaceHeight - topOffset; + return maxHeight > 0 ? maxHeight : 0; +}; +TableView.prototype.mainViewIsActive = function() { + return this.wt === this.activeWt; +}; +TableView.prototype.destroy = function() { + this.wt.destroy(); + this.eventManager.destroy(); +}; +; + +//# +},{"3rdparty/walkontable/src/cell/coords.js":5,"3rdparty/walkontable/src/core.js":7,"3rdparty/walkontable/src/selection.js":18,"dom.js":27,"eventManager.js":41,"helpers.js":42}],81:[function(require,module,exports){ +"use strict"; +Object.defineProperties(exports, { + GhostTable: {get: function() { + return GhostTable; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_helpers_46_js__; +var $__0 = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}), + addClass = $__0.addClass, + outerHeight = $__0.outerHeight, + outerWidth = $__0.outerWidth; +var $__1 = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}), + arrayEach = $__1.arrayEach, + objectEach = $__1.objectEach, + rangeEach = $__1.rangeEach, + stringify = $__1.stringify; +var GhostTable = function GhostTable(hotInstance) { + this.hot = hotInstance; + this.container = null; + this.injected = false; + this.rows = []; + this.columns = []; + this.samples = null; +}; +($traceurRuntime.createClass)(GhostTable, { + addRow: function(row, samples) { + if (this.columns.length) { + throw new Error('Doesn\'t support multi-dimensional table'); + } + if (!this.rows.length) { + this.container = this.createContainer(this.hot.rootElement.className); + } + var rowObject = {row: row}; + this.rows.push(rowObject); + this.samples = samples; + this.table = this.createTable(this.hot.table.className); + this.table.colGroup.appendChild(this.createColGroupsCol()); + this.table.tr.appendChild(this.createRow(row)); + this.container.container.appendChild(this.table.fragment); + rowObject.table = this.table.table; + }, + addColumn: function(column, samples) { + if (this.rows.length) { + throw new Error('Doesn\'t support multi-dimensional table'); + } + if (!this.columns.length) { + this.container = this.createContainer(this.hot.rootElement.className); + } + var columnObject = {col: column}; + this.columns.push(columnObject); + this.samples = samples; + this.table = this.createTable(this.hot.table.className); + if (this.hot.getColHeader(column) !== null) { + this.hot.view.appendColHeader(column, this.table.th); + } + this.table.tBody.appendChild(this.createCol(column)); + this.container.container.appendChild(this.table.fragment); + columnObject.table = this.table.table; + }, + getHeights: function(callback) { + if (!this.injected) { + this.injectTable(); + } + arrayEach(this.rows, (function(row) { + callback(row.row, outerHeight(row.table) - 1); + })); + }, + getWidths: function(callback) { + if (!this.injected) { + this.injectTable(); + } + arrayEach(this.columns, (function(column) { + callback(column.col, outerWidth(column.table)); + })); + }, + createColGroupsCol: function() { + var $__2 = this; + var d = document; + var fragment = d.createDocumentFragment(); + fragment.appendChild(this.createColElement(-1)); + this.samples.forEach((function(sample) { + arrayEach(sample.strings, (function(string) { + fragment.appendChild($__2.createColElement(string.col)); + })); + })); + return fragment; + }, + createRow: function(row) { + var $__2 = this; + var d = document; + var fragment = d.createDocumentFragment(); + var th = d.createElement('th'); + if (this.hot.getRowHeader(row) !== null) { + this.hot.view.appendRowHeader(row, th); + } + fragment.appendChild(th); + this.samples.forEach((function(sample) { + arrayEach(sample.strings, (function(string) { + var column = string.col; + var cellProperties = $__2.hot.getCellMeta(row, column); + cellProperties.col = column; + cellProperties.row = row; + var renderer = $__2.hot.getCellRenderer(cellProperties); + var td = d.createElement('td'); + renderer($__2.hot, td, row, column, $__2.hot.colToProp(column), string.value, cellProperties); + fragment.appendChild(td); + })); + })); + return fragment; + }, + createCol: function(column) { + var $__2 = this; + var d = document; + var fragment = d.createDocumentFragment(); + this.samples.forEach((function(sample) { + arrayEach(sample.strings, (function(string) { + var row = string.row; + var cellProperties = $__2.hot.getCellMeta(row, column); + cellProperties.col = column; + cellProperties.row = row; + var renderer = $__2.hot.getCellRenderer(cellProperties); + var td = d.createElement('td'); + var tr = d.createElement('tr'); + renderer($__2.hot, td, row, column, $__2.hot.colToProp(row), string.value, cellProperties); + tr.appendChild(td); + fragment.appendChild(tr); + })); + })); + return fragment; + }, + clean: function() { + this.rows.length = 0; + this.columns.length = 0; + if (this.samples) { + this.samples.clear(); + } + this.samples = null; + this.removeTable(); + }, + injectTable: function() { + var parent = arguments[0] !== (void 0) ? arguments[0] : null; + if (!this.injected) { + (parent || this.hot.rootElement).appendChild(this.container.fragment); + this.injected = true; + } + }, + removeTable: function() { + if (this.injected && this.container.container.parentNode) { + this.container.container.parentNode.removeChild(this.container.container); + this.container = null; + this.injected = false; + } + }, + createColElement: function(column) { + var d = document; + var col = d.createElement('col'); + col.style.width = this.hot.view.wt.wtTable.getStretchedColumnWidth(column) + 'px'; + return col; + }, + createTable: function() { + var className = arguments[0] !== (void 0) ? arguments[0] : ''; + var d = document; + var fragment = d.createDocumentFragment(); + var table = d.createElement('table'); + var tHead = d.createElement('thead'); + var tBody = d.createElement('tbody'); + var colGroup = d.createElement('colgroup'); + var tr = d.createElement('tr'); + var th = d.createElement('th'); + if (this.isVertical()) { + table.appendChild(colGroup); + } + if (this.isHorizontal()) { + tr.appendChild(th); + tHead.appendChild(tr); + table.style.tableLayout = 'auto'; + table.style.width = 'auto'; + } + table.appendChild(tHead); + if (this.isVertical()) { + tBody.appendChild(tr); + } + table.appendChild(tBody); + addClass(table, className); + fragment.appendChild(table); + return { + fragment: fragment, + table: table, + tHead: tHead, + tBody: tBody, + colGroup: colGroup, + tr: tr, + th: th + }; + }, + createContainer: function() { + var className = arguments[0] !== (void 0) ? arguments[0] : ''; + var d = document; + var fragment = d.createDocumentFragment(); + var container = d.createElement('div'); + className = 'htGhostTable htAutoSize ' + className.trim(); + addClass(container, className); + fragment.appendChild(container); + return { + fragment: fragment, + container: container + }; + }, + isVertical: function() { + return this.rows.length && !this.columns.length ? true : false; + }, + isHorizontal: function() { + return this.columns.length && !this.rows.length ? true : false; + } +}, {}); +; +Handsontable.utils = Handsontable.utils || {}; +Handsontable.utils.GhostTable = GhostTable; + +//# +},{"dom.js":27,"helpers.js":42}],82:[function(require,module,exports){ +"use strict"; +var $__4; +Object.defineProperties(exports, { + SamplesGenerator: {get: function() { + return SamplesGenerator; + }}, + __esModule: {value: true} +}); +var $___46__46__47_dom_46_js__, + $___46__46__47_helpers_46_js__; +var $__0 = ($___46__46__47_dom_46_js__ = require("dom.js"), $___46__46__47_dom_46_js__ && $___46__46__47_dom_46_js__.__esModule && $___46__46__47_dom_46_js__ || {default: $___46__46__47_dom_46_js__}), + addClass = $__0.addClass, + outerHeight = $__0.outerHeight, + outerWidth = $__0.outerWidth; +var $__1 = ($___46__46__47_helpers_46_js__ = require("helpers.js"), $___46__46__47_helpers_46_js__ && $___46__46__47_helpers_46_js__.__esModule && $___46__46__47_helpers_46_js__ || {default: $___46__46__47_helpers_46_js__}), + arrayEach = $__1.arrayEach, + objectEach = $__1.objectEach, + rangeEach = $__1.rangeEach, + stringify = $__1.stringify; +var SamplesGenerator = function SamplesGenerator(dataFactory) { + this.samples = null; + this.dataFactory = dataFactory; +}; +var $SamplesGenerator = SamplesGenerator; +($traceurRuntime.createClass)(SamplesGenerator, ($__4 = {}, Object.defineProperty($__4, "generateRowSamples", { + value: function(rowRange, colRange) { + return this.generateSamples('row', colRange, rowRange); + }, + configurable: true, + enumerable: true, + writable: true +}), Object.defineProperty($__4, "generateColumnSamples", { + value: function(colRange, rowRange) { + return this.generateSamples('col', rowRange, colRange); + }, + configurable: true, + enumerable: true, + writable: true +}), Object.defineProperty($__4, "generateSamples", { + value: function(type, range, specifierRange) { + var $__2 = this; + var samples = new Map(); + if (typeof specifierRange === 'number') { + specifierRange = { + from: specifierRange, + to: specifierRange + }; + } + rangeEach(specifierRange.from, specifierRange.to, (function(index) { + var sample = $__2.generateSample(type, range, index); + samples.set(index, sample); + })); + return samples; + }, + configurable: true, + enumerable: true, + writable: true +}), Object.defineProperty($__4, "generateSample", { + value: function(type, range, specifierValue) { + var $__2 = this; + var samples = new Map(); + rangeEach(range.from, range.to, (function(index) { + var $__4; + var value; + if (type === 'row') { + value = $__2.dataFactory(specifierValue, index); + } else if (type === 'col') { + value = $__2.dataFactory(index, specifierValue); + } else { + throw new Error('Unsupported sample type'); + } + if (!Array.isArray(value)) { + value = stringify(value); + } + var len = value.length; + if (!samples.has(len)) { + samples.set(len, { + needed: $SamplesGenerator.SAMPLE_COUNT, + strings: [] + }); + } + var sample = samples.get(len); + if (sample.needed) { + sample.strings.push(($__4 = {}, Object.defineProperty($__4, "value", { + value: value, + configurable: true, + enumerable: true, + writable: true + }), Object.defineProperty($__4, type === 'row' ? 'col' : 'row', { + value: index, + configurable: true, + enumerable: true, + writable: true + }), $__4)); + sample.needed--; + } + })); + return samples; + }, + configurable: true, + enumerable: true, + writable: true +}), $__4), {get SAMPLE_COUNT() { + return 3; + }}); +; +Handsontable.utils = Handsontable.utils || {}; +Handsontable.utils.SamplesGenerator = SamplesGenerator; + +//# +},{"dom.js":27,"helpers.js":42}],83:[function(require,module,exports){ +"use strict"; +var process = function(value, callback) { + var originalVal = value; + var lowercaseVal = typeof originalVal === 'string' ? originalVal.toLowerCase() : null; + return function(source) { + var found = false; + for (var s = 0, + slen = source.length; s < slen; s++) { + if (originalVal === source[s]) { + found = true; + break; + } else if (lowercaseVal === Handsontable.helper.stringify(source[s]).toLowerCase()) { + found = true; + break; + } + } + callback(found); + }; +}; +Handsontable.AutocompleteValidator = function(value, callback) { + if (this.strict && this.source) { + if (typeof this.source === 'function') { + this.source(value, process(value, callback)); + } else { + process(value, callback)(this.source); + } + } else { + callback(true); + } +}; + +//# +},{}],84:[function(require,module,exports){ +"use strict"; +var $__moment__, + $___46__46__47_editors_46_js__; +var moment = ($__moment__ = require("moment"), $__moment__ && $__moment__.__esModule && $__moment__ || {default: $__moment__}).default; +var getEditor = ($___46__46__47_editors_46_js__ = require("editors.js"), $___46__46__47_editors_46_js__ && $___46__46__47_editors_46_js__.__esModule && $___46__46__47_editors_46_js__ || {default: $___46__46__47_editors_46_js__}).getEditor; +Handsontable.DateValidator = function(value, callback) { + var valid = true; + var dateEditor = getEditor('date', this.instance); + if (value === null) { + value = ''; + } + var isValidDate = moment(new Date(value)).isValid(); + var isValidFormat = moment(value, this.dateFormat || dateEditor.defaultDateFormat, true).isValid(); + if (!isValidDate) { + valid = false; + } + if (!isValidDate && isValidFormat) { + valid = true; + } + if (isValidDate && !isValidFormat) { + if (this.correctFormat === true) { + var correctedValue = correctFormat(value, this.dateFormat); + this.instance.setDataAtCell(this.row, this.col, correctedValue, 'dateValidator'); + valid = true; + } else { + valid = false; + } + } + callback(valid); +}; +var correctFormat = function correctFormat(value, dateFormat) { + var date = moment(new Date(value)); + var year = date.format('YYYY'); + var yearNow = moment().format('YYYY'); + if (year.substr(0, 2) !== yearNow.substr(0, 2)) { + if (!value.match(new RegExp(year))) { + date.year(year.replace(year.substr(0, 2), yearNow.substr(0, 2))); + } + } else if (year.length > 4) { + date.year((date.year() + '').substr(0, 4)); + } + return date.format(dateFormat); +}; + +//# +},{"editors.js":29,"moment":"moment"}],85:[function(require,module,exports){ +"use strict"; +Handsontable.NumericValidator = function(value, callback) { + if (value === null) { + value = ''; + } + callback(/^-?\d*(\.|\,)?\d*$/.test(value)); +}; + +//# +},{}],"SheetClip":[function(require,module,exports){ +"use strict"; +(function(global) { + "use strict"; + function countQuotes(str) { + return str.split('"').length - 1; + } + var SheetClip = { + parse: function(str) { + var r, + rLen, + rows, + arr = [], + a = 0, + c, + cLen, + multiline, + last; + rows = str.split('\n'); + if (rows.length > 1 && rows[rows.length - 1] === '') { + rows.pop(); + } + for (r = 0, rLen = rows.length; r < rLen; r += 1) { + rows[r] = rows[r].split('\t'); + for (c = 0, cLen = rows[r].length; c < cLen; c += 1) { + if (!arr[a]) { + arr[a] = []; + } + if (multiline && c === 0) { + last = arr[a].length - 1; + arr[a][last] = arr[a][last] + '\n' + rows[r][0]; + if (multiline && (countQuotes(rows[r][0]) & 1)) { + multiline = false; + arr[a][last] = arr[a][last].substring(0, arr[a][last].length - 1).replace(/""/g, '"'); + } + } else { + if (c === cLen - 1 && rows[r][c].indexOf('"') === 0 && (countQuotes(rows[r][c]) & 1)) { + arr[a].push(rows[r][c].substring(1).replace(/""/g, '"')); + multiline = true; + } else { + arr[a].push(rows[r][c].replace(/""/g, '"')); + multiline = false; + } + } + } + if (!multiline) { + a += 1; + } + } + return arr; + }, + stringify: function(arr) { + var r, + rLen, + c, + cLen, + str = '', + val; + for (r = 0, rLen = arr.length; r < rLen; r += 1) { + cLen = arr[r].length; + for (c = 0; c < cLen; c += 1) { + if (c > 0) { + str += '\t'; + } + val = arr[r][c]; + if (typeof val === 'string') { + if (val.indexOf('\n') > -1) { + str += '"' + val.replace(/"/g, '""') + '"'; + } else { + str += val; + } + } else if (val === null || val === void 0) { + str += ''; + } else { + str += val; + } + } + str += '\n'; + } + return str; + } + }; + if (typeof exports !== 'undefined') { + exports.parse = SheetClip.parse; + exports.stringify = SheetClip.stringify; + } else { + global.SheetClip = SheetClip; + } +}(window)); + +//# +},{}],"autoResize":[function(require,module,exports){ +"use strict"; +function autoResize() { + var defaults = { + minHeight: 200, + maxHeight: 300, + minWidth: 100, + maxWidth: 300 + }, + el, + body = document.body, + text = document.createTextNode(''), + span = document.createElement('SPAN'), + observe = function(element, event, handler) { + if (window.attachEvent) { + element.attachEvent('on' + event, handler); + } else { + element.addEventListener(event, handler, false); + } + }, + unObserve = function(element, event, handler) { + if (window.removeEventListener) { + element.removeEventListener(event, handler, false); + } else { + element.detachEvent('on' + event, handler); + } + }, + resize = function(newChar) { + var width, + scrollHeight; + if (!newChar) { + newChar = ""; + } else if (!/^[a-zA-Z \.,\\\/\|0-9]$/.test(newChar)) { + newChar = "."; + } + if (text.textContent !== void 0) { + text.textContent = el.value + newChar; + } else { + text.data = el.value + newChar; + } + span.style.fontSize = Handsontable.Dom.getComputedStyle(el).fontSize; + span.style.fontFamily = Handsontable.Dom.getComputedStyle(el).fontFamily; + span.style.whiteSpace = "pre"; + body.appendChild(span); + width = span.clientWidth + 2; + body.removeChild(span); + el.style.height = defaults.minHeight + 'px'; + if (defaults.minWidth > width) { + el.style.width = defaults.minWidth + 'px'; + } else if (width > defaults.maxWidth) { + el.style.width = defaults.maxWidth + 'px'; + } else { + el.style.width = width + 'px'; + } + scrollHeight = el.scrollHeight ? el.scrollHeight - 1 : 0; + if (defaults.minHeight > scrollHeight) { + el.style.height = defaults.minHeight + 'px'; + } else if (defaults.maxHeight < scrollHeight) { + el.style.height = defaults.maxHeight + 'px'; + el.style.overflowY = 'visible'; + } else { + el.style.height = scrollHeight + 'px'; + } + }, + delayedResize = function() { + window.setTimeout(resize, 0); + }, + extendDefaults = function(config) { + if (config && config.minHeight) { + if (config.minHeight == 'inherit') { + defaults.minHeight = el.clientHeight; + } else { + var minHeight = parseInt(config.minHeight); + if (!isNaN(minHeight)) { + defaults.minHeight = minHeight; + } + } + } + if (config && config.maxHeight) { + if (config.maxHeight == 'inherit') { + defaults.maxHeight = el.clientHeight; + } else { + var maxHeight = parseInt(config.maxHeight); + if (!isNaN(maxHeight)) { + defaults.maxHeight = maxHeight; + } + } + } + if (config && config.minWidth) { + if (config.minWidth == 'inherit') { + defaults.minWidth = el.clientWidth; + } else { + var minWidth = parseInt(config.minWidth); + if (!isNaN(minWidth)) { + defaults.minWidth = minWidth; + } + } + } + if (config && config.maxWidth) { + if (config.maxWidth == 'inherit') { + defaults.maxWidth = el.clientWidth; + } else { + var maxWidth = parseInt(config.maxWidth); + if (!isNaN(maxWidth)) { + defaults.maxWidth = maxWidth; + } + } + } + if (!span.firstChild) { + span.className = "autoResize"; + span.style.display = 'inline-block'; + span.appendChild(text); + } + }, + init = function(el_, config, doObserve) { + el = el_; + extendDefaults(config); + if (el.nodeName == 'TEXTAREA') { + el.style.resize = 'none'; + el.style.overflowY = ''; + el.style.height = defaults.minHeight + 'px'; + el.style.minWidth = defaults.minWidth + 'px'; + el.style.maxWidth = defaults.maxWidth + 'px'; + el.style.overflowY = 'hidden'; + } + if (doObserve) { + observe(el, 'change', resize); + observe(el, 'cut', delayedResize); + observe(el, 'paste', delayedResize); + observe(el, 'drop', delayedResize); + observe(el, 'keydown', delayedResize); + } + resize(); + }; + return { + init: function(el_, config, doObserve) { + init(el_, config, doObserve); + }, + unObserve: function() { + unObserve(el, 'change', resize); + unObserve(el, 'cut', delayedResize); + unObserve(el, 'paste', delayedResize); + unObserve(el, 'drop', delayedResize); + unObserve(el, 'keydown', delayedResize); + }, + resize: resize + }; +} +if (typeof exports !== 'undefined') { + module.exports = autoResize; +} + +//# +},{}],"copyPaste":[function(require,module,exports){ +"use strict"; +var instance; +function copyPaste() { + if (!instance) { + instance = new CopyPasteClass(); + } else if (instance.hasBeenDestroyed()) { + instance.init(); + } + instance.refCounter++; + return instance; +} +if (typeof exports !== 'undefined') { + module.exports = copyPaste; +} +function CopyPasteClass() { + this.refCounter = 0; + this.init(); +} +CopyPasteClass.prototype.init = function() { + var style, + parent; + this.copyCallbacks = []; + this.cutCallbacks = []; + this.pasteCallbacks = []; + parent = document.body; + if (document.getElementById('CopyPasteDiv')) { + this.elDiv = document.getElementById('CopyPasteDiv'); + this.elTextarea = this.elDiv.firstChild; + } else { + this.elDiv = document.createElement('div'); + this.elDiv.id = 'CopyPasteDiv'; + style = this.elDiv.style; + style.position = 'fixed'; + style.top = '-10000px'; + style.left = '-10000px'; + parent.appendChild(this.elDiv); + this.elTextarea = document.createElement('textarea'); + this.elTextarea.className = 'copyPaste'; + this.elTextarea.onpaste = function(event) { + var clipboardContents, + temp; + if ('WebkitAppearance' in document.documentElement.style) { + clipboardContents = event.clipboardData.getData("Text"); + if (navigator.userAgent.indexOf('Safari') !== -1 && navigator.userAgent.indexOf('Chrome') === -1) { + temp = clipboardContents.split('\n'); + if (temp[temp.length - 1] === '') { + temp.pop(); + } + clipboardContents = temp.join('\n'); + } + this.value = clipboardContents; + return false; + } + }; + style = this.elTextarea.style; + style.width = '10000px'; + style.height = '10000px'; + style.overflow = 'hidden'; + this.elDiv.appendChild(this.elTextarea); + if (typeof style.opacity !== 'undefined') { + style.opacity = 0; + } + } + this.onKeyDownRef = this.onKeyDown.bind(this); + document.documentElement.addEventListener('keydown', this.onKeyDownRef, false); +}; +CopyPasteClass.prototype.onKeyDown = function(event) { + var _this = this, + isCtrlDown = false; + function isActiveElementEditable() { + var element = document.activeElement; + if (element.shadowRoot && element.shadowRoot.activeElement) { + element = element.shadowRoot.activeElement; + } + return ['INPUT', 'SELECT', 'TEXTAREA'].indexOf(element.nodeName) > -1 || element.contentEditable === 'true'; + } + if (event.metaKey) { + isCtrlDown = true; + } else if (event.ctrlKey && navigator.userAgent.indexOf('Mac') === -1) { + isCtrlDown = true; + } + if (isCtrlDown) { + if (document.activeElement !== this.elTextarea && (this.getSelectionText() !== '' || isActiveElementEditable())) { + return; + } + this.selectNodeText(this.elTextarea); + setTimeout(function() { + if (document.activeElement !== _this.elTextarea) { + _this.selectNodeText(_this.elTextarea); + } + }, 0); + } + if (isCtrlDown && (event.keyCode === 67 || event.keyCode === 86 || event.keyCode === 88)) { + if (event.keyCode === 88) { + setTimeout(function() { + _this.triggerCut(event); + }, 0); + } else if (event.keyCode === 86) { + setTimeout(function() { + _this.triggerPaste(event); + }, 0); + } + } +}; +CopyPasteClass.prototype.selectNodeText = function(element) { + if (element) { + element.select(); + } +}; +CopyPasteClass.prototype.getSelectionText = function() { + var text = ''; + if (window.getSelection) { + text = window.getSelection().toString(); + } else if (document.selection && document.selection.type !== 'Control') { + text = document.selection.createRange().text; + } + return text; +}; +CopyPasteClass.prototype.copyable = function(string) { + if (typeof string !== 'string' && string.toString === void 0) { + throw new Error('copyable requires string parameter'); + } + this.elTextarea.value = string; + this.selectNodeText(this.elTextarea); +}; +CopyPasteClass.prototype.onCut = function(callback) { + this.cutCallbacks.push(callback); +}; +CopyPasteClass.prototype.onPaste = function(callback) { + this.pasteCallbacks.push(callback); +}; +CopyPasteClass.prototype.removeCallback = function(callback) { + var i, + len; + for (i = 0, len = this.copyCallbacks.length; i < len; i++) { + if (this.copyCallbacks[i] === callback) { + this.copyCallbacks.splice(i, 1); + return true; + } + } + for (i = 0, len = this.cutCallbacks.length; i < len; i++) { + if (this.cutCallbacks[i] === callback) { + this.cutCallbacks.splice(i, 1); + return true; + } + } + for (i = 0, len = this.pasteCallbacks.length; i < len; i++) { + if (this.pasteCallbacks[i] === callback) { + this.pasteCallbacks.splice(i, 1); + return true; + } + } + return false; +}; +CopyPasteClass.prototype.triggerCut = function(event) { + var _this = this; + if (_this.cutCallbacks) { + setTimeout(function() { + for (var i = 0, + len = _this.cutCallbacks.length; i < len; i++) { + _this.cutCallbacks[i](event); + } + }, 50); + } +}; +CopyPasteClass.prototype.triggerPaste = function(event, string) { + var _this = this; + if (_this.pasteCallbacks) { + setTimeout(function() { + var val = string || _this.elTextarea.value; + for (var i = 0, + len = _this.pasteCallbacks.length; i < len; i++) { + _this.pasteCallbacks[i](val, event); + } + }, 50); + } +}; +CopyPasteClass.prototype.destroy = function() { + if (!this.hasBeenDestroyed() && --this.refCounter === 0) { + if (this.elDiv && this.elDiv.parentNode) { + this.elDiv.parentNode.removeChild(this.elDiv); + this.elDiv = null; + this.elTextarea = null; + } + document.documentElement.removeEventListener('keydown', this.onKeyDownRef); + this.onKeyDownRef = null; + } +}; +CopyPasteClass.prototype.hasBeenDestroyed = function() { + return !this.refCounter; +}; + +//# +},{}],"es6collections":[function(require,module,exports){ +"use strict"; +(function(exports) { + 'use strict'; + var i; + var defineProperty = Object.defineProperty, + is = function(a, b) { + return isNaN(a) ? isNaN(b) : a === b; + }; + if (typeof WeakMap == 'undefined') { + exports.WeakMap = createCollection({ + 'delete': sharedDelete, + clear: sharedClear, + get: sharedGet, + has: mapHas, + set: sharedSet + }, true); + } + if (typeof Map == 'undefined') { + exports.Map = createCollection({ + 'delete': sharedDelete, + has: mapHas, + get: sharedGet, + set: sharedSet, + keys: sharedKeys, + values: sharedValues, + entries: mapEntries, + forEach: sharedForEach, + clear: sharedClear + }); + } + if (typeof Set == 'undefined') { + exports.Set = createCollection({ + has: setHas, + add: sharedAdd, + 'delete': sharedDelete, + clear: sharedClear, + keys: sharedValues, + values: sharedValues, + entries: setEntries, + forEach: sharedForEach + }); + } + if (typeof WeakSet == 'undefined') { + exports.WeakSet = createCollection({ + 'delete': sharedDelete, + add: sharedAdd, + clear: sharedClear, + has: setHas + }, true); + } + function createCollection(proto, objectOnly) { + function Collection(a) { + if (!this || this.constructor !== Collection) + return new Collection(a); + this._keys = []; + this._values = []; + this._itp = []; + this.objectOnly = objectOnly; + if (a) + init.call(this, a); + } + if (!objectOnly) { + defineProperty(proto, 'size', {get: sharedSize}); + } + proto.constructor = Collection; + Collection.prototype = proto; + return Collection; + } + function init(a) { + var i; + if (this.add) + a.forEach(this.add, this); + else + a.forEach(function(a) { + this.set(a[0], a[1]); + }, this); + } + function sharedDelete(key) { + if (this.has(key)) { + this._keys.splice(i, 1); + this._values.splice(i, 1); + this._itp.forEach(function(p) { + if (i < p[0]) + p[0]--; + }); + } + return -1 < i; + } + ; + function sharedGet(key) { + return this.has(key) ? this._values[i] : undefined; + } + function has(list, key) { + if (this.objectOnly && key !== Object(key)) + throw new TypeError("Invalid value used as weak collection key"); + if (key != key || key === 0) + for (i = list.length; i-- && !is(list[i], key); ) {} + else + i = list.indexOf(key); + return -1 < i; + } + function setHas(value) { + return has.call(this, this._values, value); + } + function mapHas(value) { + return has.call(this, this._keys, value); + } + function sharedSet(key, value) { + this.has(key) ? this._values[i] = value : this._values[this._keys.push(key) - 1] = value; + return this; + } + function sharedAdd(value) { + if (!this.has(value)) + this._values.push(value); + return this; + } + function sharedClear() { + this._values.length = 0; + } + function sharedKeys() { + return sharedIterator(this._itp, this._keys); + } + function sharedValues() { + return sharedIterator(this._itp, this._values); + } + function mapEntries() { + return sharedIterator(this._itp, this._keys, this._values); + } + function setEntries() { + return sharedIterator(this._itp, this._values, this._values); + } + function sharedIterator(itp, array, array2) { + var p = [0], + done = false; + itp.push(p); + return {next: function() { + var v, + k = p[0]; + if (!done && k < array.length) { + v = array2 ? [array[k], array2[k]] : array[k]; + p[0]++; + } else { + done = true; + itp.splice(itp.indexOf(p), 1); + } + return { + done: done, + value: v + }; + }}; + } + function sharedSize() { + return this._values.length; + } + function sharedForEach(callback, context) { + var it = this.entries(); + for (; ; ) { + var r = it.next(); + if (r.done) + break; + callback.call(context, r.value[1], r.value[0], this); + } + } +})(typeof exports != 'undefined' && typeof global != 'undefined' ? global : window); + +//# +},{}],"jsonpatch":[function(require,module,exports){ +"use strict"; +var jsonpatch; +(function(jsonpatch) { + var objOps = { + add: function(obj, key) { + obj[key] = this.value; + return true; + }, + remove: function(obj, key) { + delete obj[key]; + return true; + }, + replace: function(obj, key) { + obj[key] = this.value; + return true; + }, + move: function(obj, key, tree) { + var temp = { + op: "_get", + path: this.from + }; + apply(tree, [temp]); + apply(tree, [{ + op: "remove", + path: this.from + }]); + apply(tree, [{ + op: "add", + path: this.path, + value: temp.value + }]); + return true; + }, + copy: function(obj, key, tree) { + var temp = { + op: "_get", + path: this.from + }; + apply(tree, [temp]); + apply(tree, [{ + op: "add", + path: this.path, + value: temp.value + }]); + return true; + }, + test: function(obj, key) { + return (JSON.stringify(obj[key]) === JSON.stringify(this.value)); + }, + _get: function(obj, key) { + this.value = obj[key]; + } + }; + var arrOps = { + add: function(arr, i) { + arr.splice(i, 0, this.value); + return true; + }, + remove: function(arr, i) { + arr.splice(i, 1); + return true; + }, + replace: function(arr, i) { + arr[i] = this.value; + return true; + }, + move: objOps.move, + copy: objOps.copy, + test: objOps.test, + _get: objOps._get + }; + var observeOps = { + add: function(patches, path) { + var patch = { + op: "add", + path: path + escapePathComponent(this.name), + value: this.object[this.name] + }; + patches.push(patch); + }, + 'delete': function(patches, path) { + var patch = { + op: "remove", + path: path + escapePathComponent(this.name) + }; + patches.push(patch); + }, + update: function(patches, path) { + var patch = { + op: "replace", + path: path + escapePathComponent(this.name), + value: this.object[this.name] + }; + patches.push(patch); + } + }; + function escapePathComponent(str) { + if (str.indexOf('/') === -1 && str.indexOf('~') === -1) { + return str; + } + return str.replace(/~/g, '~0').replace(/\//g, '~1'); + } + function _getPathRecursive(root, obj) { + var found; + for (var key in root) { + if (root.hasOwnProperty(key)) { + if (root[key] === obj) { + return escapePathComponent(key) + '/'; + } else if (typeof root[key] === 'object') { + found = _getPathRecursive(root[key], obj); + if (found != '') { + return escapePathComponent(key) + '/' + found; + } + } + } + } + return ''; + } + function getPath(root, obj) { + if (root === obj) { + return '/'; + } + var path = _getPathRecursive(root, obj); + if (path === '') { + throw new Error("Object not found in root"); + } + return '/' + path; + } + var beforeDict = []; + jsonpatch.intervals; + var Mirror = (function() { + function Mirror(obj) { + this.observers = []; + this.obj = obj; + } + return Mirror; + })(); + var ObserverInfo = (function() { + function ObserverInfo(callback, observer) { + this.callback = callback; + this.observer = observer; + } + return ObserverInfo; + })(); + function getMirror(obj) { + for (var i = 0, + ilen = beforeDict.length; i < ilen; i++) { + if (beforeDict[i].obj === obj) { + return beforeDict[i]; + } + } + } + function removeMirror(obj) { + for (var i = 0, + ilen = beforeDict.length; i < ilen; i++) { + if (beforeDict[i] === obj) { + beforeDict.splice(i, 1); + } + } + } + function getObserverFromMirror(mirror, callback) { + for (var j = 0, + jlen = mirror.observers.length; j < jlen; j++) { + if (mirror.observers[j].callback === callback) { + return mirror.observers[j].observer; + } + } + } + function removeObserverFromMirror(mirror, observer) { + for (var j = 0, + jlen = mirror.observers.length; j < jlen; j++) { + if (mirror.observers[j].observer === observer) { + mirror.observers.splice(j, 1); + if (!mirror.observers.length) { + removeMirror(mirror); + } + return; + } + } + } + function unobserve(root, observer) { + generate(observer); + if (Object.observe) { + _unobserve(observer, root); + } else { + clearTimeout(observer.next); + } + var mirror = getMirror(root); + removeObserverFromMirror(mirror, observer); + } + jsonpatch.unobserve = unobserve; + function observe(obj, callback) { + var patches = []; + var root = obj; + var observer; + var mirror = getMirror(obj); + if (!mirror) { + mirror = new Mirror(obj); + beforeDict.push(mirror); + } else { + observer = getObserverFromMirror(mirror, callback); + } + if (observer) { + return observer; + } + if (Object.observe) { + observer = function(arr) { + _unobserve(observer, obj); + _observe(observer, obj); + var a = 0, + alen = arr.length; + while (a < alen) { + if (!(arr[a].name === 'length' && _isArray(arr[a].object)) && !(arr[a].name === '__Jasmine_been_here_before__')) { + var type = arr[a].type; + switch (type) { + case 'new': + type = 'add'; + break; + case 'deleted': + type = 'delete'; + break; + case 'updated': + type = 'update'; + break; + } + observeOps[type].call(arr[a], patches, getPath(root, arr[a].object)); + } + a++; + } + if (patches) { + if (callback) { + callback(patches); + } + } + observer.patches = patches; + patches = []; + }; + } else { + observer = {}; + mirror.value = JSON.parse(JSON.stringify(obj)); + if (callback) { + observer.callback = callback; + observer.next = null; + var intervals = this.intervals || [100, 1000, 10000, 60000]; + var currentInterval = 0; + var dirtyCheck = function() { + generate(observer); + }; + var fastCheck = function() { + clearTimeout(observer.next); + observer.next = setTimeout(function() { + dirtyCheck(); + currentInterval = 0; + observer.next = setTimeout(slowCheck, intervals[currentInterval++]); + }, 0); + }; + var slowCheck = function() { + dirtyCheck(); + if (currentInterval == intervals.length) { + currentInterval = intervals.length - 1; + } + observer.next = setTimeout(slowCheck, intervals[currentInterval++]); + }; + if (typeof window !== 'undefined') { + if (window.addEventListener) { + window.addEventListener('mousedown', fastCheck); + window.addEventListener('mouseup', fastCheck); + window.addEventListener('keydown', fastCheck); + } else { + window.attachEvent('onmousedown', fastCheck); + window.attachEvent('onmouseup', fastCheck); + window.attachEvent('onkeydown', fastCheck); + } + } + observer.next = setTimeout(slowCheck, intervals[currentInterval++]); + } + } + observer.patches = patches; + observer.object = obj; + mirror.observers.push(new ObserverInfo(callback, observer)); + return _observe(observer, obj); + } + jsonpatch.observe = observe; + function _observe(observer, obj) { + if (Object.observe) { + Object.observe(obj, observer); + for (var key in obj) { + if (obj.hasOwnProperty(key)) { + var v = obj[key]; + if (v && typeof(v) === "object") { + _observe(observer, v); + } + } + } + } + return observer; + } + function _unobserve(observer, obj) { + if (Object.observe) { + Object.unobserve(obj, observer); + for (var key in obj) { + if (obj.hasOwnProperty(key)) { + var v = obj[key]; + if (v && typeof(v) === "object") { + _unobserve(observer, v); + } + } + } + } + return observer; + } + function generate(observer) { + if (Object.observe) { + Object.deliverChangeRecords(observer); + } else { + var mirror; + for (var i = 0, + ilen = beforeDict.length; i < ilen; i++) { + if (beforeDict[i].obj === observer.object) { + mirror = beforeDict[i]; + break; + } + } + if (mirror) { + _generate(mirror.value, observer.object, observer.patches, ""); + } + } + var temp = observer.patches; + if (temp.length > 0) { + observer.patches = []; + if (observer.callback) { + observer.callback(temp); + } + } + return temp; + } + jsonpatch.generate = generate; + var _objectKeys; + if (Object.keys) { + _objectKeys = Object.keys; + } else { + _objectKeys = function(obj) { + var keys = []; + for (var o in obj) { + if (obj.hasOwnProperty(o)) { + keys.push(o); + } + } + return keys; + }; + } + function _generate(mirror, obj, patches, path) { + var newKeys = _objectKeys(obj); + var oldKeys = _objectKeys(mirror); + var changed = false; + var deleted = false; + for (var t = oldKeys.length - 1; t >= 0; t--) { + var key = oldKeys[t]; + var oldVal = mirror[key]; + if (obj.hasOwnProperty(key)) { + var newVal = obj[key]; + if (oldVal instanceof Object) { + _generate(oldVal, newVal, patches, path + "/" + escapePathComponent(key)); + } else { + if (oldVal != newVal) { + changed = true; + patches.push({ + op: "replace", + path: path + "/" + escapePathComponent(key), + value: newVal + }); + mirror[key] = newVal; + } + } + } else { + patches.push({ + op: "remove", + path: path + "/" + escapePathComponent(key) + }); + delete mirror[key]; + deleted = true; + } + } + if (!deleted && newKeys.length == oldKeys.length) { + return; + } + for (var t = 0; t < newKeys.length; t++) { + var key = newKeys[t]; + if (!mirror.hasOwnProperty(key)) { + patches.push({ + op: "add", + path: path + "/" + escapePathComponent(key), + value: obj[key] + }); + mirror[key] = JSON.parse(JSON.stringify(obj[key])); + } + } + } + var _isArray; + if (Array.isArray) { + _isArray = Array.isArray; + } else { + _isArray = function(obj) { + return obj.push && typeof obj.length === 'number'; + }; + } + function apply(tree, patches) { + var result = false, + p = 0, + plen = patches.length, + patch; + while (p < plen) { + patch = patches[p]; + var keys = patch.path.split('/'); + var obj = tree; + var t = 1; + var len = keys.length; + while (true) { + if (_isArray(obj)) { + var index = parseInt(keys[t], 10); + t++; + if (t >= len) { + result = arrOps[patch.op].call(patch, obj, index, tree); + break; + } + obj = obj[index]; + } else { + var key = keys[t]; + if (key.indexOf('~') != -1) { + key = key.replace(/~1/g, '/').replace(/~0/g, '~'); + } + t++; + if (t >= len) { + result = objOps[patch.op].call(patch, obj, key, tree); + break; + } + obj = obj[key]; + } + } + p++; + } + return result; + } + jsonpatch.apply = apply; +})(jsonpatch || (jsonpatch = {})); +if (typeof exports !== "undefined") { + exports.apply = jsonpatch.apply; + exports.observe = jsonpatch.observe; + exports.unobserve = jsonpatch.unobserve; + exports.generate = jsonpatch.generate; +} + +//# +},{}],"moment":[function(require,module,exports){ +//! moment.js +//! version : 2.10.6 +//! authors : Tim Wood, Iskren Chernev, Moment.js contributors +//! license : MIT +//! momentjs.com + +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : + typeof define === 'function' && define.amd ? define(factory) : + global.moment = factory() +}(this, function () { 'use strict'; + + var hookCallback; + + function utils_hooks__hooks () { + return hookCallback.apply(null, arguments); + } + + // This is done to register the method called with moment() + // without creating circular dependencies. + function setHookCallback (callback) { + hookCallback = callback; + } + + function isArray(input) { + return Object.prototype.toString.call(input) === '[object Array]'; + } + + function isDate(input) { + return input instanceof Date || Object.prototype.toString.call(input) === '[object Date]'; + } + + function map(arr, fn) { + var res = [], i; + for (i = 0; i < arr.length; ++i) { + res.push(fn(arr[i], i)); + } + return res; + } + + function hasOwnProp(a, b) { + return Object.prototype.hasOwnProperty.call(a, b); + } + + function extend(a, b) { + for (var i in b) { + if (hasOwnProp(b, i)) { + a[i] = b[i]; + } + } + + if (hasOwnProp(b, 'toString')) { + a.toString = b.toString; + } + + if (hasOwnProp(b, 'valueOf')) { + a.valueOf = b.valueOf; + } + + return a; + } + + function create_utc__createUTC (input, format, locale, strict) { + return createLocalOrUTC(input, format, locale, strict, true).utc(); + } + + function defaultParsingFlags() { + // We need to deep clone this object. + return { + empty : false, + unusedTokens : [], + unusedInput : [], + overflow : -2, + charsLeftOver : 0, + nullInput : false, + invalidMonth : null, + invalidFormat : false, + userInvalidated : false, + iso : false + }; + } + + function getParsingFlags(m) { + if (m._pf == null) { + m._pf = defaultParsingFlags(); + } + return m._pf; + } + + function valid__isValid(m) { + if (m._isValid == null) { + var flags = getParsingFlags(m); + m._isValid = !isNaN(m._d.getTime()) && + flags.overflow < 0 && + !flags.empty && + !flags.invalidMonth && + !flags.invalidWeekday && + !flags.nullInput && + !flags.invalidFormat && + !flags.userInvalidated; + + if (m._strict) { + m._isValid = m._isValid && + flags.charsLeftOver === 0 && + flags.unusedTokens.length === 0 && + flags.bigHour === undefined; + } + } + return m._isValid; + } + + function valid__createInvalid (flags) { + var m = create_utc__createUTC(NaN); + if (flags != null) { + extend(getParsingFlags(m), flags); + } + else { + getParsingFlags(m).userInvalidated = true; + } + + return m; + } + + var momentProperties = utils_hooks__hooks.momentProperties = []; + + function copyConfig(to, from) { + var i, prop, val; + + if (typeof from._isAMomentObject !== 'undefined') { + to._isAMomentObject = from._isAMomentObject; + } + if (typeof from._i !== 'undefined') { + to._i = from._i; + } + if (typeof from._f !== 'undefined') { + to._f = from._f; + } + if (typeof from._l !== 'undefined') { + to._l = from._l; + } + if (typeof from._strict !== 'undefined') { + to._strict = from._strict; + } + if (typeof from._tzm !== 'undefined') { + to._tzm = from._tzm; + } + if (typeof from._isUTC !== 'undefined') { + to._isUTC = from._isUTC; + } + if (typeof from._offset !== 'undefined') { + to._offset = from._offset; + } + if (typeof from._pf !== 'undefined') { + to._pf = getParsingFlags(from); + } + if (typeof from._locale !== 'undefined') { + to._locale = from._locale; + } + + if (momentProperties.length > 0) { + for (i in momentProperties) { + prop = momentProperties[i]; + val = from[prop]; + if (typeof val !== 'undefined') { + to[prop] = val; + } + } + } + + return to; + } + + var updateInProgress = false; + + // Moment prototype object + function Moment(config) { + copyConfig(this, config); + this._d = new Date(config._d != null ? config._d.getTime() : NaN); + // Prevent infinite loop in case updateOffset creates new moment + // objects. + if (updateInProgress === false) { + updateInProgress = true; + utils_hooks__hooks.updateOffset(this); + updateInProgress = false; + } + } + + function isMoment (obj) { + return obj instanceof Moment || (obj != null && obj._isAMomentObject != null); + } + + function absFloor (number) { + if (number < 0) { + return Math.ceil(number); + } else { + return Math.floor(number); + } + } + + function toInt(argumentForCoercion) { + var coercedNumber = +argumentForCoercion, + value = 0; + + if (coercedNumber !== 0 && isFinite(coercedNumber)) { + value = absFloor(coercedNumber); + } + + return value; + } + + function compareArrays(array1, array2, dontConvert) { + var len = Math.min(array1.length, array2.length), + lengthDiff = Math.abs(array1.length - array2.length), + diffs = 0, + i; + for (i = 0; i < len; i++) { + if ((dontConvert && array1[i] !== array2[i]) || + (!dontConvert && toInt(array1[i]) !== toInt(array2[i]))) { + diffs++; + } + } + return diffs + lengthDiff; + } + + function Locale() { + } + + var locales = {}; + var globalLocale; + + function normalizeLocale(key) { + return key ? key.toLowerCase().replace('_', '-') : key; + } + + // pick the locale from the array + // try ['en-au', 'en-gb'] as 'en-au', 'en-gb', 'en', as in move through the list trying each + // substring from most specific to least, but move to the next array item if it's a more specific variant than the current root + function chooseLocale(names) { + var i = 0, j, next, locale, split; + + while (i < names.length) { + split = normalizeLocale(names[i]).split('-'); + j = split.length; + next = normalizeLocale(names[i + 1]); + next = next ? next.split('-') : null; + while (j > 0) { + locale = loadLocale(split.slice(0, j).join('-')); + if (locale) { + return locale; + } + if (next && next.length >= j && compareArrays(split, next, true) >= j - 1) { + //the next array item is better than a shallower substring of this one + break; + } + j--; + } + i++; + } + return null; + } + + function loadLocale(name) { + var oldLocale = null; + // TODO: Find a better way to register and load all the locales in Node + if (!locales[name] && typeof module !== 'undefined' && + module && module.exports) { + try { + oldLocale = globalLocale._abbr; + require('./locale/' + name); + // because defineLocale currently also sets the global locale, we + // want to undo that for lazy loaded locales + locale_locales__getSetGlobalLocale(oldLocale); + } catch (e) { } + } + return locales[name]; + } + + // This function will load locale and then set the global locale. If + // no arguments are passed in, it will simply return the current global + // locale key. + function locale_locales__getSetGlobalLocale (key, values) { + var data; + if (key) { + if (typeof values === 'undefined') { + data = locale_locales__getLocale(key); + } + else { + data = defineLocale(key, values); + } + + if (data) { + // moment.duration._locale = moment._locale = data; + globalLocale = data; + } + } + + return globalLocale._abbr; + } + + function defineLocale (name, values) { + if (values !== null) { + values.abbr = name; + locales[name] = locales[name] || new Locale(); + locales[name].set(values); + + // backwards compat for now: also set the locale + locale_locales__getSetGlobalLocale(name); + + return locales[name]; + } else { + // useful for testing + delete locales[name]; + return null; + } + } + + // returns locale data + function locale_locales__getLocale (key) { + var locale; + + if (key && key._locale && key._locale._abbr) { + key = key._locale._abbr; + } + + if (!key) { + return globalLocale; + } + + if (!isArray(key)) { + //short-circuit everything else + locale = loadLocale(key); + if (locale) { + return locale; + } + key = [key]; + } + + return chooseLocale(key); + } + + var aliases = {}; + + function addUnitAlias (unit, shorthand) { + var lowerCase = unit.toLowerCase(); + aliases[lowerCase] = aliases[lowerCase + 's'] = aliases[shorthand] = unit; + } + + function normalizeUnits(units) { + return typeof units === 'string' ? aliases[units] || aliases[units.toLowerCase()] : undefined; + } + + function normalizeObjectUnits(inputObject) { + var normalizedInput = {}, + normalizedProp, + prop; + + for (prop in inputObject) { + if (hasOwnProp(inputObject, prop)) { + normalizedProp = normalizeUnits(prop); + if (normalizedProp) { + normalizedInput[normalizedProp] = inputObject[prop]; + } + } + } + + return normalizedInput; + } + + function makeGetSet (unit, keepTime) { + return function (value) { + if (value != null) { + get_set__set(this, unit, value); + utils_hooks__hooks.updateOffset(this, keepTime); + return this; + } else { + return get_set__get(this, unit); + } + }; + } + + function get_set__get (mom, unit) { + return mom._d['get' + (mom._isUTC ? 'UTC' : '') + unit](); + } + + function get_set__set (mom, unit, value) { + return mom._d['set' + (mom._isUTC ? 'UTC' : '') + unit](value); + } + + // MOMENTS + + function getSet (units, value) { + var unit; + if (typeof units === 'object') { + for (unit in units) { + this.set(unit, units[unit]); + } + } else { + units = normalizeUnits(units); + if (typeof this[units] === 'function') { + return this[units](value); + } + } + return this; + } + + function zeroFill(number, targetLength, forceSign) { + var absNumber = '' + Math.abs(number), + zerosToFill = targetLength - absNumber.length, + sign = number >= 0; + return (sign ? (forceSign ? '+' : '') : '-') + + Math.pow(10, Math.max(0, zerosToFill)).toString().substr(1) + absNumber; + } + + var formattingTokens = /(\[[^\[]*\])|(\\)?(Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Q|YYYYYY|YYYYY|YYYY|YY|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g; + + var localFormattingTokens = /(\[[^\[]*\])|(\\)?(LTS|LT|LL?L?L?|l{1,4})/g; + + var formatFunctions = {}; + + var formatTokenFunctions = {}; + + // token: 'M' + // padded: ['MM', 2] + // ordinal: 'Mo' + // callback: function () { this.month() + 1 } + function addFormatToken (token, padded, ordinal, callback) { + var func = callback; + if (typeof callback === 'string') { + func = function () { + return this[callback](); + }; + } + if (token) { + formatTokenFunctions[token] = func; + } + if (padded) { + formatTokenFunctions[padded[0]] = function () { + return zeroFill(func.apply(this, arguments), padded[1], padded[2]); + }; + } + if (ordinal) { + formatTokenFunctions[ordinal] = function () { + return this.localeData().ordinal(func.apply(this, arguments), token); + }; + } + } + + function removeFormattingTokens(input) { + if (input.match(/\[[\s\S]/)) { + return input.replace(/^\[|\]$/g, ''); + } + return input.replace(/\\/g, ''); + } + + function makeFormatFunction(format) { + var array = format.match(formattingTokens), i, length; + + for (i = 0, length = array.length; i < length; i++) { + if (formatTokenFunctions[array[i]]) { + array[i] = formatTokenFunctions[array[i]]; + } else { + array[i] = removeFormattingTokens(array[i]); + } + } + + return function (mom) { + var output = ''; + for (i = 0; i < length; i++) { + output += array[i] instanceof Function ? array[i].call(mom, format) : array[i]; + } + return output; + }; + } + + // format date using native date object + function formatMoment(m, format) { + if (!m.isValid()) { + return m.localeData().invalidDate(); + } + + format = expandFormat(format, m.localeData()); + formatFunctions[format] = formatFunctions[format] || makeFormatFunction(format); + + return formatFunctions[format](m); + } + + function expandFormat(format, locale) { + var i = 5; + + function replaceLongDateFormatTokens(input) { + return locale.longDateFormat(input) || input; + } + + localFormattingTokens.lastIndex = 0; + while (i >= 0 && localFormattingTokens.test(format)) { + format = format.replace(localFormattingTokens, replaceLongDateFormatTokens); + localFormattingTokens.lastIndex = 0; + i -= 1; + } + + return format; + } + + var match1 = /\d/; // 0 - 9 + var match2 = /\d\d/; // 00 - 99 + var match3 = /\d{3}/; // 000 - 999 + var match4 = /\d{4}/; // 0000 - 9999 + var match6 = /[+-]?\d{6}/; // -999999 - 999999 + var match1to2 = /\d\d?/; // 0 - 99 + var match1to3 = /\d{1,3}/; // 0 - 999 + var match1to4 = /\d{1,4}/; // 0 - 9999 + var match1to6 = /[+-]?\d{1,6}/; // -999999 - 999999 + + var matchUnsigned = /\d+/; // 0 - inf + var matchSigned = /[+-]?\d+/; // -inf - inf + + var matchOffset = /Z|[+-]\d\d:?\d\d/gi; // +00:00 -00:00 +0000 -0000 or Z + + var matchTimestamp = /[+-]?\d+(\.\d{1,3})?/; // 123456789 123456789.123 + + // any word (or two) characters or numbers including two/three word month in arabic. + var matchWord = /[0-9]*['a-z\u00A0-\u05FF\u0700-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+|[\u0600-\u06FF\/]+(\s*?[\u0600-\u06FF]+){1,2}/i; + + var regexes = {}; + + function isFunction (sth) { + // https://github.com/moment/moment/issues/2325 + return typeof sth === 'function' && + Object.prototype.toString.call(sth) === '[object Function]'; + } + + + function addRegexToken (token, regex, strictRegex) { + regexes[token] = isFunction(regex) ? regex : function (isStrict) { + return (isStrict && strictRegex) ? strictRegex : regex; + }; + } + + function getParseRegexForToken (token, config) { + if (!hasOwnProp(regexes, token)) { + return new RegExp(unescapeFormat(token)); + } + + return regexes[token](config._strict, config._locale); + } + + // Code from http://stackoverflow.com/questions/3561493/is-there-a-regexp-escape-function-in-javascript + function unescapeFormat(s) { + return s.replace('\\', '').replace(/\\(\[)|\\(\])|\[([^\]\[]*)\]|\\(.)/g, function (matched, p1, p2, p3, p4) { + return p1 || p2 || p3 || p4; + }).replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&'); + } + + var tokens = {}; + + function addParseToken (token, callback) { + var i, func = callback; + if (typeof token === 'string') { + token = [token]; + } + if (typeof callback === 'number') { + func = function (input, array) { + array[callback] = toInt(input); + }; + } + for (i = 0; i < token.length; i++) { + tokens[token[i]] = func; + } + } + + function addWeekParseToken (token, callback) { + addParseToken(token, function (input, array, config, token) { + config._w = config._w || {}; + callback(input, config._w, config, token); + }); + } + + function addTimeToArrayFromToken(token, input, config) { + if (input != null && hasOwnProp(tokens, token)) { + tokens[token](input, config._a, config, token); + } + } + + var YEAR = 0; + var MONTH = 1; + var DATE = 2; + var HOUR = 3; + var MINUTE = 4; + var SECOND = 5; + var MILLISECOND = 6; + + function daysInMonth(year, month) { + return new Date(Date.UTC(year, month + 1, 0)).getUTCDate(); + } + + // FORMATTING + + addFormatToken('M', ['MM', 2], 'Mo', function () { + return this.month() + 1; + }); + + addFormatToken('MMM', 0, 0, function (format) { + return this.localeData().monthsShort(this, format); + }); + + addFormatToken('MMMM', 0, 0, function (format) { + return this.localeData().months(this, format); + }); + + // ALIASES + + addUnitAlias('month', 'M'); + + // PARSING + + addRegexToken('M', match1to2); + addRegexToken('MM', match1to2, match2); + addRegexToken('MMM', matchWord); + addRegexToken('MMMM', matchWord); + + addParseToken(['M', 'MM'], function (input, array) { + array[MONTH] = toInt(input) - 1; + }); + + addParseToken(['MMM', 'MMMM'], function (input, array, config, token) { + var month = config._locale.monthsParse(input, token, config._strict); + // if we didn't find a month name, mark the date as invalid. + if (month != null) { + array[MONTH] = month; + } else { + getParsingFlags(config).invalidMonth = input; + } + }); + + // LOCALES + + var defaultLocaleMonths = 'January_February_March_April_May_June_July_August_September_October_November_December'.split('_'); + function localeMonths (m) { + return this._months[m.month()]; + } + + var defaultLocaleMonthsShort = 'Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec'.split('_'); + function localeMonthsShort (m) { + return this._monthsShort[m.month()]; + } + + function localeMonthsParse (monthName, format, strict) { + var i, mom, regex; + + if (!this._monthsParse) { + this._monthsParse = []; + this._longMonthsParse = []; + this._shortMonthsParse = []; + } + + for (i = 0; i < 12; i++) { + // make the regex if we don't have it already + mom = create_utc__createUTC([2000, i]); + if (strict && !this._longMonthsParse[i]) { + this._longMonthsParse[i] = new RegExp('^' + this.months(mom, '').replace('.', '') + '$', 'i'); + this._shortMonthsParse[i] = new RegExp('^' + this.monthsShort(mom, '').replace('.', '') + '$', 'i'); + } + if (!strict && !this._monthsParse[i]) { + regex = '^' + this.months(mom, '') + '|^' + this.monthsShort(mom, ''); + this._monthsParse[i] = new RegExp(regex.replace('.', ''), 'i'); + } + // test the regex + if (strict && format === 'MMMM' && this._longMonthsParse[i].test(monthName)) { + return i; + } else if (strict && format === 'MMM' && this._shortMonthsParse[i].test(monthName)) { + return i; + } else if (!strict && this._monthsParse[i].test(monthName)) { + return i; + } + } + } + + // MOMENTS + + function setMonth (mom, value) { + var dayOfMonth; + + // TODO: Move this out of here! + if (typeof value === 'string') { + value = mom.localeData().monthsParse(value); + // TODO: Another silent failure? + if (typeof value !== 'number') { + return mom; + } + } + + dayOfMonth = Math.min(mom.date(), daysInMonth(mom.year(), value)); + mom._d['set' + (mom._isUTC ? 'UTC' : '') + 'Month'](value, dayOfMonth); + return mom; + } + + function getSetMonth (value) { + if (value != null) { + setMonth(this, value); + utils_hooks__hooks.updateOffset(this, true); + return this; + } else { + return get_set__get(this, 'Month'); + } + } + + function getDaysInMonth () { + return daysInMonth(this.year(), this.month()); + } + + function checkOverflow (m) { + var overflow; + var a = m._a; + + if (a && getParsingFlags(m).overflow === -2) { + overflow = + a[MONTH] < 0 || a[MONTH] > 11 ? MONTH : + a[DATE] < 1 || a[DATE] > daysInMonth(a[YEAR], a[MONTH]) ? DATE : + a[HOUR] < 0 || a[HOUR] > 24 || (a[HOUR] === 24 && (a[MINUTE] !== 0 || a[SECOND] !== 0 || a[MILLISECOND] !== 0)) ? HOUR : + a[MINUTE] < 0 || a[MINUTE] > 59 ? MINUTE : + a[SECOND] < 0 || a[SECOND] > 59 ? SECOND : + a[MILLISECOND] < 0 || a[MILLISECOND] > 999 ? MILLISECOND : + -1; + + if (getParsingFlags(m)._overflowDayOfYear && (overflow < YEAR || overflow > DATE)) { + overflow = DATE; + } + + getParsingFlags(m).overflow = overflow; + } + + return m; + } + + function warn(msg) { + if (utils_hooks__hooks.suppressDeprecationWarnings === false && typeof console !== 'undefined' && console.warn) { + console.warn('Deprecation warning: ' + msg); + } + } + + function deprecate(msg, fn) { + var firstTime = true; + + return extend(function () { + if (firstTime) { + warn(msg + '\n' + (new Error()).stack); + firstTime = false; + } + return fn.apply(this, arguments); + }, fn); + } + + var deprecations = {}; + + function deprecateSimple(name, msg) { + if (!deprecations[name]) { + warn(msg); + deprecations[name] = true; + } + } + + utils_hooks__hooks.suppressDeprecationWarnings = false; + + var from_string__isoRegex = /^\s*(?:[+-]\d{6}|\d{4})-(?:(\d\d-\d\d)|(W\d\d$)|(W\d\d-\d)|(\d\d\d))((T| )(\d\d(:\d\d(:\d\d(\.\d+)?)?)?)?([\+\-]\d\d(?::?\d\d)?|\s*Z)?)?$/; + + var isoDates = [ + ['YYYYYY-MM-DD', /[+-]\d{6}-\d{2}-\d{2}/], + ['YYYY-MM-DD', /\d{4}-\d{2}-\d{2}/], + ['GGGG-[W]WW-E', /\d{4}-W\d{2}-\d/], + ['GGGG-[W]WW', /\d{4}-W\d{2}/], + ['YYYY-DDD', /\d{4}-\d{3}/] + ]; + + // iso time formats and regexes + var isoTimes = [ + ['HH:mm:ss.SSSS', /(T| )\d\d:\d\d:\d\d\.\d+/], + ['HH:mm:ss', /(T| )\d\d:\d\d:\d\d/], + ['HH:mm', /(T| )\d\d:\d\d/], + ['HH', /(T| )\d\d/] + ]; + + var aspNetJsonRegex = /^\/?Date\((\-?\d+)/i; + + // date from iso format + function configFromISO(config) { + var i, l, + string = config._i, + match = from_string__isoRegex.exec(string); + + if (match) { + getParsingFlags(config).iso = true; + for (i = 0, l = isoDates.length; i < l; i++) { + if (isoDates[i][1].exec(string)) { + config._f = isoDates[i][0]; + break; + } + } + for (i = 0, l = isoTimes.length; i < l; i++) { + if (isoTimes[i][1].exec(string)) { + // match[6] should be 'T' or space + config._f += (match[6] || ' ') + isoTimes[i][0]; + break; + } + } + if (string.match(matchOffset)) { + config._f += 'Z'; + } + configFromStringAndFormat(config); + } else { + config._isValid = false; + } + } + + // date from iso format or fallback + function configFromString(config) { + var matched = aspNetJsonRegex.exec(config._i); + + if (matched !== null) { + config._d = new Date(+matched[1]); + return; + } + + configFromISO(config); + if (config._isValid === false) { + delete config._isValid; + utils_hooks__hooks.createFromInputFallback(config); + } + } + + utils_hooks__hooks.createFromInputFallback = deprecate( + 'moment construction falls back to js Date. This is ' + + 'discouraged and will be removed in upcoming major ' + + 'release. Please refer to ' + + 'https://github.com/moment/moment/issues/1407 for more info.', + function (config) { + config._d = new Date(config._i + (config._useUTC ? ' UTC' : '')); + } + ); + + function createDate (y, m, d, h, M, s, ms) { + //can't just apply() to create a date: + //http://stackoverflow.com/questions/181348/instantiating-a-javascript-object-by-calling-prototype-constructor-apply + var date = new Date(y, m, d, h, M, s, ms); + + //the date constructor doesn't accept years < 1970 + if (y < 1970) { + date.setFullYear(y); + } + return date; + } + + function createUTCDate (y) { + var date = new Date(Date.UTC.apply(null, arguments)); + if (y < 1970) { + date.setUTCFullYear(y); + } + return date; + } + + addFormatToken(0, ['YY', 2], 0, function () { + return this.year() % 100; + }); + + addFormatToken(0, ['YYYY', 4], 0, 'year'); + addFormatToken(0, ['YYYYY', 5], 0, 'year'); + addFormatToken(0, ['YYYYYY', 6, true], 0, 'year'); + + // ALIASES + + addUnitAlias('year', 'y'); + + // PARSING + + addRegexToken('Y', matchSigned); + addRegexToken('YY', match1to2, match2); + addRegexToken('YYYY', match1to4, match4); + addRegexToken('YYYYY', match1to6, match6); + addRegexToken('YYYYYY', match1to6, match6); + + addParseToken(['YYYYY', 'YYYYYY'], YEAR); + addParseToken('YYYY', function (input, array) { + array[YEAR] = input.length === 2 ? utils_hooks__hooks.parseTwoDigitYear(input) : toInt(input); + }); + addParseToken('YY', function (input, array) { + array[YEAR] = utils_hooks__hooks.parseTwoDigitYear(input); + }); + + // HELPERS + + function daysInYear(year) { + return isLeapYear(year) ? 366 : 365; + } + + function isLeapYear(year) { + return (year % 4 === 0 && year % 100 !== 0) || year % 400 === 0; + } + + // HOOKS + + utils_hooks__hooks.parseTwoDigitYear = function (input) { + return toInt(input) + (toInt(input) > 68 ? 1900 : 2000); + }; + + // MOMENTS + + var getSetYear = makeGetSet('FullYear', false); + + function getIsLeapYear () { + return isLeapYear(this.year()); + } + + addFormatToken('w', ['ww', 2], 'wo', 'week'); + addFormatToken('W', ['WW', 2], 'Wo', 'isoWeek'); + + // ALIASES + + addUnitAlias('week', 'w'); + addUnitAlias('isoWeek', 'W'); + + // PARSING + + addRegexToken('w', match1to2); + addRegexToken('ww', match1to2, match2); + addRegexToken('W', match1to2); + addRegexToken('WW', match1to2, match2); + + addWeekParseToken(['w', 'ww', 'W', 'WW'], function (input, week, config, token) { + week[token.substr(0, 1)] = toInt(input); + }); + + // HELPERS + + // firstDayOfWeek 0 = sun, 6 = sat + // the day of the week that starts the week + // (usually sunday or monday) + // firstDayOfWeekOfYear 0 = sun, 6 = sat + // the first week is the week that contains the first + // of this day of the week + // (eg. ISO weeks use thursday (4)) + function weekOfYear(mom, firstDayOfWeek, firstDayOfWeekOfYear) { + var end = firstDayOfWeekOfYear - firstDayOfWeek, + daysToDayOfWeek = firstDayOfWeekOfYear - mom.day(), + adjustedMoment; + + + if (daysToDayOfWeek > end) { + daysToDayOfWeek -= 7; + } + + if (daysToDayOfWeek < end - 7) { + daysToDayOfWeek += 7; + } + + adjustedMoment = local__createLocal(mom).add(daysToDayOfWeek, 'd'); + return { + week: Math.ceil(adjustedMoment.dayOfYear() / 7), + year: adjustedMoment.year() + }; + } + + // LOCALES + + function localeWeek (mom) { + return weekOfYear(mom, this._week.dow, this._week.doy).week; + } + + var defaultLocaleWeek = { + dow : 0, // Sunday is the first day of the week. + doy : 6 // The week that contains Jan 1st is the first week of the year. + }; + + function localeFirstDayOfWeek () { + return this._week.dow; + } + + function localeFirstDayOfYear () { + return this._week.doy; + } + + // MOMENTS + + function getSetWeek (input) { + var week = this.localeData().week(this); + return input == null ? week : this.add((input - week) * 7, 'd'); + } + + function getSetISOWeek (input) { + var week = weekOfYear(this, 1, 4).week; + return input == null ? week : this.add((input - week) * 7, 'd'); + } + + addFormatToken('DDD', ['DDDD', 3], 'DDDo', 'dayOfYear'); + + // ALIASES + + addUnitAlias('dayOfYear', 'DDD'); + + // PARSING + + addRegexToken('DDD', match1to3); + addRegexToken('DDDD', match3); + addParseToken(['DDD', 'DDDD'], function (input, array, config) { + config._dayOfYear = toInt(input); + }); + + // HELPERS + + //http://en.wikipedia.org/wiki/ISO_week_date#Calculating_a_date_given_the_year.2C_week_number_and_weekday + function dayOfYearFromWeeks(year, week, weekday, firstDayOfWeekOfYear, firstDayOfWeek) { + var week1Jan = 6 + firstDayOfWeek - firstDayOfWeekOfYear, janX = createUTCDate(year, 0, 1 + week1Jan), d = janX.getUTCDay(), dayOfYear; + if (d < firstDayOfWeek) { + d += 7; + } + + weekday = weekday != null ? 1 * weekday : firstDayOfWeek; + + dayOfYear = 1 + week1Jan + 7 * (week - 1) - d + weekday; + + return { + year: dayOfYear > 0 ? year : year - 1, + dayOfYear: dayOfYear > 0 ? dayOfYear : daysInYear(year - 1) + dayOfYear + }; + } + + // MOMENTS + + function getSetDayOfYear (input) { + var dayOfYear = Math.round((this.clone().startOf('day') - this.clone().startOf('year')) / 864e5) + 1; + return input == null ? dayOfYear : this.add((input - dayOfYear), 'd'); + } + + // Pick the first defined of two or three arguments. + function defaults(a, b, c) { + if (a != null) { + return a; + } + if (b != null) { + return b; + } + return c; + } + + function currentDateArray(config) { + var now = new Date(); + if (config._useUTC) { + return [now.getUTCFullYear(), now.getUTCMonth(), now.getUTCDate()]; + } + return [now.getFullYear(), now.getMonth(), now.getDate()]; + } + + // convert an array to a date. + // the array should mirror the parameters below + // note: all values past the year are optional and will default to the lowest possible value. + // [year, month, day , hour, minute, second, millisecond] + function configFromArray (config) { + var i, date, input = [], currentDate, yearToUse; + + if (config._d) { + return; + } + + currentDate = currentDateArray(config); + + //compute day of the year from weeks and weekdays + if (config._w && config._a[DATE] == null && config._a[MONTH] == null) { + dayOfYearFromWeekInfo(config); + } + + //if the day of the year is set, figure out what it is + if (config._dayOfYear) { + yearToUse = defaults(config._a[YEAR], currentDate[YEAR]); + + if (config._dayOfYear > daysInYear(yearToUse)) { + getParsingFlags(config)._overflowDayOfYear = true; + } + + date = createUTCDate(yearToUse, 0, config._dayOfYear); + config._a[MONTH] = date.getUTCMonth(); + config._a[DATE] = date.getUTCDate(); + } + + // Default to current date. + // * if no year, month, day of month are given, default to today + // * if day of month is given, default month and year + // * if month is given, default only year + // * if year is given, don't default anything + for (i = 0; i < 3 && config._a[i] == null; ++i) { + config._a[i] = input[i] = currentDate[i]; + } + + // Zero out whatever was not defaulted, including time + for (; i < 7; i++) { + config._a[i] = input[i] = (config._a[i] == null) ? (i === 2 ? 1 : 0) : config._a[i]; + } + + // Check for 24:00:00.000 + if (config._a[HOUR] === 24 && + config._a[MINUTE] === 0 && + config._a[SECOND] === 0 && + config._a[MILLISECOND] === 0) { + config._nextDay = true; + config._a[HOUR] = 0; + } + + config._d = (config._useUTC ? createUTCDate : createDate).apply(null, input); + // Apply timezone offset from input. The actual utcOffset can be changed + // with parseZone. + if (config._tzm != null) { + config._d.setUTCMinutes(config._d.getUTCMinutes() - config._tzm); + } + + if (config._nextDay) { + config._a[HOUR] = 24; + } + } + + function dayOfYearFromWeekInfo(config) { + var w, weekYear, week, weekday, dow, doy, temp; + + w = config._w; + if (w.GG != null || w.W != null || w.E != null) { + dow = 1; + doy = 4; + + // TODO: We need to take the current isoWeekYear, but that depends on + // how we interpret now (local, utc, fixed offset). So create + // a now version of current config (take local/utc/offset flags, and + // create now). + weekYear = defaults(w.GG, config._a[YEAR], weekOfYear(local__createLocal(), 1, 4).year); + week = defaults(w.W, 1); + weekday = defaults(w.E, 1); + } else { + dow = config._locale._week.dow; + doy = config._locale._week.doy; + + weekYear = defaults(w.gg, config._a[YEAR], weekOfYear(local__createLocal(), dow, doy).year); + week = defaults(w.w, 1); + + if (w.d != null) { + // weekday -- low day numbers are considered next week + weekday = w.d; + if (weekday < dow) { + ++week; + } + } else if (w.e != null) { + // local weekday -- counting starts from begining of week + weekday = w.e + dow; + } else { + // default to begining of week + weekday = dow; + } + } + temp = dayOfYearFromWeeks(weekYear, week, weekday, doy, dow); + + config._a[YEAR] = temp.year; + config._dayOfYear = temp.dayOfYear; + } + + utils_hooks__hooks.ISO_8601 = function () {}; + + // date from string and format string + function configFromStringAndFormat(config) { + // TODO: Move this to another part of the creation flow to prevent circular deps + if (config._f === utils_hooks__hooks.ISO_8601) { + configFromISO(config); + return; + } + + config._a = []; + getParsingFlags(config).empty = true; + + // This array is used to make a Date, either with `new Date` or `Date.UTC` + var string = '' + config._i, + i, parsedInput, tokens, token, skipped, + stringLength = string.length, + totalParsedInputLength = 0; + + tokens = expandFormat(config._f, config._locale).match(formattingTokens) || []; + + for (i = 0; i < tokens.length; i++) { + token = tokens[i]; + parsedInput = (string.match(getParseRegexForToken(token, config)) || [])[0]; + if (parsedInput) { + skipped = string.substr(0, string.indexOf(parsedInput)); + if (skipped.length > 0) { + getParsingFlags(config).unusedInput.push(skipped); + } + string = string.slice(string.indexOf(parsedInput) + parsedInput.length); + totalParsedInputLength += parsedInput.length; + } + // don't parse if it's not a known token + if (formatTokenFunctions[token]) { + if (parsedInput) { + getParsingFlags(config).empty = false; + } + else { + getParsingFlags(config).unusedTokens.push(token); + } + addTimeToArrayFromToken(token, parsedInput, config); + } + else if (config._strict && !parsedInput) { + getParsingFlags(config).unusedTokens.push(token); + } + } + + // add remaining unparsed input length to the string + getParsingFlags(config).charsLeftOver = stringLength - totalParsedInputLength; + if (string.length > 0) { + getParsingFlags(config).unusedInput.push(string); + } + + // clear _12h flag if hour is <= 12 + if (getParsingFlags(config).bigHour === true && + config._a[HOUR] <= 12 && + config._a[HOUR] > 0) { + getParsingFlags(config).bigHour = undefined; + } + // handle meridiem + config._a[HOUR] = meridiemFixWrap(config._locale, config._a[HOUR], config._meridiem); + + configFromArray(config); + checkOverflow(config); + } + + + function meridiemFixWrap (locale, hour, meridiem) { + var isPm; + + if (meridiem == null) { + // nothing to do + return hour; + } + if (locale.meridiemHour != null) { + return locale.meridiemHour(hour, meridiem); + } else if (locale.isPM != null) { + // Fallback + isPm = locale.isPM(meridiem); + if (isPm && hour < 12) { + hour += 12; + } + if (!isPm && hour === 12) { + hour = 0; + } + return hour; + } else { + // this is not supposed to happen + return hour; + } + } + + function configFromStringAndArray(config) { + var tempConfig, + bestMoment, + + scoreToBeat, + i, + currentScore; + + if (config._f.length === 0) { + getParsingFlags(config).invalidFormat = true; + config._d = new Date(NaN); + return; + } + + for (i = 0; i < config._f.length; i++) { + currentScore = 0; + tempConfig = copyConfig({}, config); + if (config._useUTC != null) { + tempConfig._useUTC = config._useUTC; + } + tempConfig._f = config._f[i]; + configFromStringAndFormat(tempConfig); + + if (!valid__isValid(tempConfig)) { + continue; + } + + // if there is any input that was not parsed add a penalty for that format + currentScore += getParsingFlags(tempConfig).charsLeftOver; + + //or tokens + currentScore += getParsingFlags(tempConfig).unusedTokens.length * 10; + + getParsingFlags(tempConfig).score = currentScore; + + if (scoreToBeat == null || currentScore < scoreToBeat) { + scoreToBeat = currentScore; + bestMoment = tempConfig; + } + } + + extend(config, bestMoment || tempConfig); + } + + function configFromObject(config) { + if (config._d) { + return; + } + + var i = normalizeObjectUnits(config._i); + config._a = [i.year, i.month, i.day || i.date, i.hour, i.minute, i.second, i.millisecond]; + + configFromArray(config); + } + + function createFromConfig (config) { + var res = new Moment(checkOverflow(prepareConfig(config))); + if (res._nextDay) { + // Adding is smart enough around DST + res.add(1, 'd'); + res._nextDay = undefined; + } + + return res; + } + + function prepareConfig (config) { + var input = config._i, + format = config._f; + + config._locale = config._locale || locale_locales__getLocale(config._l); + + if (input === null || (format === undefined && input === '')) { + return valid__createInvalid({nullInput: true}); + } + + if (typeof input === 'string') { + config._i = input = config._locale.preparse(input); + } + + if (isMoment(input)) { + return new Moment(checkOverflow(input)); + } else if (isArray(format)) { + configFromStringAndArray(config); + } else if (format) { + configFromStringAndFormat(config); + } else if (isDate(input)) { + config._d = input; + } else { + configFromInput(config); + } + + return config; + } + + function configFromInput(config) { + var input = config._i; + if (input === undefined) { + config._d = new Date(); + } else if (isDate(input)) { + config._d = new Date(+input); + } else if (typeof input === 'string') { + configFromString(config); + } else if (isArray(input)) { + config._a = map(input.slice(0), function (obj) { + return parseInt(obj, 10); + }); + configFromArray(config); + } else if (typeof(input) === 'object') { + configFromObject(config); + } else if (typeof(input) === 'number') { + // from milliseconds + config._d = new Date(input); + } else { + utils_hooks__hooks.createFromInputFallback(config); + } + } + + function createLocalOrUTC (input, format, locale, strict, isUTC) { + var c = {}; + + if (typeof(locale) === 'boolean') { + strict = locale; + locale = undefined; + } + // object construction must be done this way. + // https://github.com/moment/moment/issues/1423 + c._isAMomentObject = true; + c._useUTC = c._isUTC = isUTC; + c._l = locale; + c._i = input; + c._f = format; + c._strict = strict; + + return createFromConfig(c); + } + + function local__createLocal (input, format, locale, strict) { + return createLocalOrUTC(input, format, locale, strict, false); + } + + var prototypeMin = deprecate( + 'moment().min is deprecated, use moment.min instead. https://github.com/moment/moment/issues/1548', + function () { + var other = local__createLocal.apply(null, arguments); + return other < this ? this : other; + } + ); + + var prototypeMax = deprecate( + 'moment().max is deprecated, use moment.max instead. https://github.com/moment/moment/issues/1548', + function () { + var other = local__createLocal.apply(null, arguments); + return other > this ? this : other; + } + ); + + // Pick a moment m from moments so that m[fn](other) is true for all + // other. This relies on the function fn to be transitive. + // + // moments should either be an array of moment objects or an array, whose + // first element is an array of moment objects. + function pickBy(fn, moments) { + var res, i; + if (moments.length === 1 && isArray(moments[0])) { + moments = moments[0]; + } + if (!moments.length) { + return local__createLocal(); + } + res = moments[0]; + for (i = 1; i < moments.length; ++i) { + if (!moments[i].isValid() || moments[i][fn](res)) { + res = moments[i]; + } + } + return res; + } + + // TODO: Use [].sort instead? + function min () { + var args = [].slice.call(arguments, 0); + + return pickBy('isBefore', args); + } + + function max () { + var args = [].slice.call(arguments, 0); + + return pickBy('isAfter', args); + } + + function Duration (duration) { + var normalizedInput = normalizeObjectUnits(duration), + years = normalizedInput.year || 0, + quarters = normalizedInput.quarter || 0, + months = normalizedInput.month || 0, + weeks = normalizedInput.week || 0, + days = normalizedInput.day || 0, + hours = normalizedInput.hour || 0, + minutes = normalizedInput.minute || 0, + seconds = normalizedInput.second || 0, + milliseconds = normalizedInput.millisecond || 0; + + // representation for dateAddRemove + this._milliseconds = +milliseconds + + seconds * 1e3 + // 1000 + minutes * 6e4 + // 1000 * 60 + hours * 36e5; // 1000 * 60 * 60 + // Because of dateAddRemove treats 24 hours as different from a + // day when working around DST, we need to store them separately + this._days = +days + + weeks * 7; + // It is impossible translate months into days without knowing + // which months you are are talking about, so we have to store + // it separately. + this._months = +months + + quarters * 3 + + years * 12; + + this._data = {}; + + this._locale = locale_locales__getLocale(); + + this._bubble(); + } + + function isDuration (obj) { + return obj instanceof Duration; + } + + function offset (token, separator) { + addFormatToken(token, 0, 0, function () { + var offset = this.utcOffset(); + var sign = '+'; + if (offset < 0) { + offset = -offset; + sign = '-'; + } + return sign + zeroFill(~~(offset / 60), 2) + separator + zeroFill(~~(offset) % 60, 2); + }); + } + + offset('Z', ':'); + offset('ZZ', ''); + + // PARSING + + addRegexToken('Z', matchOffset); + addRegexToken('ZZ', matchOffset); + addParseToken(['Z', 'ZZ'], function (input, array, config) { + config._useUTC = true; + config._tzm = offsetFromString(input); + }); + + // HELPERS + + // timezone chunker + // '+10:00' > ['10', '00'] + // '-1530' > ['-15', '30'] + var chunkOffset = /([\+\-]|\d\d)/gi; + + function offsetFromString(string) { + var matches = ((string || '').match(matchOffset) || []); + var chunk = matches[matches.length - 1] || []; + var parts = (chunk + '').match(chunkOffset) || ['-', 0, 0]; + var minutes = +(parts[1] * 60) + toInt(parts[2]); + + return parts[0] === '+' ? minutes : -minutes; + } + + // Return a moment from input, that is local/utc/zone equivalent to model. + function cloneWithOffset(input, model) { + var res, diff; + if (model._isUTC) { + res = model.clone(); + diff = (isMoment(input) || isDate(input) ? +input : +local__createLocal(input)) - (+res); + // Use low-level api, because this fn is low-level api. + res._d.setTime(+res._d + diff); + utils_hooks__hooks.updateOffset(res, false); + return res; + } else { + return local__createLocal(input).local(); + } + } + + function getDateOffset (m) { + // On Firefox.24 Date#getTimezoneOffset returns a floating point. + // https://github.com/moment/moment/pull/1871 + return -Math.round(m._d.getTimezoneOffset() / 15) * 15; + } + + // HOOKS + + // This function will be called whenever a moment is mutated. + // It is intended to keep the offset in sync with the timezone. + utils_hooks__hooks.updateOffset = function () {}; + + // MOMENTS + + // keepLocalTime = true means only change the timezone, without + // affecting the local hour. So 5:31:26 +0300 --[utcOffset(2, true)]--> + // 5:31:26 +0200 It is possible that 5:31:26 doesn't exist with offset + // +0200, so we adjust the time as needed, to be valid. + // + // Keeping the time actually adds/subtracts (one hour) + // from the actual represented time. That is why we call updateOffset + // a second time. In case it wants us to change the offset again + // _changeInProgress == true case, then we have to adjust, because + // there is no such time in the given timezone. + function getSetOffset (input, keepLocalTime) { + var offset = this._offset || 0, + localAdjust; + if (input != null) { + if (typeof input === 'string') { + input = offsetFromString(input); + } + if (Math.abs(input) < 16) { + input = input * 60; + } + if (!this._isUTC && keepLocalTime) { + localAdjust = getDateOffset(this); + } + this._offset = input; + this._isUTC = true; + if (localAdjust != null) { + this.add(localAdjust, 'm'); + } + if (offset !== input) { + if (!keepLocalTime || this._changeInProgress) { + add_subtract__addSubtract(this, create__createDuration(input - offset, 'm'), 1, false); + } else if (!this._changeInProgress) { + this._changeInProgress = true; + utils_hooks__hooks.updateOffset(this, true); + this._changeInProgress = null; + } + } + return this; + } else { + return this._isUTC ? offset : getDateOffset(this); + } + } + + function getSetZone (input, keepLocalTime) { + if (input != null) { + if (typeof input !== 'string') { + input = -input; + } + + this.utcOffset(input, keepLocalTime); + + return this; + } else { + return -this.utcOffset(); + } + } + + function setOffsetToUTC (keepLocalTime) { + return this.utcOffset(0, keepLocalTime); + } + + function setOffsetToLocal (keepLocalTime) { + if (this._isUTC) { + this.utcOffset(0, keepLocalTime); + this._isUTC = false; + + if (keepLocalTime) { + this.subtract(getDateOffset(this), 'm'); + } + } + return this; + } + + function setOffsetToParsedOffset () { + if (this._tzm) { + this.utcOffset(this._tzm); + } else if (typeof this._i === 'string') { + this.utcOffset(offsetFromString(this._i)); + } + return this; + } + + function hasAlignedHourOffset (input) { + input = input ? local__createLocal(input).utcOffset() : 0; + + return (this.utcOffset() - input) % 60 === 0; + } + + function isDaylightSavingTime () { + return ( + this.utcOffset() > this.clone().month(0).utcOffset() || + this.utcOffset() > this.clone().month(5).utcOffset() + ); + } + + function isDaylightSavingTimeShifted () { + if (typeof this._isDSTShifted !== 'undefined') { + return this._isDSTShifted; + } + + var c = {}; + + copyConfig(c, this); + c = prepareConfig(c); + + if (c._a) { + var other = c._isUTC ? create_utc__createUTC(c._a) : local__createLocal(c._a); + this._isDSTShifted = this.isValid() && + compareArrays(c._a, other.toArray()) > 0; + } else { + this._isDSTShifted = false; + } + + return this._isDSTShifted; + } + + function isLocal () { + return !this._isUTC; + } + + function isUtcOffset () { + return this._isUTC; + } + + function isUtc () { + return this._isUTC && this._offset === 0; + } + + var aspNetRegex = /(\-)?(?:(\d*)\.)?(\d+)\:(\d+)(?:\:(\d+)\.?(\d{3})?)?/; + + // from http://docs.closure-library.googlecode.com/git/closure_goog_date_date.js.source.html + // somewhat more in line with 4.4.3.2 2004 spec, but allows decimal anywhere + var create__isoRegex = /^(-)?P(?:(?:([0-9,.]*)Y)?(?:([0-9,.]*)M)?(?:([0-9,.]*)D)?(?:T(?:([0-9,.]*)H)?(?:([0-9,.]*)M)?(?:([0-9,.]*)S)?)?|([0-9,.]*)W)$/; + + function create__createDuration (input, key) { + var duration = input, + // matching against regexp is expensive, do it on demand + match = null, + sign, + ret, + diffRes; + + if (isDuration(input)) { + duration = { + ms : input._milliseconds, + d : input._days, + M : input._months + }; + } else if (typeof input === 'number') { + duration = {}; + if (key) { + duration[key] = input; + } else { + duration.milliseconds = input; + } + } else if (!!(match = aspNetRegex.exec(input))) { + sign = (match[1] === '-') ? -1 : 1; + duration = { + y : 0, + d : toInt(match[DATE]) * sign, + h : toInt(match[HOUR]) * sign, + m : toInt(match[MINUTE]) * sign, + s : toInt(match[SECOND]) * sign, + ms : toInt(match[MILLISECOND]) * sign + }; + } else if (!!(match = create__isoRegex.exec(input))) { + sign = (match[1] === '-') ? -1 : 1; + duration = { + y : parseIso(match[2], sign), + M : parseIso(match[3], sign), + d : parseIso(match[4], sign), + h : parseIso(match[5], sign), + m : parseIso(match[6], sign), + s : parseIso(match[7], sign), + w : parseIso(match[8], sign) + }; + } else if (duration == null) {// checks for null or undefined + duration = {}; + } else if (typeof duration === 'object' && ('from' in duration || 'to' in duration)) { + diffRes = momentsDifference(local__createLocal(duration.from), local__createLocal(duration.to)); + + duration = {}; + duration.ms = diffRes.milliseconds; + duration.M = diffRes.months; + } + + ret = new Duration(duration); + + if (isDuration(input) && hasOwnProp(input, '_locale')) { + ret._locale = input._locale; + } + + return ret; + } + + create__createDuration.fn = Duration.prototype; + + function parseIso (inp, sign) { + // We'd normally use ~~inp for this, but unfortunately it also + // converts floats to ints. + // inp may be undefined, so careful calling replace on it. + var res = inp && parseFloat(inp.replace(',', '.')); + // apply sign while we're at it + return (isNaN(res) ? 0 : res) * sign; + } + + function positiveMomentsDifference(base, other) { + var res = {milliseconds: 0, months: 0}; + + res.months = other.month() - base.month() + + (other.year() - base.year()) * 12; + if (base.clone().add(res.months, 'M').isAfter(other)) { + --res.months; + } + + res.milliseconds = +other - +(base.clone().add(res.months, 'M')); + + return res; + } + + function momentsDifference(base, other) { + var res; + other = cloneWithOffset(other, base); + if (base.isBefore(other)) { + res = positiveMomentsDifference(base, other); + } else { + res = positiveMomentsDifference(other, base); + res.milliseconds = -res.milliseconds; + res.months = -res.months; + } + + return res; + } + + function createAdder(direction, name) { + return function (val, period) { + var dur, tmp; + //invert the arguments, but complain about it + if (period !== null && !isNaN(+period)) { + deprecateSimple(name, 'moment().' + name + '(period, number) is deprecated. Please use moment().' + name + '(number, period).'); + tmp = val; val = period; period = tmp; + } + + val = typeof val === 'string' ? +val : val; + dur = create__createDuration(val, period); + add_subtract__addSubtract(this, dur, direction); + return this; + }; + } + + function add_subtract__addSubtract (mom, duration, isAdding, updateOffset) { + var milliseconds = duration._milliseconds, + days = duration._days, + months = duration._months; + updateOffset = updateOffset == null ? true : updateOffset; + + if (milliseconds) { + mom._d.setTime(+mom._d + milliseconds * isAdding); + } + if (days) { + get_set__set(mom, 'Date', get_set__get(mom, 'Date') + days * isAdding); + } + if (months) { + setMonth(mom, get_set__get(mom, 'Month') + months * isAdding); + } + if (updateOffset) { + utils_hooks__hooks.updateOffset(mom, days || months); + } + } + + var add_subtract__add = createAdder(1, 'add'); + var add_subtract__subtract = createAdder(-1, 'subtract'); + + function moment_calendar__calendar (time, formats) { + // We want to compare the start of today, vs this. + // Getting start-of-today depends on whether we're local/utc/offset or not. + var now = time || local__createLocal(), + sod = cloneWithOffset(now, this).startOf('day'), + diff = this.diff(sod, 'days', true), + format = diff < -6 ? 'sameElse' : + diff < -1 ? 'lastWeek' : + diff < 0 ? 'lastDay' : + diff < 1 ? 'sameDay' : + diff < 2 ? 'nextDay' : + diff < 7 ? 'nextWeek' : 'sameElse'; + return this.format(formats && formats[format] || this.localeData().calendar(format, this, local__createLocal(now))); + } + + function clone () { + return new Moment(this); + } + + function isAfter (input, units) { + var inputMs; + units = normalizeUnits(typeof units !== 'undefined' ? units : 'millisecond'); + if (units === 'millisecond') { + input = isMoment(input) ? input : local__createLocal(input); + return +this > +input; + } else { + inputMs = isMoment(input) ? +input : +local__createLocal(input); + return inputMs < +this.clone().startOf(units); + } + } + + function isBefore (input, units) { + var inputMs; + units = normalizeUnits(typeof units !== 'undefined' ? units : 'millisecond'); + if (units === 'millisecond') { + input = isMoment(input) ? input : local__createLocal(input); + return +this < +input; + } else { + inputMs = isMoment(input) ? +input : +local__createLocal(input); + return +this.clone().endOf(units) < inputMs; + } + } + + function isBetween (from, to, units) { + return this.isAfter(from, units) && this.isBefore(to, units); + } + + function isSame (input, units) { + var inputMs; + units = normalizeUnits(units || 'millisecond'); + if (units === 'millisecond') { + input = isMoment(input) ? input : local__createLocal(input); + return +this === +input; + } else { + inputMs = +local__createLocal(input); + return +(this.clone().startOf(units)) <= inputMs && inputMs <= +(this.clone().endOf(units)); + } + } + + function diff (input, units, asFloat) { + var that = cloneWithOffset(input, this), + zoneDelta = (that.utcOffset() - this.utcOffset()) * 6e4, + delta, output; + + units = normalizeUnits(units); + + if (units === 'year' || units === 'month' || units === 'quarter') { + output = monthDiff(this, that); + if (units === 'quarter') { + output = output / 3; + } else if (units === 'year') { + output = output / 12; + } + } else { + delta = this - that; + output = units === 'second' ? delta / 1e3 : // 1000 + units === 'minute' ? delta / 6e4 : // 1000 * 60 + units === 'hour' ? delta / 36e5 : // 1000 * 60 * 60 + units === 'day' ? (delta - zoneDelta) / 864e5 : // 1000 * 60 * 60 * 24, negate dst + units === 'week' ? (delta - zoneDelta) / 6048e5 : // 1000 * 60 * 60 * 24 * 7, negate dst + delta; + } + return asFloat ? output : absFloor(output); + } + + function monthDiff (a, b) { + // difference in months + var wholeMonthDiff = ((b.year() - a.year()) * 12) + (b.month() - a.month()), + // b is in (anchor - 1 month, anchor + 1 month) + anchor = a.clone().add(wholeMonthDiff, 'months'), + anchor2, adjust; + + if (b - anchor < 0) { + anchor2 = a.clone().add(wholeMonthDiff - 1, 'months'); + // linear across the month + adjust = (b - anchor) / (anchor - anchor2); + } else { + anchor2 = a.clone().add(wholeMonthDiff + 1, 'months'); + // linear across the month + adjust = (b - anchor) / (anchor2 - anchor); + } + + return -(wholeMonthDiff + adjust); + } + + utils_hooks__hooks.defaultFormat = 'YYYY-MM-DDTHH:mm:ssZ'; + + function toString () { + return this.clone().locale('en').format('ddd MMM DD YYYY HH:mm:ss [GMT]ZZ'); + } + + function moment_format__toISOString () { + var m = this.clone().utc(); + if (0 < m.year() && m.year() <= 9999) { + if ('function' === typeof Date.prototype.toISOString) { + // native implementation is ~50x faster, use it when we can + return this.toDate().toISOString(); + } else { + return formatMoment(m, 'YYYY-MM-DD[T]HH:mm:ss.SSS[Z]'); + } + } else { + return formatMoment(m, 'YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]'); + } + } + + function format (inputString) { + var output = formatMoment(this, inputString || utils_hooks__hooks.defaultFormat); + return this.localeData().postformat(output); + } + + function from (time, withoutSuffix) { + if (!this.isValid()) { + return this.localeData().invalidDate(); + } + return create__createDuration({to: this, from: time}).locale(this.locale()).humanize(!withoutSuffix); + } + + function fromNow (withoutSuffix) { + return this.from(local__createLocal(), withoutSuffix); + } + + function to (time, withoutSuffix) { + if (!this.isValid()) { + return this.localeData().invalidDate(); + } + return create__createDuration({from: this, to: time}).locale(this.locale()).humanize(!withoutSuffix); + } + + function toNow (withoutSuffix) { + return this.to(local__createLocal(), withoutSuffix); + } + + function locale (key) { + var newLocaleData; + + if (key === undefined) { + return this._locale._abbr; + } else { + newLocaleData = locale_locales__getLocale(key); + if (newLocaleData != null) { + this._locale = newLocaleData; + } + return this; + } + } + + var lang = deprecate( + 'moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.', + function (key) { + if (key === undefined) { + return this.localeData(); + } else { + return this.locale(key); + } + } + ); + + function localeData () { + return this._locale; + } + + function startOf (units) { + units = normalizeUnits(units); + // the following switch intentionally omits break keywords + // to utilize falling through the cases. + switch (units) { + case 'year': + this.month(0); + /* falls through */ + case 'quarter': + case 'month': + this.date(1); + /* falls through */ + case 'week': + case 'isoWeek': + case 'day': + this.hours(0); + /* falls through */ + case 'hour': + this.minutes(0); + /* falls through */ + case 'minute': + this.seconds(0); + /* falls through */ + case 'second': + this.milliseconds(0); + } + + // weeks are a special case + if (units === 'week') { + this.weekday(0); + } + if (units === 'isoWeek') { + this.isoWeekday(1); + } + + // quarters are also special + if (units === 'quarter') { + this.month(Math.floor(this.month() / 3) * 3); + } + + return this; + } + + function endOf (units) { + units = normalizeUnits(units); + if (units === undefined || units === 'millisecond') { + return this; + } + return this.startOf(units).add(1, (units === 'isoWeek' ? 'week' : units)).subtract(1, 'ms'); + } + + function to_type__valueOf () { + return +this._d - ((this._offset || 0) * 60000); + } + + function unix () { + return Math.floor(+this / 1000); + } + + function toDate () { + return this._offset ? new Date(+this) : this._d; + } + + function toArray () { + var m = this; + return [m.year(), m.month(), m.date(), m.hour(), m.minute(), m.second(), m.millisecond()]; + } + + function toObject () { + var m = this; + return { + years: m.year(), + months: m.month(), + date: m.date(), + hours: m.hours(), + minutes: m.minutes(), + seconds: m.seconds(), + milliseconds: m.milliseconds() + }; + } + + function moment_valid__isValid () { + return valid__isValid(this); + } + + function parsingFlags () { + return extend({}, getParsingFlags(this)); + } + + function invalidAt () { + return getParsingFlags(this).overflow; + } + + addFormatToken(0, ['gg', 2], 0, function () { + return this.weekYear() % 100; + }); + + addFormatToken(0, ['GG', 2], 0, function () { + return this.isoWeekYear() % 100; + }); + + function addWeekYearFormatToken (token, getter) { + addFormatToken(0, [token, token.length], 0, getter); + } + + addWeekYearFormatToken('gggg', 'weekYear'); + addWeekYearFormatToken('ggggg', 'weekYear'); + addWeekYearFormatToken('GGGG', 'isoWeekYear'); + addWeekYearFormatToken('GGGGG', 'isoWeekYear'); + + // ALIASES + + addUnitAlias('weekYear', 'gg'); + addUnitAlias('isoWeekYear', 'GG'); + + // PARSING + + addRegexToken('G', matchSigned); + addRegexToken('g', matchSigned); + addRegexToken('GG', match1to2, match2); + addRegexToken('gg', match1to2, match2); + addRegexToken('GGGG', match1to4, match4); + addRegexToken('gggg', match1to4, match4); + addRegexToken('GGGGG', match1to6, match6); + addRegexToken('ggggg', match1to6, match6); + + addWeekParseToken(['gggg', 'ggggg', 'GGGG', 'GGGGG'], function (input, week, config, token) { + week[token.substr(0, 2)] = toInt(input); + }); + + addWeekParseToken(['gg', 'GG'], function (input, week, config, token) { + week[token] = utils_hooks__hooks.parseTwoDigitYear(input); + }); + + // HELPERS + + function weeksInYear(year, dow, doy) { + return weekOfYear(local__createLocal([year, 11, 31 + dow - doy]), dow, doy).week; + } + + // MOMENTS + + function getSetWeekYear (input) { + var year = weekOfYear(this, this.localeData()._week.dow, this.localeData()._week.doy).year; + return input == null ? year : this.add((input - year), 'y'); + } + + function getSetISOWeekYear (input) { + var year = weekOfYear(this, 1, 4).year; + return input == null ? year : this.add((input - year), 'y'); + } + + function getISOWeeksInYear () { + return weeksInYear(this.year(), 1, 4); + } + + function getWeeksInYear () { + var weekInfo = this.localeData()._week; + return weeksInYear(this.year(), weekInfo.dow, weekInfo.doy); + } + + addFormatToken('Q', 0, 0, 'quarter'); + + // ALIASES + + addUnitAlias('quarter', 'Q'); + + // PARSING + + addRegexToken('Q', match1); + addParseToken('Q', function (input, array) { + array[MONTH] = (toInt(input) - 1) * 3; + }); + + // MOMENTS + + function getSetQuarter (input) { + return input == null ? Math.ceil((this.month() + 1) / 3) : this.month((input - 1) * 3 + this.month() % 3); + } + + addFormatToken('D', ['DD', 2], 'Do', 'date'); + + // ALIASES + + addUnitAlias('date', 'D'); + + // PARSING + + addRegexToken('D', match1to2); + addRegexToken('DD', match1to2, match2); + addRegexToken('Do', function (isStrict, locale) { + return isStrict ? locale._ordinalParse : locale._ordinalParseLenient; + }); + + addParseToken(['D', 'DD'], DATE); + addParseToken('Do', function (input, array) { + array[DATE] = toInt(input.match(match1to2)[0], 10); + }); + + // MOMENTS + + var getSetDayOfMonth = makeGetSet('Date', true); + + addFormatToken('d', 0, 'do', 'day'); + + addFormatToken('dd', 0, 0, function (format) { + return this.localeData().weekdaysMin(this, format); + }); + + addFormatToken('ddd', 0, 0, function (format) { + return this.localeData().weekdaysShort(this, format); + }); + + addFormatToken('dddd', 0, 0, function (format) { + return this.localeData().weekdays(this, format); + }); + + addFormatToken('e', 0, 0, 'weekday'); + addFormatToken('E', 0, 0, 'isoWeekday'); + + // ALIASES + + addUnitAlias('day', 'd'); + addUnitAlias('weekday', 'e'); + addUnitAlias('isoWeekday', 'E'); + + // PARSING + + addRegexToken('d', match1to2); + addRegexToken('e', match1to2); + addRegexToken('E', match1to2); + addRegexToken('dd', matchWord); + addRegexToken('ddd', matchWord); + addRegexToken('dddd', matchWord); + + addWeekParseToken(['dd', 'ddd', 'dddd'], function (input, week, config) { + var weekday = config._locale.weekdaysParse(input); + // if we didn't get a weekday name, mark the date as invalid + if (weekday != null) { + week.d = weekday; + } else { + getParsingFlags(config).invalidWeekday = input; + } + }); + + addWeekParseToken(['d', 'e', 'E'], function (input, week, config, token) { + week[token] = toInt(input); + }); + + // HELPERS + + function parseWeekday(input, locale) { + if (typeof input !== 'string') { + return input; + } + + if (!isNaN(input)) { + return parseInt(input, 10); + } + + input = locale.weekdaysParse(input); + if (typeof input === 'number') { + return input; + } + + return null; + } + + // LOCALES + + var defaultLocaleWeekdays = 'Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday'.split('_'); + function localeWeekdays (m) { + return this._weekdays[m.day()]; + } + + var defaultLocaleWeekdaysShort = 'Sun_Mon_Tue_Wed_Thu_Fri_Sat'.split('_'); + function localeWeekdaysShort (m) { + return this._weekdaysShort[m.day()]; + } + + var defaultLocaleWeekdaysMin = 'Su_Mo_Tu_We_Th_Fr_Sa'.split('_'); + function localeWeekdaysMin (m) { + return this._weekdaysMin[m.day()]; + } + + function localeWeekdaysParse (weekdayName) { + var i, mom, regex; + + this._weekdaysParse = this._weekdaysParse || []; + + for (i = 0; i < 7; i++) { + // make the regex if we don't have it already + if (!this._weekdaysParse[i]) { + mom = local__createLocal([2000, 1]).day(i); + regex = '^' + this.weekdays(mom, '') + '|^' + this.weekdaysShort(mom, '') + '|^' + this.weekdaysMin(mom, ''); + this._weekdaysParse[i] = new RegExp(regex.replace('.', ''), 'i'); + } + // test the regex + if (this._weekdaysParse[i].test(weekdayName)) { + return i; + } + } + } + + // MOMENTS + + function getSetDayOfWeek (input) { + var day = this._isUTC ? this._d.getUTCDay() : this._d.getDay(); + if (input != null) { + input = parseWeekday(input, this.localeData()); + return this.add(input - day, 'd'); + } else { + return day; + } + } + + function getSetLocaleDayOfWeek (input) { + var weekday = (this.day() + 7 - this.localeData()._week.dow) % 7; + return input == null ? weekday : this.add(input - weekday, 'd'); + } + + function getSetISODayOfWeek (input) { + // behaves the same as moment#day except + // as a getter, returns 7 instead of 0 (1-7 range instead of 0-6) + // as a setter, sunday should belong to the previous week. + return input == null ? this.day() || 7 : this.day(this.day() % 7 ? input : input - 7); + } + + addFormatToken('H', ['HH', 2], 0, 'hour'); + addFormatToken('h', ['hh', 2], 0, function () { + return this.hours() % 12 || 12; + }); + + function meridiem (token, lowercase) { + addFormatToken(token, 0, 0, function () { + return this.localeData().meridiem(this.hours(), this.minutes(), lowercase); + }); + } + + meridiem('a', true); + meridiem('A', false); + + // ALIASES + + addUnitAlias('hour', 'h'); + + // PARSING + + function matchMeridiem (isStrict, locale) { + return locale._meridiemParse; + } + + addRegexToken('a', matchMeridiem); + addRegexToken('A', matchMeridiem); + addRegexToken('H', match1to2); + addRegexToken('h', match1to2); + addRegexToken('HH', match1to2, match2); + addRegexToken('hh', match1to2, match2); + + addParseToken(['H', 'HH'], HOUR); + addParseToken(['a', 'A'], function (input, array, config) { + config._isPm = config._locale.isPM(input); + config._meridiem = input; + }); + addParseToken(['h', 'hh'], function (input, array, config) { + array[HOUR] = toInt(input); + getParsingFlags(config).bigHour = true; + }); + + // LOCALES + + function localeIsPM (input) { + // IE8 Quirks Mode & IE7 Standards Mode do not allow accessing strings like arrays + // Using charAt should be more compatible. + return ((input + '').toLowerCase().charAt(0) === 'p'); + } + + var defaultLocaleMeridiemParse = /[ap]\.?m?\.?/i; + function localeMeridiem (hours, minutes, isLower) { + if (hours > 11) { + return isLower ? 'pm' : 'PM'; + } else { + return isLower ? 'am' : 'AM'; + } + } + + + // MOMENTS + + // Setting the hour should keep the time, because the user explicitly + // specified which hour he wants. So trying to maintain the same hour (in + // a new timezone) makes sense. Adding/subtracting hours does not follow + // this rule. + var getSetHour = makeGetSet('Hours', true); + + addFormatToken('m', ['mm', 2], 0, 'minute'); + + // ALIASES + + addUnitAlias('minute', 'm'); + + // PARSING + + addRegexToken('m', match1to2); + addRegexToken('mm', match1to2, match2); + addParseToken(['m', 'mm'], MINUTE); + + // MOMENTS + + var getSetMinute = makeGetSet('Minutes', false); + + addFormatToken('s', ['ss', 2], 0, 'second'); + + // ALIASES + + addUnitAlias('second', 's'); + + // PARSING + + addRegexToken('s', match1to2); + addRegexToken('ss', match1to2, match2); + addParseToken(['s', 'ss'], SECOND); + + // MOMENTS + + var getSetSecond = makeGetSet('Seconds', false); + + addFormatToken('S', 0, 0, function () { + return ~~(this.millisecond() / 100); + }); + + addFormatToken(0, ['SS', 2], 0, function () { + return ~~(this.millisecond() / 10); + }); + + addFormatToken(0, ['SSS', 3], 0, 'millisecond'); + addFormatToken(0, ['SSSS', 4], 0, function () { + return this.millisecond() * 10; + }); + addFormatToken(0, ['SSSSS', 5], 0, function () { + return this.millisecond() * 100; + }); + addFormatToken(0, ['SSSSSS', 6], 0, function () { + return this.millisecond() * 1000; + }); + addFormatToken(0, ['SSSSSSS', 7], 0, function () { + return this.millisecond() * 10000; + }); + addFormatToken(0, ['SSSSSSSS', 8], 0, function () { + return this.millisecond() * 100000; + }); + addFormatToken(0, ['SSSSSSSSS', 9], 0, function () { + return this.millisecond() * 1000000; + }); + + + // ALIASES + + addUnitAlias('millisecond', 'ms'); + + // PARSING + + addRegexToken('S', match1to3, match1); + addRegexToken('SS', match1to3, match2); + addRegexToken('SSS', match1to3, match3); + + var token; + for (token = 'SSSS'; token.length <= 9; token += 'S') { + addRegexToken(token, matchUnsigned); + } + + function parseMs(input, array) { + array[MILLISECOND] = toInt(('0.' + input) * 1000); + } + + for (token = 'S'; token.length <= 9; token += 'S') { + addParseToken(token, parseMs); + } + // MOMENTS + + var getSetMillisecond = makeGetSet('Milliseconds', false); + + addFormatToken('z', 0, 0, 'zoneAbbr'); + addFormatToken('zz', 0, 0, 'zoneName'); + + // MOMENTS + + function getZoneAbbr () { + return this._isUTC ? 'UTC' : ''; + } + + function getZoneName () { + return this._isUTC ? 'Coordinated Universal Time' : ''; + } + + var momentPrototype__proto = Moment.prototype; + + momentPrototype__proto.add = add_subtract__add; + momentPrototype__proto.calendar = moment_calendar__calendar; + momentPrototype__proto.clone = clone; + momentPrototype__proto.diff = diff; + momentPrototype__proto.endOf = endOf; + momentPrototype__proto.format = format; + momentPrototype__proto.from = from; + momentPrototype__proto.fromNow = fromNow; + momentPrototype__proto.to = to; + momentPrototype__proto.toNow = toNow; + momentPrototype__proto.get = getSet; + momentPrototype__proto.invalidAt = invalidAt; + momentPrototype__proto.isAfter = isAfter; + momentPrototype__proto.isBefore = isBefore; + momentPrototype__proto.isBetween = isBetween; + momentPrototype__proto.isSame = isSame; + momentPrototype__proto.isValid = moment_valid__isValid; + momentPrototype__proto.lang = lang; + momentPrototype__proto.locale = locale; + momentPrototype__proto.localeData = localeData; + momentPrototype__proto.max = prototypeMax; + momentPrototype__proto.min = prototypeMin; + momentPrototype__proto.parsingFlags = parsingFlags; + momentPrototype__proto.set = getSet; + momentPrototype__proto.startOf = startOf; + momentPrototype__proto.subtract = add_subtract__subtract; + momentPrototype__proto.toArray = toArray; + momentPrototype__proto.toObject = toObject; + momentPrototype__proto.toDate = toDate; + momentPrototype__proto.toISOString = moment_format__toISOString; + momentPrototype__proto.toJSON = moment_format__toISOString; + momentPrototype__proto.toString = toString; + momentPrototype__proto.unix = unix; + momentPrototype__proto.valueOf = to_type__valueOf; + + // Year + momentPrototype__proto.year = getSetYear; + momentPrototype__proto.isLeapYear = getIsLeapYear; + + // Week Year + momentPrototype__proto.weekYear = getSetWeekYear; + momentPrototype__proto.isoWeekYear = getSetISOWeekYear; + + // Quarter + momentPrototype__proto.quarter = momentPrototype__proto.quarters = getSetQuarter; + + // Month + momentPrototype__proto.month = getSetMonth; + momentPrototype__proto.daysInMonth = getDaysInMonth; + + // Week + momentPrototype__proto.week = momentPrototype__proto.weeks = getSetWeek; + momentPrototype__proto.isoWeek = momentPrototype__proto.isoWeeks = getSetISOWeek; + momentPrototype__proto.weeksInYear = getWeeksInYear; + momentPrototype__proto.isoWeeksInYear = getISOWeeksInYear; + + // Day + momentPrototype__proto.date = getSetDayOfMonth; + momentPrototype__proto.day = momentPrototype__proto.days = getSetDayOfWeek; + momentPrototype__proto.weekday = getSetLocaleDayOfWeek; + momentPrototype__proto.isoWeekday = getSetISODayOfWeek; + momentPrototype__proto.dayOfYear = getSetDayOfYear; + + // Hour + momentPrototype__proto.hour = momentPrototype__proto.hours = getSetHour; + + // Minute + momentPrototype__proto.minute = momentPrototype__proto.minutes = getSetMinute; + + // Second + momentPrototype__proto.second = momentPrototype__proto.seconds = getSetSecond; + + // Millisecond + momentPrototype__proto.millisecond = momentPrototype__proto.milliseconds = getSetMillisecond; + + // Offset + momentPrototype__proto.utcOffset = getSetOffset; + momentPrototype__proto.utc = setOffsetToUTC; + momentPrototype__proto.local = setOffsetToLocal; + momentPrototype__proto.parseZone = setOffsetToParsedOffset; + momentPrototype__proto.hasAlignedHourOffset = hasAlignedHourOffset; + momentPrototype__proto.isDST = isDaylightSavingTime; + momentPrototype__proto.isDSTShifted = isDaylightSavingTimeShifted; + momentPrototype__proto.isLocal = isLocal; + momentPrototype__proto.isUtcOffset = isUtcOffset; + momentPrototype__proto.isUtc = isUtc; + momentPrototype__proto.isUTC = isUtc; + + // Timezone + momentPrototype__proto.zoneAbbr = getZoneAbbr; + momentPrototype__proto.zoneName = getZoneName; + + // Deprecations + momentPrototype__proto.dates = deprecate('dates accessor is deprecated. Use date instead.', getSetDayOfMonth); + momentPrototype__proto.months = deprecate('months accessor is deprecated. Use month instead', getSetMonth); + momentPrototype__proto.years = deprecate('years accessor is deprecated. Use year instead', getSetYear); + momentPrototype__proto.zone = deprecate('moment().zone is deprecated, use moment().utcOffset instead. https://github.com/moment/moment/issues/1779', getSetZone); + + var momentPrototype = momentPrototype__proto; + + function moment__createUnix (input) { + return local__createLocal(input * 1000); + } + + function moment__createInZone () { + return local__createLocal.apply(null, arguments).parseZone(); + } + + var defaultCalendar = { + sameDay : '[Today at] LT', + nextDay : '[Tomorrow at] LT', + nextWeek : 'dddd [at] LT', + lastDay : '[Yesterday at] LT', + lastWeek : '[Last] dddd [at] LT', + sameElse : 'L' + }; + + function locale_calendar__calendar (key, mom, now) { + var output = this._calendar[key]; + return typeof output === 'function' ? output.call(mom, now) : output; + } + + var defaultLongDateFormat = { + LTS : 'h:mm:ss A', + LT : 'h:mm A', + L : 'MM/DD/YYYY', + LL : 'MMMM D, YYYY', + LLL : 'MMMM D, YYYY h:mm A', + LLLL : 'dddd, MMMM D, YYYY h:mm A' + }; + + function longDateFormat (key) { + var format = this._longDateFormat[key], + formatUpper = this._longDateFormat[key.toUpperCase()]; + + if (format || !formatUpper) { + return format; + } + + this._longDateFormat[key] = formatUpper.replace(/MMMM|MM|DD|dddd/g, function (val) { + return val.slice(1); + }); + + return this._longDateFormat[key]; + } + + var defaultInvalidDate = 'Invalid date'; + + function invalidDate () { + return this._invalidDate; + } + + var defaultOrdinal = '%d'; + var defaultOrdinalParse = /\d{1,2}/; + + function ordinal (number) { + return this._ordinal.replace('%d', number); + } + + function preParsePostFormat (string) { + return string; + } + + var defaultRelativeTime = { + future : 'in %s', + past : '%s ago', + s : 'a few seconds', + m : 'a minute', + mm : '%d minutes', + h : 'an hour', + hh : '%d hours', + d : 'a day', + dd : '%d days', + M : 'a month', + MM : '%d months', + y : 'a year', + yy : '%d years' + }; + + function relative__relativeTime (number, withoutSuffix, string, isFuture) { + var output = this._relativeTime[string]; + return (typeof output === 'function') ? + output(number, withoutSuffix, string, isFuture) : + output.replace(/%d/i, number); + } + + function pastFuture (diff, output) { + var format = this._relativeTime[diff > 0 ? 'future' : 'past']; + return typeof format === 'function' ? format(output) : format.replace(/%s/i, output); + } + + function locale_set__set (config) { + var prop, i; + for (i in config) { + prop = config[i]; + if (typeof prop === 'function') { + this[i] = prop; + } else { + this['_' + i] = prop; + } + } + // Lenient ordinal parsing accepts just a number in addition to + // number + (possibly) stuff coming from _ordinalParseLenient. + this._ordinalParseLenient = new RegExp(this._ordinalParse.source + '|' + (/\d{1,2}/).source); + } + + var prototype__proto = Locale.prototype; + + prototype__proto._calendar = defaultCalendar; + prototype__proto.calendar = locale_calendar__calendar; + prototype__proto._longDateFormat = defaultLongDateFormat; + prototype__proto.longDateFormat = longDateFormat; + prototype__proto._invalidDate = defaultInvalidDate; + prototype__proto.invalidDate = invalidDate; + prototype__proto._ordinal = defaultOrdinal; + prototype__proto.ordinal = ordinal; + prototype__proto._ordinalParse = defaultOrdinalParse; + prototype__proto.preparse = preParsePostFormat; + prototype__proto.postformat = preParsePostFormat; + prototype__proto._relativeTime = defaultRelativeTime; + prototype__proto.relativeTime = relative__relativeTime; + prototype__proto.pastFuture = pastFuture; + prototype__proto.set = locale_set__set; + + // Month + prototype__proto.months = localeMonths; + prototype__proto._months = defaultLocaleMonths; + prototype__proto.monthsShort = localeMonthsShort; + prototype__proto._monthsShort = defaultLocaleMonthsShort; + prototype__proto.monthsParse = localeMonthsParse; + + // Week + prototype__proto.week = localeWeek; + prototype__proto._week = defaultLocaleWeek; + prototype__proto.firstDayOfYear = localeFirstDayOfYear; + prototype__proto.firstDayOfWeek = localeFirstDayOfWeek; + + // Day of Week + prototype__proto.weekdays = localeWeekdays; + prototype__proto._weekdays = defaultLocaleWeekdays; + prototype__proto.weekdaysMin = localeWeekdaysMin; + prototype__proto._weekdaysMin = defaultLocaleWeekdaysMin; + prototype__proto.weekdaysShort = localeWeekdaysShort; + prototype__proto._weekdaysShort = defaultLocaleWeekdaysShort; + prototype__proto.weekdaysParse = localeWeekdaysParse; + + // Hours + prototype__proto.isPM = localeIsPM; + prototype__proto._meridiemParse = defaultLocaleMeridiemParse; + prototype__proto.meridiem = localeMeridiem; + + function lists__get (format, index, field, setter) { + var locale = locale_locales__getLocale(); + var utc = create_utc__createUTC().set(setter, index); + return locale[field](utc, format); + } + + function list (format, index, field, count, setter) { + if (typeof format === 'number') { + index = format; + format = undefined; + } + + format = format || ''; + + if (index != null) { + return lists__get(format, index, field, setter); + } + + var i; + var out = []; + for (i = 0; i < count; i++) { + out[i] = lists__get(format, i, field, setter); + } + return out; + } + + function lists__listMonths (format, index) { + return list(format, index, 'months', 12, 'month'); + } + + function lists__listMonthsShort (format, index) { + return list(format, index, 'monthsShort', 12, 'month'); + } + + function lists__listWeekdays (format, index) { + return list(format, index, 'weekdays', 7, 'day'); + } + + function lists__listWeekdaysShort (format, index) { + return list(format, index, 'weekdaysShort', 7, 'day'); + } + + function lists__listWeekdaysMin (format, index) { + return list(format, index, 'weekdaysMin', 7, 'day'); + } + + locale_locales__getSetGlobalLocale('en', { + ordinalParse: /\d{1,2}(th|st|nd|rd)/, + ordinal : function (number) { + var b = number % 10, + output = (toInt(number % 100 / 10) === 1) ? 'th' : + (b === 1) ? 'st' : + (b === 2) ? 'nd' : + (b === 3) ? 'rd' : 'th'; + return number + output; + } + }); + + // Side effect imports + utils_hooks__hooks.lang = deprecate('moment.lang is deprecated. Use moment.locale instead.', locale_locales__getSetGlobalLocale); + utils_hooks__hooks.langData = deprecate('moment.langData is deprecated. Use moment.localeData instead.', locale_locales__getLocale); + + var mathAbs = Math.abs; + + function duration_abs__abs () { + var data = this._data; + + this._milliseconds = mathAbs(this._milliseconds); + this._days = mathAbs(this._days); + this._months = mathAbs(this._months); + + data.milliseconds = mathAbs(data.milliseconds); + data.seconds = mathAbs(data.seconds); + data.minutes = mathAbs(data.minutes); + data.hours = mathAbs(data.hours); + data.months = mathAbs(data.months); + data.years = mathAbs(data.years); + + return this; + } + + function duration_add_subtract__addSubtract (duration, input, value, direction) { + var other = create__createDuration(input, value); + + duration._milliseconds += direction * other._milliseconds; + duration._days += direction * other._days; + duration._months += direction * other._months; + + return duration._bubble(); + } + + // supports only 2.0-style add(1, 's') or add(duration) + function duration_add_subtract__add (input, value) { + return duration_add_subtract__addSubtract(this, input, value, 1); + } + + // supports only 2.0-style subtract(1, 's') or subtract(duration) + function duration_add_subtract__subtract (input, value) { + return duration_add_subtract__addSubtract(this, input, value, -1); + } + + function absCeil (number) { + if (number < 0) { + return Math.floor(number); + } else { + return Math.ceil(number); + } + } + + function bubble () { + var milliseconds = this._milliseconds; + var days = this._days; + var months = this._months; + var data = this._data; + var seconds, minutes, hours, years, monthsFromDays; + + // if we have a mix of positive and negative values, bubble down first + // check: https://github.com/moment/moment/issues/2166 + if (!((milliseconds >= 0 && days >= 0 && months >= 0) || + (milliseconds <= 0 && days <= 0 && months <= 0))) { + milliseconds += absCeil(monthsToDays(months) + days) * 864e5; + days = 0; + months = 0; + } + + // The following code bubbles up values, see the tests for + // examples of what that means. + data.milliseconds = milliseconds % 1000; + + seconds = absFloor(milliseconds / 1000); + data.seconds = seconds % 60; + + minutes = absFloor(seconds / 60); + data.minutes = minutes % 60; + + hours = absFloor(minutes / 60); + data.hours = hours % 24; + + days += absFloor(hours / 24); + + // convert days to months + monthsFromDays = absFloor(daysToMonths(days)); + months += monthsFromDays; + days -= absCeil(monthsToDays(monthsFromDays)); + + // 12 months -> 1 year + years = absFloor(months / 12); + months %= 12; + + data.days = days; + data.months = months; + data.years = years; + + return this; + } + + function daysToMonths (days) { + // 400 years have 146097 days (taking into account leap year rules) + // 400 years have 12 months === 4800 + return days * 4800 / 146097; + } + + function monthsToDays (months) { + // the reverse of daysToMonths + return months * 146097 / 4800; + } + + function as (units) { + var days; + var months; + var milliseconds = this._milliseconds; + + units = normalizeUnits(units); + + if (units === 'month' || units === 'year') { + days = this._days + milliseconds / 864e5; + months = this._months + daysToMonths(days); + return units === 'month' ? months : months / 12; + } else { + // handle milliseconds separately because of floating point math errors (issue #1867) + days = this._days + Math.round(monthsToDays(this._months)); + switch (units) { + case 'week' : return days / 7 + milliseconds / 6048e5; + case 'day' : return days + milliseconds / 864e5; + case 'hour' : return days * 24 + milliseconds / 36e5; + case 'minute' : return days * 1440 + milliseconds / 6e4; + case 'second' : return days * 86400 + milliseconds / 1000; + // Math.floor prevents floating point math errors here + case 'millisecond': return Math.floor(days * 864e5) + milliseconds; + default: throw new Error('Unknown unit ' + units); + } + } + } + + // TODO: Use this.as('ms')? + function duration_as__valueOf () { + return ( + this._milliseconds + + this._days * 864e5 + + (this._months % 12) * 2592e6 + + toInt(this._months / 12) * 31536e6 + ); + } + + function makeAs (alias) { + return function () { + return this.as(alias); + }; + } + + var asMilliseconds = makeAs('ms'); + var asSeconds = makeAs('s'); + var asMinutes = makeAs('m'); + var asHours = makeAs('h'); + var asDays = makeAs('d'); + var asWeeks = makeAs('w'); + var asMonths = makeAs('M'); + var asYears = makeAs('y'); + + function duration_get__get (units) { + units = normalizeUnits(units); + return this[units + 's'](); + } + + function makeGetter(name) { + return function () { + return this._data[name]; + }; + } + + var milliseconds = makeGetter('milliseconds'); + var seconds = makeGetter('seconds'); + var minutes = makeGetter('minutes'); + var hours = makeGetter('hours'); + var days = makeGetter('days'); + var months = makeGetter('months'); + var years = makeGetter('years'); + + function weeks () { + return absFloor(this.days() / 7); + } + + var round = Math.round; + var thresholds = { + s: 45, // seconds to minute + m: 45, // minutes to hour + h: 22, // hours to day + d: 26, // days to month + M: 11 // months to year + }; + + // helper function for moment.fn.from, moment.fn.fromNow, and moment.duration.fn.humanize + function substituteTimeAgo(string, number, withoutSuffix, isFuture, locale) { + return locale.relativeTime(number || 1, !!withoutSuffix, string, isFuture); + } + + function duration_humanize__relativeTime (posNegDuration, withoutSuffix, locale) { + var duration = create__createDuration(posNegDuration).abs(); + var seconds = round(duration.as('s')); + var minutes = round(duration.as('m')); + var hours = round(duration.as('h')); + var days = round(duration.as('d')); + var months = round(duration.as('M')); + var years = round(duration.as('y')); + + var a = seconds < thresholds.s && ['s', seconds] || + minutes === 1 && ['m'] || + minutes < thresholds.m && ['mm', minutes] || + hours === 1 && ['h'] || + hours < thresholds.h && ['hh', hours] || + days === 1 && ['d'] || + days < thresholds.d && ['dd', days] || + months === 1 && ['M'] || + months < thresholds.M && ['MM', months] || + years === 1 && ['y'] || ['yy', years]; + + a[2] = withoutSuffix; + a[3] = +posNegDuration > 0; + a[4] = locale; + return substituteTimeAgo.apply(null, a); + } + + // This function allows you to set a threshold for relative time strings + function duration_humanize__getSetRelativeTimeThreshold (threshold, limit) { + if (thresholds[threshold] === undefined) { + return false; + } + if (limit === undefined) { + return thresholds[threshold]; + } + thresholds[threshold] = limit; + return true; + } + + function humanize (withSuffix) { + var locale = this.localeData(); + var output = duration_humanize__relativeTime(this, !withSuffix, locale); + + if (withSuffix) { + output = locale.pastFuture(+this, output); + } + + return locale.postformat(output); + } + + var iso_string__abs = Math.abs; + + function iso_string__toISOString() { + // for ISO strings we do not use the normal bubbling rules: + // * milliseconds bubble up until they become hours + // * days do not bubble at all + // * months bubble up until they become years + // This is because there is no context-free conversion between hours and days + // (think of clock changes) + // and also not between days and months (28-31 days per month) + var seconds = iso_string__abs(this._milliseconds) / 1000; + var days = iso_string__abs(this._days); + var months = iso_string__abs(this._months); + var minutes, hours, years; + + // 3600 seconds -> 60 minutes -> 1 hour + minutes = absFloor(seconds / 60); + hours = absFloor(minutes / 60); + seconds %= 60; + minutes %= 60; + + // 12 months -> 1 year + years = absFloor(months / 12); + months %= 12; + + + // inspired by https://github.com/dordille/moment-isoduration/blob/master/moment.isoduration.js + var Y = years; + var M = months; + var D = days; + var h = hours; + var m = minutes; + var s = seconds; + var total = this.asSeconds(); + + if (!total) { + // this is the same as C#'s (Noda) and python (isodate)... + // but not other JS (goog.date) + return 'P0D'; + } + + return (total < 0 ? '-' : '') + + 'P' + + (Y ? Y + 'Y' : '') + + (M ? M + 'M' : '') + + (D ? D + 'D' : '') + + ((h || m || s) ? 'T' : '') + + (h ? h + 'H' : '') + + (m ? m + 'M' : '') + + (s ? s + 'S' : ''); + } + + var duration_prototype__proto = Duration.prototype; + + duration_prototype__proto.abs = duration_abs__abs; + duration_prototype__proto.add = duration_add_subtract__add; + duration_prototype__proto.subtract = duration_add_subtract__subtract; + duration_prototype__proto.as = as; + duration_prototype__proto.asMilliseconds = asMilliseconds; + duration_prototype__proto.asSeconds = asSeconds; + duration_prototype__proto.asMinutes = asMinutes; + duration_prototype__proto.asHours = asHours; + duration_prototype__proto.asDays = asDays; + duration_prototype__proto.asWeeks = asWeeks; + duration_prototype__proto.asMonths = asMonths; + duration_prototype__proto.asYears = asYears; + duration_prototype__proto.valueOf = duration_as__valueOf; + duration_prototype__proto._bubble = bubble; + duration_prototype__proto.get = duration_get__get; + duration_prototype__proto.milliseconds = milliseconds; + duration_prototype__proto.seconds = seconds; + duration_prototype__proto.minutes = minutes; + duration_prototype__proto.hours = hours; + duration_prototype__proto.days = days; + duration_prototype__proto.weeks = weeks; + duration_prototype__proto.months = months; + duration_prototype__proto.years = years; + duration_prototype__proto.humanize = humanize; + duration_prototype__proto.toISOString = iso_string__toISOString; + duration_prototype__proto.toString = iso_string__toISOString; + duration_prototype__proto.toJSON = iso_string__toISOString; + duration_prototype__proto.locale = locale; + duration_prototype__proto.localeData = localeData; + + // Deprecations + duration_prototype__proto.toIsoString = deprecate('toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)', iso_string__toISOString); + duration_prototype__proto.lang = lang; + + // Side effect imports + + addFormatToken('X', 0, 0, 'unix'); + addFormatToken('x', 0, 0, 'valueOf'); + + // PARSING + + addRegexToken('x', matchSigned); + addRegexToken('X', matchTimestamp); + addParseToken('X', function (input, array, config) { + config._d = new Date(parseFloat(input, 10) * 1000); + }); + addParseToken('x', function (input, array, config) { + config._d = new Date(toInt(input)); + }); + + // Side effect imports + + + utils_hooks__hooks.version = '2.10.6'; + + setHookCallback(local__createLocal); + + utils_hooks__hooks.fn = momentPrototype; + utils_hooks__hooks.min = min; + utils_hooks__hooks.max = max; + utils_hooks__hooks.utc = create_utc__createUTC; + utils_hooks__hooks.unix = moment__createUnix; + utils_hooks__hooks.months = lists__listMonths; + utils_hooks__hooks.isDate = isDate; + utils_hooks__hooks.locale = locale_locales__getSetGlobalLocale; + utils_hooks__hooks.invalid = valid__createInvalid; + utils_hooks__hooks.duration = create__createDuration; + utils_hooks__hooks.isMoment = isMoment; + utils_hooks__hooks.weekdays = lists__listWeekdays; + utils_hooks__hooks.parseZone = moment__createInZone; + utils_hooks__hooks.localeData = locale_locales__getLocale; + utils_hooks__hooks.isDuration = isDuration; + utils_hooks__hooks.monthsShort = lists__listMonthsShort; + utils_hooks__hooks.weekdaysMin = lists__listWeekdaysMin; + utils_hooks__hooks.defineLocale = defineLocale; + utils_hooks__hooks.weekdaysShort = lists__listWeekdaysShort; + utils_hooks__hooks.normalizeUnits = normalizeUnits; + utils_hooks__hooks.relativeTimeThreshold = duration_humanize__getSetRelativeTimeThreshold; + + var _moment = utils_hooks__hooks; + + return _moment; + +})); +},{}],"numeral":[function(require,module,exports){ +"use strict"; +(function() { + var numeral, + VERSION = '1.5.3', + languages = {}, + currentLanguage = 'en', + zeroFormat = null, + defaultFormat = '0,0', + hasModule = (typeof module !== 'undefined' && module.exports); + function Numeral(number) { + this._value = number; + } + function toFixed(value, precision, roundingFunction, optionals) { + var power = Math.pow(10, precision), + optionalsRegExp, + output; + output = (roundingFunction(value * power) / power).toFixed(precision); + if (optionals) { + optionalsRegExp = new RegExp('0{1,' + optionals + '}$'); + output = output.replace(optionalsRegExp, ''); + } + return output; + } + function formatNumeral(n, format, roundingFunction) { + var output; + if (format.indexOf('$') > -1) { + output = formatCurrency(n, format, roundingFunction); + } else if (format.indexOf('%') > -1) { + output = formatPercentage(n, format, roundingFunction); + } else if (format.indexOf(':') > -1) { + output = formatTime(n, format); + } else { + output = formatNumber(n._value, format, roundingFunction); + } + return output; + } + function unformatNumeral(n, string) { + var stringOriginal = string, + thousandRegExp, + millionRegExp, + billionRegExp, + trillionRegExp, + suffixes = ['KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'], + bytesMultiplier = false, + power; + if (string.indexOf(':') > -1) { + n._value = unformatTime(string); + } else { + if (string === zeroFormat) { + n._value = 0; + } else { + if (languages[currentLanguage].delimiters.decimal !== '.') { + string = string.replace(/\./g, '').replace(languages[currentLanguage].delimiters.decimal, '.'); + } + thousandRegExp = new RegExp('[^a-zA-Z]' + languages[currentLanguage].abbreviations.thousand + '(?:\\)|(\\' + languages[currentLanguage].currency.symbol + ')?(?:\\))?)?$'); + millionRegExp = new RegExp('[^a-zA-Z]' + languages[currentLanguage].abbreviations.million + '(?:\\)|(\\' + languages[currentLanguage].currency.symbol + ')?(?:\\))?)?$'); + billionRegExp = new RegExp('[^a-zA-Z]' + languages[currentLanguage].abbreviations.billion + '(?:\\)|(\\' + languages[currentLanguage].currency.symbol + ')?(?:\\))?)?$'); + trillionRegExp = new RegExp('[^a-zA-Z]' + languages[currentLanguage].abbreviations.trillion + '(?:\\)|(\\' + languages[currentLanguage].currency.symbol + ')?(?:\\))?)?$'); + for (power = 0; power <= suffixes.length; power++) { + bytesMultiplier = (string.indexOf(suffixes[power]) > -1) ? Math.pow(1024, power + 1) : false; + if (bytesMultiplier) { + break; + } + } + n._value = ((bytesMultiplier) ? bytesMultiplier : 1) * ((stringOriginal.match(thousandRegExp)) ? Math.pow(10, 3) : 1) * ((stringOriginal.match(millionRegExp)) ? Math.pow(10, 6) : 1) * ((stringOriginal.match(billionRegExp)) ? Math.pow(10, 9) : 1) * ((stringOriginal.match(trillionRegExp)) ? Math.pow(10, 12) : 1) * ((string.indexOf('%') > -1) ? 0.01 : 1) * (((string.split('-').length + Math.min(string.split('(').length - 1, string.split(')').length - 1)) % 2) ? 1 : -1) * Number(string.replace(/[^0-9\.]+/g, '')); + n._value = (bytesMultiplier) ? Math.ceil(n._value) : n._value; + } + } + return n._value; + } + function formatCurrency(n, format, roundingFunction) { + var symbolIndex = format.indexOf('$'), + openParenIndex = format.indexOf('('), + minusSignIndex = format.indexOf('-'), + space = '', + spliceIndex, + output; + if (format.indexOf(' $') > -1) { + space = ' '; + format = format.replace(' $', ''); + } else if (format.indexOf('$ ') > -1) { + space = ' '; + format = format.replace('$ ', ''); + } else { + format = format.replace('$', ''); + } + output = formatNumber(n._value, format, roundingFunction); + if (symbolIndex <= 1) { + if (output.indexOf('(') > -1 || output.indexOf('-') > -1) { + output = output.split(''); + spliceIndex = 1; + if (symbolIndex < openParenIndex || symbolIndex < minusSignIndex) { + spliceIndex = 0; + } + output.splice(spliceIndex, 0, languages[currentLanguage].currency.symbol + space); + output = output.join(''); + } else { + output = languages[currentLanguage].currency.symbol + space + output; + } + } else { + if (output.indexOf(')') > -1) { + output = output.split(''); + output.splice(-1, 0, space + languages[currentLanguage].currency.symbol); + output = output.join(''); + } else { + output = output + space + languages[currentLanguage].currency.symbol; + } + } + return output; + } + function formatPercentage(n, format, roundingFunction) { + var space = '', + output, + value = n._value * 100; + if (format.indexOf(' %') > -1) { + space = ' '; + format = format.replace(' %', ''); + } else { + format = format.replace('%', ''); + } + output = formatNumber(value, format, roundingFunction); + if (output.indexOf(')') > -1) { + output = output.split(''); + output.splice(-1, 0, space + '%'); + output = output.join(''); + } else { + output = output + space + '%'; + } + return output; + } + function formatTime(n) { + var hours = Math.floor(n._value / 60 / 60), + minutes = Math.floor((n._value - (hours * 60 * 60)) / 60), + seconds = Math.round(n._value - (hours * 60 * 60) - (minutes * 60)); + return hours + ':' + ((minutes < 10) ? '0' + minutes : minutes) + ':' + ((seconds < 10) ? '0' + seconds : seconds); + } + function unformatTime(string) { + var timeArray = string.split(':'), + seconds = 0; + if (timeArray.length === 3) { + seconds = seconds + (Number(timeArray[0]) * 60 * 60); + seconds = seconds + (Number(timeArray[1]) * 60); + seconds = seconds + Number(timeArray[2]); + } else if (timeArray.length === 2) { + seconds = seconds + (Number(timeArray[0]) * 60); + seconds = seconds + Number(timeArray[1]); + } + return Number(seconds); + } + function formatNumber(value, format, roundingFunction) { + var negP = false, + signed = false, + optDec = false, + abbr = '', + abbrK = false, + abbrM = false, + abbrB = false, + abbrT = false, + abbrForce = false, + bytes = '', + ord = '', + abs = Math.abs(value), + suffixes = ['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'], + min, + max, + power, + w, + precision, + thousands, + d = '', + neg = false; + if (value === 0 && zeroFormat !== null) { + return zeroFormat; + } else { + if (format.indexOf('(') > -1) { + negP = true; + format = format.slice(1, -1); + } else if (format.indexOf('+') > -1) { + signed = true; + format = format.replace(/\+/g, ''); + } + if (format.indexOf('a') > -1) { + abbrK = format.indexOf('aK') >= 0; + abbrM = format.indexOf('aM') >= 0; + abbrB = format.indexOf('aB') >= 0; + abbrT = format.indexOf('aT') >= 0; + abbrForce = abbrK || abbrM || abbrB || abbrT; + if (format.indexOf(' a') > -1) { + abbr = ' '; + format = format.replace(' a', ''); + } else { + format = format.replace('a', ''); + } + if (abs >= Math.pow(10, 12) && !abbrForce || abbrT) { + abbr = abbr + languages[currentLanguage].abbreviations.trillion; + value = value / Math.pow(10, 12); + } else if (abs < Math.pow(10, 12) && abs >= Math.pow(10, 9) && !abbrForce || abbrB) { + abbr = abbr + languages[currentLanguage].abbreviations.billion; + value = value / Math.pow(10, 9); + } else if (abs < Math.pow(10, 9) && abs >= Math.pow(10, 6) && !abbrForce || abbrM) { + abbr = abbr + languages[currentLanguage].abbreviations.million; + value = value / Math.pow(10, 6); + } else if (abs < Math.pow(10, 6) && abs >= Math.pow(10, 3) && !abbrForce || abbrK) { + abbr = abbr + languages[currentLanguage].abbreviations.thousand; + value = value / Math.pow(10, 3); + } + } + if (format.indexOf('b') > -1) { + if (format.indexOf(' b') > -1) { + bytes = ' '; + format = format.replace(' b', ''); + } else { + format = format.replace('b', ''); + } + for (power = 0; power <= suffixes.length; power++) { + min = Math.pow(1024, power); + max = Math.pow(1024, power + 1); + if (value >= min && value < max) { + bytes = bytes + suffixes[power]; + if (min > 0) { + value = value / min; + } + break; + } + } + } + if (format.indexOf('o') > -1) { + if (format.indexOf(' o') > -1) { + ord = ' '; + format = format.replace(' o', ''); + } else { + format = format.replace('o', ''); + } + ord = ord + languages[currentLanguage].ordinal(value); + } + if (format.indexOf('[.]') > -1) { + optDec = true; + format = format.replace('[.]', '.'); + } + w = value.toString().split('.')[0]; + precision = format.split('.')[1]; + thousands = format.indexOf(','); + if (precision) { + if (precision.indexOf('[') > -1) { + precision = precision.replace(']', ''); + precision = precision.split('['); + d = toFixed(value, (precision[0].length + precision[1].length), roundingFunction, precision[1].length); + } else { + d = toFixed(value, precision.length, roundingFunction); + } + w = d.split('.')[0]; + if (d.split('.')[1].length) { + d = languages[currentLanguage].delimiters.decimal + d.split('.')[1]; + } else { + d = ''; + } + if (optDec && Number(d.slice(1)) === 0) { + d = ''; + } + } else { + w = toFixed(value, null, roundingFunction); + } + if (w.indexOf('-') > -1) { + w = w.slice(1); + neg = true; + } + if (thousands > -1) { + w = w.toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1' + languages[currentLanguage].delimiters.thousands); + } + if (format.indexOf('.') === 0) { + w = ''; + } + return ((negP && neg) ? '(' : '') + ((!negP && neg) ? '-' : '') + ((!neg && signed) ? '+' : '') + w + d + ((ord) ? ord : '') + ((abbr) ? abbr : '') + ((bytes) ? bytes : '') + ((negP && neg) ? ')' : ''); + } + } + numeral = function(input) { + if (numeral.isNumeral(input)) { + input = input.value(); + } else if (input === 0 || typeof input === 'undefined') { + input = 0; + } else if (!Number(input)) { + input = numeral.fn.unformat(input); + } + return new Numeral(Number(input)); + }; + numeral.version = VERSION; + numeral.isNumeral = function(obj) { + return obj instanceof Numeral; + }; + numeral.language = function(key, values) { + if (!key) { + return currentLanguage; + } + if (key && !values) { + if (!languages[key]) { + throw new Error('Unknown language : ' + key); + } + currentLanguage = key; + } + if (values || !languages[key]) { + loadLanguage(key, values); + } + return numeral; + }; + numeral.languageData = function(key) { + if (!key) { + return languages[currentLanguage]; + } + if (!languages[key]) { + throw new Error('Unknown language : ' + key); + } + return languages[key]; + }; + numeral.language('en', { + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function(number) { + var b = number % 10; + return (~~(number % 100 / 10) === 1) ? 'th' : (b === 1) ? 'st' : (b === 2) ? 'nd' : (b === 3) ? 'rd' : 'th'; + }, + currency: {symbol: '$'} + }); + numeral.zeroFormat = function(format) { + zeroFormat = typeof(format) === 'string' ? format : null; + }; + numeral.defaultFormat = function(format) { + defaultFormat = typeof(format) === 'string' ? format : '0.0'; + }; + numeral.validate = function(val, culture) { + var _decimalSep, + _thousandSep, + _currSymbol, + _valArray, + _abbrObj, + _thousandRegEx, + languageData, + temp; + if (typeof val !== 'string') { + val += ''; + if (console.warn) { + console.warn('Numeral.js: Value is not string. It has been co-erced to: ', val); + } + } + val = val.trim(); + if (val === '') { + return false; + } + val = val.replace(/^[+-]?/, ''); + try { + languageData = numeral.languageData(culture); + } catch (e) { + languageData = numeral.languageData(numeral.language()); + } + _currSymbol = languageData.currency.symbol; + _abbrObj = languageData.abbreviations; + _decimalSep = languageData.delimiters.decimal; + if (languageData.delimiters.thousands === '.') { + _thousandSep = '\\.'; + } else { + _thousandSep = languageData.delimiters.thousands; + } + temp = val.match(/^[^\d\.\,]+/); + if (temp !== null) { + val = val.substr(1); + if (temp[0] !== _currSymbol) { + return false; + } + } + temp = val.match(/[^\d]+$/); + if (temp !== null) { + val = val.slice(0, -1); + if (temp[0] !== _abbrObj.thousand && temp[0] !== _abbrObj.million && temp[0] !== _abbrObj.billion && temp[0] !== _abbrObj.trillion) { + return false; + } + } + if (!!val.match(/^\d+$/)) { + return true; + } + _thousandRegEx = new RegExp(_thousandSep + '{2}'); + if (!val.match(/[^\d.,]/g)) { + _valArray = val.split(_decimalSep); + if (_valArray.length > 2) { + return false; + } else { + if (_valArray.length < 2) { + return (!!_valArray[0].match(/^\d+.*\d$/) && !_valArray[0].match(_thousandRegEx)); + } else { + if (_valArray[0] === '') { + return (!_valArray[0].match(_thousandRegEx) && !!_valArray[1].match(/^\d+$/)); + } else if (_valArray[0].length === 1) { + return (!!_valArray[0].match(/^\d+$/) && !_valArray[0].match(_thousandRegEx) && !!_valArray[1].match(/^\d+$/)); + } else { + return (!!_valArray[0].match(/^\d+.*\d$/) && !_valArray[0].match(_thousandRegEx) && !!_valArray[1].match(/^\d+$/)); + } + } + } + } + return false; + }; + function loadLanguage(key, values) { + languages[key] = values; + } + if ('function' !== typeof Array.prototype.reduce) { + Array.prototype.reduce = function(callback, opt_initialValue) { + 'use strict'; + if (null === this || 'undefined' === typeof this) { + throw new TypeError('Array.prototype.reduce called on null or undefined'); + } + if ('function' !== typeof callback) { + throw new TypeError(callback + ' is not a function'); + } + var index, + value, + length = this.length >>> 0, + isValueSet = false; + if (1 < arguments.length) { + value = opt_initialValue; + isValueSet = true; + } + for (index = 0; length > index; ++index) { + if (this.hasOwnProperty(index)) { + if (isValueSet) { + value = callback(value, this[index], index, this); + } else { + value = this[index]; + isValueSet = true; + } + } + } + if (!isValueSet) { + throw new TypeError('Reduce of empty array with no initial value'); + } + return value; + }; + } + function multiplier(x) { + var parts = x.toString().split('.'); + if (parts.length < 2) { + return 1; + } + return Math.pow(10, parts[1].length); + } + function correctionFactor() { + var args = Array.prototype.slice.call(arguments); + return args.reduce(function(prev, next) { + var mp = multiplier(prev), + mn = multiplier(next); + return mp > mn ? mp : mn; + }, -Infinity); + } + numeral.fn = Numeral.prototype = { + clone: function() { + return numeral(this); + }, + format: function(inputString, roundingFunction) { + return formatNumeral(this, inputString ? inputString : defaultFormat, (roundingFunction !== undefined) ? roundingFunction : Math.round); + }, + unformat: function(inputString) { + if (Object.prototype.toString.call(inputString) === '[object Number]') { + return inputString; + } + return unformatNumeral(this, inputString ? inputString : defaultFormat); + }, + value: function() { + return this._value; + }, + valueOf: function() { + return this._value; + }, + set: function(value) { + this._value = Number(value); + return this; + }, + add: function(value) { + var corrFactor = correctionFactor.call(null, this._value, value); + function cback(accum, curr, currI, O) { + return accum + corrFactor * curr; + } + this._value = [this._value, value].reduce(cback, 0) / corrFactor; + return this; + }, + subtract: function(value) { + var corrFactor = correctionFactor.call(null, this._value, value); + function cback(accum, curr, currI, O) { + return accum - corrFactor * curr; + } + this._value = [value].reduce(cback, this._value * corrFactor) / corrFactor; + return this; + }, + multiply: function(value) { + function cback(accum, curr, currI, O) { + var corrFactor = correctionFactor(accum, curr); + return (accum * corrFactor) * (curr * corrFactor) / (corrFactor * corrFactor); + } + this._value = [this._value, value].reduce(cback, 1); + return this; + }, + divide: function(value) { + function cback(accum, curr, currI, O) { + var corrFactor = correctionFactor(accum, curr); + return (accum * corrFactor) / (curr * corrFactor); + } + this._value = [this._value, value].reduce(cback); + return this; + }, + difference: function(value) { + return Math.abs(numeral(this._value).subtract(value).value()); + } + }; + if (hasModule) { + module.exports = numeral; + } + if (typeof ender === 'undefined') { + this['numeral'] = numeral; + } + if (typeof define === 'function' && define.amd) { + define([], function() { + return numeral; + }); + } +}).call(window); + +//# +},{}],"pikaday":[function(require,module,exports){ +/*! + * Pikaday + * + * Copyright © 2014 David Bushell | BSD & MIT license | https://github.com/dbushell/Pikaday + */ + +(function (root, factory) +{ + 'use strict'; + + var moment; + if (typeof exports === 'object') { + // CommonJS module + // Load moment.js as an optional dependency + try { moment = require('moment'); } catch (e) {} + module.exports = factory(moment); + } else if (typeof define === 'function' && define.amd) { + // AMD. Register as an anonymous module. + define(function (req) + { + // Load moment.js as an optional dependency + var id = 'moment'; + try { moment = req(id); } catch (e) {} + return factory(moment); + }); + } else { + root.Pikaday = factory(root.moment); + } +}(this, function (moment) +{ + 'use strict'; + + /** + * feature detection and helper functions + */ + var hasMoment = typeof moment === 'function', + + hasEventListeners = !!window.addEventListener, + + document = window.document, + + sto = window.setTimeout, + + addEvent = function(el, e, callback, capture) + { + if (hasEventListeners) { + el.addEventListener(e, callback, !!capture); + } else { + el.attachEvent('on' + e, callback); + } + }, + + removeEvent = function(el, e, callback, capture) + { + if (hasEventListeners) { + el.removeEventListener(e, callback, !!capture); + } else { + el.detachEvent('on' + e, callback); + } + }, + + fireEvent = function(el, eventName, data) + { + var ev; + + if (document.createEvent) { + ev = document.createEvent('HTMLEvents'); + ev.initEvent(eventName, true, false); + ev = extend(ev, data); + el.dispatchEvent(ev); + } else if (document.createEventObject) { + ev = document.createEventObject(); + ev = extend(ev, data); + el.fireEvent('on' + eventName, ev); + } + }, + + trim = function(str) + { + return str.trim ? str.trim() : str.replace(/^\s+|\s+$/g,''); + }, + + hasClass = function(el, cn) + { + return (' ' + el.className + ' ').indexOf(' ' + cn + ' ') !== -1; + }, + + addClass = function(el, cn) + { + if (!hasClass(el, cn)) { + el.className = (el.className === '') ? cn : el.className + ' ' + cn; + } + }, + + removeClass = function(el, cn) + { + el.className = trim((' ' + el.className + ' ').replace(' ' + cn + ' ', ' ')); + }, + + isArray = function(obj) + { + return (/Array/).test(Object.prototype.toString.call(obj)); + }, + + isDate = function(obj) + { + return (/Date/).test(Object.prototype.toString.call(obj)) && !isNaN(obj.getTime()); + }, + + isWeekend = function(date) + { + var day = date.getDay(); + return day === 0 || day === 6; + }, + + isLeapYear = function(year) + { + // solution by Matti Virkkunen: http://stackoverflow.com/a/4881951 + return year % 4 === 0 && year % 100 !== 0 || year % 400 === 0; + }, + + getDaysInMonth = function(year, month) + { + return [31, isLeapYear(year) ? 29 : 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31][month]; + }, + + setToStartOfDay = function(date) + { + if (isDate(date)) date.setHours(0,0,0,0); + }, + + compareDates = function(a,b) + { + // weak date comparison (use setToStartOfDay(date) to ensure correct result) + return a.getTime() === b.getTime(); + }, + + extend = function(to, from, overwrite) + { + var prop, hasProp; + for (prop in from) { + hasProp = to[prop] !== undefined; + if (hasProp && typeof from[prop] === 'object' && from[prop] !== null && from[prop].nodeName === undefined) { + if (isDate(from[prop])) { + if (overwrite) { + to[prop] = new Date(from[prop].getTime()); + } + } + else if (isArray(from[prop])) { + if (overwrite) { + to[prop] = from[prop].slice(0); + } + } else { + to[prop] = extend({}, from[prop], overwrite); + } + } else if (overwrite || !hasProp) { + to[prop] = from[prop]; + } + } + return to; + }, + + adjustCalendar = function(calendar) { + if (calendar.month < 0) { + calendar.year -= Math.ceil(Math.abs(calendar.month)/12); + calendar.month += 12; + } + if (calendar.month > 11) { + calendar.year += Math.floor(Math.abs(calendar.month)/12); + calendar.month -= 12; + } + return calendar; + }, + + /** + * defaults and localisation + */ + defaults = { + + // bind the picker to a form field + field: null, + + // automatically show/hide the picker on `field` focus (default `true` if `field` is set) + bound: undefined, + + // position of the datepicker, relative to the field (default to bottom & left) + // ('bottom' & 'left' keywords are not used, 'top' & 'right' are modifier on the bottom/left position) + position: 'bottom left', + + // automatically fit in the viewport even if it means repositioning from the position option + reposition: true, + + // the default output format for `.toString()` and `field` value + format: 'YYYY-MM-DD', + + // the initial date to view when first opened + defaultDate: null, + + // make the `defaultDate` the initial selected value + setDefaultDate: false, + + // first day of week (0: Sunday, 1: Monday etc) + firstDay: 0, + + // the minimum/earliest date that can be selected + minDate: null, + // the maximum/latest date that can be selected + maxDate: null, + + // number of years either side, or array of upper/lower range + yearRange: 10, + + // show week numbers at head of row + showWeekNumber: false, + + // used internally (don't config outside) + minYear: 0, + maxYear: 9999, + minMonth: undefined, + maxMonth: undefined, + + startRange: null, + endRange: null, + + isRTL: false, + + // Additional text to append to the year in the calendar title + yearSuffix: '', + + // Render the month after year in the calendar title + showMonthAfterYear: false, + + // how many months are visible + numberOfMonths: 1, + + // when numberOfMonths is used, this will help you to choose where the main calendar will be (default `left`, can be set to `right`) + // only used for the first display or when a selected date is not visible + mainCalendar: 'left', + + // Specify a DOM element to render the calendar in + container: undefined, + + // internationalization + i18n: { + previousMonth : 'Previous Month', + nextMonth : 'Next Month', + months : ['January','February','March','April','May','June','July','August','September','October','November','December'], + weekdays : ['Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday'], + weekdaysShort : ['Sun','Mon','Tue','Wed','Thu','Fri','Sat'] + }, + + // Theme Classname + theme: null, + + // callback function + onSelect: null, + onOpen: null, + onClose: null, + onDraw: null + }, + + + /** + * templating functions to abstract HTML rendering + */ + renderDayName = function(opts, day, abbr) + { + day += opts.firstDay; + while (day >= 7) { + day -= 7; + } + return abbr ? opts.i18n.weekdaysShort[day] : opts.i18n.weekdays[day]; + }, + + renderDay = function(opts) + { + if (opts.isEmpty) { + return ''; + } + var arr = []; + if (opts.isDisabled) { + arr.push('is-disabled'); + } + if (opts.isToday) { + arr.push('is-today'); + } + if (opts.isSelected) { + arr.push('is-selected'); + } + if (opts.isInRange) { + arr.push('is-inrange'); + } + if (opts.isStartRange) { + arr.push('is-startrange'); + } + if (opts.isEndRange) { + arr.push('is-endrange'); + } + return '' + + '' + + ''; + }, + + renderWeek = function (d, m, y) { + // Lifted from http://javascript.about.com/library/blweekyear.htm, lightly modified. + var onejan = new Date(y, 0, 1), + weekNum = Math.ceil((((new Date(y, m, d) - onejan) / 86400000) + onejan.getDay()+1)/7); + return '' + weekNum + ''; + }, + + renderRow = function(days, isRTL) + { + return '' + (isRTL ? days.reverse() : days).join('') + ''; + }, + + renderBody = function(rows) + { + return '' + rows.join('') + ''; + }, + + renderHead = function(opts) + { + var i, arr = []; + if (opts.showWeekNumber) { + arr.push(''); + } + for (i = 0; i < 7; i++) { + arr.push('' + renderDayName(opts, i, true) + ''); + } + return '' + (opts.isRTL ? arr.reverse() : arr).join('') + ''; + }, + + renderTitle = function(instance, c, year, month, refYear) + { + var i, j, arr, + opts = instance._o, + isMinYear = year === opts.minYear, + isMaxYear = year === opts.maxYear, + html = '
', + monthHtml, + yearHtml, + prev = true, + next = true; + + for (arr = [], i = 0; i < 12; i++) { + arr.push(''); + } + monthHtml = '
' + opts.i18n.months[month] + '
'; + + if (isArray(opts.yearRange)) { + i = opts.yearRange[0]; + j = opts.yearRange[1] + 1; + } else { + i = year - opts.yearRange; + j = 1 + year + opts.yearRange; + } + + for (arr = []; i < j && i <= opts.maxYear; i++) { + if (i >= opts.minYear) { + arr.push(''); + } + } + yearHtml = '
' + year + opts.yearSuffix + '
'; + + if (opts.showMonthAfterYear) { + html += yearHtml + monthHtml; + } else { + html += monthHtml + yearHtml; + } + + if (isMinYear && (month === 0 || opts.minMonth >= month)) { + prev = false; + } + + if (isMaxYear && (month === 11 || opts.maxMonth <= month)) { + next = false; + } + + if (c === 0) { + html += ''; + } + if (c === (instance._o.numberOfMonths - 1) ) { + html += ''; + } + + return html += '
'; + }, + + renderTable = function(opts, data) + { + return '' + renderHead(opts) + renderBody(data) + '
'; + }, + + + /** + * Pikaday constructor + */ + Pikaday = function(options) + { + var self = this, + opts = self.config(options); + + self._onMouseDown = function(e) + { + if (!self._v) { + return; + } + e = e || window.event; + var target = e.target || e.srcElement; + if (!target) { + return; + } + + if (!hasClass(target.parentNode, 'is-disabled')) { + if (hasClass(target, 'pika-button') && !hasClass(target, 'is-empty')) { + self.setDate(new Date(target.getAttribute('data-pika-year'), target.getAttribute('data-pika-month'), target.getAttribute('data-pika-day'))); + if (opts.bound) { + sto(function() { + self.hide(); + if (opts.field) { + opts.field.blur(); + } + }, 100); + } + return; + } + else if (hasClass(target, 'pika-prev')) { + self.prevMonth(); + } + else if (hasClass(target, 'pika-next')) { + self.nextMonth(); + } + } + if (!hasClass(target, 'pika-select')) { + if (e.preventDefault) { + e.preventDefault(); + } else { + e.returnValue = false; + return false; + } + } else { + self._c = true; + } + }; + + self._onChange = function(e) + { + e = e || window.event; + var target = e.target || e.srcElement; + if (!target) { + return; + } + if (hasClass(target, 'pika-select-month')) { + self.gotoMonth(target.value); + } + else if (hasClass(target, 'pika-select-year')) { + self.gotoYear(target.value); + } + }; + + self._onInputChange = function(e) + { + var date; + + if (e.firedBy === self) { + return; + } + if (hasMoment) { + date = moment(opts.field.value, opts.format); + date = (date && date.isValid()) ? date.toDate() : null; + } + else { + date = new Date(Date.parse(opts.field.value)); + } + if (isDate(date)) { + self.setDate(date); + } + if (!self._v) { + self.show(); + } + }; + + self._onInputFocus = function() + { + self.show(); + }; + + self._onInputClick = function() + { + self.show(); + }; + + self._onInputBlur = function() + { + // IE allows pika div to gain focus; catch blur the input field + var pEl = document.activeElement; + do { + if (hasClass(pEl, 'pika-single')) { + return; + } + } + while ((pEl = pEl.parentNode)); + + if (!self._c) { + self._b = sto(function() { + self.hide(); + }, 50); + } + self._c = false; + }; + + self._onClick = function(e) + { + e = e || window.event; + var target = e.target || e.srcElement, + pEl = target; + if (!target) { + return; + } + if (!hasEventListeners && hasClass(target, 'pika-select')) { + if (!target.onchange) { + target.setAttribute('onchange', 'return;'); + addEvent(target, 'change', self._onChange); + } + } + do { + if (hasClass(pEl, 'pika-single') || pEl === opts.trigger) { + return; + } + } + while ((pEl = pEl.parentNode)); + if (self._v && target !== opts.trigger && pEl !== opts.trigger) { + self.hide(); + } + }; + + self.el = document.createElement('div'); + self.el.className = 'pika-single' + (opts.isRTL ? ' is-rtl' : '') + (opts.theme ? ' ' + opts.theme : ''); + + addEvent(self.el, 'ontouchend' in document ? 'touchend' : 'mousedown', self._onMouseDown, true); + addEvent(self.el, 'change', self._onChange); + + if (opts.field) { + if (opts.container) { + opts.container.appendChild(self.el); + } else if (opts.bound) { + document.body.appendChild(self.el); + } else { + opts.field.parentNode.insertBefore(self.el, opts.field.nextSibling); + } + addEvent(opts.field, 'change', self._onInputChange); + + if (!opts.defaultDate) { + if (hasMoment && opts.field.value) { + opts.defaultDate = moment(opts.field.value, opts.format).toDate(); + } else { + opts.defaultDate = new Date(Date.parse(opts.field.value)); + } + opts.setDefaultDate = true; + } + } + + var defDate = opts.defaultDate; + + if (isDate(defDate)) { + if (opts.setDefaultDate) { + self.setDate(defDate, true); + } else { + self.gotoDate(defDate); + } + } else { + self.gotoDate(new Date()); + } + + if (opts.bound) { + this.hide(); + self.el.className += ' is-bound'; + addEvent(opts.trigger, 'click', self._onInputClick); + addEvent(opts.trigger, 'focus', self._onInputFocus); + addEvent(opts.trigger, 'blur', self._onInputBlur); + } else { + this.show(); + } + }; + + + /** + * public Pikaday API + */ + Pikaday.prototype = { + + + /** + * configure functionality + */ + config: function(options) + { + if (!this._o) { + this._o = extend({}, defaults, true); + } + + var opts = extend(this._o, options, true); + + opts.isRTL = !!opts.isRTL; + + opts.field = (opts.field && opts.field.nodeName) ? opts.field : null; + + opts.theme = (typeof opts.theme) === 'string' && opts.theme ? opts.theme : null; + + opts.bound = !!(opts.bound !== undefined ? opts.field && opts.bound : opts.field); + + opts.trigger = (opts.trigger && opts.trigger.nodeName) ? opts.trigger : opts.field; + + opts.disableWeekends = !!opts.disableWeekends; + + opts.disableDayFn = (typeof opts.disableDayFn) === 'function' ? opts.disableDayFn : null; + + var nom = parseInt(opts.numberOfMonths, 10) || 1; + opts.numberOfMonths = nom > 4 ? 4 : nom; + + if (!isDate(opts.minDate)) { + opts.minDate = false; + } + if (!isDate(opts.maxDate)) { + opts.maxDate = false; + } + if ((opts.minDate && opts.maxDate) && opts.maxDate < opts.minDate) { + opts.maxDate = opts.minDate = false; + } + if (opts.minDate) { + this.setMinDate(opts.minDate); + } + if (opts.maxDate) { + setToStartOfDay(opts.maxDate); + opts.maxYear = opts.maxDate.getFullYear(); + opts.maxMonth = opts.maxDate.getMonth(); + } + + if (isArray(opts.yearRange)) { + var fallback = new Date().getFullYear() - 10; + opts.yearRange[0] = parseInt(opts.yearRange[0], 10) || fallback; + opts.yearRange[1] = parseInt(opts.yearRange[1], 10) || fallback; + } else { + opts.yearRange = Math.abs(parseInt(opts.yearRange, 10)) || defaults.yearRange; + if (opts.yearRange > 100) { + opts.yearRange = 100; + } + } + + return opts; + }, + + /** + * return a formatted string of the current selection (using Moment.js if available) + */ + toString: function(format) + { + return !isDate(this._d) ? '' : hasMoment ? moment(this._d).format(format || this._o.format) : this._d.toDateString(); + }, + + /** + * return a Moment.js object of the current selection (if available) + */ + getMoment: function() + { + return hasMoment ? moment(this._d) : null; + }, + + /** + * set the current selection from a Moment.js object (if available) + */ + setMoment: function(date, preventOnSelect) + { + if (hasMoment && moment.isMoment(date)) { + this.setDate(date.toDate(), preventOnSelect); + } + }, + + /** + * return a Date object of the current selection + */ + getDate: function() + { + return isDate(this._d) ? new Date(this._d.getTime()) : null; + }, + + /** + * set the current selection + */ + setDate: function(date, preventOnSelect) + { + if (!date) { + this._d = null; + + if (this._o.field) { + this._o.field.value = ''; + fireEvent(this._o.field, 'change', { firedBy: this }); + } + + return this.draw(); + } + if (typeof date === 'string') { + date = new Date(Date.parse(date)); + } + if (!isDate(date)) { + return; + } + + var min = this._o.minDate, + max = this._o.maxDate; + + if (isDate(min) && date < min) { + date = min; + } else if (isDate(max) && date > max) { + date = max; + } + + this._d = new Date(date.getTime()); + setToStartOfDay(this._d); + this.gotoDate(this._d); + + if (this._o.field) { + this._o.field.value = this.toString(); + fireEvent(this._o.field, 'change', { firedBy: this }); + } + if (!preventOnSelect && typeof this._o.onSelect === 'function') { + this._o.onSelect.call(this, this.getDate()); + } + }, + + /** + * change view to a specific date + */ + gotoDate: function(date) + { + var newCalendar = true; + + if (!isDate(date)) { + return; + } + + if (this.calendars) { + var firstVisibleDate = new Date(this.calendars[0].year, this.calendars[0].month, 1), + lastVisibleDate = new Date(this.calendars[this.calendars.length-1].year, this.calendars[this.calendars.length-1].month, 1), + visibleDate = date.getTime(); + // get the end of the month + lastVisibleDate.setMonth(lastVisibleDate.getMonth()+1); + lastVisibleDate.setDate(lastVisibleDate.getDate()-1); + newCalendar = (visibleDate < firstVisibleDate.getTime() || lastVisibleDate.getTime() < visibleDate); + } + + if (newCalendar) { + this.calendars = [{ + month: date.getMonth(), + year: date.getFullYear() + }]; + if (this._o.mainCalendar === 'right') { + this.calendars[0].month += 1 - this._o.numberOfMonths; + } + } + + this.adjustCalendars(); + }, + + adjustCalendars: function() { + this.calendars[0] = adjustCalendar(this.calendars[0]); + for (var c = 1; c < this._o.numberOfMonths; c++) { + this.calendars[c] = adjustCalendar({ + month: this.calendars[0].month + c, + year: this.calendars[0].year + }); + } + this.draw(); + }, + + gotoToday: function() + { + this.gotoDate(new Date()); + }, + + /** + * change view to a specific month (zero-index, e.g. 0: January) + */ + gotoMonth: function(month) + { + if (!isNaN(month)) { + this.calendars[0].month = parseInt(month, 10); + this.adjustCalendars(); + } + }, + + nextMonth: function() + { + this.calendars[0].month++; + this.adjustCalendars(); + }, + + prevMonth: function() + { + this.calendars[0].month--; + this.adjustCalendars(); + }, + + /** + * change view to a specific full year (e.g. "2012") + */ + gotoYear: function(year) + { + if (!isNaN(year)) { + this.calendars[0].year = parseInt(year, 10); + this.adjustCalendars(); + } + }, + + /** + * change the minDate + */ + setMinDate: function(value) + { + setToStartOfDay(value); + this._o.minDate = value; + this._o.minYear = value.getFullYear(); + this._o.minMonth = value.getMonth(); + }, + + /** + * change the maxDate + */ + setMaxDate: function(value) + { + this._o.maxDate = value; + }, + + setStartRange: function(value) + { + this._o.startRange = value; + }, + + setEndRange: function(value) + { + this._o.endRange = value; + }, + + /** + * refresh the HTML + */ + draw: function(force) + { + if (!this._v && !force) { + return; + } + var opts = this._o, + minYear = opts.minYear, + maxYear = opts.maxYear, + minMonth = opts.minMonth, + maxMonth = opts.maxMonth, + html = ''; + + if (this._y <= minYear) { + this._y = minYear; + if (!isNaN(minMonth) && this._m < minMonth) { + this._m = minMonth; + } + } + if (this._y >= maxYear) { + this._y = maxYear; + if (!isNaN(maxMonth) && this._m > maxMonth) { + this._m = maxMonth; + } + } + + for (var c = 0; c < opts.numberOfMonths; c++) { + html += '
' + renderTitle(this, c, this.calendars[c].year, this.calendars[c].month, this.calendars[0].year) + this.render(this.calendars[c].year, this.calendars[c].month) + '
'; + } + + this.el.innerHTML = html; + + if (opts.bound) { + if(opts.field.type !== 'hidden') { + sto(function() { + opts.trigger.focus(); + }, 1); + } + } + + if (typeof this._o.onDraw === 'function') { + var self = this; + sto(function() { + self._o.onDraw.call(self); + }, 0); + } + }, + + adjustPosition: function() + { + var field, pEl, width, height, viewportWidth, viewportHeight, scrollTop, left, top, clientRect; + + if (this._o.container) return; + + this.el.style.position = 'absolute'; + + field = this._o.trigger; + pEl = field; + width = this.el.offsetWidth; + height = this.el.offsetHeight; + viewportWidth = window.innerWidth || document.documentElement.clientWidth; + viewportHeight = window.innerHeight || document.documentElement.clientHeight; + scrollTop = window.pageYOffset || document.body.scrollTop || document.documentElement.scrollTop; + + if (typeof field.getBoundingClientRect === 'function') { + clientRect = field.getBoundingClientRect(); + left = clientRect.left + window.pageXOffset; + top = clientRect.bottom + window.pageYOffset; + } else { + left = pEl.offsetLeft; + top = pEl.offsetTop + pEl.offsetHeight; + while((pEl = pEl.offsetParent)) { + left += pEl.offsetLeft; + top += pEl.offsetTop; + } + } + + // default position is bottom & left + if ((this._o.reposition && left + width > viewportWidth) || + ( + this._o.position.indexOf('right') > -1 && + left - width + field.offsetWidth > 0 + ) + ) { + left = left - width + field.offsetWidth; + } + if ((this._o.reposition && top + height > viewportHeight + scrollTop) || + ( + this._o.position.indexOf('top') > -1 && + top - height - field.offsetHeight > 0 + ) + ) { + top = top - height - field.offsetHeight; + } + + this.el.style.left = left + 'px'; + this.el.style.top = top + 'px'; + }, + + /** + * render HTML for a particular month + */ + render: function(year, month) + { + var opts = this._o, + now = new Date(), + days = getDaysInMonth(year, month), + before = new Date(year, month, 1).getDay(), + data = [], + row = []; + setToStartOfDay(now); + if (opts.firstDay > 0) { + before -= opts.firstDay; + if (before < 0) { + before += 7; + } + } + var cells = days + before, + after = cells; + while(after > 7) { + after -= 7; + } + cells += 7 - after; + for (var i = 0, r = 0; i < cells; i++) + { + var dayConfig, + day = new Date(year, month, 1 + (i - before)), + isSelected = isDate(this._d) ? compareDates(day, this._d) : false, + isToday = compareDates(day, now), + isEmpty = i < before || i >= (days + before), + isStartRange = opts.startRange && compareDates(opts.startRange, day), + isEndRange = opts.endRange && compareDates(opts.endRange, day), + isInRange = opts.startRange && opts.endRange && opts.startRange < day && day < opts.endRange, + isDisabled = (opts.minDate && day < opts.minDate) || + (opts.maxDate && day > opts.maxDate) || + (opts.disableWeekends && isWeekend(day)) || + (opts.disableDayFn && opts.disableDayFn(day)), + dayConfig = { + day: 1 + (i - before), + month: month, + year: year, + isSelected: isSelected, + isToday: isToday, + isDisabled: isDisabled, + isEmpty: isEmpty, + isStartRange: isStartRange, + isEndRange: isEndRange, + isInRange: isInRange + }; + + row.push(renderDay(dayConfig)); + + if (++r === 7) { + if (opts.showWeekNumber) { + row.unshift(renderWeek(i - before, month, year)); + } + data.push(renderRow(row, opts.isRTL)); + row = []; + r = 0; + } + } + return renderTable(opts, data); + }, + + isVisible: function() + { + return this._v; + }, + + show: function() + { + if (!this._v) { + removeClass(this.el, 'is-hidden'); + this._v = true; + this.draw(); + if (this._o.bound) { + addEvent(document, 'click', this._onClick); + this.adjustPosition(); + } + if (typeof this._o.onOpen === 'function') { + this._o.onOpen.call(this); + } + } + }, + + hide: function() + { + var v = this._v; + if (v !== false) { + if (this._o.bound) { + removeEvent(document, 'click', this._onClick); + } + this.el.style.position = 'static'; // reset + this.el.style.left = 'auto'; + this.el.style.top = 'auto'; + addClass(this.el, 'is-hidden'); + this._v = false; + if (v !== undefined && typeof this._o.onClose === 'function') { + this._o.onClose.call(this); + } + } + }, + + /** + * GAME OVER + */ + destroy: function() + { + this.hide(); + removeEvent(this.el, 'mousedown', this._onMouseDown, true); + removeEvent(this.el, 'change', this._onChange); + if (this._o.field) { + removeEvent(this._o.field, 'change', this._onInputChange); + if (this._o.bound) { + removeEvent(this._o.trigger, 'click', this._onInputClick); + removeEvent(this._o.trigger, 'focus', this._onInputFocus); + removeEvent(this._o.trigger, 'blur', this._onInputBlur); + } + } + if (this.el.parentNode) { + this.el.parentNode.removeChild(this.el); + } + } + + }; + + return Pikaday; + +})); + +},{"moment":"moment"}],"zeroclipboard":[function(require,module,exports){ +/*! + * ZeroClipboard + * The ZeroClipboard library provides an easy way to copy text to the clipboard using an invisible Adobe Flash movie and a JavaScript interface. + * Copyright (c) 2009-2014 Jon Rohan, James M. Greene + * Licensed MIT + * http://zeroclipboard.org/ + * v2.2.0 + */ +(function(window, undefined) { + "use strict"; + /** + * Store references to critically important global functions that may be + * overridden on certain web pages. + */ + var _window = window, _document = _window.document, _navigator = _window.navigator, _setTimeout = _window.setTimeout, _clearTimeout = _window.clearTimeout, _setInterval = _window.setInterval, _clearInterval = _window.clearInterval, _getComputedStyle = _window.getComputedStyle, _encodeURIComponent = _window.encodeURIComponent, _ActiveXObject = _window.ActiveXObject, _Error = _window.Error, _parseInt = _window.Number.parseInt || _window.parseInt, _parseFloat = _window.Number.parseFloat || _window.parseFloat, _isNaN = _window.Number.isNaN || _window.isNaN, _now = _window.Date.now, _keys = _window.Object.keys, _defineProperty = _window.Object.defineProperty, _hasOwn = _window.Object.prototype.hasOwnProperty, _slice = _window.Array.prototype.slice, _unwrap = function() { + var unwrapper = function(el) { + return el; + }; + if (typeof _window.wrap === "function" && typeof _window.unwrap === "function") { + try { + var div = _document.createElement("div"); + var unwrappedDiv = _window.unwrap(div); + if (div.nodeType === 1 && unwrappedDiv && unwrappedDiv.nodeType === 1) { + unwrapper = _window.unwrap; + } + } catch (e) {} + } + return unwrapper; + }(); + /** + * Convert an `arguments` object into an Array. + * + * @returns The arguments as an Array + * @private + */ + var _args = function(argumentsObj) { + return _slice.call(argumentsObj, 0); + }; + /** + * Shallow-copy the owned, enumerable properties of one object over to another, similar to jQuery's `$.extend`. + * + * @returns The target object, augmented + * @private + */ + var _extend = function() { + var i, len, arg, prop, src, copy, args = _args(arguments), target = args[0] || {}; + for (i = 1, len = args.length; i < len; i++) { + if ((arg = args[i]) != null) { + for (prop in arg) { + if (_hasOwn.call(arg, prop)) { + src = target[prop]; + copy = arg[prop]; + if (target !== copy && copy !== undefined) { + target[prop] = copy; + } + } + } + } + } + return target; + }; + /** + * Return a deep copy of the source object or array. + * + * @returns Object or Array + * @private + */ + var _deepCopy = function(source) { + var copy, i, len, prop; + if (typeof source !== "object" || source == null || typeof source.nodeType === "number") { + copy = source; + } else if (typeof source.length === "number") { + copy = []; + for (i = 0, len = source.length; i < len; i++) { + if (_hasOwn.call(source, i)) { + copy[i] = _deepCopy(source[i]); + } + } + } else { + copy = {}; + for (prop in source) { + if (_hasOwn.call(source, prop)) { + copy[prop] = _deepCopy(source[prop]); + } + } + } + return copy; + }; + /** + * Makes a shallow copy of `obj` (like `_extend`) but filters its properties based on a list of `keys` to keep. + * The inverse of `_omit`, mostly. The big difference is that these properties do NOT need to be enumerable to + * be kept. + * + * @returns A new filtered object. + * @private + */ + var _pick = function(obj, keys) { + var newObj = {}; + for (var i = 0, len = keys.length; i < len; i++) { + if (keys[i] in obj) { + newObj[keys[i]] = obj[keys[i]]; + } + } + return newObj; + }; + /** + * Makes a shallow copy of `obj` (like `_extend`) but filters its properties based on a list of `keys` to omit. + * The inverse of `_pick`. + * + * @returns A new filtered object. + * @private + */ + var _omit = function(obj, keys) { + var newObj = {}; + for (var prop in obj) { + if (keys.indexOf(prop) === -1) { + newObj[prop] = obj[prop]; + } + } + return newObj; + }; + /** + * Remove all owned, enumerable properties from an object. + * + * @returns The original object without its owned, enumerable properties. + * @private + */ + var _deleteOwnProperties = function(obj) { + if (obj) { + for (var prop in obj) { + if (_hasOwn.call(obj, prop)) { + delete obj[prop]; + } + } + } + return obj; + }; + /** + * Determine if an element is contained within another element. + * + * @returns Boolean + * @private + */ + var _containedBy = function(el, ancestorEl) { + if (el && el.nodeType === 1 && el.ownerDocument && ancestorEl && (ancestorEl.nodeType === 1 && ancestorEl.ownerDocument && ancestorEl.ownerDocument === el.ownerDocument || ancestorEl.nodeType === 9 && !ancestorEl.ownerDocument && ancestorEl === el.ownerDocument)) { + do { + if (el === ancestorEl) { + return true; + } + el = el.parentNode; + } while (el); + } + return false; + }; + /** + * Get the URL path's parent directory. + * + * @returns String or `undefined` + * @private + */ + var _getDirPathOfUrl = function(url) { + var dir; + if (typeof url === "string" && url) { + dir = url.split("#")[0].split("?")[0]; + dir = url.slice(0, url.lastIndexOf("/") + 1); + } + return dir; + }; + /** + * Get the current script's URL by throwing an `Error` and analyzing it. + * + * @returns String or `undefined` + * @private + */ + var _getCurrentScriptUrlFromErrorStack = function(stack) { + var url, matches; + if (typeof stack === "string" && stack) { + matches = stack.match(/^(?:|[^:@]*@|.+\)@(?=http[s]?|file)|.+?\s+(?: at |@)(?:[^:\(]+ )*[\(]?)((?:http[s]?|file):\/\/[\/]?.+?\/[^:\)]*?)(?::\d+)(?::\d+)?/); + if (matches && matches[1]) { + url = matches[1]; + } else { + matches = stack.match(/\)@((?:http[s]?|file):\/\/[\/]?.+?\/[^:\)]*?)(?::\d+)(?::\d+)?/); + if (matches && matches[1]) { + url = matches[1]; + } + } + } + return url; + }; + /** + * Get the current script's URL by throwing an `Error` and analyzing it. + * + * @returns String or `undefined` + * @private + */ + var _getCurrentScriptUrlFromError = function() { + var url, err; + try { + throw new _Error(); + } catch (e) { + err = e; + } + if (err) { + url = err.sourceURL || err.fileName || _getCurrentScriptUrlFromErrorStack(err.stack); + } + return url; + }; + /** + * Get the current script's URL. + * + * @returns String or `undefined` + * @private + */ + var _getCurrentScriptUrl = function() { + var jsPath, scripts, i; + if (_document.currentScript && (jsPath = _document.currentScript.src)) { + return jsPath; + } + scripts = _document.getElementsByTagName("script"); + if (scripts.length === 1) { + return scripts[0].src || undefined; + } + if ("readyState" in scripts[0]) { + for (i = scripts.length; i--; ) { + if (scripts[i].readyState === "interactive" && (jsPath = scripts[i].src)) { + return jsPath; + } + } + } + if (_document.readyState === "loading" && (jsPath = scripts[scripts.length - 1].src)) { + return jsPath; + } + if (jsPath = _getCurrentScriptUrlFromError()) { + return jsPath; + } + return undefined; + }; + /** + * Get the unanimous parent directory of ALL script tags. + * If any script tags are either (a) inline or (b) from differing parent + * directories, this method must return `undefined`. + * + * @returns String or `undefined` + * @private + */ + var _getUnanimousScriptParentDir = function() { + var i, jsDir, jsPath, scripts = _document.getElementsByTagName("script"); + for (i = scripts.length; i--; ) { + if (!(jsPath = scripts[i].src)) { + jsDir = null; + break; + } + jsPath = _getDirPathOfUrl(jsPath); + if (jsDir == null) { + jsDir = jsPath; + } else if (jsDir !== jsPath) { + jsDir = null; + break; + } + } + return jsDir || undefined; + }; + /** + * Get the presumed location of the "ZeroClipboard.swf" file, based on the location + * of the executing JavaScript file (e.g. "ZeroClipboard.js", etc.). + * + * @returns String + * @private + */ + var _getDefaultSwfPath = function() { + var jsDir = _getDirPathOfUrl(_getCurrentScriptUrl()) || _getUnanimousScriptParentDir() || ""; + return jsDir + "ZeroClipboard.swf"; + }; + /** + * Keep track of if the page is framed (in an `iframe`). This can never change. + * @private + */ + var _pageIsFramed = function() { + return window.opener == null && (!!window.top && window != window.top || !!window.parent && window != window.parent); + }(); + /** + * Keep track of the state of the Flash object. + * @private + */ + var _flashState = { + bridge: null, + version: "0.0.0", + pluginType: "unknown", + disabled: null, + outdated: null, + sandboxed: null, + unavailable: null, + degraded: null, + deactivated: null, + overdue: null, + ready: null + }; + /** + * The minimum Flash Player version required to use ZeroClipboard completely. + * @readonly + * @private + */ + var _minimumFlashVersion = "11.0.0"; + /** + * The ZeroClipboard library version number, as reported by Flash, at the time the SWF was compiled. + */ + var _zcSwfVersion; + /** + * Keep track of all event listener registrations. + * @private + */ + var _handlers = {}; + /** + * Keep track of the currently activated element. + * @private + */ + var _currentElement; + /** + * Keep track of the element that was activated when a `copy` process started. + * @private + */ + var _copyTarget; + /** + * Keep track of data for the pending clipboard transaction. + * @private + */ + var _clipData = {}; + /** + * Keep track of data formats for the pending clipboard transaction. + * @private + */ + var _clipDataFormatMap = null; + /** + * Keep track of the Flash availability check timeout. + * @private + */ + var _flashCheckTimeout = 0; + /** + * Keep track of SWF network errors interval polling. + * @private + */ + var _swfFallbackCheckInterval = 0; + /** + * The `message` store for events + * @private + */ + var _eventMessages = { + ready: "Flash communication is established", + error: { + "flash-disabled": "Flash is disabled or not installed. May also be attempting to run Flash in a sandboxed iframe, which is impossible.", + "flash-outdated": "Flash is too outdated to support ZeroClipboard", + "flash-sandboxed": "Attempting to run Flash in a sandboxed iframe, which is impossible", + "flash-unavailable": "Flash is unable to communicate bidirectionally with JavaScript", + "flash-degraded": "Flash is unable to preserve data fidelity when communicating with JavaScript", + "flash-deactivated": "Flash is too outdated for your browser and/or is configured as click-to-activate.\nThis may also mean that the ZeroClipboard SWF object could not be loaded, so please check your `swfPath` configuration and/or network connectivity.\nMay also be attempting to run Flash in a sandboxed iframe, which is impossible.", + "flash-overdue": "Flash communication was established but NOT within the acceptable time limit", + "version-mismatch": "ZeroClipboard JS version number does not match ZeroClipboard SWF version number", + "clipboard-error": "At least one error was thrown while ZeroClipboard was attempting to inject your data into the clipboard", + "config-mismatch": "ZeroClipboard configuration does not match Flash's reality", + "swf-not-found": "The ZeroClipboard SWF object could not be loaded, so please check your `swfPath` configuration and/or network connectivity" + } + }; + /** + * The `name`s of `error` events that can only occur is Flash has at least + * been able to load the SWF successfully. + * @private + */ + var _errorsThatOnlyOccurAfterFlashLoads = [ "flash-unavailable", "flash-degraded", "flash-overdue", "version-mismatch", "config-mismatch", "clipboard-error" ]; + /** + * The `name`s of `error` events that should likely result in the `_flashState` + * variable's property values being updated. + * @private + */ + var _flashStateErrorNames = [ "flash-disabled", "flash-outdated", "flash-sandboxed", "flash-unavailable", "flash-degraded", "flash-deactivated", "flash-overdue" ]; + /** + * A RegExp to match the `name` property of `error` events related to Flash. + * @private + */ + var _flashStateErrorNameMatchingRegex = new RegExp("^flash-(" + _flashStateErrorNames.map(function(errorName) { + return errorName.replace(/^flash-/, ""); + }).join("|") + ")$"); + /** + * A RegExp to match the `name` property of `error` events related to Flash, + * which is enabled. + * @private + */ + var _flashStateEnabledErrorNameMatchingRegex = new RegExp("^flash-(" + _flashStateErrorNames.slice(1).map(function(errorName) { + return errorName.replace(/^flash-/, ""); + }).join("|") + ")$"); + /** + * ZeroClipboard configuration defaults for the Core module. + * @private + */ + var _globalConfig = { + swfPath: _getDefaultSwfPath(), + trustedDomains: window.location.host ? [ window.location.host ] : [], + cacheBust: true, + forceEnhancedClipboard: false, + flashLoadTimeout: 3e4, + autoActivate: true, + bubbleEvents: true, + containerId: "global-zeroclipboard-html-bridge", + containerClass: "global-zeroclipboard-container", + swfObjectId: "global-zeroclipboard-flash-bridge", + hoverClass: "zeroclipboard-is-hover", + activeClass: "zeroclipboard-is-active", + forceHandCursor: false, + title: null, + zIndex: 999999999 + }; + /** + * The underlying implementation of `ZeroClipboard.config`. + * @private + */ + var _config = function(options) { + if (typeof options === "object" && options !== null) { + for (var prop in options) { + if (_hasOwn.call(options, prop)) { + if (/^(?:forceHandCursor|title|zIndex|bubbleEvents)$/.test(prop)) { + _globalConfig[prop] = options[prop]; + } else if (_flashState.bridge == null) { + if (prop === "containerId" || prop === "swfObjectId") { + if (_isValidHtml4Id(options[prop])) { + _globalConfig[prop] = options[prop]; + } else { + throw new Error("The specified `" + prop + "` value is not valid as an HTML4 Element ID"); + } + } else { + _globalConfig[prop] = options[prop]; + } + } + } + } + } + if (typeof options === "string" && options) { + if (_hasOwn.call(_globalConfig, options)) { + return _globalConfig[options]; + } + return; + } + return _deepCopy(_globalConfig); + }; + /** + * The underlying implementation of `ZeroClipboard.state`. + * @private + */ + var _state = function() { + _detectSandbox(); + return { + browser: _pick(_navigator, [ "userAgent", "platform", "appName" ]), + flash: _omit(_flashState, [ "bridge" ]), + zeroclipboard: { + version: ZeroClipboard.version, + config: ZeroClipboard.config() + } + }; + }; + /** + * The underlying implementation of `ZeroClipboard.isFlashUnusable`. + * @private + */ + var _isFlashUnusable = function() { + return !!(_flashState.disabled || _flashState.outdated || _flashState.sandboxed || _flashState.unavailable || _flashState.degraded || _flashState.deactivated); + }; + /** + * The underlying implementation of `ZeroClipboard.on`. + * @private + */ + var _on = function(eventType, listener) { + var i, len, events, added = {}; + if (typeof eventType === "string" && eventType) { + events = eventType.toLowerCase().split(/\s+/); + } else if (typeof eventType === "object" && eventType && typeof listener === "undefined") { + for (i in eventType) { + if (_hasOwn.call(eventType, i) && typeof i === "string" && i && typeof eventType[i] === "function") { + ZeroClipboard.on(i, eventType[i]); + } + } + } + if (events && events.length) { + for (i = 0, len = events.length; i < len; i++) { + eventType = events[i].replace(/^on/, ""); + added[eventType] = true; + if (!_handlers[eventType]) { + _handlers[eventType] = []; + } + _handlers[eventType].push(listener); + } + if (added.ready && _flashState.ready) { + ZeroClipboard.emit({ + type: "ready" + }); + } + if (added.error) { + for (i = 0, len = _flashStateErrorNames.length; i < len; i++) { + if (_flashState[_flashStateErrorNames[i].replace(/^flash-/, "")] === true) { + ZeroClipboard.emit({ + type: "error", + name: _flashStateErrorNames[i] + }); + break; + } + } + if (_zcSwfVersion !== undefined && ZeroClipboard.version !== _zcSwfVersion) { + ZeroClipboard.emit({ + type: "error", + name: "version-mismatch", + jsVersion: ZeroClipboard.version, + swfVersion: _zcSwfVersion + }); + } + } + } + return ZeroClipboard; + }; + /** + * The underlying implementation of `ZeroClipboard.off`. + * @private + */ + var _off = function(eventType, listener) { + var i, len, foundIndex, events, perEventHandlers; + if (arguments.length === 0) { + events = _keys(_handlers); + } else if (typeof eventType === "string" && eventType) { + events = eventType.split(/\s+/); + } else if (typeof eventType === "object" && eventType && typeof listener === "undefined") { + for (i in eventType) { + if (_hasOwn.call(eventType, i) && typeof i === "string" && i && typeof eventType[i] === "function") { + ZeroClipboard.off(i, eventType[i]); + } + } + } + if (events && events.length) { + for (i = 0, len = events.length; i < len; i++) { + eventType = events[i].toLowerCase().replace(/^on/, ""); + perEventHandlers = _handlers[eventType]; + if (perEventHandlers && perEventHandlers.length) { + if (listener) { + foundIndex = perEventHandlers.indexOf(listener); + while (foundIndex !== -1) { + perEventHandlers.splice(foundIndex, 1); + foundIndex = perEventHandlers.indexOf(listener, foundIndex); + } + } else { + perEventHandlers.length = 0; + } + } + } + } + return ZeroClipboard; + }; + /** + * The underlying implementation of `ZeroClipboard.handlers`. + * @private + */ + var _listeners = function(eventType) { + var copy; + if (typeof eventType === "string" && eventType) { + copy = _deepCopy(_handlers[eventType]) || null; + } else { + copy = _deepCopy(_handlers); + } + return copy; + }; + /** + * The underlying implementation of `ZeroClipboard.emit`. + * @private + */ + var _emit = function(event) { + var eventCopy, returnVal, tmp; + event = _createEvent(event); + if (!event) { + return; + } + if (_preprocessEvent(event)) { + return; + } + if (event.type === "ready" && _flashState.overdue === true) { + return ZeroClipboard.emit({ + type: "error", + name: "flash-overdue" + }); + } + eventCopy = _extend({}, event); + _dispatchCallbacks.call(this, eventCopy); + if (event.type === "copy") { + tmp = _mapClipDataToFlash(_clipData); + returnVal = tmp.data; + _clipDataFormatMap = tmp.formatMap; + } + return returnVal; + }; + /** + * The underlying implementation of `ZeroClipboard.create`. + * @private + */ + var _create = function() { + var previousState = _flashState.sandboxed; + _detectSandbox(); + if (typeof _flashState.ready !== "boolean") { + _flashState.ready = false; + } + if (_flashState.sandboxed !== previousState && _flashState.sandboxed === true) { + _flashState.ready = false; + ZeroClipboard.emit({ + type: "error", + name: "flash-sandboxed" + }); + } else if (!ZeroClipboard.isFlashUnusable() && _flashState.bridge === null) { + var maxWait = _globalConfig.flashLoadTimeout; + if (typeof maxWait === "number" && maxWait >= 0) { + _flashCheckTimeout = _setTimeout(function() { + if (typeof _flashState.deactivated !== "boolean") { + _flashState.deactivated = true; + } + if (_flashState.deactivated === true) { + ZeroClipboard.emit({ + type: "error", + name: "flash-deactivated" + }); + } + }, maxWait); + } + _flashState.overdue = false; + _embedSwf(); + } + }; + /** + * The underlying implementation of `ZeroClipboard.destroy`. + * @private + */ + var _destroy = function() { + ZeroClipboard.clearData(); + ZeroClipboard.blur(); + ZeroClipboard.emit("destroy"); + _unembedSwf(); + ZeroClipboard.off(); + }; + /** + * The underlying implementation of `ZeroClipboard.setData`. + * @private + */ + var _setData = function(format, data) { + var dataObj; + if (typeof format === "object" && format && typeof data === "undefined") { + dataObj = format; + ZeroClipboard.clearData(); + } else if (typeof format === "string" && format) { + dataObj = {}; + dataObj[format] = data; + } else { + return; + } + for (var dataFormat in dataObj) { + if (typeof dataFormat === "string" && dataFormat && _hasOwn.call(dataObj, dataFormat) && typeof dataObj[dataFormat] === "string" && dataObj[dataFormat]) { + _clipData[dataFormat] = dataObj[dataFormat]; + } + } + }; + /** + * The underlying implementation of `ZeroClipboard.clearData`. + * @private + */ + var _clearData = function(format) { + if (typeof format === "undefined") { + _deleteOwnProperties(_clipData); + _clipDataFormatMap = null; + } else if (typeof format === "string" && _hasOwn.call(_clipData, format)) { + delete _clipData[format]; + } + }; + /** + * The underlying implementation of `ZeroClipboard.getData`. + * @private + */ + var _getData = function(format) { + if (typeof format === "undefined") { + return _deepCopy(_clipData); + } else if (typeof format === "string" && _hasOwn.call(_clipData, format)) { + return _clipData[format]; + } + }; + /** + * The underlying implementation of `ZeroClipboard.focus`/`ZeroClipboard.activate`. + * @private + */ + var _focus = function(element) { + if (!(element && element.nodeType === 1)) { + return; + } + if (_currentElement) { + _removeClass(_currentElement, _globalConfig.activeClass); + if (_currentElement !== element) { + _removeClass(_currentElement, _globalConfig.hoverClass); + } + } + _currentElement = element; + _addClass(element, _globalConfig.hoverClass); + var newTitle = element.getAttribute("title") || _globalConfig.title; + if (typeof newTitle === "string" && newTitle) { + var htmlBridge = _getHtmlBridge(_flashState.bridge); + if (htmlBridge) { + htmlBridge.setAttribute("title", newTitle); + } + } + var useHandCursor = _globalConfig.forceHandCursor === true || _getStyle(element, "cursor") === "pointer"; + _setHandCursor(useHandCursor); + _reposition(); + }; + /** + * The underlying implementation of `ZeroClipboard.blur`/`ZeroClipboard.deactivate`. + * @private + */ + var _blur = function() { + var htmlBridge = _getHtmlBridge(_flashState.bridge); + if (htmlBridge) { + htmlBridge.removeAttribute("title"); + htmlBridge.style.left = "0px"; + htmlBridge.style.top = "-9999px"; + htmlBridge.style.width = "1px"; + htmlBridge.style.height = "1px"; + } + if (_currentElement) { + _removeClass(_currentElement, _globalConfig.hoverClass); + _removeClass(_currentElement, _globalConfig.activeClass); + _currentElement = null; + } + }; + /** + * The underlying implementation of `ZeroClipboard.activeElement`. + * @private + */ + var _activeElement = function() { + return _currentElement || null; + }; + /** + * Check if a value is a valid HTML4 `ID` or `Name` token. + * @private + */ + var _isValidHtml4Id = function(id) { + return typeof id === "string" && id && /^[A-Za-z][A-Za-z0-9_:\-\.]*$/.test(id); + }; + /** + * Create or update an `event` object, based on the `eventType`. + * @private + */ + var _createEvent = function(event) { + var eventType; + if (typeof event === "string" && event) { + eventType = event; + event = {}; + } else if (typeof event === "object" && event && typeof event.type === "string" && event.type) { + eventType = event.type; + } + if (!eventType) { + return; + } + eventType = eventType.toLowerCase(); + if (!event.target && (/^(copy|aftercopy|_click)$/.test(eventType) || eventType === "error" && event.name === "clipboard-error")) { + event.target = _copyTarget; + } + _extend(event, { + type: eventType, + target: event.target || _currentElement || null, + relatedTarget: event.relatedTarget || null, + currentTarget: _flashState && _flashState.bridge || null, + timeStamp: event.timeStamp || _now() || null + }); + var msg = _eventMessages[event.type]; + if (event.type === "error" && event.name && msg) { + msg = msg[event.name]; + } + if (msg) { + event.message = msg; + } + if (event.type === "ready") { + _extend(event, { + target: null, + version: _flashState.version + }); + } + if (event.type === "error") { + if (_flashStateErrorNameMatchingRegex.test(event.name)) { + _extend(event, { + target: null, + minimumVersion: _minimumFlashVersion + }); + } + if (_flashStateEnabledErrorNameMatchingRegex.test(event.name)) { + _extend(event, { + version: _flashState.version + }); + } + } + if (event.type === "copy") { + event.clipboardData = { + setData: ZeroClipboard.setData, + clearData: ZeroClipboard.clearData + }; + } + if (event.type === "aftercopy") { + event = _mapClipResultsFromFlash(event, _clipDataFormatMap); + } + if (event.target && !event.relatedTarget) { + event.relatedTarget = _getRelatedTarget(event.target); + } + return _addMouseData(event); + }; + /** + * Get a relatedTarget from the target's `data-clipboard-target` attribute + * @private + */ + var _getRelatedTarget = function(targetEl) { + var relatedTargetId = targetEl && targetEl.getAttribute && targetEl.getAttribute("data-clipboard-target"); + return relatedTargetId ? _document.getElementById(relatedTargetId) : null; + }; + /** + * Add element and position data to `MouseEvent` instances + * @private + */ + var _addMouseData = function(event) { + if (event && /^_(?:click|mouse(?:over|out|down|up|move))$/.test(event.type)) { + var srcElement = event.target; + var fromElement = event.type === "_mouseover" && event.relatedTarget ? event.relatedTarget : undefined; + var toElement = event.type === "_mouseout" && event.relatedTarget ? event.relatedTarget : undefined; + var pos = _getElementPosition(srcElement); + var screenLeft = _window.screenLeft || _window.screenX || 0; + var screenTop = _window.screenTop || _window.screenY || 0; + var scrollLeft = _document.body.scrollLeft + _document.documentElement.scrollLeft; + var scrollTop = _document.body.scrollTop + _document.documentElement.scrollTop; + var pageX = pos.left + (typeof event._stageX === "number" ? event._stageX : 0); + var pageY = pos.top + (typeof event._stageY === "number" ? event._stageY : 0); + var clientX = pageX - scrollLeft; + var clientY = pageY - scrollTop; + var screenX = screenLeft + clientX; + var screenY = screenTop + clientY; + var moveX = typeof event.movementX === "number" ? event.movementX : 0; + var moveY = typeof event.movementY === "number" ? event.movementY : 0; + delete event._stageX; + delete event._stageY; + _extend(event, { + srcElement: srcElement, + fromElement: fromElement, + toElement: toElement, + screenX: screenX, + screenY: screenY, + pageX: pageX, + pageY: pageY, + clientX: clientX, + clientY: clientY, + x: clientX, + y: clientY, + movementX: moveX, + movementY: moveY, + offsetX: 0, + offsetY: 0, + layerX: 0, + layerY: 0 + }); + } + return event; + }; + /** + * Determine if an event's registered handlers should be execute synchronously or asynchronously. + * + * @returns {boolean} + * @private + */ + var _shouldPerformAsync = function(event) { + var eventType = event && typeof event.type === "string" && event.type || ""; + return !/^(?:(?:before)?copy|destroy)$/.test(eventType); + }; + /** + * Control if a callback should be executed asynchronously or not. + * + * @returns `undefined` + * @private + */ + var _dispatchCallback = function(func, context, args, async) { + if (async) { + _setTimeout(function() { + func.apply(context, args); + }, 0); + } else { + func.apply(context, args); + } + }; + /** + * Handle the actual dispatching of events to client instances. + * + * @returns `undefined` + * @private + */ + var _dispatchCallbacks = function(event) { + if (!(typeof event === "object" && event && event.type)) { + return; + } + var async = _shouldPerformAsync(event); + var wildcardTypeHandlers = _handlers["*"] || []; + var specificTypeHandlers = _handlers[event.type] || []; + var handlers = wildcardTypeHandlers.concat(specificTypeHandlers); + if (handlers && handlers.length) { + var i, len, func, context, eventCopy, originalContext = this; + for (i = 0, len = handlers.length; i < len; i++) { + func = handlers[i]; + context = originalContext; + if (typeof func === "string" && typeof _window[func] === "function") { + func = _window[func]; + } + if (typeof func === "object" && func && typeof func.handleEvent === "function") { + context = func; + func = func.handleEvent; + } + if (typeof func === "function") { + eventCopy = _extend({}, event); + _dispatchCallback(func, context, [ eventCopy ], async); + } + } + } + return this; + }; + /** + * Check an `error` event's `name` property to see if Flash has + * already loaded, which rules out possible `iframe` sandboxing. + * @private + */ + var _getSandboxStatusFromErrorEvent = function(event) { + var isSandboxed = null; + if (_pageIsFramed === false || event && event.type === "error" && event.name && _errorsThatOnlyOccurAfterFlashLoads.indexOf(event.name) !== -1) { + isSandboxed = false; + } + return isSandboxed; + }; + /** + * Preprocess any special behaviors, reactions, or state changes after receiving this event. + * Executes only once per event emitted, NOT once per client. + * @private + */ + var _preprocessEvent = function(event) { + var element = event.target || _currentElement || null; + var sourceIsSwf = event._source === "swf"; + delete event._source; + switch (event.type) { + case "error": + var isSandboxed = event.name === "flash-sandboxed" || _getSandboxStatusFromErrorEvent(event); + if (typeof isSandboxed === "boolean") { + _flashState.sandboxed = isSandboxed; + } + if (_flashStateErrorNames.indexOf(event.name) !== -1) { + _extend(_flashState, { + disabled: event.name === "flash-disabled", + outdated: event.name === "flash-outdated", + unavailable: event.name === "flash-unavailable", + degraded: event.name === "flash-degraded", + deactivated: event.name === "flash-deactivated", + overdue: event.name === "flash-overdue", + ready: false + }); + } else if (event.name === "version-mismatch") { + _zcSwfVersion = event.swfVersion; + _extend(_flashState, { + disabled: false, + outdated: false, + unavailable: false, + degraded: false, + deactivated: false, + overdue: false, + ready: false + }); + } + _clearTimeoutsAndPolling(); + break; + + case "ready": + _zcSwfVersion = event.swfVersion; + var wasDeactivated = _flashState.deactivated === true; + _extend(_flashState, { + disabled: false, + outdated: false, + sandboxed: false, + unavailable: false, + degraded: false, + deactivated: false, + overdue: wasDeactivated, + ready: !wasDeactivated + }); + _clearTimeoutsAndPolling(); + break; + + case "beforecopy": + _copyTarget = element; + break; + + case "copy": + var textContent, htmlContent, targetEl = event.relatedTarget; + if (!(_clipData["text/html"] || _clipData["text/plain"]) && targetEl && (htmlContent = targetEl.value || targetEl.outerHTML || targetEl.innerHTML) && (textContent = targetEl.value || targetEl.textContent || targetEl.innerText)) { + event.clipboardData.clearData(); + event.clipboardData.setData("text/plain", textContent); + if (htmlContent !== textContent) { + event.clipboardData.setData("text/html", htmlContent); + } + } else if (!_clipData["text/plain"] && event.target && (textContent = event.target.getAttribute("data-clipboard-text"))) { + event.clipboardData.clearData(); + event.clipboardData.setData("text/plain", textContent); + } + break; + + case "aftercopy": + _queueEmitClipboardErrors(event); + ZeroClipboard.clearData(); + if (element && element !== _safeActiveElement() && element.focus) { + element.focus(); + } + break; + + case "_mouseover": + ZeroClipboard.focus(element); + if (_globalConfig.bubbleEvents === true && sourceIsSwf) { + if (element && element !== event.relatedTarget && !_containedBy(event.relatedTarget, element)) { + _fireMouseEvent(_extend({}, event, { + type: "mouseenter", + bubbles: false, + cancelable: false + })); + } + _fireMouseEvent(_extend({}, event, { + type: "mouseover" + })); + } + break; + + case "_mouseout": + ZeroClipboard.blur(); + if (_globalConfig.bubbleEvents === true && sourceIsSwf) { + if (element && element !== event.relatedTarget && !_containedBy(event.relatedTarget, element)) { + _fireMouseEvent(_extend({}, event, { + type: "mouseleave", + bubbles: false, + cancelable: false + })); + } + _fireMouseEvent(_extend({}, event, { + type: "mouseout" + })); + } + break; + + case "_mousedown": + _addClass(element, _globalConfig.activeClass); + if (_globalConfig.bubbleEvents === true && sourceIsSwf) { + _fireMouseEvent(_extend({}, event, { + type: event.type.slice(1) + })); + } + break; + + case "_mouseup": + _removeClass(element, _globalConfig.activeClass); + if (_globalConfig.bubbleEvents === true && sourceIsSwf) { + _fireMouseEvent(_extend({}, event, { + type: event.type.slice(1) + })); + } + break; + + case "_click": + _copyTarget = null; + if (_globalConfig.bubbleEvents === true && sourceIsSwf) { + _fireMouseEvent(_extend({}, event, { + type: event.type.slice(1) + })); + } + break; + + case "_mousemove": + if (_globalConfig.bubbleEvents === true && sourceIsSwf) { + _fireMouseEvent(_extend({}, event, { + type: event.type.slice(1) + })); + } + break; + } + if (/^_(?:click|mouse(?:over|out|down|up|move))$/.test(event.type)) { + return true; + } + }; + /** + * Check an "aftercopy" event for clipboard errors and emit a corresponding "error" event. + * @private + */ + var _queueEmitClipboardErrors = function(aftercopyEvent) { + if (aftercopyEvent.errors && aftercopyEvent.errors.length > 0) { + var errorEvent = _deepCopy(aftercopyEvent); + _extend(errorEvent, { + type: "error", + name: "clipboard-error" + }); + delete errorEvent.success; + _setTimeout(function() { + ZeroClipboard.emit(errorEvent); + }, 0); + } + }; + /** + * Dispatch a synthetic MouseEvent. + * + * @returns `undefined` + * @private + */ + var _fireMouseEvent = function(event) { + if (!(event && typeof event.type === "string" && event)) { + return; + } + var e, target = event.target || null, doc = target && target.ownerDocument || _document, defaults = { + view: doc.defaultView || _window, + canBubble: true, + cancelable: true, + detail: event.type === "click" ? 1 : 0, + button: typeof event.which === "number" ? event.which - 1 : typeof event.button === "number" ? event.button : doc.createEvent ? 0 : 1 + }, args = _extend(defaults, event); + if (!target) { + return; + } + if (doc.createEvent && target.dispatchEvent) { + args = [ args.type, args.canBubble, args.cancelable, args.view, args.detail, args.screenX, args.screenY, args.clientX, args.clientY, args.ctrlKey, args.altKey, args.shiftKey, args.metaKey, args.button, args.relatedTarget ]; + e = doc.createEvent("MouseEvents"); + if (e.initMouseEvent) { + e.initMouseEvent.apply(e, args); + e._source = "js"; + target.dispatchEvent(e); + } + } + }; + /** + * Continuously poll the DOM until either: + * (a) the fallback content becomes visible, or + * (b) we receive an event from SWF (handled elsewhere) + * + * IMPORTANT: + * This is NOT a necessary check but it can result in significantly faster + * detection of bad `swfPath` configuration and/or network/server issues [in + * supported browsers] than waiting for the entire `flashLoadTimeout` duration + * to elapse before detecting that the SWF cannot be loaded. The detection + * duration can be anywhere from 10-30 times faster [in supported browsers] by + * using this approach. + * + * @returns `undefined` + * @private + */ + var _watchForSwfFallbackContent = function() { + var maxWait = _globalConfig.flashLoadTimeout; + if (typeof maxWait === "number" && maxWait >= 0) { + var pollWait = Math.min(1e3, maxWait / 10); + var fallbackContentId = _globalConfig.swfObjectId + "_fallbackContent"; + _swfFallbackCheckInterval = _setInterval(function() { + var el = _document.getElementById(fallbackContentId); + if (_isElementVisible(el)) { + _clearTimeoutsAndPolling(); + _flashState.deactivated = null; + ZeroClipboard.emit({ + type: "error", + name: "swf-not-found" + }); + } + }, pollWait); + } + }; + /** + * Create the HTML bridge element to embed the Flash object into. + * @private + */ + var _createHtmlBridge = function() { + var container = _document.createElement("div"); + container.id = _globalConfig.containerId; + container.className = _globalConfig.containerClass; + container.style.position = "absolute"; + container.style.left = "0px"; + container.style.top = "-9999px"; + container.style.width = "1px"; + container.style.height = "1px"; + container.style.zIndex = "" + _getSafeZIndex(_globalConfig.zIndex); + return container; + }; + /** + * Get the HTML element container that wraps the Flash bridge object/element. + * @private + */ + var _getHtmlBridge = function(flashBridge) { + var htmlBridge = flashBridge && flashBridge.parentNode; + while (htmlBridge && htmlBridge.nodeName === "OBJECT" && htmlBridge.parentNode) { + htmlBridge = htmlBridge.parentNode; + } + return htmlBridge || null; + }; + /** + * Create the SWF object. + * + * @returns The SWF object reference. + * @private + */ + var _embedSwf = function() { + var len, flashBridge = _flashState.bridge, container = _getHtmlBridge(flashBridge); + if (!flashBridge) { + var allowScriptAccess = _determineScriptAccess(_window.location.host, _globalConfig); + var allowNetworking = allowScriptAccess === "never" ? "none" : "all"; + var flashvars = _vars(_extend({ + jsVersion: ZeroClipboard.version + }, _globalConfig)); + var swfUrl = _globalConfig.swfPath + _cacheBust(_globalConfig.swfPath, _globalConfig); + container = _createHtmlBridge(); + var divToBeReplaced = _document.createElement("div"); + container.appendChild(divToBeReplaced); + _document.body.appendChild(container); + var tmpDiv = _document.createElement("div"); + var usingActiveX = _flashState.pluginType === "activex"; + tmpDiv.innerHTML = '" + (usingActiveX ? '' : "") + '' + '' + '' + '' + '' + '
 
' + "
"; + flashBridge = tmpDiv.firstChild; + tmpDiv = null; + _unwrap(flashBridge).ZeroClipboard = ZeroClipboard; + container.replaceChild(flashBridge, divToBeReplaced); + _watchForSwfFallbackContent(); + } + if (!flashBridge) { + flashBridge = _document[_globalConfig.swfObjectId]; + if (flashBridge && (len = flashBridge.length)) { + flashBridge = flashBridge[len - 1]; + } + if (!flashBridge && container) { + flashBridge = container.firstChild; + } + } + _flashState.bridge = flashBridge || null; + return flashBridge; + }; + /** + * Destroy the SWF object. + * @private + */ + var _unembedSwf = function() { + var flashBridge = _flashState.bridge; + if (flashBridge) { + var htmlBridge = _getHtmlBridge(flashBridge); + if (htmlBridge) { + if (_flashState.pluginType === "activex" && "readyState" in flashBridge) { + flashBridge.style.display = "none"; + (function removeSwfFromIE() { + if (flashBridge.readyState === 4) { + for (var prop in flashBridge) { + if (typeof flashBridge[prop] === "function") { + flashBridge[prop] = null; + } + } + if (flashBridge.parentNode) { + flashBridge.parentNode.removeChild(flashBridge); + } + if (htmlBridge.parentNode) { + htmlBridge.parentNode.removeChild(htmlBridge); + } + } else { + _setTimeout(removeSwfFromIE, 10); + } + })(); + } else { + if (flashBridge.parentNode) { + flashBridge.parentNode.removeChild(flashBridge); + } + if (htmlBridge.parentNode) { + htmlBridge.parentNode.removeChild(htmlBridge); + } + } + } + _clearTimeoutsAndPolling(); + _flashState.ready = null; + _flashState.bridge = null; + _flashState.deactivated = null; + _zcSwfVersion = undefined; + } + }; + /** + * Map the data format names of the "clipData" to Flash-friendly names. + * + * @returns A new transformed object. + * @private + */ + var _mapClipDataToFlash = function(clipData) { + var newClipData = {}, formatMap = {}; + if (!(typeof clipData === "object" && clipData)) { + return; + } + for (var dataFormat in clipData) { + if (dataFormat && _hasOwn.call(clipData, dataFormat) && typeof clipData[dataFormat] === "string" && clipData[dataFormat]) { + switch (dataFormat.toLowerCase()) { + case "text/plain": + case "text": + case "air:text": + case "flash:text": + newClipData.text = clipData[dataFormat]; + formatMap.text = dataFormat; + break; + + case "text/html": + case "html": + case "air:html": + case "flash:html": + newClipData.html = clipData[dataFormat]; + formatMap.html = dataFormat; + break; + + case "application/rtf": + case "text/rtf": + case "rtf": + case "richtext": + case "air:rtf": + case "flash:rtf": + newClipData.rtf = clipData[dataFormat]; + formatMap.rtf = dataFormat; + break; + + default: + break; + } + } + } + return { + data: newClipData, + formatMap: formatMap + }; + }; + /** + * Map the data format names from Flash-friendly names back to their original "clipData" names (via a format mapping). + * + * @returns A new transformed object. + * @private + */ + var _mapClipResultsFromFlash = function(clipResults, formatMap) { + if (!(typeof clipResults === "object" && clipResults && typeof formatMap === "object" && formatMap)) { + return clipResults; + } + var newResults = {}; + for (var prop in clipResults) { + if (_hasOwn.call(clipResults, prop)) { + if (prop === "errors") { + newResults[prop] = clipResults[prop] ? clipResults[prop].slice() : []; + for (var i = 0, len = newResults[prop].length; i < len; i++) { + newResults[prop][i].format = formatMap[newResults[prop][i].format]; + } + } else if (prop !== "success" && prop !== "data") { + newResults[prop] = clipResults[prop]; + } else { + newResults[prop] = {}; + var tmpHash = clipResults[prop]; + for (var dataFormat in tmpHash) { + if (dataFormat && _hasOwn.call(tmpHash, dataFormat) && _hasOwn.call(formatMap, dataFormat)) { + newResults[prop][formatMap[dataFormat]] = tmpHash[dataFormat]; + } + } + } + } + } + return newResults; + }; + /** + * Will look at a path, and will create a "?noCache={time}" or "&noCache={time}" + * query param string to return. Does NOT append that string to the original path. + * This is useful because ExternalInterface often breaks when a Flash SWF is cached. + * + * @returns The `noCache` query param with necessary "?"/"&" prefix. + * @private + */ + var _cacheBust = function(path, options) { + var cacheBust = options == null || options && options.cacheBust === true; + if (cacheBust) { + return (path.indexOf("?") === -1 ? "?" : "&") + "noCache=" + _now(); + } else { + return ""; + } + }; + /** + * Creates a query string for the FlashVars param. + * Does NOT include the cache-busting query param. + * + * @returns FlashVars query string + * @private + */ + var _vars = function(options) { + var i, len, domain, domains, str = "", trustedOriginsExpanded = []; + if (options.trustedDomains) { + if (typeof options.trustedDomains === "string") { + domains = [ options.trustedDomains ]; + } else if (typeof options.trustedDomains === "object" && "length" in options.trustedDomains) { + domains = options.trustedDomains; + } + } + if (domains && domains.length) { + for (i = 0, len = domains.length; i < len; i++) { + if (_hasOwn.call(domains, i) && domains[i] && typeof domains[i] === "string") { + domain = _extractDomain(domains[i]); + if (!domain) { + continue; + } + if (domain === "*") { + trustedOriginsExpanded.length = 0; + trustedOriginsExpanded.push(domain); + break; + } + trustedOriginsExpanded.push.apply(trustedOriginsExpanded, [ domain, "//" + domain, _window.location.protocol + "//" + domain ]); + } + } + } + if (trustedOriginsExpanded.length) { + str += "trustedOrigins=" + _encodeURIComponent(trustedOriginsExpanded.join(",")); + } + if (options.forceEnhancedClipboard === true) { + str += (str ? "&" : "") + "forceEnhancedClipboard=true"; + } + if (typeof options.swfObjectId === "string" && options.swfObjectId) { + str += (str ? "&" : "") + "swfObjectId=" + _encodeURIComponent(options.swfObjectId); + } + if (typeof options.jsVersion === "string" && options.jsVersion) { + str += (str ? "&" : "") + "jsVersion=" + _encodeURIComponent(options.jsVersion); + } + return str; + }; + /** + * Extract the domain (e.g. "github.com") from an origin (e.g. "https://github.com") or + * URL (e.g. "https://github.com/zeroclipboard/zeroclipboard/"). + * + * @returns the domain + * @private + */ + var _extractDomain = function(originOrUrl) { + if (originOrUrl == null || originOrUrl === "") { + return null; + } + originOrUrl = originOrUrl.replace(/^\s+|\s+$/g, ""); + if (originOrUrl === "") { + return null; + } + var protocolIndex = originOrUrl.indexOf("//"); + originOrUrl = protocolIndex === -1 ? originOrUrl : originOrUrl.slice(protocolIndex + 2); + var pathIndex = originOrUrl.indexOf("/"); + originOrUrl = pathIndex === -1 ? originOrUrl : protocolIndex === -1 || pathIndex === 0 ? null : originOrUrl.slice(0, pathIndex); + if (originOrUrl && originOrUrl.slice(-4).toLowerCase() === ".swf") { + return null; + } + return originOrUrl || null; + }; + /** + * Set `allowScriptAccess` based on `trustedDomains` and `window.location.host` vs. `swfPath`. + * + * @returns The appropriate script access level. + * @private + */ + var _determineScriptAccess = function() { + var _extractAllDomains = function(origins) { + var i, len, tmp, resultsArray = []; + if (typeof origins === "string") { + origins = [ origins ]; + } + if (!(typeof origins === "object" && origins && typeof origins.length === "number")) { + return resultsArray; + } + for (i = 0, len = origins.length; i < len; i++) { + if (_hasOwn.call(origins, i) && (tmp = _extractDomain(origins[i]))) { + if (tmp === "*") { + resultsArray.length = 0; + resultsArray.push("*"); + break; + } + if (resultsArray.indexOf(tmp) === -1) { + resultsArray.push(tmp); + } + } + } + return resultsArray; + }; + return function(currentDomain, configOptions) { + var swfDomain = _extractDomain(configOptions.swfPath); + if (swfDomain === null) { + swfDomain = currentDomain; + } + var trustedDomains = _extractAllDomains(configOptions.trustedDomains); + var len = trustedDomains.length; + if (len > 0) { + if (len === 1 && trustedDomains[0] === "*") { + return "always"; + } + if (trustedDomains.indexOf(currentDomain) !== -1) { + if (len === 1 && currentDomain === swfDomain) { + return "sameDomain"; + } + return "always"; + } + } + return "never"; + }; + }(); + /** + * Get the currently active/focused DOM element. + * + * @returns the currently active/focused element, or `null` + * @private + */ + var _safeActiveElement = function() { + try { + return _document.activeElement; + } catch (err) { + return null; + } + }; + /** + * Add a class to an element, if it doesn't already have it. + * + * @returns The element, with its new class added. + * @private + */ + var _addClass = function(element, value) { + var c, cl, className, classNames = []; + if (typeof value === "string" && value) { + classNames = value.split(/\s+/); + } + if (element && element.nodeType === 1 && classNames.length > 0) { + if (element.classList) { + for (c = 0, cl = classNames.length; c < cl; c++) { + element.classList.add(classNames[c]); + } + } else if (element.hasOwnProperty("className")) { + className = " " + element.className + " "; + for (c = 0, cl = classNames.length; c < cl; c++) { + if (className.indexOf(" " + classNames[c] + " ") === -1) { + className += classNames[c] + " "; + } + } + element.className = className.replace(/^\s+|\s+$/g, ""); + } + } + return element; + }; + /** + * Remove a class from an element, if it has it. + * + * @returns The element, with its class removed. + * @private + */ + var _removeClass = function(element, value) { + var c, cl, className, classNames = []; + if (typeof value === "string" && value) { + classNames = value.split(/\s+/); + } + if (element && element.nodeType === 1 && classNames.length > 0) { + if (element.classList && element.classList.length > 0) { + for (c = 0, cl = classNames.length; c < cl; c++) { + element.classList.remove(classNames[c]); + } + } else if (element.className) { + className = (" " + element.className + " ").replace(/[\r\n\t]/g, " "); + for (c = 0, cl = classNames.length; c < cl; c++) { + className = className.replace(" " + classNames[c] + " ", " "); + } + element.className = className.replace(/^\s+|\s+$/g, ""); + } + } + return element; + }; + /** + * Attempt to interpret the element's CSS styling. If `prop` is `"cursor"`, + * then we assume that it should be a hand ("pointer") cursor if the element + * is an anchor element ("a" tag). + * + * @returns The computed style property. + * @private + */ + var _getStyle = function(el, prop) { + var value = _getComputedStyle(el, null).getPropertyValue(prop); + if (prop === "cursor") { + if (!value || value === "auto") { + if (el.nodeName === "A") { + return "pointer"; + } + } + } + return value; + }; + /** + * Get the absolutely positioned coordinates of a DOM element. + * + * @returns Object containing the element's position, width, and height. + * @private + */ + var _getElementPosition = function(el) { + var pos = { + left: 0, + top: 0, + width: 0, + height: 0 + }; + if (el.getBoundingClientRect) { + var elRect = el.getBoundingClientRect(); + var pageXOffset = _window.pageXOffset; + var pageYOffset = _window.pageYOffset; + var leftBorderWidth = _document.documentElement.clientLeft || 0; + var topBorderWidth = _document.documentElement.clientTop || 0; + var leftBodyOffset = 0; + var topBodyOffset = 0; + if (_getStyle(_document.body, "position") === "relative") { + var bodyRect = _document.body.getBoundingClientRect(); + var htmlRect = _document.documentElement.getBoundingClientRect(); + leftBodyOffset = bodyRect.left - htmlRect.left || 0; + topBodyOffset = bodyRect.top - htmlRect.top || 0; + } + pos.left = elRect.left + pageXOffset - leftBorderWidth - leftBodyOffset; + pos.top = elRect.top + pageYOffset - topBorderWidth - topBodyOffset; + pos.width = "width" in elRect ? elRect.width : elRect.right - elRect.left; + pos.height = "height" in elRect ? elRect.height : elRect.bottom - elRect.top; + } + return pos; + }; + /** + * Determine is an element is visible somewhere within the document (page). + * + * @returns Boolean + * @private + */ + var _isElementVisible = function(el) { + if (!el) { + return false; + } + var styles = _getComputedStyle(el, null); + var hasCssHeight = _parseFloat(styles.height) > 0; + var hasCssWidth = _parseFloat(styles.width) > 0; + var hasCssTop = _parseFloat(styles.top) >= 0; + var hasCssLeft = _parseFloat(styles.left) >= 0; + var cssKnows = hasCssHeight && hasCssWidth && hasCssTop && hasCssLeft; + var rect = cssKnows ? null : _getElementPosition(el); + var isVisible = styles.display !== "none" && styles.visibility !== "collapse" && (cssKnows || !!rect && (hasCssHeight || rect.height > 0) && (hasCssWidth || rect.width > 0) && (hasCssTop || rect.top >= 0) && (hasCssLeft || rect.left >= 0)); + return isVisible; + }; + /** + * Clear all existing timeouts and interval polling delegates. + * + * @returns `undefined` + * @private + */ + var _clearTimeoutsAndPolling = function() { + _clearTimeout(_flashCheckTimeout); + _flashCheckTimeout = 0; + _clearInterval(_swfFallbackCheckInterval); + _swfFallbackCheckInterval = 0; + }; + /** + * Reposition the Flash object to cover the currently activated element. + * + * @returns `undefined` + * @private + */ + var _reposition = function() { + var htmlBridge; + if (_currentElement && (htmlBridge = _getHtmlBridge(_flashState.bridge))) { + var pos = _getElementPosition(_currentElement); + _extend(htmlBridge.style, { + width: pos.width + "px", + height: pos.height + "px", + top: pos.top + "px", + left: pos.left + "px", + zIndex: "" + _getSafeZIndex(_globalConfig.zIndex) + }); + } + }; + /** + * Sends a signal to the Flash object to display the hand cursor if `true`. + * + * @returns `undefined` + * @private + */ + var _setHandCursor = function(enabled) { + if (_flashState.ready === true) { + if (_flashState.bridge && typeof _flashState.bridge.setHandCursor === "function") { + _flashState.bridge.setHandCursor(enabled); + } else { + _flashState.ready = false; + } + } + }; + /** + * Get a safe value for `zIndex` + * + * @returns an integer, or "auto" + * @private + */ + var _getSafeZIndex = function(val) { + if (/^(?:auto|inherit)$/.test(val)) { + return val; + } + var zIndex; + if (typeof val === "number" && !_isNaN(val)) { + zIndex = val; + } else if (typeof val === "string") { + zIndex = _getSafeZIndex(_parseInt(val, 10)); + } + return typeof zIndex === "number" ? zIndex : "auto"; + }; + /** + * Attempt to detect if ZeroClipboard is executing inside of a sandboxed iframe. + * If it is, Flash Player cannot be used, so ZeroClipboard is dead in the water. + * + * @see {@link http://lists.w3.org/Archives/Public/public-whatwg-archive/2014Dec/0002.html} + * @see {@link https://github.com/zeroclipboard/zeroclipboard/issues/511} + * @see {@link http://zeroclipboard.org/test-iframes.html} + * + * @returns `true` (is sandboxed), `false` (is not sandboxed), or `null` (uncertain) + * @private + */ + var _detectSandbox = function(doNotReassessFlashSupport) { + var effectiveScriptOrigin, frame, frameError, previousState = _flashState.sandboxed, isSandboxed = null; + doNotReassessFlashSupport = doNotReassessFlashSupport === true; + if (_pageIsFramed === false) { + isSandboxed = false; + } else { + try { + frame = window.frameElement || null; + } catch (e) { + frameError = { + name: e.name, + message: e.message + }; + } + if (frame && frame.nodeType === 1 && frame.nodeName === "IFRAME") { + try { + isSandboxed = frame.hasAttribute("sandbox"); + } catch (e) { + isSandboxed = null; + } + } else { + try { + effectiveScriptOrigin = document.domain || null; + } catch (e) { + effectiveScriptOrigin = null; + } + if (effectiveScriptOrigin === null || frameError && frameError.name === "SecurityError" && /(^|[\s\(\[@])sandbox(es|ed|ing|[\s\.,!\)\]@]|$)/.test(frameError.message.toLowerCase())) { + isSandboxed = true; + } + } + } + _flashState.sandboxed = isSandboxed; + if (previousState !== isSandboxed && !doNotReassessFlashSupport) { + _detectFlashSupport(_ActiveXObject); + } + return isSandboxed; + }; + /** + * Detect the Flash Player status, version, and plugin type. + * + * @see {@link https://code.google.com/p/doctype-mirror/wiki/ArticleDetectFlash#The_code} + * @see {@link http://stackoverflow.com/questions/12866060/detecting-pepper-ppapi-flash-with-javascript} + * + * @returns `undefined` + * @private + */ + var _detectFlashSupport = function(ActiveXObject) { + var plugin, ax, mimeType, hasFlash = false, isActiveX = false, isPPAPI = false, flashVersion = ""; + /** + * Derived from Apple's suggested sniffer. + * @param {String} desc e.g. "Shockwave Flash 7.0 r61" + * @returns {String} "7.0.61" + * @private + */ + function parseFlashVersion(desc) { + var matches = desc.match(/[\d]+/g); + matches.length = 3; + return matches.join("."); + } + function isPepperFlash(flashPlayerFileName) { + return !!flashPlayerFileName && (flashPlayerFileName = flashPlayerFileName.toLowerCase()) && (/^(pepflashplayer\.dll|libpepflashplayer\.so|pepperflashplayer\.plugin)$/.test(flashPlayerFileName) || flashPlayerFileName.slice(-13) === "chrome.plugin"); + } + function inspectPlugin(plugin) { + if (plugin) { + hasFlash = true; + if (plugin.version) { + flashVersion = parseFlashVersion(plugin.version); + } + if (!flashVersion && plugin.description) { + flashVersion = parseFlashVersion(plugin.description); + } + if (plugin.filename) { + isPPAPI = isPepperFlash(plugin.filename); + } + } + } + if (_navigator.plugins && _navigator.plugins.length) { + plugin = _navigator.plugins["Shockwave Flash"]; + inspectPlugin(plugin); + if (_navigator.plugins["Shockwave Flash 2.0"]) { + hasFlash = true; + flashVersion = "2.0.0.11"; + } + } else if (_navigator.mimeTypes && _navigator.mimeTypes.length) { + mimeType = _navigator.mimeTypes["application/x-shockwave-flash"]; + plugin = mimeType && mimeType.enabledPlugin; + inspectPlugin(plugin); + } else if (typeof ActiveXObject !== "undefined") { + isActiveX = true; + try { + ax = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7"); + hasFlash = true; + flashVersion = parseFlashVersion(ax.GetVariable("$version")); + } catch (e1) { + try { + ax = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6"); + hasFlash = true; + flashVersion = "6.0.21"; + } catch (e2) { + try { + ax = new ActiveXObject("ShockwaveFlash.ShockwaveFlash"); + hasFlash = true; + flashVersion = parseFlashVersion(ax.GetVariable("$version")); + } catch (e3) { + isActiveX = false; + } + } + } + } + _flashState.disabled = hasFlash !== true; + _flashState.outdated = flashVersion && _parseFloat(flashVersion) < _parseFloat(_minimumFlashVersion); + _flashState.version = flashVersion || "0.0.0"; + _flashState.pluginType = isPPAPI ? "pepper" : isActiveX ? "activex" : hasFlash ? "netscape" : "unknown"; + }; + /** + * Invoke the Flash detection algorithms immediately upon inclusion so we're not waiting later. + */ + _detectFlashSupport(_ActiveXObject); + /** + * Always assess the `sandboxed` state of the page at important Flash-related moments. + */ + _detectSandbox(true); + /** + * A shell constructor for `ZeroClipboard` client instances. + * + * @constructor + */ + var ZeroClipboard = function() { + if (!(this instanceof ZeroClipboard)) { + return new ZeroClipboard(); + } + if (typeof ZeroClipboard._createClient === "function") { + ZeroClipboard._createClient.apply(this, _args(arguments)); + } + }; + /** + * The ZeroClipboard library's version number. + * + * @static + * @readonly + * @property {string} + */ + _defineProperty(ZeroClipboard, "version", { + value: "2.2.0", + writable: false, + configurable: true, + enumerable: true + }); + /** + * Update or get a copy of the ZeroClipboard global configuration. + * Returns a copy of the current/updated configuration. + * + * @returns Object + * @static + */ + ZeroClipboard.config = function() { + return _config.apply(this, _args(arguments)); + }; + /** + * Diagnostic method that describes the state of the browser, Flash Player, and ZeroClipboard. + * + * @returns Object + * @static + */ + ZeroClipboard.state = function() { + return _state.apply(this, _args(arguments)); + }; + /** + * Check if Flash is unusable for any reason: disabled, outdated, deactivated, etc. + * + * @returns Boolean + * @static + */ + ZeroClipboard.isFlashUnusable = function() { + return _isFlashUnusable.apply(this, _args(arguments)); + }; + /** + * Register an event listener. + * + * @returns `ZeroClipboard` + * @static + */ + ZeroClipboard.on = function() { + return _on.apply(this, _args(arguments)); + }; + /** + * Unregister an event listener. + * If no `listener` function/object is provided, it will unregister all listeners for the provided `eventType`. + * If no `eventType` is provided, it will unregister all listeners for every event type. + * + * @returns `ZeroClipboard` + * @static + */ + ZeroClipboard.off = function() { + return _off.apply(this, _args(arguments)); + }; + /** + * Retrieve event listeners for an `eventType`. + * If no `eventType` is provided, it will retrieve all listeners for every event type. + * + * @returns array of listeners for the `eventType`; if no `eventType`, then a map/hash object of listeners for all event types; or `null` + */ + ZeroClipboard.handlers = function() { + return _listeners.apply(this, _args(arguments)); + }; + /** + * Event emission receiver from the Flash object, forwarding to any registered JavaScript event listeners. + * + * @returns For the "copy" event, returns the Flash-friendly "clipData" object; otherwise `undefined`. + * @static + */ + ZeroClipboard.emit = function() { + return _emit.apply(this, _args(arguments)); + }; + /** + * Create and embed the Flash object. + * + * @returns The Flash object + * @static + */ + ZeroClipboard.create = function() { + return _create.apply(this, _args(arguments)); + }; + /** + * Self-destruct and clean up everything, including the embedded Flash object. + * + * @returns `undefined` + * @static + */ + ZeroClipboard.destroy = function() { + return _destroy.apply(this, _args(arguments)); + }; + /** + * Set the pending data for clipboard injection. + * + * @returns `undefined` + * @static + */ + ZeroClipboard.setData = function() { + return _setData.apply(this, _args(arguments)); + }; + /** + * Clear the pending data for clipboard injection. + * If no `format` is provided, all pending data formats will be cleared. + * + * @returns `undefined` + * @static + */ + ZeroClipboard.clearData = function() { + return _clearData.apply(this, _args(arguments)); + }; + /** + * Get a copy of the pending data for clipboard injection. + * If no `format` is provided, a copy of ALL pending data formats will be returned. + * + * @returns `String` or `Object` + * @static + */ + ZeroClipboard.getData = function() { + return _getData.apply(this, _args(arguments)); + }; + /** + * Sets the current HTML object that the Flash object should overlay. This will put the global + * Flash object on top of the current element; depending on the setup, this may also set the + * pending clipboard text data as well as the Flash object's wrapping element's title attribute + * based on the underlying HTML element and ZeroClipboard configuration. + * + * @returns `undefined` + * @static + */ + ZeroClipboard.focus = ZeroClipboard.activate = function() { + return _focus.apply(this, _args(arguments)); + }; + /** + * Un-overlays the Flash object. This will put the global Flash object off-screen; depending on + * the setup, this may also unset the Flash object's wrapping element's title attribute based on + * the underlying HTML element and ZeroClipboard configuration. + * + * @returns `undefined` + * @static + */ + ZeroClipboard.blur = ZeroClipboard.deactivate = function() { + return _blur.apply(this, _args(arguments)); + }; + /** + * Returns the currently focused/"activated" HTML element that the Flash object is wrapping. + * + * @returns `HTMLElement` or `null` + * @static + */ + ZeroClipboard.activeElement = function() { + return _activeElement.apply(this, _args(arguments)); + }; + /** + * Keep track of the ZeroClipboard client instance counter. + */ + var _clientIdCounter = 0; + /** + * Keep track of the state of the client instances. + * + * Entry structure: + * _clientMeta[client.id] = { + * instance: client, + * elements: [], + * handlers: {} + * }; + */ + var _clientMeta = {}; + /** + * Keep track of the ZeroClipboard clipped elements counter. + */ + var _elementIdCounter = 0; + /** + * Keep track of the state of the clipped element relationships to clients. + * + * Entry structure: + * _elementMeta[element.zcClippingId] = [client1.id, client2.id]; + */ + var _elementMeta = {}; + /** + * Keep track of the state of the mouse event handlers for clipped elements. + * + * Entry structure: + * _mouseHandlers[element.zcClippingId] = { + * mouseover: function(event) {}, + * mouseout: function(event) {}, + * mouseenter: function(event) {}, + * mouseleave: function(event) {}, + * mousemove: function(event) {} + * }; + */ + var _mouseHandlers = {}; + /** + * Extending the ZeroClipboard configuration defaults for the Client module. + */ + _extend(_globalConfig, { + autoActivate: true + }); + /** + * The real constructor for `ZeroClipboard` client instances. + * @private + */ + var _clientConstructor = function(elements) { + var client = this; + client.id = "" + _clientIdCounter++; + _clientMeta[client.id] = { + instance: client, + elements: [], + handlers: {} + }; + if (elements) { + client.clip(elements); + } + ZeroClipboard.on("*", function(event) { + return client.emit(event); + }); + ZeroClipboard.on("destroy", function() { + client.destroy(); + }); + ZeroClipboard.create(); + }; + /** + * The underlying implementation of `ZeroClipboard.Client.prototype.on`. + * @private + */ + var _clientOn = function(eventType, listener) { + var i, len, events, added = {}, meta = _clientMeta[this.id], handlers = meta && meta.handlers; + if (!meta) { + throw new Error("Attempted to add new listener(s) to a destroyed ZeroClipboard client instance"); + } + if (typeof eventType === "string" && eventType) { + events = eventType.toLowerCase().split(/\s+/); + } else if (typeof eventType === "object" && eventType && typeof listener === "undefined") { + for (i in eventType) { + if (_hasOwn.call(eventType, i) && typeof i === "string" && i && typeof eventType[i] === "function") { + this.on(i, eventType[i]); + } + } + } + if (events && events.length) { + for (i = 0, len = events.length; i < len; i++) { + eventType = events[i].replace(/^on/, ""); + added[eventType] = true; + if (!handlers[eventType]) { + handlers[eventType] = []; + } + handlers[eventType].push(listener); + } + if (added.ready && _flashState.ready) { + this.emit({ + type: "ready", + client: this + }); + } + if (added.error) { + for (i = 0, len = _flashStateErrorNames.length; i < len; i++) { + if (_flashState[_flashStateErrorNames[i].replace(/^flash-/, "")]) { + this.emit({ + type: "error", + name: _flashStateErrorNames[i], + client: this + }); + break; + } + } + if (_zcSwfVersion !== undefined && ZeroClipboard.version !== _zcSwfVersion) { + this.emit({ + type: "error", + name: "version-mismatch", + jsVersion: ZeroClipboard.version, + swfVersion: _zcSwfVersion + }); + } + } + } + return this; + }; + /** + * The underlying implementation of `ZeroClipboard.Client.prototype.off`. + * @private + */ + var _clientOff = function(eventType, listener) { + var i, len, foundIndex, events, perEventHandlers, meta = _clientMeta[this.id], handlers = meta && meta.handlers; + if (!handlers) { + return this; + } + if (arguments.length === 0) { + events = _keys(handlers); + } else if (typeof eventType === "string" && eventType) { + events = eventType.split(/\s+/); + } else if (typeof eventType === "object" && eventType && typeof listener === "undefined") { + for (i in eventType) { + if (_hasOwn.call(eventType, i) && typeof i === "string" && i && typeof eventType[i] === "function") { + this.off(i, eventType[i]); + } + } + } + if (events && events.length) { + for (i = 0, len = events.length; i < len; i++) { + eventType = events[i].toLowerCase().replace(/^on/, ""); + perEventHandlers = handlers[eventType]; + if (perEventHandlers && perEventHandlers.length) { + if (listener) { + foundIndex = perEventHandlers.indexOf(listener); + while (foundIndex !== -1) { + perEventHandlers.splice(foundIndex, 1); + foundIndex = perEventHandlers.indexOf(listener, foundIndex); + } + } else { + perEventHandlers.length = 0; + } + } + } + } + return this; + }; + /** + * The underlying implementation of `ZeroClipboard.Client.prototype.handlers`. + * @private + */ + var _clientListeners = function(eventType) { + var copy = null, handlers = _clientMeta[this.id] && _clientMeta[this.id].handlers; + if (handlers) { + if (typeof eventType === "string" && eventType) { + copy = handlers[eventType] ? handlers[eventType].slice(0) : []; + } else { + copy = _deepCopy(handlers); + } + } + return copy; + }; + /** + * The underlying implementation of `ZeroClipboard.Client.prototype.emit`. + * @private + */ + var _clientEmit = function(event) { + if (_clientShouldEmit.call(this, event)) { + if (typeof event === "object" && event && typeof event.type === "string" && event.type) { + event = _extend({}, event); + } + var eventCopy = _extend({}, _createEvent(event), { + client: this + }); + _clientDispatchCallbacks.call(this, eventCopy); + } + return this; + }; + /** + * The underlying implementation of `ZeroClipboard.Client.prototype.clip`. + * @private + */ + var _clientClip = function(elements) { + if (!_clientMeta[this.id]) { + throw new Error("Attempted to clip element(s) to a destroyed ZeroClipboard client instance"); + } + elements = _prepClip(elements); + for (var i = 0; i < elements.length; i++) { + if (_hasOwn.call(elements, i) && elements[i] && elements[i].nodeType === 1) { + if (!elements[i].zcClippingId) { + elements[i].zcClippingId = "zcClippingId_" + _elementIdCounter++; + _elementMeta[elements[i].zcClippingId] = [ this.id ]; + if (_globalConfig.autoActivate === true) { + _addMouseHandlers(elements[i]); + } + } else if (_elementMeta[elements[i].zcClippingId].indexOf(this.id) === -1) { + _elementMeta[elements[i].zcClippingId].push(this.id); + } + var clippedElements = _clientMeta[this.id] && _clientMeta[this.id].elements; + if (clippedElements.indexOf(elements[i]) === -1) { + clippedElements.push(elements[i]); + } + } + } + return this; + }; + /** + * The underlying implementation of `ZeroClipboard.Client.prototype.unclip`. + * @private + */ + var _clientUnclip = function(elements) { + var meta = _clientMeta[this.id]; + if (!meta) { + return this; + } + var clippedElements = meta.elements; + var arrayIndex; + if (typeof elements === "undefined") { + elements = clippedElements.slice(0); + } else { + elements = _prepClip(elements); + } + for (var i = elements.length; i--; ) { + if (_hasOwn.call(elements, i) && elements[i] && elements[i].nodeType === 1) { + arrayIndex = 0; + while ((arrayIndex = clippedElements.indexOf(elements[i], arrayIndex)) !== -1) { + clippedElements.splice(arrayIndex, 1); + } + var clientIds = _elementMeta[elements[i].zcClippingId]; + if (clientIds) { + arrayIndex = 0; + while ((arrayIndex = clientIds.indexOf(this.id, arrayIndex)) !== -1) { + clientIds.splice(arrayIndex, 1); + } + if (clientIds.length === 0) { + if (_globalConfig.autoActivate === true) { + _removeMouseHandlers(elements[i]); + } + delete elements[i].zcClippingId; + } + } + } + } + return this; + }; + /** + * The underlying implementation of `ZeroClipboard.Client.prototype.elements`. + * @private + */ + var _clientElements = function() { + var meta = _clientMeta[this.id]; + return meta && meta.elements ? meta.elements.slice(0) : []; + }; + /** + * The underlying implementation of `ZeroClipboard.Client.prototype.destroy`. + * @private + */ + var _clientDestroy = function() { + if (!_clientMeta[this.id]) { + return; + } + this.unclip(); + this.off(); + delete _clientMeta[this.id]; + }; + /** + * Inspect an Event to see if the Client (`this`) should honor it for emission. + * @private + */ + var _clientShouldEmit = function(event) { + if (!(event && event.type)) { + return false; + } + if (event.client && event.client !== this) { + return false; + } + var meta = _clientMeta[this.id]; + var clippedEls = meta && meta.elements; + var hasClippedEls = !!clippedEls && clippedEls.length > 0; + var goodTarget = !event.target || hasClippedEls && clippedEls.indexOf(event.target) !== -1; + var goodRelTarget = event.relatedTarget && hasClippedEls && clippedEls.indexOf(event.relatedTarget) !== -1; + var goodClient = event.client && event.client === this; + if (!meta || !(goodTarget || goodRelTarget || goodClient)) { + return false; + } + return true; + }; + /** + * Handle the actual dispatching of events to a client instance. + * + * @returns `undefined` + * @private + */ + var _clientDispatchCallbacks = function(event) { + var meta = _clientMeta[this.id]; + if (!(typeof event === "object" && event && event.type && meta)) { + return; + } + var async = _shouldPerformAsync(event); + var wildcardTypeHandlers = meta && meta.handlers["*"] || []; + var specificTypeHandlers = meta && meta.handlers[event.type] || []; + var handlers = wildcardTypeHandlers.concat(specificTypeHandlers); + if (handlers && handlers.length) { + var i, len, func, context, eventCopy, originalContext = this; + for (i = 0, len = handlers.length; i < len; i++) { + func = handlers[i]; + context = originalContext; + if (typeof func === "string" && typeof _window[func] === "function") { + func = _window[func]; + } + if (typeof func === "object" && func && typeof func.handleEvent === "function") { + context = func; + func = func.handleEvent; + } + if (typeof func === "function") { + eventCopy = _extend({}, event); + _dispatchCallback(func, context, [ eventCopy ], async); + } + } + } + }; + /** + * Prepares the elements for clipping/unclipping. + * + * @returns An Array of elements. + * @private + */ + var _prepClip = function(elements) { + if (typeof elements === "string") { + elements = []; + } + return typeof elements.length !== "number" ? [ elements ] : elements; + }; + /** + * Add a `mouseover` handler function for a clipped element. + * + * @returns `undefined` + * @private + */ + var _addMouseHandlers = function(element) { + if (!(element && element.nodeType === 1)) { + return; + } + var _suppressMouseEvents = function(event) { + if (!(event || (event = _window.event))) { + return; + } + if (event._source !== "js") { + event.stopImmediatePropagation(); + event.preventDefault(); + } + delete event._source; + }; + var _elementMouseOver = function(event) { + if (!(event || (event = _window.event))) { + return; + } + _suppressMouseEvents(event); + ZeroClipboard.focus(element); + }; + element.addEventListener("mouseover", _elementMouseOver, false); + element.addEventListener("mouseout", _suppressMouseEvents, false); + element.addEventListener("mouseenter", _suppressMouseEvents, false); + element.addEventListener("mouseleave", _suppressMouseEvents, false); + element.addEventListener("mousemove", _suppressMouseEvents, false); + _mouseHandlers[element.zcClippingId] = { + mouseover: _elementMouseOver, + mouseout: _suppressMouseEvents, + mouseenter: _suppressMouseEvents, + mouseleave: _suppressMouseEvents, + mousemove: _suppressMouseEvents + }; + }; + /** + * Remove a `mouseover` handler function for a clipped element. + * + * @returns `undefined` + * @private + */ + var _removeMouseHandlers = function(element) { + if (!(element && element.nodeType === 1)) { + return; + } + var mouseHandlers = _mouseHandlers[element.zcClippingId]; + if (!(typeof mouseHandlers === "object" && mouseHandlers)) { + return; + } + var key, val, mouseEvents = [ "move", "leave", "enter", "out", "over" ]; + for (var i = 0, len = mouseEvents.length; i < len; i++) { + key = "mouse" + mouseEvents[i]; + val = mouseHandlers[key]; + if (typeof val === "function") { + element.removeEventListener(key, val, false); + } + } + delete _mouseHandlers[element.zcClippingId]; + }; + /** + * Creates a new ZeroClipboard client instance. + * Optionally, auto-`clip` an element or collection of elements. + * + * @constructor + */ + ZeroClipboard._createClient = function() { + _clientConstructor.apply(this, _args(arguments)); + }; + /** + * Register an event listener to the client. + * + * @returns `this` + */ + ZeroClipboard.prototype.on = function() { + return _clientOn.apply(this, _args(arguments)); + }; + /** + * Unregister an event handler from the client. + * If no `listener` function/object is provided, it will unregister all handlers for the provided `eventType`. + * If no `eventType` is provided, it will unregister all handlers for every event type. + * + * @returns `this` + */ + ZeroClipboard.prototype.off = function() { + return _clientOff.apply(this, _args(arguments)); + }; + /** + * Retrieve event listeners for an `eventType` from the client. + * If no `eventType` is provided, it will retrieve all listeners for every event type. + * + * @returns array of listeners for the `eventType`; if no `eventType`, then a map/hash object of listeners for all event types; or `null` + */ + ZeroClipboard.prototype.handlers = function() { + return _clientListeners.apply(this, _args(arguments)); + }; + /** + * Event emission receiver from the Flash object for this client's registered JavaScript event listeners. + * + * @returns For the "copy" event, returns the Flash-friendly "clipData" object; otherwise `undefined`. + */ + ZeroClipboard.prototype.emit = function() { + return _clientEmit.apply(this, _args(arguments)); + }; + /** + * Register clipboard actions for new element(s) to the client. + * + * @returns `this` + */ + ZeroClipboard.prototype.clip = function() { + return _clientClip.apply(this, _args(arguments)); + }; + /** + * Unregister the clipboard actions of previously registered element(s) on the page. + * If no elements are provided, ALL registered elements will be unregistered. + * + * @returns `this` + */ + ZeroClipboard.prototype.unclip = function() { + return _clientUnclip.apply(this, _args(arguments)); + }; + /** + * Get all of the elements to which this client is clipped. + * + * @returns array of clipped elements + */ + ZeroClipboard.prototype.elements = function() { + return _clientElements.apply(this, _args(arguments)); + }; + /** + * Self-destruct and clean up everything for a single client. + * This will NOT destroy the embedded Flash object. + * + * @returns `undefined` + */ + ZeroClipboard.prototype.destroy = function() { + return _clientDestroy.apply(this, _args(arguments)); + }; + /** + * Stores the pending plain text to inject into the clipboard. + * + * @returns `this` + */ + ZeroClipboard.prototype.setText = function(text) { + if (!_clientMeta[this.id]) { + throw new Error("Attempted to set pending clipboard data from a destroyed ZeroClipboard client instance"); + } + ZeroClipboard.setData("text/plain", text); + return this; + }; + /** + * Stores the pending HTML text to inject into the clipboard. + * + * @returns `this` + */ + ZeroClipboard.prototype.setHtml = function(html) { + if (!_clientMeta[this.id]) { + throw new Error("Attempted to set pending clipboard data from a destroyed ZeroClipboard client instance"); + } + ZeroClipboard.setData("text/html", html); + return this; + }; + /** + * Stores the pending rich text (RTF) to inject into the clipboard. + * + * @returns `this` + */ + ZeroClipboard.prototype.setRichText = function(richText) { + if (!_clientMeta[this.id]) { + throw new Error("Attempted to set pending clipboard data from a destroyed ZeroClipboard client instance"); + } + ZeroClipboard.setData("application/rtf", richText); + return this; + }; + /** + * Stores the pending data to inject into the clipboard. + * + * @returns `this` + */ + ZeroClipboard.prototype.setData = function() { + if (!_clientMeta[this.id]) { + throw new Error("Attempted to set pending clipboard data from a destroyed ZeroClipboard client instance"); + } + ZeroClipboard.setData.apply(this, _args(arguments)); + return this; + }; + /** + * Clears the pending data to inject into the clipboard. + * If no `format` is provided, all pending data formats will be cleared. + * + * @returns `this` + */ + ZeroClipboard.prototype.clearData = function() { + if (!_clientMeta[this.id]) { + throw new Error("Attempted to clear pending clipboard data from a destroyed ZeroClipboard client instance"); + } + ZeroClipboard.clearData.apply(this, _args(arguments)); + return this; + }; + /** + * Gets a copy of the pending data to inject into the clipboard. + * If no `format` is provided, a copy of ALL pending data formats will be returned. + * + * @returns `String` or `Object` + */ + ZeroClipboard.prototype.getData = function() { + if (!_clientMeta[this.id]) { + throw new Error("Attempted to get pending clipboard data from a destroyed ZeroClipboard client instance"); + } + return ZeroClipboard.getData.apply(this, _args(arguments)); + }; + if (typeof define === "function" && define.amd) { + define(function() { + return ZeroClipboard; + }); + } else if (typeof module === "object" && module && typeof module.exports === "object" && module.exports) { + module.exports = ZeroClipboard; + } else { + window.ZeroClipboard = ZeroClipboard; + } +})(function() { + return this || window; +}()); +},{}]},{},[23,47,48,49,50,66,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,67,68,69,70,83,84,85,73,74,75,76,77,78,31,35,32,33,40,34,36,37,38,39])("zeroclipboard") +}); \ No newline at end of file diff --git a/script/jquery.handsontable.columnmove.js b/script/jquery.handsontable.columnmove.js deleted file mode 100644 index 5b649ae..0000000 --- a/script/jquery.handsontable.columnmove.js +++ /dev/null @@ -1,175 +0,0 @@ -/** - * Handle Column Moves on our Editor - * - * based on the example plugin that comes with Handsontable but simplified and adjusted to work on our - * custom data/meta datastructure - * - * @author Andreas Gohr - * @constructor - */ -function EditTableColumnMove() { - var pressed, - startCol, - endCol, - startX, - startOffset; - - var ghost = document.createElement('DIV'), - ghostStyle = ghost.style; - - ghost.className = 'ghost'; - ghostStyle.position = 'absolute'; - ghostStyle.top = '25px'; - ghostStyle.left = 0; - ghostStyle.width = '10px'; - ghostStyle.height = '10px'; - ghostStyle.backgroundColor = '#CCC'; - ghostStyle.opacity = 0.7; - - /** - * Attach all the events - */ - var bindMoveColEvents = function () { - var instance = this; - - /** - * during drag operation - */ - instance.rootElement.on('mousemove.editTableColumnMove', function (e) { - if (pressed) { - ghostStyle.left = startOffset + e.pageX - startX + 6 + 'px'; - if (ghostStyle.display === 'none') { - ghostStyle.display = 'block'; - } - } - }); - - /** - * end of drag operation - * - * The column move is executed here - */ - instance.rootElement.on('mouseup.editTableColumnMove', function () { - if (pressed) { - if (startCol < endCol) { - endCol--; - } - if (instance.getSettings().rowHeaders) { - startCol--; - endCol--; - } - jQuery('.editTableColumnMover.active').removeClass('active'); - pressed = false; - ghostStyle.display = 'none'; - - if (startCol == endCol) return; - - // if this row is part of a row span, do not move - if (instance.raw.colinfo[endCol].colspan) return; - - // swap cols in each row - for (var i = 0; i < instance.raw.data.length; i++) { - instance.raw.data[i].splice(endCol, 0, instance.raw.data[i].splice(startCol, 1)[0]); - instance.raw.meta[i].splice(endCol, 0, instance.raw.meta[i].splice(startCol, 1)[0]); - } - - instance.forceFullRender = true; - instance.view.render(); //updates all - } - }); - - /** - * start drag operation - */ - instance.rootElement.on('mousedown.editTableColumnMove', '.editTableColumnMover', function (e) { - - var mover = e.currentTarget; - var TH = instance.view.wt.wtDom.closest(mover, 'TH'); - startCol = instance.view.wt.wtDom.index(TH) + instance.colOffset(); - endCol = startCol; - pressed = true; - startX = e.pageX; - - var TABLE = instance.$table[0]; - TABLE.parentNode.appendChild(ghost); - ghostStyle.width = instance.view.wt.wtDom.outerWidth(TH) + 'px'; - ghostStyle.height = instance.view.wt.wtDom.outerHeight(TABLE) + 'px'; - startOffset = parseInt(instance.view.wt.wtDom.offset(TH).left - instance.view.wt.wtDom.offset(TABLE).left, 10); - ghostStyle.left = startOffset + 6 + 'px'; - }); - - /** - * on mouseover, show drag handle - */ - instance.rootElement.on('mouseenter.editTableColumnMove', 'td, th', function () { - if (pressed) { - var active = instance.view.THEAD.querySelector('.editTableColumnMover.active'); - if (active) { - instance.view.wt.wtDom.removeClass(active, 'active'); - } - endCol = instance.view.wt.wtDom.index(this) + instance.colOffset(); - - // if this row is part of a row span, do not move - if (instance.raw.colinfo[endCol - 1].colspan) return; - - var THs = instance.view.THEAD.querySelectorAll('th'); - var mover = THs[endCol].querySelector('.editTableColumnMover'); - instance.view.wt.wtDom.addClass(mover, 'active'); - } - }); - - instance.addHook('afterDestroy', unbindMoveColEvents); - }; - - /** - * Remove all the Events - */ - var unbindMoveColEvents = function () { - var instance = this; - instance.rootElement.off('mouseup.editTableColumnMove'); - instance.rootElement.off('mousemove.editTableColumnMove'); - instance.rootElement.off('mousedown.editTableColumnMove'); - instance.rootElement.off('mouseenter.editTableColumnMove'); - }; - - /** - * Initialize the plugin - */ - this.init = function () { - var instance = this; - var editTableColMoveEnabled = !!(this.getSettings().editTableColumnMove); - - if (editTableColMoveEnabled) { - instance.forceFullRender = true; - bindMoveColEvents.call(this); - - } else { - unbindMoveColEvents.call(this); - } - }; - - /** - * Add a move handler to each column head - * - * @param col - * @param TH - */ - this.getColHeader = function (col, TH) { - if (this.getSettings().editTableColumnMove) { - // if this col is part of a col span, do not add move handle - if (this.raw.colinfo[col].colspan) return; - - var DIV = document.createElement('DIV'); - DIV.className = 'editTableColumnMover'; - TH.firstChild.appendChild(DIV); - } - }; -} - -var htEditTableColumnMove = new EditTableColumnMove(); - -Handsontable.PluginHooks.add('afterInit', function () { - htEditTableColumnMove.init.call(this); -}); - -Handsontable.PluginHooks.add('afterGetColHeader', htEditTableColumnMove.getColHeader); diff --git a/script/jquery.handsontable.full.js b/script/jquery.handsontable.full.js deleted file mode 100644 index 0cc08a9..0000000 --- a/script/jquery.handsontable.full.js +++ /dev/null @@ -1,14266 +0,0 @@ -/** - * Handsontable 0.10.1 - * Handsontable is a simple jQuery plugin for editable tables with basic copy-paste compatibility with Excel and Google Docs - * - * Copyright 2012, Marcin Warpechowski - * Licensed under the MIT license. - * http://handsontable.com/ - * - * Date: Wed May 14 2014 15:53:30 GMT+0200 (CEST) - */ -/*jslint white: true, browser: true, plusplus: true, indent: 4, maxerr: 50 */ - -var Handsontable = { //class namespace - extension: {}, //extenstion namespace - helper: {} //helper namespace -}; - -(function ($, window, Handsontable) { - "use strict"; -//http://stackoverflow.com/questions/3629183/why-doesnt-indexof-work-on-an-array-ie8 -if (!Array.prototype.indexOf) { - Array.prototype.indexOf = function (elt /*, from*/) { - var len = this.length >>> 0; - - var from = Number(arguments[1]) || 0; - from = (from < 0) - ? Math.ceil(from) - : Math.floor(from); - if (from < 0) - from += len; - - for (; from < len; from++) { - if (from in this && - this[from] === elt) - return from; - } - return -1; - }; -} -/** - * Array.filter() shim by Trevor Menagh (https://github.com/trevmex) with some modifications - */ - -if (!Array.prototype.filter) { - Array.prototype.filter = function (fun, thisp) { - "use strict"; - - if (typeof this === "undefined" || this === null) { - throw new TypeError(); - } - if (typeof fun !== "function") { - throw new TypeError(); - } - - thisp = thisp || this; - - if (isNodeList(thisp)) { - thisp = convertNodeListToArray(thisp); - } - - var len = thisp.length, - res = [], - i, - val; - - for (i = 0; i < len; i += 1) { - if (thisp.hasOwnProperty(i)) { - val = thisp[i]; // in case fun mutates this - if (fun.call(thisp, val, i, thisp)) { - res.push(val); - } - } - } - - return res; - - function isNodeList(object) { - return /NodeList/i.test(object.item); - } - - function convertNodeListToArray(nodeList) { - var array = []; - - for (var i = 0, len = nodeList.length; i < len; i++){ - array[i] = nodeList[i] - } - - return array; - } - }; -} - -/* - * Copyright 2012 The Polymer Authors. All rights reserved. - * Use of this source code is governed by a BSD-style - * license that can be found in the LICENSE file. - */ - -if (typeof WeakMap === 'undefined') { - (function() { - var defineProperty = Object.defineProperty; - - try { - var properDefineProperty = true; - defineProperty(function(){}, 'foo', {}); - } catch (e) { - properDefineProperty = false; - } - - /* - IE8 does not support Date.now() but IE8 compatibility mode in IE9 and IE10 does. - M$ deserves a high five for this one :) - */ - var counter = +(new Date) % 1e9; - - var WeakMap = function() { - this.name = '__st' + (Math.random() * 1e9 >>> 0) + (counter++ + '__'); - if(!properDefineProperty){ - this._wmCache = []; - } - }; - - if(properDefineProperty){ - WeakMap.prototype = { - set: function(key, value) { - var entry = key[this.name]; - if (entry && entry[0] === key) - entry[1] = value; - else - defineProperty(key, this.name, {value: [key, value], writable: true}); - - }, - get: function(key) { - var entry; - return (entry = key[this.name]) && entry[0] === key ? - entry[1] : undefined; - }, - 'delete': function(key) { - this.set(key, undefined); - } - }; - } else { - WeakMap.prototype = { - set: function(key, value) { - - if(typeof key == 'undefined' || typeof value == 'undefined') return; - - for(var i = 0, len = this._wmCache.length; i < len; i++){ - if(this._wmCache[i].key == key){ - this._wmCache[i].value = value; - return; - } - } - - this._wmCache.push({key: key, value: value}); - - }, - get: function(key) { - - if(typeof key == 'undefined') return; - - for(var i = 0, len = this._wmCache.length; i < len; i++){ - if(this._wmCache[i].key == key){ - return this._wmCache[i].value; - } - } - - return; - - }, - 'delete': function(key) { - - if(typeof key == 'undefined') return; - - for(var i = 0, len = this._wmCache.length; i < len; i++){ - if(this._wmCache[i].key == key){ - Array.prototype.slice.call(this._wmCache, i, 1); - } - } - } - }; - } - - window.WeakMap = WeakMap; - })(); -} - -Handsontable.activeGuid = null; - -/** - * Handsontable constructor - * @param rootElement The jQuery element in which Handsontable DOM will be inserted - * @param userSettings - * @constructor - */ -Handsontable.Core = function (rootElement, userSettings) { - var priv - , datamap - , grid - , selection - , editorManager - , autofill - , instance = this - , GridSettings = function () {}; - - Handsontable.helper.extend(GridSettings.prototype, DefaultSettings.prototype); //create grid settings as a copy of default settings - Handsontable.helper.extend(GridSettings.prototype, userSettings); //overwrite defaults with user settings - Handsontable.helper.extend(GridSettings.prototype, expandType(userSettings)); - - this.rootElement = rootElement; - var $document = $(document.documentElement); - var $body = $(document.body); - this.guid = 'ht_' + Handsontable.helper.randomString(); //this is the namespace for global events - - if (!this.rootElement[0].id) { - this.rootElement[0].id = this.guid; //if root element does not have an id, assign a random id - } - - priv = { - cellSettings: [], - columnSettings: [], - columnsSettingConflicts: ['data', 'width'], - settings: new GridSettings(), // current settings instance - settingsFromDOM: {}, - selStart: new Handsontable.SelectionPoint(), - selEnd: new Handsontable.SelectionPoint(), - isPopulated: null, - scrollable: null, - extensions: {}, - colToProp: null, - propToCol: null, - dataSchema: null, - dataType: 'array', - firstRun: true - }; - - datamap = { - recursiveDuckSchema: function (obj) { - var schema; - if ($.isPlainObject(obj)) { - schema = {}; - for (var i in obj) { - if (obj.hasOwnProperty(i)) { - if ($.isPlainObject(obj[i])) { - schema[i] = datamap.recursiveDuckSchema(obj[i]); - } - else { - schema[i] = null; - } - } - } - } - else { - schema = []; - } - return schema; - }, - - recursiveDuckColumns: function (schema, lastCol, parent) { - var prop, i; - if (typeof lastCol === 'undefined') { - lastCol = 0; - parent = ''; - } - if ($.isPlainObject(schema)) { - for (i in schema) { - if (schema.hasOwnProperty(i)) { - if (schema[i] === null) { - prop = parent + i; - priv.colToProp.push(prop); - priv.propToCol[prop] = lastCol; - lastCol++; - } - else { - lastCol = datamap.recursiveDuckColumns(schema[i], lastCol, i + '.'); - } - } - } - } - return lastCol; - }, - - createMap: function () { - if (typeof datamap.getSchema() === "undefined") { - throw new Error("trying to create `columns` definition but you didnt' provide `schema` nor `data`"); - } - var i, ilen, schema = datamap.getSchema(); - priv.colToProp = []; - priv.propToCol = {}; - if (priv.settings.columns) { - for (i = 0, ilen = priv.settings.columns.length; i < ilen; i++) { - priv.colToProp[i] = priv.settings.columns[i].data; - priv.propToCol[priv.settings.columns[i].data] = i; - } - } - else { - datamap.recursiveDuckColumns(schema); - } - }, - - colToProp: function (col) { - col = Handsontable.PluginHooks.execute(instance, 'modifyCol', col); - if (priv.colToProp && typeof priv.colToProp[col] !== 'undefined') { - return priv.colToProp[col]; - } - else { - return col; - } - }, - - propToCol: function (prop) { - var col; - if (typeof priv.propToCol[prop] !== 'undefined') { - col = priv.propToCol[prop]; - } - else { - col = prop; - } - col = Handsontable.PluginHooks.execute(instance, 'modifyCol', col); - return col; - }, - - getSchema: function () { - if (priv.settings.dataSchema) { - if (typeof priv.settings.dataSchema === 'function') { - return priv.settings.dataSchema(); - } - return priv.settings.dataSchema; - } - return priv.duckDataSchema; - }, - - /** - * Creates row at the bottom of the data array - * @param {Number} [index] Optional. Index of the row before which the new row will be inserted - */ - createRow: function (index, amount) { - var row - , colCount = instance.countCols() - , numberOfCreatedRows = 0 - , currentIndex; - - if (!amount) { - amount = 1; - } - - if (typeof index !== 'number' || index >= instance.countRows()) { - index = instance.countRows(); - } - - currentIndex = index; - while (numberOfCreatedRows < amount && instance.countRows() < priv.settings.maxRows) { - - if (priv.dataType === 'array') { - row = []; - for (var c = 0; c < colCount; c++) { - row.push(null); - } - } - else if (priv.dataType === 'function') { - row = priv.settings.dataSchema(index); - } - else { - row = $.extend(true, {}, datamap.getSchema()); - } - - if (index === instance.countRows()) { - GridSettings.prototype.data.push(row); - } - else { - GridSettings.prototype.data.splice(index, 0, row); - } - - numberOfCreatedRows++; - currentIndex++; - } - - - instance.PluginHooks.run('afterCreateRow', index, numberOfCreatedRows); - instance.forceFullRender = true; //used when data was changed - - return numberOfCreatedRows; - }, - - /** - * Creates col at the right of the data array - * @param {Number} [index] Optional. Index of the column before which the new column will be inserted - * * @param {Number} [amount] Optional. - */ - createCol: function (index, amount) { - if (priv.dataType === 'object' || priv.settings.columns) { - throw new Error("Cannot create new column. When data source in an object, " + - "you can only have as much columns as defined in first data row, data schema or in the 'columns' setting." + - "If you want to be able to add new columns, you have to use array datasource."); - } - var rlen = instance.countRows() - , data = GridSettings.prototype.data - , constructor - , numberOfCreatedCols = 0 - , currentIndex; - - if (!amount) { - amount = 1; - } - - currentIndex = index; - - while (numberOfCreatedCols < amount && instance.countCols() < priv.settings.maxCols){ - constructor = Handsontable.helper.columnFactory(GridSettings, priv.columnsSettingConflicts); - if (typeof index !== 'number' || index >= instance.countCols()) { - for (var r = 0; r < rlen; r++) { - if (typeof data[r] === 'undefined') { - data[r] = []; - } - data[r].push(null); - } - // Add new column constructor - priv.columnSettings.push(constructor); - } - else { - for (var r = 0 ; r < rlen; r++) { - data[r].splice(currentIndex, 0, null); - } - // Add new column constructor at given index - priv.columnSettings.splice(currentIndex, 0, constructor); - } - - numberOfCreatedCols++; - currentIndex++; - } - - instance.PluginHooks.run('afterCreateCol', index, numberOfCreatedCols); - instance.forceFullRender = true; //used when data was changed - - return numberOfCreatedCols; - }, - - /** - * Removes row from the data array - * @param {Number} [index] Optional. Index of the row to be removed. If not provided, the last row will be removed - * @param {Number} [amount] Optional. Amount of the rows to be removed. If not provided, one row will be removed - */ - removeRow: function (index, amount) { - if (!amount) { - amount = 1; - } - if (typeof index !== 'number') { - index = -amount; - } - - index = (instance.countRows() + index) % instance.countRows(); - - // We have to map the physical row ids to logical and than perform removing with (possibly) new row id - var logicRows = this.physicalRowsToLogical(index, amount); - - var actionWasNotCancelled = instance.PluginHooks.execute('beforeRemoveRow', index, amount); - - if(actionWasNotCancelled === false){ - return; - } - - var newData = GridSettings.prototype.data.filter(function (row, index) { - return logicRows.indexOf(index) == -1; - }); - - GridSettings.prototype.data.length = 0; - Array.prototype.push.apply(GridSettings.prototype.data, newData); - - instance.PluginHooks.run('afterRemoveRow', index, amount); - - instance.forceFullRender = true; //used when data was changed - }, - - /** - * Removes column from the data array - * @param {Number} [index] Optional. Index of the column to be removed. If not provided, the last column will be removed - * @param {Number} [amount] Optional. Amount of the columns to be removed. If not provided, one column will be removed - */ - removeCol: function (index, amount) { - if (priv.dataType === 'object' || priv.settings.columns) { - throw new Error("cannot remove column with object data source or columns option specified"); - } - if (!amount) { - amount = 1; - } - if (typeof index !== 'number') { - index = -amount; - } - - index = (instance.countCols() + index) % instance.countCols(); - - var actionWasNotCancelled = instance.PluginHooks.execute('beforeRemoveCol', index, amount); - - if(actionWasNotCancelled === false){ - return; - } - - var data = GridSettings.prototype.data; - for (var r = 0, rlen = instance.countRows(); r < rlen; r++) { - data[r].splice(index, amount); - } - priv.columnSettings.splice(index, amount); - - instance.PluginHooks.run('afterRemoveCol', index, amount); - instance.forceFullRender = true; //used when data was changed - }, - - /** - * Add / removes data from the column - * @param {Number} col Index of column in which do you want to do splice. - * @param {Number} index Index at which to start changing the array. If negative, will begin that many elements from the end - * @param {Number} amount An integer indicating the number of old array elements to remove. If amount is 0, no elements are removed - * param {...*} elements Optional. The elements to add to the array. If you don't specify any elements, spliceCol simply removes elements from the array - */ - spliceCol: function (col, index, amount/*, elements...*/) { - var elements = 4 <= arguments.length ? [].slice.call(arguments, 3) : []; - - var colData = instance.getDataAtCol(col); - var removed = colData.slice(index, index + amount); - var after = colData.slice(index + amount); - - Handsontable.helper.extendArray(elements, after); - var i = 0; - while (i < amount) { - elements.push(null); //add null in place of removed elements - i++; - } - Handsontable.helper.to2dArray(elements); - instance.populateFromArray(index, col, elements, null, null, 'spliceCol'); - - return removed; - }, - - /** - * Add / removes data from the row - * @param {Number} row Index of row in which do you want to do splice. - * @param {Number} index Index at which to start changing the array. If negative, will begin that many elements from the end - * @param {Number} amount An integer indicating the number of old array elements to remove. If amount is 0, no elements are removed - * param {...*} elements Optional. The elements to add to the array. If you don't specify any elements, spliceCol simply removes elements from the array - */ - spliceRow: function (row, index, amount/*, elements...*/) { - var elements = 4 <= arguments.length ? [].slice.call(arguments, 3) : []; - - var rowData = instance.getDataAtRow(row); - var removed = rowData.slice(index, index + amount); - var after = rowData.slice(index + amount); - - Handsontable.helper.extendArray(elements, after); - var i = 0; - while (i < amount) { - elements.push(null); //add null in place of removed elements - i++; - } - instance.populateFromArray(row, index, [elements], null, null, 'spliceRow'); - - return removed; - }, - - /** - * Returns single value from the data array - * @param {Number} row - * @param {Number} prop - */ - getVars: {}, - get: function (row, prop) { - datamap.getVars.row = row; - datamap.getVars.prop = prop; - instance.PluginHooks.run('beforeGet', datamap.getVars); - if (typeof datamap.getVars.prop === 'string' && datamap.getVars.prop.indexOf('.') > -1) { - var sliced = datamap.getVars.prop.split("."); - var out = priv.settings.data[datamap.getVars.row]; - if (!out) { - return null; - } - for (var i = 0, ilen = sliced.length; i < ilen; i++) { - out = out[sliced[i]]; - if (typeof out === 'undefined') { - return null; - } - } - return out; - } - else if (typeof datamap.getVars.prop === 'function') { - /** - * allows for interacting with complex structures, for example - * d3/jQuery getter/setter properties: - * - * {columns: [{ - * data: function(row, value){ - * if(arguments.length === 1){ - * return row.property(); - * } - * row.property(value); - * } - * }]} - */ - return datamap.getVars.prop(priv.settings.data.slice( - datamap.getVars.row, - datamap.getVars.row + 1 - )[0]); - } - else { - return priv.settings.data[datamap.getVars.row] ? priv.settings.data[datamap.getVars.row][datamap.getVars.prop] : null; - } - }, - - /** - * Saves single value to the data array - * @param {Number} row - * @param {Number} prop - * @param {String} value - * @param {String} [source] Optional. Source of hook runner. - */ - setVars: {}, - set: function (row, prop, value, source) { - datamap.setVars.row = row; - datamap.setVars.prop = prop; - datamap.setVars.value = value; - instance.PluginHooks.run('beforeSet', datamap.setVars, source || "datamapGet"); - if (typeof datamap.setVars.prop === 'string' && datamap.setVars.prop.indexOf('.') > -1) { - var sliced = datamap.setVars.prop.split("."); - var out = priv.settings.data[datamap.setVars.row]; - for (var i = 0, ilen = sliced.length - 1; i < ilen; i++) { - out = out[sliced[i]]; - } - out[sliced[i]] = datamap.setVars.value; - } - else if (typeof datamap.setVars.prop === 'function') { - /* see the `function` handler in `get` */ - datamap.setVars.prop(priv.settings.data.slice( - datamap.setVars.row, - datamap.setVars.row + 1 - )[0], datamap.setVars.value); - } - else { - priv.settings.data[datamap.setVars.row][datamap.setVars.prop] = datamap.setVars.value; - } - }, - /** - * This ridiculous piece of code maps rows Id that are present in table data to those displayed for user. - * The trick is, the physical row id (stored in settings.data) is not necessary the same - * as the logical (displayed) row id (e.g. when sorting is applied). - */ - physicalRowsToLogical: function (index, amount) { - var physicRow = (GridSettings.prototype.data.length + index) % GridSettings.prototype.data.length; - var logicRows = []; - var rowsToRemove = amount; - - while (physicRow < GridSettings.prototype.data.length && rowsToRemove) { - this.get(physicRow, 0); //this performs an actual mapping and saves the result to getVars - logicRows.push(this.getVars.row); - - rowsToRemove--; - physicRow++; - } - - return logicRows; - }, - - /** - * Clears the data array - */ - clear: function () { - for (var r = 0; r < instance.countRows(); r++) { - for (var c = 0; c < instance.countCols(); c++) { - datamap.set(r, datamap.colToProp(c), ''); - } - } - }, - - /** - * Returns the data array - * @return {Array} - */ - getAll: function () { - return priv.settings.data; - }, - - /** - * Returns data range as array - * @param {Object} start Start selection position - * @param {Object} end End selection position - * @return {Array} - */ - getRange: function (start, end) { - var r, rlen, c, clen, output = [], row; - rlen = Math.max(start.row, end.row); - clen = Math.max(start.col, end.col); - for (r = Math.min(start.row, end.row); r <= rlen; r++) { - row = []; - for (c = Math.min(start.col, end.col); c <= clen; c++) { - row.push(datamap.get(r, datamap.colToProp(c))); - } - output.push(row); - } - return output; - }, - - /** - * Return data as text (tab separated columns) - * @param {Object} start (Optional) Start selection position - * @param {Object} end (Optional) End selection position - * @return {String} - */ - getText: function (start, end) { - return SheetClip.stringify(datamap.getRange(start, end)); - } - }; - - grid = { - /** - * Inserts or removes rows and columns - * @param {String} action Possible values: "insert_row", "insert_col", "remove_row", "remove_col" - * @param {Number} index - * @param {Number} amount - * @param {String} [source] Optional. Source of hook runner. - * @param {Boolean} [keepEmptyRows] Optional. Flag for preventing deletion of empty rows. - */ - alter: function (action, index, amount, source, keepEmptyRows) { - var delta; - - amount = amount || 1; - - switch (action) { - case "insert_row": - delta = datamap.createRow(index, amount); - - if (delta) { - if (priv.selStart.exists() && priv.selStart.row() >= index) { - priv.selStart.row(priv.selStart.row() + delta); - selection.transformEnd(delta, 0); //will call render() internally - } - else { - selection.refreshBorders(); //it will call render and prepare methods - } - } - break; - - case "insert_col": - delta = datamap.createCol(index, amount); - - if (delta) { - - if(Handsontable.helper.isArray(instance.getSettings().colHeaders)){ - var spliceArray = [index, 0]; - spliceArray.length += delta; //inserts empty (undefined) elements at the end of an array - Array.prototype.splice.apply(instance.getSettings().colHeaders, spliceArray); //inserts empty (undefined) elements into the colHeader array - } - - if (priv.selStart.exists() && priv.selStart.col() >= index) { - priv.selStart.col(priv.selStart.col() + delta); - selection.transformEnd(0, delta); //will call render() internally - } - else { - selection.refreshBorders(); //it will call render and prepare methods - } - } - break; - - case "remove_row": - datamap.removeRow(index, amount); - priv.cellSettings.splice(index, amount); - grid.adjustRowsAndCols(); - selection.refreshBorders(); //it will call render and prepare methods - break; - - case "remove_col": - datamap.removeCol(index, amount); - - for(var row = 0, len = datamap.getAll().length; row < len; row++){ - if(row in priv.cellSettings){ //if row hasn't been rendered it wouldn't have cellSettings - priv.cellSettings[row].splice(index, amount); - } - } - - if(Handsontable.helper.isArray(instance.getSettings().colHeaders)){ - if(typeof index == 'undefined'){ - index = -1; - } - instance.getSettings().colHeaders.splice(index, amount); - } - - priv.columnSettings.splice(index, amount); - - grid.adjustRowsAndCols(); - selection.refreshBorders(); //it will call render and prepare methods - break; - - default: - throw new Error('There is no such action "' + action + '"'); - break; - } - - if (!keepEmptyRows) { - grid.adjustRowsAndCols(); //makes sure that we did not add rows that will be removed in next refresh - } - }, - - /** - * Makes sure there are empty rows at the bottom of the table - */ - adjustRowsAndCols: function () { - var r, rlen, emptyRows = instance.countEmptyRows(true), emptyCols; - - //should I add empty rows to data source to meet minRows? - rlen = instance.countRows(); - if (rlen < priv.settings.minRows) { - for (r = 0; r < priv.settings.minRows - rlen; r++) { - datamap.createRow(); - } - } - - //should I add empty rows to meet minSpareRows? - if (emptyRows < priv.settings.minSpareRows) { - for (; emptyRows < priv.settings.minSpareRows && instance.countRows() < priv.settings.maxRows; emptyRows++) { - datamap.createRow(); - } - } - - //count currently empty cols - emptyCols = instance.countEmptyCols(true); - - //should I add empty cols to meet minCols? - if (!priv.settings.columns && instance.countCols() < priv.settings.minCols) { - for (; instance.countCols() < priv.settings.minCols; emptyCols++) { - datamap.createCol(); - } - } - - //should I add empty cols to meet minSpareCols? - if (!priv.settings.columns && priv.dataType === 'array' && emptyCols < priv.settings.minSpareCols) { - for (; emptyCols < priv.settings.minSpareCols && instance.countCols() < priv.settings.maxCols; emptyCols++) { - datamap.createCol(); - } - } - - if (priv.settings.enterBeginsEditing) { - for (; (((priv.settings.minRows || priv.settings.minSpareRows) && instance.countRows() > priv.settings.minRows) && (priv.settings.minSpareRows && emptyRows > priv.settings.minSpareRows)); emptyRows--) { - datamap.removeRow(); - } - } - - if (priv.settings.enterBeginsEditing && !priv.settings.columns) { - for (; (((priv.settings.minCols || priv.settings.minSpareCols) && instance.countCols() > priv.settings.minCols) && (priv.settings.minSpareCols && emptyCols > priv.settings.minSpareCols)); emptyCols--) { - datamap.removeCol(); - } - } - - var rowCount = instance.countRows(); - var colCount = instance.countCols(); - - if (rowCount === 0 || colCount === 0) { - selection.deselect(); - } - - if (priv.selStart.exists()) { - var selectionChanged; - var fromRow = priv.selStart.row(); - var fromCol = priv.selStart.col(); - var toRow = priv.selEnd.row(); - var toCol = priv.selEnd.col(); - - //if selection is outside, move selection to last row - if (fromRow > rowCount - 1) { - fromRow = rowCount - 1; - selectionChanged = true; - if (toRow > fromRow) { - toRow = fromRow; - } - } else if (toRow > rowCount - 1) { - toRow = rowCount - 1; - selectionChanged = true; - if (fromRow > toRow) { - fromRow = toRow; - } - } - - //if selection is outside, move selection to last row - if (fromCol > colCount - 1) { - fromCol = colCount - 1; - selectionChanged = true; - if (toCol > fromCol) { - toCol = fromCol; - } - } else if (toCol > colCount - 1) { - toCol = colCount - 1; - selectionChanged = true; - if (fromCol > toCol) { - fromCol = toCol; - } - } - - if (selectionChanged) { - instance.selectCell(fromRow, fromCol, toRow, toCol); - } - } - }, - - /** - * Populate cells at position with 2d array - * @param {Object} start Start selection position - * @param {Array} input 2d array - * @param {Object} [end] End selection position (only for drag-down mode) - * @param {String} [source="populateFromArray"] - * @param {String} [method="overwrite"] - * @return {Object|undefined} ending td in pasted area (only if any cell was changed) - */ - populateFromArray: function (start, input, end, source, method) { - var r, rlen, c, clen, setData = [], current = {}; - rlen = input.length; - if (rlen === 0) { - return false; - } - - var repeatCol - , repeatRow - , cmax - , rmax; - - // insert data with specified pasteMode method - switch (method) { - case 'shift_down' : - repeatCol = end ? end.col - start.col + 1 : 0; - repeatRow = end ? end.row - start.row + 1 : 0; - input = Handsontable.helper.translateRowsToColumns(input); - for (c = 0, clen = input.length, cmax = Math.max(clen, repeatCol); c < cmax; c++) { - if (c < clen) { - for (r = 0, rlen = input[c].length; r < repeatRow - rlen; r++) { - input[c].push(input[c][r % rlen]); - } - input[c].unshift(start.col + c, start.row, 0); - instance.spliceCol.apply(instance, input[c]); - } - else { - input[c % clen][0] = start.col + c; - instance.spliceCol.apply(instance, input[c % clen]); - } - } - break; - - case 'shift_right' : - repeatCol = end ? end.col - start.col + 1 : 0; - repeatRow = end ? end.row - start.row + 1 : 0; - for (r = 0, rlen = input.length, rmax = Math.max(rlen, repeatRow); r < rmax; r++) { - if (r < rlen) { - for (c = 0, clen = input[r].length; c < repeatCol - clen; c++) { - input[r].push(input[r][c % clen]); - } - input[r].unshift(start.row + r, start.col, 0); - instance.spliceRow.apply(instance, input[r]); - } - else { - input[r % rlen][0] = start.row + r; - instance.spliceRow.apply(instance, input[r % rlen]); - } - } - break; - - case 'overwrite' : - default: - // overwrite and other not specified options - current.row = start.row; - current.col = start.col; - for (r = 0; r < rlen; r++) { - if ((end && current.row > end.row) || (!priv.settings.minSpareRows && current.row > instance.countRows() - 1) || (current.row >= priv.settings.maxRows)) { - break; - } - current.col = start.col; - clen = input[r] ? input[r].length : 0; - for (c = 0; c < clen; c++) { - if ((end && current.col > end.col) || (!priv.settings.minSpareCols && current.col > instance.countCols() - 1) || (current.col >= priv.settings.maxCols)) { - break; - } - if (!instance.getCellMeta(current.row, current.col).readOnly) { - setData.push([current.row, current.col, input[r][c]]); - } - current.col++; - if (end && c === clen - 1) { - c = -1; - } - } - current.row++; - if (end && r === rlen - 1) { - r = -1; - } - } - instance.setDataAtCell(setData, null, null, source || 'populateFromArray'); - break; - } - }, - - /** - * Returns the top left (TL) and bottom right (BR) selection coordinates - * @param {Object[]} coordsArr - * @returns {Object} - */ - getCornerCoords: function (coordsArr) { - function mapProp(func, array, prop) { - function getProp(el) { - return el[prop]; - } - - if (Array.prototype.map) { - return func.apply(Math, array.map(getProp)); - } - return func.apply(Math, $.map(array, getProp)); - } - - return { - TL: { - row: mapProp(Math.min, coordsArr, "row"), - col: mapProp(Math.min, coordsArr, "col") - }, - BR: { - row: mapProp(Math.max, coordsArr, "row"), - col: mapProp(Math.max, coordsArr, "col") - } - }; - }, - - /** - * Returns array of td objects given start and end coordinates - */ - getCellsAtCoords: function (start, end) { - var corners = grid.getCornerCoords([start, end]); - var r, c, output = []; - for (r = corners.TL.row; r <= corners.BR.row; r++) { - for (c = corners.TL.col; c <= corners.BR.col; c++) { - output.push(instance.view.getCellAtCoords({ - row: r, - col: c - })); - } - } - return output; - } - }; - - this.selection = selection = { //this public assignment is only temporary - inProgress: false, - - /** - * Sets inProgress to true. This enables onSelectionEnd and onSelectionEndByProp to function as desired - */ - begin: function () { - instance.selection.inProgress = true; - }, - - /** - * Sets inProgress to false. Triggers onSelectionEnd and onSelectionEndByProp - */ - finish: function () { - var sel = instance.getSelected(); - instance.PluginHooks.run("afterSelectionEnd", sel[0], sel[1], sel[2], sel[3]); - instance.PluginHooks.run("afterSelectionEndByProp", sel[0], instance.colToProp(sel[1]), sel[2], instance.colToProp(sel[3])); - instance.selection.inProgress = false; - }, - - isInProgress: function () { - return instance.selection.inProgress; - }, - - /** - * Starts selection range on given td object - * @param {Object} coords - */ - setRangeStart: function (coords) { - priv.selStart.coords(coords); - selection.setRangeEnd(coords); - }, - - /** - * Ends selection range on given td object - * @param {Object} coords - * @param {Boolean} [scrollToCell=true] If true, viewport will be scrolled to range end - */ - setRangeEnd: function (coords, scrollToCell) { - instance.selection.begin(); - - priv.selEnd.coords(coords); - if (!priv.settings.multiSelect) { - priv.selStart.coords(coords); - } - - //set up current selection - instance.view.wt.selections.current.clear(); - instance.view.wt.selections.current.add(priv.selStart.arr()); - - //set up area selection - instance.view.wt.selections.area.clear(); - if (selection.isMultiple()) { - instance.view.wt.selections.area.add(priv.selStart.arr()); - instance.view.wt.selections.area.add(priv.selEnd.arr()); - } - - //set up highlight - if (priv.settings.currentRowClassName || priv.settings.currentColClassName) { - instance.view.wt.selections.highlight.clear(); - instance.view.wt.selections.highlight.add(priv.selStart.arr()); - instance.view.wt.selections.highlight.add(priv.selEnd.arr()); - } - - //trigger handlers - instance.PluginHooks.run("afterSelection", priv.selStart.row(), priv.selStart.col(), priv.selEnd.row(), priv.selEnd.col()); - instance.PluginHooks.run("afterSelectionByProp", priv.selStart.row(), datamap.colToProp(priv.selStart.col()), priv.selEnd.row(), datamap.colToProp(priv.selEnd.col())); - - if (scrollToCell !== false) { - instance.view.scrollViewport(coords); - } - selection.refreshBorders(); - }, - - /** - * Destroys editor, redraws borders around cells, prepares editor - * @param {Boolean} revertOriginal - * @param {Boolean} keepEditor - */ - refreshBorders: function (revertOriginal, keepEditor) { - if (!keepEditor) { - editorManager.destroyEditor(revertOriginal); - } - instance.view.render(); - if (selection.isSelected() && !keepEditor) { - editorManager.prepareEditor(); - } - }, - - /** - * Returns information if we have a multiselection - * @return {Boolean} - */ - isMultiple: function () { - return !(priv.selEnd.col() === priv.selStart.col() && priv.selEnd.row() === priv.selStart.row()); - }, - - /** - * Selects cell relative to current cell (if possible) - */ - transformStart: function (rowDelta, colDelta, force) { - if (priv.selStart.row() + rowDelta > instance.countRows() - 1) { - if (force && priv.settings.minSpareRows > 0) { - instance.alter("insert_row", instance.countRows()); - } - else if (priv.settings.autoWrapCol) { - rowDelta = 1 - instance.countRows(); - colDelta = priv.selStart.col() + colDelta == instance.countCols() - 1 ? 1 - instance.countCols() : 1; - } - } - else if (priv.settings.autoWrapCol && priv.selStart.row() + rowDelta < 0 && priv.selStart.col() + colDelta >= 0) { - rowDelta = instance.countRows() - 1; - colDelta = priv.selStart.col() + colDelta == 0 ? instance.countCols() - 1 : -1; - } - - if (priv.selStart.col() + colDelta > instance.countCols() - 1) { - if (force && priv.settings.minSpareCols > 0) { - instance.alter("insert_col", instance.countCols()); - } - else if (priv.settings.autoWrapRow) { - rowDelta = priv.selStart.row() + rowDelta == instance.countRows() - 1 ? 1 - instance.countRows() : 1; - colDelta = 1 - instance.countCols(); - } - } - else if (priv.settings.autoWrapRow && priv.selStart.col() + colDelta < 0 && priv.selStart.row() + rowDelta >= 0) { - rowDelta = priv.selStart.row() + rowDelta == 0 ? instance.countRows() - 1 : -1; - colDelta = instance.countCols() - 1; - } - - var totalRows = instance.countRows(); - var totalCols = instance.countCols(); - var coords = { - row: priv.selStart.row() + rowDelta, - col: priv.selStart.col() + colDelta - }; - - if (coords.row < 0) { - coords.row = 0; - } - else if (coords.row > 0 && coords.row >= totalRows) { - coords.row = totalRows - 1; - } - - if (coords.col < 0) { - coords.col = 0; - } - else if (coords.col > 0 && coords.col >= totalCols) { - coords.col = totalCols - 1; - } - - selection.setRangeStart(coords); - }, - - /** - * Sets selection end cell relative to current selection end cell (if possible) - */ - transformEnd: function (rowDelta, colDelta) { - if (priv.selEnd.exists()) { - var totalRows = instance.countRows(); - var totalCols = instance.countCols(); - var coords = { - row: priv.selEnd.row() + rowDelta, - col: priv.selEnd.col() + colDelta - }; - - if (coords.row < 0) { - coords.row = 0; - } - else if (coords.row > 0 && coords.row >= totalRows) { - coords.row = totalRows - 1; - } - - if (coords.col < 0) { - coords.col = 0; - } - else if (coords.col > 0 && coords.col >= totalCols) { - coords.col = totalCols - 1; - } - - selection.setRangeEnd(coords); - } - }, - - /** - * Returns true if currently there is a selection on screen, false otherwise - * @return {Boolean} - */ - isSelected: function () { - return priv.selEnd.exists(); - }, - - /** - * Returns true if coords is within current selection coords - * @return {Boolean} - */ - inInSelection: function (coords) { - if (!selection.isSelected()) { - return false; - } - var sel = grid.getCornerCoords([priv.selStart.coords(), priv.selEnd.coords()]); - return (sel.TL.row <= coords.row && sel.BR.row >= coords.row && sel.TL.col <= coords.col && sel.BR.col >= coords.col); - }, - - /** - * Deselects all selected cells - */ - deselect: function () { - if (!selection.isSelected()) { - return; - } - instance.selection.inProgress = false; //needed by HT inception - priv.selEnd = new Handsontable.SelectionPoint(); //create new empty point to remove the existing one - instance.view.wt.selections.current.clear(); - instance.view.wt.selections.area.clear(); - editorManager.destroyEditor(); - selection.refreshBorders(); - instance.PluginHooks.run('afterDeselect'); - }, - - /** - * Select all cells - */ - selectAll: function () { - if (!priv.settings.multiSelect) { - return; - } - selection.setRangeStart({ - row: 0, - col: 0 - }); - selection.setRangeEnd({ - row: instance.countRows() - 1, - col: instance.countCols() - 1 - }, false); - }, - - /** - * Deletes data from selected cells - */ - empty: function () { - if (!selection.isSelected()) { - return; - } - var corners = grid.getCornerCoords([priv.selStart.coords(), priv.selEnd.coords()]); - var r, c, changes = []; - for (r = corners.TL.row; r <= corners.BR.row; r++) { - for (c = corners.TL.col; c <= corners.BR.col; c++) { - if (!instance.getCellMeta(r, c).readOnly) { - changes.push([r, c, '']); - } - } - } - instance.setDataAtCell(changes); - } - }; - - this.autofill = autofill = { //this public assignment is only temporary - handle: null, - - /** - * Create fill handle and fill border objects - */ - init: function () { - if (!autofill.handle) { - autofill.handle = {}; - } - else { - autofill.handle.disabled = false; - } - }, - - /** - * Hide fill handle and fill border permanently - */ - disable: function () { - autofill.handle.disabled = true; - }, - - /** - * Selects cells down to the last row in the left column, then fills down to that cell - */ - selectAdjacent: function () { - var select, data, r, maxR, c; - - if (selection.isMultiple()) { - select = instance.view.wt.selections.area.getCorners(); - } - else { - select = instance.view.wt.selections.current.getCorners(); - } - - data = datamap.getAll(); - rows : for (r = select[2] + 1; r < instance.countRows(); r++) { - for (c = select[1]; c <= select[3]; c++) { - if (data[r][c]) { - break rows; - } - } - if (!!data[r][select[1] - 1] || !!data[r][select[3] + 1]) { - maxR = r; - } - } - if (maxR) { - instance.view.wt.selections.fill.clear(); - instance.view.wt.selections.fill.add([select[0], select[1]]); - instance.view.wt.selections.fill.add([maxR, select[3]]); - autofill.apply(); - } - }, - - /** - * Apply fill values to the area in fill border, omitting the selection border - */ - apply: function () { - var drag, select, start, end, _data; - - autofill.handle.isDragged = 0; - - drag = instance.view.wt.selections.fill.getCorners(); - if (!drag) { - return; - } - - instance.view.wt.selections.fill.clear(); - - if (selection.isMultiple()) { - select = instance.view.wt.selections.area.getCorners(); - } - else { - select = instance.view.wt.selections.current.getCorners(); - } - - if (drag[0] === select[0] && drag[1] < select[1]) { - start = { - row: drag[0], - col: drag[1] - }; - end = { - row: drag[2], - col: select[1] - 1 - }; - } - else if (drag[0] === select[0] && drag[3] > select[3]) { - start = { - row: drag[0], - col: select[3] + 1 - }; - end = { - row: drag[2], - col: drag[3] - }; - } - else if (drag[0] < select[0] && drag[1] === select[1]) { - start = { - row: drag[0], - col: drag[1] - }; - end = { - row: select[0] - 1, - col: drag[3] - }; - } - else if (drag[2] > select[2] && drag[1] === select[1]) { - start = { - row: select[2] + 1, - col: drag[1] - }; - end = { - row: drag[2], - col: drag[3] - }; - } - - if (start) { - - _data = SheetClip.parse(datamap.getText(priv.selStart.coords(), priv.selEnd.coords())); - instance.PluginHooks.run('beforeAutofill', start, end, _data); - - grid.populateFromArray(start, _data, end, 'autofill'); - - selection.setRangeStart({row: drag[0], col: drag[1]}); - selection.setRangeEnd({row: drag[2], col: drag[3]}); - } - /*else { - //reset to avoid some range bug - selection.refreshBorders(); - }*/ - }, - - /** - * Show fill border - */ - showBorder: function (coords) { - coords.row = coords[0]; - coords.col = coords[1]; - - var corners = grid.getCornerCoords([priv.selStart.coords(), priv.selEnd.coords()]); - if (priv.settings.fillHandle !== 'horizontal' && (corners.BR.row < coords.row || corners.TL.row > coords.row)) { - coords = [coords.row, corners.BR.col]; - } - else if (priv.settings.fillHandle !== 'vertical') { - coords = [corners.BR.row, coords.col]; - } - else { - return; //wrong direction - } - - instance.view.wt.selections.fill.clear(); - instance.view.wt.selections.fill.add([priv.selStart.coords().row, priv.selStart.coords().col]); - instance.view.wt.selections.fill.add([priv.selEnd.coords().row, priv.selEnd.coords().col]); - instance.view.wt.selections.fill.add(coords); - instance.view.render(); - } - }; - - this.init = function () { - instance.PluginHooks.run('beforeInit'); - - this.view = new Handsontable.TableView(this); - editorManager = new Handsontable.EditorManager(instance, priv, selection, datamap); - - this.updateSettings(priv.settings, true); - this.parseSettingsFromDOM(); - - - this.forceFullRender = true; //used when data was changed - this.view.render(); - - if (typeof priv.firstRun === 'object') { - instance.PluginHooks.run('afterChange', priv.firstRun[0], priv.firstRun[1]); - priv.firstRun = false; - } - instance.PluginHooks.run('afterInit'); - }; - - function ValidatorsQueue() { //moved this one level up so it can be used in any function here. Probably this should be moved to a separate file - var resolved = false; - - return { - validatorsInQueue: 0, - addValidatorToQueue: function () { - this.validatorsInQueue++; - resolved = false; - }, - removeValidatorFormQueue: function () { - this.validatorsInQueue = this.validatorsInQueue - 1 < 0 ? 0 : this.validatorsInQueue - 1; - this.checkIfQueueIsEmpty(); - }, - onQueueEmpty: function () { - }, - checkIfQueueIsEmpty: function () { - if (this.validatorsInQueue == 0 && resolved == false) { - resolved = true; - this.onQueueEmpty(); - } - } - }; - } - - function validateChanges(changes, source, callback) { - var waitingForValidator = new ValidatorsQueue(); - waitingForValidator.onQueueEmpty = resolve; - - for (var i = changes.length - 1; i >= 0; i--) { - if (changes[i] === null) { - changes.splice(i, 1); - } - else { - var row = changes[i][0]; - var col = datamap.propToCol(changes[i][1]); - var logicalCol = instance.runHooksAndReturn('modifyCol', col); //column order may have changes, so we need to translate physical col index (stored in datasource) to logical (displayed to user) - var cellProperties = instance.getCellMeta(row, logicalCol); - - if (cellProperties.type === 'numeric' && typeof changes[i][3] === 'string') { - if (changes[i][3].length > 0 && /^-?[\d\s]*\.?\d*$/.test(changes[i][3])) { - changes[i][3] = numeral().unformat(changes[i][3] || '0'); //numeral cannot unformat empty string - } - } - - if (instance.getCellValidator(cellProperties)) { - waitingForValidator.addValidatorToQueue(); - instance.validateCell(changes[i][3], cellProperties, (function (i, cellProperties) { - return function (result) { - if (typeof result !== 'boolean') { - throw new Error("Validation error: result is not boolean"); - } - if (result === false && cellProperties.allowInvalid === false) { - changes.splice(i, 1); // cancel the change - cellProperties.valid = true; // we cancelled the change, so cell value is still valid - --i; - } - waitingForValidator.removeValidatorFormQueue(); - } - })(i, cellProperties) - , source); - } - } - } - waitingForValidator.checkIfQueueIsEmpty(); - - function resolve() { - var beforeChangeResult; - - if (changes.length) { - beforeChangeResult = instance.PluginHooks.execute("beforeChange", changes, source); - if (typeof beforeChangeResult === 'function') { - $.when(result).then(function () { - callback(); //called when async validators and async beforeChange are resolved - }); - } - else if (beforeChangeResult === false) { - changes.splice(0, changes.length); //invalidate all changes (remove everything from array) - } - } - if (typeof beforeChangeResult !== 'function') { - callback(); //called when async validators are resolved and beforeChange was not async - } - } - } - - /** - * Internal function to apply changes. Called after validateChanges - * @param {Array} changes Array in form of [row, prop, oldValue, newValue] - * @param {String} source String that identifies how this change will be described in changes array (useful in onChange callback) - */ - function applyChanges(changes, source) { - var i = changes.length - 1; - - if (i < 0) { - return; - } - - for (; 0 <= i; i--) { - if (changes[i] === null) { - changes.splice(i, 1); - continue; - } - - if (priv.settings.minSpareRows) { - while (changes[i][0] > instance.countRows() - 1) { - datamap.createRow(); - } - } - - if (priv.dataType === 'array' && priv.settings.minSpareCols) { - while (datamap.propToCol(changes[i][1]) > instance.countCols() - 1) { - datamap.createCol(); - } - } - - datamap.set(changes[i][0], changes[i][1], changes[i][3]); - } - - instance.forceFullRender = true; //used when data was changed - grid.adjustRowsAndCols(); - selection.refreshBorders(null, true); - instance.PluginHooks.run('afterChange', changes, source || 'edit'); - } - - this.validateCell = function (value, cellProperties, callback, source) { - var validator = instance.getCellValidator(cellProperties); - - if (Object.prototype.toString.call(validator) === '[object RegExp]') { - validator = (function (validator) { - return function (value, callback) { - callback(validator.test(value)); - } - })(validator); - } - - if (typeof validator == 'function') { - - value = instance.PluginHooks.execute("beforeValidate", value, cellProperties.row, cellProperties.prop, source); - - // To provide consistent behaviour, validation should be always asynchronous - setTimeout(function () { - validator.call(cellProperties, value, function (valid) { - cellProperties.valid = valid; - - valid = instance.PluginHooks.execute("afterValidate", valid, value, cellProperties.row, cellProperties.prop, source); - - callback(valid); - }); - }); - - } else { //resolve callback even if validator function was not found - cellProperties.valid = true; - callback(true); - } - - - - }; - - function setDataInputToArray(row, prop_or_col, value) { - if (typeof row === "object") { //is it an array of changes - return row; - } - else if ($.isPlainObject(value)) { //backwards compatibility - return value; - } - else { - return [ - [row, prop_or_col, value] - ]; - } - } - - /** - * Set data at given cell - * @public - * @param {Number|Array} row or array of changes in format [[row, col, value], ...] - * @param {Number|String} col or source String - * @param {String} value - * @param {String} source String that identifies how this change will be described in changes array (useful in onChange callback) - */ - this.setDataAtCell = function (row, col, value, source) { - var input = setDataInputToArray(row, col, value) - , i - , ilen - , changes = [] - , prop; - - for (i = 0, ilen = input.length; i < ilen; i++) { - if (typeof input[i] !== 'object') { - throw new Error('Method `setDataAtCell` accepts row number or changes array of arrays as its first parameter'); - } - if (typeof input[i][1] !== 'number') { - throw new Error('Method `setDataAtCell` accepts row and column number as its parameters. If you want to use object property name, use method `setDataAtRowProp`'); - } - prop = datamap.colToProp(input[i][1]); - changes.push([ - input[i][0], - prop, - datamap.get(input[i][0], prop), - input[i][2] - ]); - } - - if (!source && typeof row === "object") { - source = col; - } - - validateChanges(changes, source, function () { - applyChanges(changes, source); - }); - }; - - - /** - * Set data at given row property - * @public - * @param {Number|Array} row or array of changes in format [[row, prop, value], ...] - * @param {String} prop or source String - * @param {String} value - * @param {String} source String that identifies how this change will be described in changes array (useful in onChange callback) - */ - this.setDataAtRowProp = function (row, prop, value, source) { - var input = setDataInputToArray(row, prop, value) - , i - , ilen - , changes = []; - - for (i = 0, ilen = input.length; i < ilen; i++) { - changes.push([ - input[i][0], - input[i][1], - datamap.get(input[i][0], input[i][1]), - input[i][2] - ]); - } - - if (!source && typeof row === "object") { - source = prop; - } - - validateChanges(changes, source, function () { - applyChanges(changes, source); - }); - }; - - /** - * Listen to document body keyboard input - */ - this.listen = function () { - Handsontable.activeGuid = instance.guid; - - if (document.activeElement && document.activeElement !== document.body) { - document.activeElement.blur(); - } - else if (!document.activeElement) { //IE - document.body.focus(); - } - }; - - /** - * Stop listening to document body keyboard input - */ - this.unlisten = function () { - Handsontable.activeGuid = null; - }; - - /** - * Returns true if current Handsontable instance is listening on document body keyboard input - */ - this.isListening = function () { - return Handsontable.activeGuid === instance.guid; - }; - - /** - * Destroys current editor, renders and selects current cell. If revertOriginal != true, edited data is saved - * @param {Boolean} revertOriginal - */ - this.destroyEditor = function (revertOriginal) { - selection.refreshBorders(revertOriginal); - }; - - /** - * Populate cells at position with 2d array - * @param {Number} row Start row - * @param {Number} col Start column - * @param {Array} input 2d array - * @param {Number=} endRow End row (use when you want to cut input when certain row is reached) - * @param {Number=} endCol End column (use when you want to cut input when certain column is reached) - * @param {String=} [source="populateFromArray"] - * @param {String=} [method="overwrite"] - * @return {Object|undefined} ending td in pasted area (only if any cell was changed) - */ - this.populateFromArray = function (row, col, input, endRow, endCol, source, method) { - if (!(typeof input === 'object' && typeof input[0] === 'object')) { - throw new Error("populateFromArray parameter `input` must be an array of arrays"); //API changed in 0.9-beta2, let's check if you use it correctly - } - return grid.populateFromArray({row: row, col: col}, input, typeof endRow === 'number' ? {row: endRow, col: endCol} : null, source, method); - }; - - /** - * Adds/removes data from the column - * @param {Number} col Index of column in which do you want to do splice. - * @param {Number} index Index at which to start changing the array. If negative, will begin that many elements from the end - * @param {Number} amount An integer indicating the number of old array elements to remove. If amount is 0, no elements are removed - * param {...*} elements Optional. The elements to add to the array. If you don't specify any elements, spliceCol simply removes elements from the array - */ - this.spliceCol = function (col, index, amount/*, elements... */) { - return datamap.spliceCol.apply(null, arguments); - }; - - /** - * Adds/removes data from the row - * @param {Number} row Index of column in which do you want to do splice. - * @param {Number} index Index at which to start changing the array. If negative, will begin that many elements from the end - * @param {Number} amount An integer indicating the number of old array elements to remove. If amount is 0, no elements are removed - * param {...*} elements Optional. The elements to add to the array. If you don't specify any elements, spliceCol simply removes elements from the array - */ - this.spliceRow = function (row, index, amount/*, elements... */) { - return datamap.spliceRow.apply(null, arguments); - }; - - /** - * Returns the top left (TL) and bottom right (BR) selection coordinates - * @param {Object[]} coordsArr - * @returns {Object} - */ - this.getCornerCoords = function (coordsArr) { - return grid.getCornerCoords(coordsArr); - }; - - /** - * Returns current selection. Returns undefined if there is no selection. - * @public - * @return {Array} [`startRow`, `startCol`, `endRow`, `endCol`] - */ - this.getSelected = function () { //https://github.com/warpech/jquery-handsontable/issues/44 //cjl - if (selection.isSelected()) { - return [priv.selStart.row(), priv.selStart.col(), priv.selEnd.row(), priv.selEnd.col()]; - } - }; - - /** - * Parse settings from DOM and CSS - * @public - */ - this.parseSettingsFromDOM = function () { - var overflow = this.rootElement.css('overflow'); - if (overflow === 'scroll' || overflow === 'auto') { - this.rootElement[0].style.overflow = 'visible'; - priv.settingsFromDOM.overflow = overflow; - } - else if (priv.settings.width === void 0 || priv.settings.height === void 0) { - priv.settingsFromDOM.overflow = 'auto'; - } - - if (priv.settings.width === void 0) { - priv.settingsFromDOM.width = this.rootElement.width(); - } - else { - priv.settingsFromDOM.width = void 0; - } - - priv.settingsFromDOM.height = void 0; - if (priv.settings.height === void 0) { - if (priv.settingsFromDOM.overflow === 'scroll' || priv.settingsFromDOM.overflow === 'auto') { - //this needs to read only CSS/inline style and not actual height - //so we need to call getComputedStyle on cloned container - var clone = this.rootElement[0].cloneNode(false); - var parent = this.rootElement[0].parentNode; - if (parent) { - clone.removeAttribute('id'); - parent.appendChild(clone); - var computedHeight = parseInt(window.getComputedStyle(clone, null).getPropertyValue('height'), 10); - - if(isNaN(computedHeight) && clone.currentStyle){ - computedHeight = parseInt(clone.currentStyle.height, 10) - } - - if (computedHeight > 0) { - priv.settingsFromDOM.height = computedHeight; - } - parent.removeChild(clone); - } - } - } - }; - - /** - * Render visible data - * @public - */ - this.render = function () { - if (instance.view) { - instance.forceFullRender = true; //used when data was changed - instance.parseSettingsFromDOM(); - selection.refreshBorders(null, true); - } - }; - - /** - * Load data from array - * @public - * @param {Array} data - */ - this.loadData = function (data) { - if (typeof data === 'object' && data !== null) { - if (!(data.push && data.splice)) { //check if data is array. Must use duck-type check so Backbone Collections also pass it - //when data is not an array, attempt to make a single-row array of it - data = [data]; - } - } - else if(data === null) { - data = []; - var row; - for (var r = 0, rlen = priv.settings.startRows; r < rlen; r++) { - row = []; - for (var c = 0, clen = priv.settings.startCols; c < clen; c++) { - row.push(null); - } - data.push(row); - } - } - else { - throw new Error("loadData only accepts array of objects or array of arrays (" + typeof data + " given)"); - } - - priv.isPopulated = false; - GridSettings.prototype.data = data; - - if (priv.settings.dataSchema instanceof Array || data[0] instanceof Array) { - priv.dataType = 'array'; - } - else if (typeof priv.settings.dataSchema === 'function') { - priv.dataType = 'function'; - } - else { - priv.dataType = 'object'; - } - - if (data[0]) { - priv.duckDataSchema = datamap.recursiveDuckSchema(data[0]); - } - else { - priv.duckDataSchema = {}; - } - datamap.createMap(); - clearCellSettingCache(); - - grid.adjustRowsAndCols(); - instance.PluginHooks.run('afterLoadData'); - - if (priv.firstRun) { - priv.firstRun = [null, 'loadData']; - } - else { - instance.PluginHooks.run('afterChange', null, 'loadData'); - instance.render(); - } - - priv.isPopulated = true; - - - - function clearCellSettingCache() { - priv.cellSettings.length = 0; - } - }; - - /** - * Return the current data object (the same that was passed by `data` configuration option or `loadData` method). Optionally you can provide cell range `r`, `c`, `r2`, `c2` to get only a fragment of grid data - * @public - * @param {Number} r (Optional) From row - * @param {Number} c (Optional) From col - * @param {Number} r2 (Optional) To row - * @param {Number} c2 (Optional) To col - * @return {Array|Object} - */ - this.getData = function (r, c, r2, c2) { - if (typeof r === 'undefined') { - return datamap.getAll(); - } - else { - return datamap.getRange({row: r, col: c}, {row: r2, col: c2}); - } - }; - - this.getCopyableData = function (startRow, startCol, endRow, endCol) { - return datamap.getText({row: startRow, col: startCol}, {row: endRow, col: endCol}); - }; - - /** - * Update settings - * @public - */ - this.updateSettings = function (settings, init) { - var i, clen; - - if (typeof settings.rows !== "undefined") { - throw new Error("'rows' setting is no longer supported. do you mean startRows, minRows or maxRows?"); - } - if (typeof settings.cols !== "undefined") { - throw new Error("'cols' setting is no longer supported. do you mean startCols, minCols or maxCols?"); - } - - for (i in settings) { - if (i === 'data') { - continue; //loadData will be triggered later - } - else { - if (instance.PluginHooks.hooks[i] !== void 0 || instance.PluginHooks.legacy[i] !== void 0) { - if (typeof settings[i] === 'function' || Handsontable.helper.isArray(settings[i])) { - instance.PluginHooks.add(i, settings[i]); - } - } - else { - // Update settings - if (!init && settings.hasOwnProperty(i)) { - GridSettings.prototype[i] = settings[i]; - } - - //launch extensions - if (Handsontable.extension[i]) { - priv.extensions[i] = new Handsontable.extension[i](instance, settings[i]); - } - } - } - } - - // Load data or create data map - if (settings.data === void 0 && priv.settings.data === void 0) { - instance.loadData(null); //data source created just now - } - else if (settings.data !== void 0) { - instance.loadData(settings.data); //data source given as option - } - else if (settings.columns !== void 0) { - datamap.createMap(); - } - - // Init columns constructors configuration - clen = instance.countCols(); - - //Clear cellSettings cache - priv.cellSettings.length = 0; - - if (clen > 0) { - var proto, column; - - for (i = 0; i < clen; i++) { - priv.columnSettings[i] = Handsontable.helper.columnFactory(GridSettings, priv.columnsSettingConflicts); - - // shortcut for prototype - proto = priv.columnSettings[i].prototype; - - // Use settings provided by user - if (GridSettings.prototype.columns) { - column = GridSettings.prototype.columns[i]; - Handsontable.helper.extend(proto, column); - Handsontable.helper.extend(proto, expandType(column)); - } - } - } - - if (typeof settings.fillHandle !== "undefined") { - if (autofill.handle && settings.fillHandle === false) { - autofill.disable(); - } - else if (!autofill.handle && settings.fillHandle !== false) { - autofill.init(); - } - } - - if (typeof settings.className !== "undefined") { - if (GridSettings.prototype.className) { - instance.rootElement.removeClass(GridSettings.prototype.className); - } - if (settings.className) { - instance.rootElement.addClass(settings.className); - } - } - - if (!init) { - instance.PluginHooks.run('afterUpdateSettings'); - } - - grid.adjustRowsAndCols(); - if (instance.view && !priv.firstRun) { - instance.forceFullRender = true; //used when data was changed - selection.refreshBorders(null, true); - } - }; - - this.getValue = function () { - var sel = instance.getSelected(); - if (GridSettings.prototype.getValue) { - if (typeof GridSettings.prototype.getValue === 'function') { - return GridSettings.prototype.getValue.call(instance); - } - else if (sel) { - return instance.getData()[sel[0]][GridSettings.prototype.getValue]; - } - } - else if (sel) { - return instance.getDataAtCell(sel[0], sel[1]); - } - }; - - function expandType(obj) { - if (!obj.hasOwnProperty('type')) return; //ignore obj.prototype.type - - - var type, expandedType = {}; - - if (typeof obj.type === 'object') { - type = obj.type; - } - else if (typeof obj.type === 'string') { - type = Handsontable.cellTypes[obj.type]; - if (type === void 0) { - throw new Error('You declared cell type "' + obj.type + '" as a string that is not mapped to a known object. Cell type must be an object or a string mapped to an object in Handsontable.cellTypes'); - } - } - - - for (var i in type) { - if (type.hasOwnProperty(i) && !obj.hasOwnProperty(i)) { - expandedType[i] = type[i]; - } - } - - return expandedType; - - } - - /** - * Returns current settings object - * @return {Object} - */ - this.getSettings = function () { - return priv.settings; - }; - - /** - * Returns current settingsFromDOM object - * @return {Object} - */ - this.getSettingsFromDOM = function () { - return priv.settingsFromDOM; - }; - - /** - * Clears grid - * @public - */ - this.clear = function () { - selection.selectAll(); - selection.empty(); - }; - - /** - * Inserts or removes rows and columns - * @param {String} action See grid.alter for possible values - * @param {Number} index - * @param {Number} amount - * @param {String} [source] Optional. Source of hook runner. - * @param {Boolean} [keepEmptyRows] Optional. Flag for preventing deletion of empty rows. - * @public - */ - this.alter = function (action, index, amount, source, keepEmptyRows) { - grid.alter(action, index, amount, source, keepEmptyRows); - }; - - /** - * Returns element corresponding to params row, col - * @param {Number} row - * @param {Number} col - * @public - * @return {Element} - */ - this.getCell = function (row, col) { - return instance.view.getCellAtCoords({row: row, col: col}); - }; - - /** - * Returns property name associated with column number - * @param {Number} col - * @public - * @return {String} - */ - this.colToProp = function (col) { - return datamap.colToProp(col); - }; - - /** - * Returns column number associated with property name - * @param {String} prop - * @public - * @return {Number} - */ - this.propToCol = function (prop) { - return datamap.propToCol(prop); - }; - - /** - * Return value at `row`, `col` - * @param {Number} row - * @param {Number} col - * @public - * @return value (mixed data type) - */ - this.getDataAtCell = function (row, col) { - return datamap.get(row, datamap.colToProp(col)); - }; - - /** - * Return value at `row`, `prop` - * @param {Number} row - * @param {String} prop - * @public - * @return value (mixed data type) - */ - this.getDataAtRowProp = function (row, prop) { - return datamap.get(row, prop); - }; - - /** - * Return value at `col` - * @param {Number} col - * @public - * @return value (mixed data type) - */ - this.getDataAtCol = function (col) { - return [].concat.apply([], datamap.getRange({row: 0, col: col}, {row: priv.settings.data.length - 1, col: col})); - }; - - /** - * Return value at `prop` - * @param {String} prop - * @public - * @return value (mixed data type) - */ - this.getDataAtProp = function (prop) { - return [].concat.apply([], datamap.getRange({row: 0, col: datamap.propToCol(prop)}, {row: priv.settings.data.length - 1, col: datamap.propToCol(prop)})); - }; - - /** - * Return value at `row` - * @param {Number} row - * @public - * @return value (mixed data type) - */ - this.getDataAtRow = function (row) { - return priv.settings.data[row]; - }; - - /** - * Returns cell meta data object corresponding to params row, col - * @param {Number} row - * @param {Number} col - * @public - * @return {Object} - */ - this.getCellMeta = function (row, col) { - var prop = datamap.colToProp(col) - , cellProperties; - - row = translateRowIndex(row); - col = translateColIndex(col); - - if ("undefined" === typeof priv.columnSettings[col]) { - priv.columnSettings[col] = Handsontable.helper.columnFactory(GridSettings, priv.columnsSettingConflicts); - } - - if (!priv.cellSettings[row]) { - priv.cellSettings[row] = []; - } - if (!priv.cellSettings[row][col]) { - priv.cellSettings[row][col] = new priv.columnSettings[col](); - } - - cellProperties = priv.cellSettings[row][col]; //retrieve cellProperties from cache - - cellProperties.row = row; - cellProperties.col = col; - cellProperties.prop = prop; - cellProperties.instance = instance; - - instance.PluginHooks.run('beforeGetCellMeta', row, col, cellProperties); - Handsontable.helper.extend(cellProperties, expandType(cellProperties)); //for `type` added in beforeGetCellMeta - - if (cellProperties.cells) { - var settings = cellProperties.cells.call(cellProperties, row, col, prop); - - if (settings) { - Handsontable.helper.extend(cellProperties, settings); - Handsontable.helper.extend(cellProperties, expandType(settings)); //for `type` added in cells - } - } - - instance.PluginHooks.run('afterGetCellMeta', row, col, cellProperties); - - return cellProperties; - - /** - * If displayed rows order is different than the order of rows stored in memory (i.e. sorting is applied) - * we need to translate logical (stored) row index to physical (displayed) index. - * @param row - original row index - * @returns {int} translated row index - */ - function translateRowIndex(row){ - var getVars = {row: row}; - - instance.PluginHooks.execute('beforeGet', getVars); - - return getVars.row; - } - - /** - * If displayed columns order is different than the order of columns stored in memory (i.e. column were moved using manualColumnMove plugin) - * we need to translate logical (stored) column index to physical (displayed) index. - * @param col - original column index - * @returns {int} - translated column index - */ - function translateColIndex(col){ - return Handsontable.PluginHooks.execute(instance, 'modifyCol', col); // warning: this must be done after datamap.colToProp - } - }; - - this.getCellRenderer = function (row, col) { - var renderer = Handsontable.helper.cellMethodLookupFactory('renderer').call(this, row, col); - return Handsontable.renderers.getRenderer(renderer); - - }; - - this.getCellEditor = Handsontable.helper.cellMethodLookupFactory('editor'); - - this.getCellValidator = Handsontable.helper.cellMethodLookupFactory('validator'); - - - /** - * Validates all cells using their validator functions and calls callback when finished. Does not render the view - * @param callback - */ - this.validateCells = function (callback) { - var waitingForValidator = new ValidatorsQueue(); - waitingForValidator.onQueueEmpty = callback; - - var i = instance.countRows() - 1; - while (i >= 0) { - var j = instance.countCols() - 1; - while (j >= 0) { - waitingForValidator.addValidatorToQueue(); - instance.validateCell(instance.getDataAtCell(i, j), instance.getCellMeta(i, j), function () { - waitingForValidator.removeValidatorFormQueue(); - }, 'validateCells'); - j--; - } - i--; - } - waitingForValidator.checkIfQueueIsEmpty(); - }; - - /** - * Return array of row headers (if they are enabled). If param `row` given, return header at given row as string - * @param {Number} row (Optional) - * @return {Array|String} - */ - this.getRowHeader = function (row) { - if (row === void 0) { - var out = []; - for (var i = 0, ilen = instance.countRows(); i < ilen; i++) { - out.push(instance.getRowHeader(i)); - } - return out; - } - else if (Object.prototype.toString.call(priv.settings.rowHeaders) === '[object Array]' && priv.settings.rowHeaders[row] !== void 0) { - return priv.settings.rowHeaders[row]; - } - else if (typeof priv.settings.rowHeaders === 'function') { - return priv.settings.rowHeaders(row); - } - else if (priv.settings.rowHeaders && typeof priv.settings.rowHeaders !== 'string' && typeof priv.settings.rowHeaders !== 'number') { - return row + 1; - } - else { - return priv.settings.rowHeaders; - } - }; - - /** - * Returns information of this table is configured to display row headers - * @returns {boolean} - */ - this.hasRowHeaders = function () { - return !!priv.settings.rowHeaders; - }; - - /** - * Returns information of this table is configured to display column headers - * @returns {boolean} - */ - this.hasColHeaders = function () { - if (priv.settings.colHeaders !== void 0 && priv.settings.colHeaders !== null) { //Polymer has empty value = null - return !!priv.settings.colHeaders; - } - for (var i = 0, ilen = instance.countCols(); i < ilen; i++) { - if (instance.getColHeader(i)) { - return true; - } - } - return false; - }; - - /** - * Return array of column headers (if they are enabled). If param `col` given, return header at given column as string - * @param {Number} col (Optional) - * @return {Array|String} - */ - this.getColHeader = function (col) { - if (col === void 0) { - var out = []; - for (var i = 0, ilen = instance.countCols(); i < ilen; i++) { - out.push(instance.getColHeader(i)); - } - return out; - } - else { - col = Handsontable.PluginHooks.execute(instance, 'modifyCol', col); - - if (priv.settings.columns && priv.settings.columns[col] && priv.settings.columns[col].title) { - return priv.settings.columns[col].title; - } - else if (Object.prototype.toString.call(priv.settings.colHeaders) === '[object Array]' && priv.settings.colHeaders[col] !== void 0) { - return priv.settings.colHeaders[col]; - } - else if (typeof priv.settings.colHeaders === 'function') { - return priv.settings.colHeaders(col); - } - else if (priv.settings.colHeaders && typeof priv.settings.colHeaders !== 'string' && typeof priv.settings.colHeaders !== 'number') { - return Handsontable.helper.spreadsheetColumnLabel(col); - } - else { - return priv.settings.colHeaders; - } - } - }; - - /** - * Return column width from settings (no guessing). Private use intended - * @param {Number} col - * @return {Number} - */ - this._getColWidthFromSettings = function (col) { - var cellProperties = instance.getCellMeta(0, col); - var width = cellProperties.width; - if (width === void 0 || width === priv.settings.width) { - width = cellProperties.colWidths; - } - if (width !== void 0 && width !== null) { - switch (typeof width) { - case 'object': //array - width = width[col]; - break; - - case 'function': - width = width(col); - break; - } - if (typeof width === 'string') { - width = parseInt(width, 10); - } - } - return width; - }; - - /** - * Return column width - * @param {Number} col - * @return {Number} - */ - this.getColWidth = function (col) { - col = Handsontable.PluginHooks.execute(instance, 'modifyCol', col); - var response = { - width: instance._getColWidthFromSettings(col) - }; - if (!response.width) { - response.width = 50; - } - instance.PluginHooks.run('afterGetColWidth', col, response); - return response.width; - }; - - /** - * Return total number of rows in grid - * @return {Number} - */ - this.countRows = function () { - return priv.settings.data.length; - }; - - /** - * Return total number of columns in grid - * @return {Number} - */ - this.countCols = function () { - if (priv.dataType === 'object' || priv.dataType === 'function') { - if (priv.settings.columns && priv.settings.columns.length) { - return priv.settings.columns.length; - } - else { - return priv.colToProp.length; - } - } - else if (priv.dataType === 'array') { - if (priv.settings.columns && priv.settings.columns.length) { - return priv.settings.columns.length; - } - else if (priv.settings.data && priv.settings.data[0] && priv.settings.data[0].length) { - return priv.settings.data[0].length; - } - else { - return 0; - } - } - }; - - /** - * Return index of first visible row - * @return {Number} - */ - this.rowOffset = function () { - return instance.view.wt.getSetting('offsetRow'); - }; - - /** - * Return index of first visible column - * @return {Number} - */ - this.colOffset = function () { - return instance.view.wt.getSetting('offsetColumn'); - }; - - /** - * Return number of visible rows. Returns -1 if table is not visible - * @return {Number} - */ - this.countVisibleRows = function () { - return instance.view.wt.drawn ? instance.view.wt.wtTable.rowStrategy.countVisible() : -1; - }; - - /** - * Return number of visible columns. Returns -1 if table is not visible - * @return {Number} - */ - this.countVisibleCols = function () { - return instance.view.wt.drawn ? instance.view.wt.wtTable.columnStrategy.countVisible() : -1; - }; - - /** - * Return number of empty rows - * @return {Boolean} ending If true, will only count empty rows at the end of the data source - */ - this.countEmptyRows = function (ending) { - var i = instance.countRows() - 1 - , empty = 0; - while (i >= 0) { - datamap.get(i, 0); - - if (instance.isEmptyRow(datamap.getVars.row)) { - empty++; - } - else if (ending) { - break; - } - i--; - } - return empty; - }; - - /** - * Return number of empty columns - * @return {Boolean} ending If true, will only count empty columns at the end of the data source row - */ - this.countEmptyCols = function (ending) { - if (instance.countRows() < 1) { - return 0; - } - - var i = instance.countCols() - 1 - , empty = 0; - while (i >= 0) { - if (instance.isEmptyCol(i)) { - empty++; - } - else if (ending) { - break; - } - i--; - } - return empty; - }; - - /** - * Return true if the row at the given index is empty, false otherwise - * @param {Number} r Row index - * @return {Boolean} - */ - this.isEmptyRow = function (r) { - return priv.settings.isEmptyRow.call(instance, r); - }; - - /** - * Return true if the column at the given index is empty, false otherwise - * @param {Number} c Column index - * @return {Boolean} - */ - this.isEmptyCol = function (c) { - return priv.settings.isEmptyCol.call(instance, c); - }; - - /** - * Selects cell on grid. Optionally selects range to another cell - * @param {Number} row - * @param {Number} col - * @param {Number} [endRow] - * @param {Number} [endCol] - * @param {Boolean} [scrollToCell=true] If true, viewport will be scrolled to the selection - * @public - * @return {Boolean} - */ - this.selectCell = function (row, col, endRow, endCol, scrollToCell) { - if (typeof row !== 'number' || row < 0 || row >= instance.countRows()) { - return false; - } - if (typeof col !== 'number' || col < 0 || col >= instance.countCols()) { - return false; - } - if (typeof endRow !== "undefined") { - if (typeof endRow !== 'number' || endRow < 0 || endRow >= instance.countRows()) { - return false; - } - if (typeof endCol !== 'number' || endCol < 0 || endCol >= instance.countCols()) { - return false; - } - } - priv.selStart.coords({row: row, col: col}); - if (document.activeElement && document.activeElement !== document.documentElement && document.activeElement !== document.body) { - document.activeElement.blur(); //needed or otherwise prepare won't focus the cell. selectionSpec tests this (should move focus to selected cell) - } - instance.listen(); - if (typeof endRow === "undefined") { - selection.setRangeEnd({row: row, col: col}, scrollToCell); - } - else { - selection.setRangeEnd({row: endRow, col: endCol}, scrollToCell); - } - - instance.selection.finish(); - return true; - }; - - this.selectCellByProp = function (row, prop, endRow, endProp, scrollToCell) { - arguments[1] = datamap.propToCol(arguments[1]); - if (typeof arguments[3] !== "undefined") { - arguments[3] = datamap.propToCol(arguments[3]); - } - return instance.selectCell.apply(instance, arguments); - }; - - /** - * Deselects current sell selection on grid - * @public - */ - this.deselectCell = function () { - selection.deselect(); - }; - - /** - * Remove grid from DOM - * @public - */ - this.destroy = function () { - instance.clearTimeouts(); - if (instance.view) { //in case HT is destroyed before initialization has finished - instance.view.wt.destroy(); - } - instance.rootElement.empty(); - instance.rootElement.removeData('handsontable'); - instance.rootElement.off('.handsontable'); - $(window).off('.' + instance.guid); - $document.off('.' + instance.guid); - $body.off('.' + instance.guid); - instance.PluginHooks.run('afterDestroy'); - }; - - /** - * Returns active editor object - * @returns {Object} - */ - this.getActiveEditor = function(){ - return editorManager.getActiveEditor(); - }; - - /** - * Return Handsontable instance - * @public - * @return {Object} - */ - this.getInstance = function () { - return instance.rootElement.data("handsontable"); - }; - - (function () { - // Create new instance of plugin hooks - instance.PluginHooks = new Handsontable.PluginHookClass(); - - // Upgrade methods to call of global PluginHooks instance - var _run = instance.PluginHooks.run - , _exe = instance.PluginHooks.execute; - - instance.PluginHooks.run = function (key, p1, p2, p3, p4, p5) { - _run.call(this, instance, key, p1, p2, p3, p4, p5); - Handsontable.PluginHooks.run(instance, key, p1, p2, p3, p4, p5); - }; - - instance.PluginHooks.execute = function (key, p1, p2, p3, p4, p5) { - var globalHandlerResult = Handsontable.PluginHooks.execute(instance, key, p1, p2, p3, p4, p5); - var localHandlerResult = _exe.call(this, instance, key, globalHandlerResult, p2, p3, p4, p5); - - return typeof localHandlerResult == 'undefined' ? globalHandlerResult : localHandlerResult; - - }; - - // Map old API with new methods - instance.addHook = function () { - instance.PluginHooks.add.apply(instance.PluginHooks, arguments); - }; - instance.addHookOnce = function () { - instance.PluginHooks.once.apply(instance.PluginHooks, arguments); - }; - - instance.removeHook = function () { - instance.PluginHooks.remove.apply(instance.PluginHooks, arguments); - }; - - instance.runHooks = function () { - instance.PluginHooks.run.apply(instance.PluginHooks, arguments); - }; - instance.runHooksAndReturn = function () { - return instance.PluginHooks.execute.apply(instance.PluginHooks, arguments); - }; - - })(); - - this.timeouts = {}; - - /** - * Sets timeout. Purpose of this method is to clear all known timeouts when `destroy` method is called - * @public - */ - this.registerTimeout = function (key, handle, ms) { - clearTimeout(this.timeouts[key]); - this.timeouts[key] = setTimeout(handle, ms || 0); - }; - - /** - * Clears all known timeouts - * @public - */ - this.clearTimeouts = function () { - for (var key in this.timeouts) { - if (this.timeouts.hasOwnProperty(key)) { - clearTimeout(this.timeouts[key]); - } - } - }; - - /** - * Handsontable version - */ - this.version = '0.10.1'; //inserted by grunt from package.json -}; - -var DefaultSettings = function () {}; - -DefaultSettings.prototype = { - data: void 0, - width: void 0, - height: void 0, - startRows: 5, - startCols: 5, - rowHeaders: null, - colHeaders: null, - minRows: 0, - minCols: 0, - maxRows: Infinity, - maxCols: Infinity, - minSpareRows: 0, - minSpareCols: 0, - multiSelect: true, - fillHandle: true, - fixedRowsTop: 0, - fixedColumnsLeft: 0, - outsideClickDeselects: true, - enterBeginsEditing: true, - enterMoves: {row: 1, col: 0}, - tabMoves: {row: 0, col: 1}, - autoWrapRow: false, - autoWrapCol: false, - copyRowsLimit: 1000, - copyColsLimit: 1000, - pasteMode: 'overwrite', - currentRowClassName: void 0, - currentColClassName: void 0, - stretchH: 'hybrid', - isEmptyRow: function (r) { - var val; - for (var c = 0, clen = this.countCols(); c < clen; c++) { - val = this.getDataAtCell(r, c); - if (val !== '' && val !== null && typeof val !== 'undefined') { - return false; - } - } - return true; - }, - isEmptyCol: function (c) { - var val; - for (var r = 0, rlen = this.countRows(); r < rlen; r++) { - val = this.getDataAtCell(r, c); - if (val !== '' && val !== null && typeof val !== 'undefined') { - return false; - } - } - return true; - }, - observeDOMVisibility: true, - allowInvalid: true, - invalidCellClassName: 'htInvalid', - placeholderCellClassName: 'htPlaceholder', - readOnlyCellClassName: 'htDimmed', - fragmentSelection: false, - readOnly: false, - nativeScrollbars: false, - type: 'text', - debug: false //shows debug overlays in Walkontable -}; -Handsontable.DefaultSettings = DefaultSettings; - -$.fn.handsontable = function (action) { - var i - , ilen - , args - , output - , userSettings - , $this = this.first() // Use only first element from list - , instance = $this.data('handsontable'); - - // Init case - if (typeof action !== 'string') { - userSettings = action || {}; - if (instance) { - instance.updateSettings(userSettings); - } - else { - instance = new Handsontable.Core($this, userSettings); - $this.data('handsontable', instance); - instance.init(); - } - - return $this; - } - // Action case - else { - args = []; - if (arguments.length > 1) { - for (i = 1, ilen = arguments.length; i < ilen; i++) { - args.push(arguments[i]); - } - } - - if (instance) { - if (typeof instance[action] !== 'undefined') { - output = instance[action].apply(instance, args); - } - else { - throw new Error('Handsontable do not provide action: ' + action); - } - } - - return output; - } -}; - -/** - * Handsontable TableView constructor - * @param {Object} instance - */ -Handsontable.TableView = function (instance) { - var that = this - , $window = $(window) - , $documentElement = $(document.documentElement); - - this.instance = instance; - this.settings = instance.getSettings(); - this.settingsFromDOM = instance.getSettingsFromDOM(); - - instance.rootElement.data('originalStyle', instance.rootElement[0].getAttribute('style')); //needed to retrieve original style in jsFiddle link generator in HT examples. may be removed in future versions - // in IE7 getAttribute('style') returns an object instead of a string, but we only support IE8+ - - instance.rootElement.addClass('handsontable'); - - var table = document.createElement('TABLE'); - table.className = 'htCore'; - this.THEAD = document.createElement('THEAD'); - table.appendChild(this.THEAD); - this.TBODY = document.createElement('TBODY'); - table.appendChild(this.TBODY); - - instance.$table = $(table); - instance.rootElement.prepend(instance.$table); - - instance.rootElement.on('mousedown.handsontable', function (event) { - if (!that.isTextSelectionAllowed(event.target)) { - clearTextSelection(); - event.preventDefault(); - window.focus(); //make sure that window that contains HOT is active. Important when HOT is in iframe. - } - }); - - $documentElement.on('keyup.' + instance.guid, function (event) { - if (instance.selection.isInProgress() && !event.shiftKey) { - instance.selection.finish(); - } - }); - - var isMouseDown; - - $documentElement.on('mouseup.' + instance.guid, function (event) { - if (instance.selection.isInProgress() && event.which === 1) { //is left mouse button - instance.selection.finish(); - } - - isMouseDown = false; - - if (instance.autofill.handle && instance.autofill.handle.isDragged) { - if (instance.autofill.handle.isDragged > 1) { - instance.autofill.apply(); - } - instance.autofill.handle.isDragged = 0; - } - - if (Handsontable.helper.isOutsideInput(document.activeElement)) { - instance.unlisten(); - } - }); - - $documentElement.on('mousedown.' + instance.guid, function (event) { - var next = event.target; - - if (next !== that.wt.wtTable.spreader) { //immediate click on "spreader" means click on the right side of vertical scrollbar - while (next !== document.documentElement) { - if (next === null) { - return; //click on something that was a row but now is detached (possibly because your click triggered a rerender) - } - if (next === instance.rootElement[0] || next.nodeName === 'HANDSONTABLE-TABLE') { - return; //click inside container or Web Component (HANDSONTABLE-TABLE is the name of the custom element) - } - if ($(next).hasClass('toolbutton')) return; //ANDI, issue #1267 - if ($(next).hasClass('pickerbutton')) return; //ANDI, issue #1267 - - next = next.parentNode; - } - } - - if (that.settings.outsideClickDeselects) { - instance.deselectCell(); - } - else { - instance.destroyEditor(); - } - }); - - instance.rootElement.on('mousedown.handsontable', '.dragdealer', function () { - instance.destroyEditor(); - }); - - instance.$table.on('selectstart', function (event) { - if (that.settings.fragmentSelection) { - return; - } - - //https://github.com/warpech/jquery-handsontable/issues/160 - //selectstart is IE only event. Prevent text from being selected when performing drag down in IE8 - event.preventDefault(); - }); - - var clearTextSelection = function () { - //http://stackoverflow.com/questions/3169786/clear-text-selection-with-javascript - if (document.getSelection) { - if (document.getSelection().empty) { // Chrome - document.getSelection().empty(); - } else if (document.getSelection().removeAllRanges) { // Firefox - document.getSelection().removeAllRanges(); - } - } else if (document.selection) { // IE? - try { document.selection.empty(); } catch(e) { /* absorb ie8 bug */ } - } - }; - - var walkontableConfig = { - debug: function () { - return that.settings.debug; - }, - table: table, - stretchH: this.settings.stretchH, - data: instance.getDataAtCell, - totalRows: instance.countRows, - totalColumns: instance.countCols, - nativeScrollbars: this.settings.nativeScrollbars, - offsetRow: 0, - offsetColumn: 0, - width: this.getWidth(), - height: this.getHeight(), - fixedColumnsLeft: function () { - return that.settings.fixedColumnsLeft; - }, - fixedRowsTop: function () { - return that.settings.fixedRowsTop; - }, - rowHeaders: function () { - return instance.hasRowHeaders() ? [function (index, TH) { - that.appendRowHeader(index, TH); - }] : [] - }, - columnHeaders: function () { - return instance.hasColHeaders() ? [function (index, TH) { - that.appendColHeader(index, TH); - }] : [] - }, - columnWidth: instance.getColWidth, - cellRenderer: function (row, col, TD) { - - var prop = that.instance.colToProp(col) - , cellProperties = that.instance.getCellMeta(row, col) - , renderer = that.instance.getCellRenderer(cellProperties); - - var value = that.instance.getDataAtRowProp(row, prop); - - renderer(that.instance, TD, row, col, prop, value, cellProperties); - - that.instance.PluginHooks.run('afterRenderer', TD, row, col, prop, value, cellProperties); - - }, - selections: { - current: { - className: 'current', - border: { - width: 2, - color: '#5292F7', - style: 'solid', - cornerVisible: function () { - return that.settings.fillHandle && !that.isCellEdited() && !instance.selection.isMultiple() - } - } - }, - area: { - className: 'area', - border: { - width: 1, - color: '#89AFF9', - style: 'solid', - cornerVisible: function () { - return that.settings.fillHandle && !that.isCellEdited() && instance.selection.isMultiple() - } - } - }, - highlight: { - highlightRowClassName: that.settings.currentRowClassName, - highlightColumnClassName: that.settings.currentColClassName - }, - fill: { - className: 'fill', - border: { - width: 1, - color: 'red', - style: 'solid' - } - } - }, - hideBorderOnMouseDownOver: function () { - return that.settings.fragmentSelection; - }, - onCellMouseDown: function (event, coords, TD) { - instance.listen(); - - isMouseDown = true; - var coordsObj = {row: coords[0], col: coords[1]}; - if (event.button === 2 && instance.selection.inInSelection(coordsObj)) { //right mouse button - //do nothing - } - else if (event.shiftKey) { - instance.selection.setRangeEnd(coordsObj); - } - else { - instance.selection.setRangeStart(coordsObj); - } - - instance.PluginHooks.run('afterOnCellMouseDown', event, coords, TD); - }, - /*onCellMouseOut: function (/*event, coords, TD* /) { - if (isMouseDown && that.settings.fragmentSelection === 'single') { - clearTextSelection(); //otherwise text selection blinks during multiple cells selection - } - },*/ - onCellMouseOver: function (event, coords, TD) { - var coordsObj = {row: coords[0], col: coords[1]}; - if (isMouseDown) { - /*if (that.settings.fragmentSelection === 'single') { - clearTextSelection(); //otherwise text selection blinks during multiple cells selection - }*/ - instance.selection.setRangeEnd(coordsObj); - } - else if (instance.autofill.handle && instance.autofill.handle.isDragged) { - instance.autofill.handle.isDragged++; - instance.autofill.showBorder(coords); - } - instance.PluginHooks.run('afterOnCellMouseOver', event, coords, TD); - }, - onCellCornerMouseDown: function (event) { - instance.autofill.handle.isDragged = 1; - event.preventDefault(); - instance.PluginHooks.run('afterOnCellCornerMouseDown', event); - }, - onCellCornerDblClick: function () { - instance.autofill.selectAdjacent(); - }, - beforeDraw: function (force) { - that.beforeRender(force); - }, - onDraw: function(force){ - that.onDraw(force); - }, - onScrollVertically: function () { - instance.runHooks('afterScrollVertically'); - }, - onScrollHorizontally: function () { - instance.runHooks('afterScrollHorizontally'); - } - }; - - instance.PluginHooks.run('beforeInitWalkontable', walkontableConfig); - - this.wt = new Walkontable(walkontableConfig); - - $window.on('resize.' + instance.guid, function () { - instance.registerTimeout('resizeTimeout', function () { - instance.parseSettingsFromDOM(); - var newWidth = that.getWidth(); - var newHeight = that.getHeight(); - if (walkontableConfig.width !== newWidth || walkontableConfig.height !== newHeight) { - instance.forceFullRender = true; - that.render(); - walkontableConfig.width = newWidth; - walkontableConfig.height = newHeight; - } - }, 60); - }); - - $(that.wt.wtTable.spreader).on('mousedown.handsontable, contextmenu.handsontable', function (event) { - if (event.target === that.wt.wtTable.spreader && event.which === 3) { //right mouse button exactly on spreader means right clickon the right hand side of vertical scrollbar - event.stopPropagation(); - } - }); - - $documentElement.on('click.' + instance.guid, function () { - if (that.settings.observeDOMVisibility) { - if (that.wt.drawInterrupted) { - that.instance.forceFullRender = true; - that.render(); - } - } - }); -}; - -Handsontable.TableView.prototype.isTextSelectionAllowed = function (el) { - if ( Handsontable.helper.isInput(el) ) { - return (true); - } - if (this.settings.fragmentSelection && this.wt.wtDom.isChildOf(el, this.TBODY)) { - return (true); - } - return false; -}; - -Handsontable.TableView.prototype.isCellEdited = function () { - var activeEditor = this.instance.getActiveEditor(); - return activeEditor && activeEditor.isOpened(); -}; - -Handsontable.TableView.prototype.getWidth = function () { - var val = this.settings.width !== void 0 ? this.settings.width : this.settingsFromDOM.width; - return typeof val === 'function' ? val() : val; -}; - -Handsontable.TableView.prototype.getHeight = function () { - var val = this.settings.height !== void 0 ? this.settings.height : this.settingsFromDOM.height; - return typeof val === 'function' ? val() : val; -}; - -Handsontable.TableView.prototype.beforeRender = function (force) { - if (force) { //force = did Walkontable decide to do full render - this.instance.PluginHooks.run('beforeRender', this.instance.forceFullRender); //this.instance.forceFullRender = did Handsontable request full render? - this.wt.update('width', this.getWidth()); - this.wt.update('height', this.getHeight()); - } -}; - -Handsontable.TableView.prototype.onDraw = function(force){ - if (force) { //force = did Walkontable decide to do full render - this.instance.PluginHooks.run('afterRender', this.instance.forceFullRender); //this.instance.forceFullRender = did Handsontable request full render? - } -}; - -Handsontable.TableView.prototype.render = function () { - this.wt.draw(!this.instance.forceFullRender); - this.instance.forceFullRender = false; - this.instance.rootElement.triggerHandler('render.handsontable'); -}; - -/** - * Returns td object given coordinates - */ -Handsontable.TableView.prototype.getCellAtCoords = function (coords) { - var td = this.wt.wtTable.getCell([coords.row, coords.col]); - if (td < 0) { //there was an exit code (cell is out of bounds) - return null; - } - else { - return td; - } -}; - -/** - * Scroll viewport to selection - * @param coords - */ -Handsontable.TableView.prototype.scrollViewport = function (coords) { - this.wt.scrollViewport([coords.row, coords.col]); -}; - -/** - * Append row header to a TH element - * @param row - * @param TH - */ -Handsontable.TableView.prototype.appendRowHeader = function (row, TH) { - var DIV = document.createElement('DIV') - , SPAN = document.createElement('SPAN'); - - DIV.className = 'relative'; - SPAN.className = 'colHeader'; - - if (row < 0) { - this.wt.wtDom.fastInnerText(DIV, '\u00A0'); - } else { - this.wt.wtDom.fastInnerHTML(SPAN, this.instance.getRowHeader(row)); - DIV.appendChild(SPAN); - } - - this.wt.wtDom.empty(TH); - TH.appendChild(DIV); - - this.instance.PluginHooks.run('afterGetRowHeader', row, TH); -}; - -/** - * Append column header to a TH element - * @param col - * @param TH - */ -Handsontable.TableView.prototype.appendColHeader = function (col, TH) { - var DIV = document.createElement('DIV') - , SPAN = document.createElement('SPAN'); - - DIV.className = 'relative'; - SPAN.className = 'colHeader'; - - this.wt.wtDom.fastInnerHTML(SPAN, this.instance.getColHeader(col)); - DIV.appendChild(SPAN); - - this.wt.wtDom.empty(TH); - TH.appendChild(DIV); - this.instance.PluginHooks.run('afterGetColHeader', col, TH); -}; - -/** - * Given a element's left position relative to the viewport, returns maximum element width until the right edge of the viewport (before scrollbar) - * @param {Number} left - * @return {Number} - */ -Handsontable.TableView.prototype.maximumVisibleElementWidth = function (left) { - var rootWidth = this.wt.wtViewport.getWorkspaceWidth(); - if(this.settings.nativeScrollbars) { - return rootWidth; - } - return rootWidth - left; -}; - -/** - * Given a element's top position relative to the viewport, returns maximum element height until the bottom edge of the viewport (before scrollbar) - * @param {Number} top - * @return {Number} - */ -Handsontable.TableView.prototype.maximumVisibleElementHeight = function (top) { - var rootHeight = this.wt.wtViewport.getWorkspaceHeight(); - if(this.settings.nativeScrollbars) { - return rootHeight; - } - return rootHeight - top; -}; - -/** - * Utility to register editors and common namespace for keeping reference to all editor classes - */ -(function (Handsontable) { - 'use strict'; - - function RegisteredEditor(editorClass) { - var clazz, instances; - - instances = {}; - clazz = editorClass; - - this.getInstance = function (hotInstance) { - if (!(hotInstance.guid in instances)) { - instances[hotInstance.guid] = new clazz(hotInstance); - } - - return instances[hotInstance.guid]; - } - - } - - var registeredEditorNames = {}; - var registeredEditorClasses = new WeakMap(); - - Handsontable.editors = { - - /** - * Registers editor under given name - * @param {String} editorName - * @param {Function} editorClass - */ - registerEditor: function (editorName, editorClass) { - var editor = new RegisteredEditor(editorClass); - if (typeof editorName === "string") { - registeredEditorNames[editorName] = editor; - } - registeredEditorClasses.set(editorClass, editor); - }, - - /** - * Returns instance (singleton) of editor class - * @param {String|Function} editorName/editorClass - * @returns {Function} editorClass - */ - getEditor: function (editorName, hotInstance) { - var editor; - if (typeof editorName == 'function') { - if (!(registeredEditorClasses.get(editorName))) { - this.registerEditor(null, editorName); - } - editor = registeredEditorClasses.get(editorName); - } - else if (typeof editorName == 'string') { - editor = registeredEditorNames[editorName]; - } - else { - throw Error('Only strings and functions can be passed as "editor" parameter '); - } - - if (!editor) { - throw Error('No editor registered under name "' + editorName + '"'); - } - - return editor.getInstance(hotInstance); - } - - }; - - -})(Handsontable); - -(function(Handsontable){ - 'use strict'; - - Handsontable.EditorManager = function(instance, priv, selection){ - var that = this; - var $document = $(document); - var keyCodes = Handsontable.helper.keyCode; - - var activeEditor; - - var init = function () { - - function onKeyDown(event) { - - if (!instance.isListening()) { - return; - } - - if (priv.settings.beforeOnKeyDown) { // HOT in HOT Plugin - priv.settings.beforeOnKeyDown.call(instance, event); - } - - instance.PluginHooks.run('beforeKeyDown', event); - - if (!event.isImmediatePropagationStopped()) { - - priv.lastKeyCode = event.keyCode; - if (selection.isSelected()) { - var ctrlDown = (event.ctrlKey || event.metaKey) && !event.altKey; //catch CTRL but not right ALT (which in some systems triggers ALT+CTRL) - - if (!activeEditor.isWaiting()) { - if (!Handsontable.helper.isMetaKey(event.keyCode) && !ctrlDown) { - that.openEditor(''); - event.stopPropagation(); //required by HandsontableEditor - return; - } - } - - var rangeModifier = event.shiftKey ? selection.setRangeEnd : selection.setRangeStart; - - switch (event.keyCode) { - - case keyCodes.A: - if (ctrlDown) { - selection.selectAll(); //select all cells - - event.preventDefault(); - event.stopPropagation(); - break; - } - - case keyCodes.ARROW_UP: - - if (that.isEditorOpened() && !activeEditor.isWaiting()){ - that.closeEditorAndSaveChanges(ctrlDown); - } - - moveSelectionUp(event.shiftKey); - - event.preventDefault(); - event.stopPropagation(); //required by HandsontableEditor - break; - - case keyCodes.ARROW_DOWN: - if (that.isEditorOpened() && !activeEditor.isWaiting()){ - that.closeEditorAndSaveChanges(ctrlDown); - } - - moveSelectionDown(event.shiftKey); - - event.preventDefault(); - event.stopPropagation(); //required by HandsontableEditor - break; - - case keyCodes.ARROW_RIGHT: - if(that.isEditorOpened() && !activeEditor.isWaiting()){ - that.closeEditorAndSaveChanges(ctrlDown); - } - - moveSelectionRight(event.shiftKey); - - event.preventDefault(); - event.stopPropagation(); //required by HandsontableEditor - break; - - case keyCodes.ARROW_LEFT: - if(that.isEditorOpened() && !activeEditor.isWaiting()){ - that.closeEditorAndSaveChanges(ctrlDown); - } - - moveSelectionLeft(event.shiftKey); - - event.preventDefault(); - event.stopPropagation(); //required by HandsontableEditor - break; - - case keyCodes.TAB: - var tabMoves = typeof priv.settings.tabMoves === 'function' ? priv.settings.tabMoves(event) : priv.settings.tabMoves; - if (event.shiftKey) { - selection.transformStart(-tabMoves.row, -tabMoves.col); //move selection left - } - else { - selection.transformStart(tabMoves.row, tabMoves.col, true); //move selection right (add a new column if needed) - } - event.preventDefault(); - event.stopPropagation(); //required by HandsontableEditor - break; - - case keyCodes.BACKSPACE: - case keyCodes.DELETE: - selection.empty(event); - that.prepareEditor(); - event.preventDefault(); - break; - - case keyCodes.F2: /* F2 */ - that.openEditor(); - event.preventDefault(); //prevent Opera from opening Go to Page dialog - break; - - case keyCodes.ENTER: /* return/enter */ - if(that.isEditorOpened()){ - - if (activeEditor.state !== Handsontable.EditorState.WAITING){ - that.closeEditorAndSaveChanges(ctrlDown); - } - - moveSelectionAfterEnter(event.shiftKey); - - } else { - - if (instance.getSettings().enterBeginsEditing){ - that.openEditor(); - } else { - moveSelectionAfterEnter(event.shiftKey); - } - - } - - event.preventDefault(); //don't add newline to field - event.stopImmediatePropagation(); //required by HandsontableEditor - break; - - case keyCodes.ESCAPE: - if(that.isEditorOpened()){ - that.closeEditorAndRestoreOriginalValue(ctrlDown); - } - event.preventDefault(); - break; - - case keyCodes.HOME: - if (event.ctrlKey || event.metaKey) { - rangeModifier({row: 0, col: priv.selStart.col()}); - } - else { - rangeModifier({row: priv.selStart.row(), col: 0}); - } - event.preventDefault(); //don't scroll the window - event.stopPropagation(); //required by HandsontableEditor - break; - - case keyCodes.END: - if (event.ctrlKey || event.metaKey) { - rangeModifier({row: instance.countRows() - 1, col: priv.selStart.col()}); - } - else { - rangeModifier({row: priv.selStart.row(), col: instance.countCols() - 1}); - } - event.preventDefault(); //don't scroll the window - event.stopPropagation(); //required by HandsontableEditor - break; - - case keyCodes.PAGE_UP: - selection.transformStart(-instance.countVisibleRows(), 0); - instance.view.wt.scrollVertical(-instance.countVisibleRows()); - instance.view.render(); - event.preventDefault(); //don't page up the window - event.stopPropagation(); //required by HandsontableEditor - break; - - case keyCodes.PAGE_DOWN: - selection.transformStart(instance.countVisibleRows(), 0); - instance.view.wt.scrollVertical(instance.countVisibleRows()); - instance.view.render(); - event.preventDefault(); //don't page down the window - event.stopPropagation(); //required by HandsontableEditor - break; - - default: - break; - } - - } - } - } - $document.on('keydown.handsontable.' + instance.guid, onKeyDown); - - function onDblClick() { -// that.instance.destroyEditor(); - that.openEditor(); - } - - instance.view.wt.update('onCellDblClick', onDblClick); - - instance.addHook('afterDestroy', function(){ - $document.off('keydown.handsontable.' + instance.guid); - }); - - function moveSelectionAfterEnter(shiftKey){ - var enterMoves = typeof priv.settings.enterMoves === 'function' ? priv.settings.enterMoves(event) : priv.settings.enterMoves; - - if (shiftKey) { - selection.transformStart(-enterMoves.row, -enterMoves.col); //move selection up - } - else { - selection.transformStart(enterMoves.row, enterMoves.col, true); //move selection down (add a new row if needed) - } - } - - function moveSelectionUp(shiftKey){ - if (shiftKey) { - selection.transformEnd(-1, 0); - } - else { - selection.transformStart(-1, 0); - } - } - - function moveSelectionDown(shiftKey){ - if (shiftKey) { - selection.transformEnd(1, 0); //expanding selection down with shift - } - else { - selection.transformStart(1, 0); //move selection down - } - } - - function moveSelectionRight(shiftKey){ - if (shiftKey) { - selection.transformEnd(0, 1); - } - else { - selection.transformStart(0, 1); - } - } - - function moveSelectionLeft(shiftKey){ - if (shiftKey) { - selection.transformEnd(0, -1); - } - else { - selection.transformStart(0, -1); - } - } - }; - - /** - * Destroy current editor, if exists - * @param {Boolean} revertOriginal - */ - this.destroyEditor = function (revertOriginal) { - this.closeEditor(revertOriginal); - }; - - this.getActiveEditor = function () { - return activeEditor; - }; - - /** - * Prepare text input to be displayed at given grid cell - */ - this.prepareEditor = function () { - - if (activeEditor && activeEditor.isWaiting()){ - - this.closeEditor(false, false, function(dataSaved){ - if(dataSaved){ - that.prepareEditor(); - } - }); - - return; - } - - var row = priv.selStart.row(); - var col = priv.selStart.col(); - var prop = instance.colToProp(col); - var td = instance.getCell(row, col); - var originalValue = instance.getDataAtCell(row, col); - var cellProperties = instance.getCellMeta(row, col); - - var editorClass = instance.getCellEditor(cellProperties); - activeEditor = Handsontable.editors.getEditor(editorClass, instance); - - activeEditor.prepare(row, col, prop, td, originalValue, cellProperties); - - }; - - this.isEditorOpened = function () { - return activeEditor.isOpened(); - }; - - this.openEditor = function (initialValue) { - activeEditor.beginEditing(initialValue); - }; - - this.closeEditor = function (restoreOriginalValue, ctrlDown, callback) { - - if (!activeEditor){ - if(callback) { - callback(false); - } - } - else { - activeEditor.finishEditing(restoreOriginalValue, ctrlDown, callback); - } - }; - - this.closeEditorAndSaveChanges = function(ctrlDown){ - return this.closeEditor(false, ctrlDown); - }; - - this.closeEditorAndRestoreOriginalValue = function(ctrlDown){ - return this.closeEditor(true, ctrlDown); - }; - - init(); - }; - -})(Handsontable); - -/** - * Utility to register renderers and common namespace for keeping reference to all renderers classes - */ -(function (Handsontable) { - 'use strict'; - - var registeredRenderers = {}; - - Handsontable.renderers = { - - /** - * Registers renderer under given name - * @param {String} rendererName - * @param {Function} rendererFunction - */ - registerRenderer: function (rendererName, rendererFunction) { - registeredRenderers[rendererName] = rendererFunction - }, - - /** - * @param {String|Function} rendererName/rendererFunction - * @returns {Function} rendererFunction - */ - getRenderer: function (rendererName) { - if (typeof rendererName == 'function'){ - return rendererName; - } - - if (typeof rendererName != 'string'){ - throw Error('Only strings and functions can be passed as "renderer" parameter '); - } - - if (!(rendererName in registeredRenderers)) { - throw Error('No editor registered under name "' + rendererName + '"'); - } - - return registeredRenderers[rendererName]; - } - - }; - - -})(Handsontable); - -/** - * DOM helper optimized for maximum performance - * It is recommended for Handsontable plugins and renderers, because it is much faster than jQuery - * @type {WalkonableDom} - */ -Handsontable.Dom = new WalkontableDom(); - -/** - * Returns true if keyCode represents a printable character - * @param {Number} keyCode - * @return {Boolean} - */ -Handsontable.helper.isPrintableChar = function (keyCode) { - return ((keyCode == 32) || //space - (keyCode >= 48 && keyCode <= 57) || //0-9 - (keyCode >= 96 && keyCode <= 111) || //numpad - (keyCode >= 186 && keyCode <= 192) || //;=,-./` - (keyCode >= 219 && keyCode <= 222) || //[]{}\|"' - keyCode >= 226 || //special chars (229 for Asian chars) - (keyCode >= 65 && keyCode <= 90)); //a-z -}; - -Handsontable.helper.isMetaKey = function (keyCode) { - var keyCodes = Handsontable.helper.keyCode; - var metaKeys = [ - keyCodes.ARROW_DOWN, - keyCodes.ARROW_UP, - keyCodes.ARROW_LEFT, - keyCodes.ARROW_RIGHT, - keyCodes.HOME, - keyCodes.END, - keyCodes.DELETE, - keyCodes.BACKSPACE, - keyCodes.F1, - keyCodes.F2, - keyCodes.F3, - keyCodes.F4, - keyCodes.F5, - keyCodes.F6, - keyCodes.F7, - keyCodes.F8, - keyCodes.F9, - keyCodes.F10, - keyCodes.F11, - keyCodes.F12, - keyCodes.TAB, - keyCodes.PAGE_DOWN, - keyCodes.PAGE_UP, - keyCodes.ENTER, - keyCodes.ESCAPE, - keyCodes.SHIFT, - keyCodes.CAPS_LOCK, - keyCodes.ALT - ]; - - return metaKeys.indexOf(keyCode) != -1; -}; - -Handsontable.helper.isCtrlKey = function (keyCode) { - - var keys = Handsontable.helper.keyCode; - - return [keys.CONTROL_LEFT, 224, keys.COMMAND_LEFT, keys.COMMAND_RIGHT].indexOf(keyCode) != -1; -}; - -/** - * Converts a value to string - * @param value - * @return {String} - */ -Handsontable.helper.stringify = function (value) { - switch (typeof value) { - case 'string': - case 'number': - return value + ''; - break; - - case 'object': - if (value === null) { - return ''; - } - else { - return value.toString(); - } - break; - - case 'undefined': - return ''; - break; - - default: - return value.toString(); - } -}; - -/** - * Generates spreadsheet-like column names: A, B, C, ..., Z, AA, AB, etc - * @param index - * @returns {String} - */ -Handsontable.helper.spreadsheetColumnLabel = function (index) { - var dividend = index + 1; - var columnLabel = ''; - var modulo; - while (dividend > 0) { - modulo = (dividend - 1) % 26; - columnLabel = String.fromCharCode(65 + modulo) + columnLabel; - dividend = parseInt((dividend - modulo) / 26, 10); - } - return columnLabel; -}; - -/** - * Checks if value of n is a numeric one - * http://jsperf.com/isnan-vs-isnumeric/4 - * @param n - * @returns {boolean} - */ -Handsontable.helper.isNumeric = function (n) { - var t = typeof n; - return t == 'number' ? !isNaN(n) && isFinite(n) : - t == 'string' ? !n.length ? false : - n.length == 1 ? /\d/.test(n) : - /^\s*[+-]?\s*(?:(?:\d+(?:\.\d+)?(?:e[+-]?\d+)?)|(?:0x[a-f\d]+))\s*$/i.test(n) : - t == 'object' ? !!n && typeof n.valueOf() == "number" && !(n instanceof Date) : false; -}; - -Handsontable.helper.isArray = function (obj) { - return Object.prototype.toString.call(obj).match(/array/i) !== null; -}; - -/** - * Checks if child is a descendant of given parent node - * http://stackoverflow.com/questions/2234979/how-to-check-in-javascript-if-one-element-is-a-child-of-another - * @param parent - * @param child - * @returns {boolean} - */ -Handsontable.helper.isDescendant = function (parent, child) { - var node = child.parentNode; - while (node != null) { - if (node == parent) { - return true; - } - node = node.parentNode; - } - return false; -}; - -/** - * Generates a random hex string. Used as namespace for Handsontable instance events. - * @return {String} - 16 character random string: "92b1bfc74ec4" - */ -Handsontable.helper.randomString = function () { - return walkontableRandomString(); -}; - -/** - * Inherit without without calling parent constructor, and setting `Child.prototype.constructor` to `Child` instead of `Parent`. - * Creates temporary dummy function to call it as constructor. - * Described in ticket: https://github.com/warpech/jquery-handsontable/pull/516 - * @param {Object} Child child class - * @param {Object} Parent parent class - * @return {Object} extended Child - */ -Handsontable.helper.inherit = function (Child, Parent) { - Parent.prototype.constructor = Parent; - Child.prototype = new Parent(); - Child.prototype.constructor = Child; - return Child; -}; - -/** - * Perform shallow extend of a target object with extension's own properties - * @param {Object} target An object that will receive the new properties - * @param {Object} extension An object containing additional properties to merge into the target - */ -Handsontable.helper.extend = function (target, extension) { - for (var i in extension) { - if (extension.hasOwnProperty(i)) { - target[i] = extension[i]; - } - } -}; - -Handsontable.helper.getPrototypeOf = function (obj) { - var prototype; - - if(typeof obj.__proto__ == "object"){ - prototype = obj.__proto__; - } else { - var oldConstructor, - constructor = obj.constructor; - - if (typeof obj.constructor == "function") { - oldConstructor = constructor; - - if (delete obj.constructor){ - constructor = obj.constructor; // get real constructor - obj.constructor = oldConstructor; // restore constructor - } - - - } - - prototype = constructor ? constructor.prototype : null; // needed for IE - - } - - return prototype; -}; - -/** - * Factory for columns constructors. - * @param {Object} GridSettings - * @param {Array} conflictList - * @return {Object} ColumnSettings - */ -Handsontable.helper.columnFactory = function (GridSettings, conflictList) { - function ColumnSettings () {} - - Handsontable.helper.inherit(ColumnSettings, GridSettings); - - // Clear conflict settings - for (var i = 0, len = conflictList.length; i < len; i++) { - ColumnSettings.prototype[conflictList[i]] = void 0; - } - - return ColumnSettings; -}; - -Handsontable.helper.translateRowsToColumns = function (input) { - var i - , ilen - , j - , jlen - , output = [] - , olen = 0; - - for (i = 0, ilen = input.length; i < ilen; i++) { - for (j = 0, jlen = input[i].length; j < jlen; j++) { - if (j == olen) { - output.push([]); - olen++; - } - output[j].push(input[i][j]) - } - } - return output; -}; - -Handsontable.helper.to2dArray = function (arr) { - var i = 0 - , ilen = arr.length; - while (i < ilen) { - arr[i] = [arr[i]]; - i++; - } -}; - -Handsontable.helper.extendArray = function (arr, extension) { - var i = 0 - , ilen = extension.length; - while (i < ilen) { - arr.push(extension[i]); - i++; - } -}; - -/** - * Determines if the given DOM element is an input field. - * Notice: By 'input' we mean input, textarea and select nodes - * @param element - DOM element - * @returns {boolean} - */ -Handsontable.helper.isInput = function (element) { - var inputs = ['INPUT', 'SELECT', 'TEXTAREA']; - - return inputs.indexOf(element.nodeName) > -1; -}; - -/** - * Determines if the given DOM element is an input field placed OUTSIDE of HOT. - * Notice: By 'input' we mean input, textarea and select nodes - * @param element - DOM element - * @returns {boolean} - */ -Handsontable.helper.isOutsideInput = function (element) { - return Handsontable.helper.isInput(element) && element.className.indexOf('handsontableInput') == -1; -}; - -Handsontable.helper.keyCode = { - MOUSE_LEFT: 1, - MOUSE_RIGHT: 3, - MOUSE_MIDDLE: 2, - BACKSPACE: 8, - COMMA: 188, - DELETE: 46, - END: 35, - ENTER: 13, - ESCAPE: 27, - CONTROL_LEFT: 91, - COMMAND_LEFT: 17, - COMMAND_RIGHT: 93, - ALT: 18, - HOME: 36, - PAGE_DOWN: 34, - PAGE_UP: 33, - PERIOD: 190, - SPACE: 32, - SHIFT: 16, - CAPS_LOCK: 20, - TAB: 9, - ARROW_RIGHT: 39, - ARROW_LEFT: 37, - ARROW_UP: 38, - ARROW_DOWN: 40, - F1: 112, - F2: 113, - F3: 114, - F4: 115, - F5: 116, - F6: 117, - F7: 118, - F8: 119, - F9: 120, - F10: 121, - F11: 122, - F12: 123, - A: 65, - X: 88, - C: 67, - V: 86 -}; - -/** - * Determines whether given object is a plain Object. - * Note: String and Array are not plain Objects - * @param {*} obj - * @returns {boolean} - */ -Handsontable.helper.isObject = function (obj) { - return Object.prototype.toString.call(obj) == '[object Object]'; -}; - -/** - * Determines whether given object is an Array. - * Note: String is not an Array - * @param {*} obj - * @returns {boolean} - */ -Handsontable.helper.isArray = function(obj){ - return Array.isArray ? Array.isArray(obj) : Object.prototype.toString.call(obj) == '[object Array]'; -}; - -Handsontable.helper.pivot = function (arr) { - var pivotedArr = []; - - if(!arr || arr.length == 0 || !arr[0] || arr[0].length == 0){ - return pivotedArr; - } - - var rowCount = arr.length; - var colCount = arr[0].length; - - for(var i = 0; i < rowCount; i++){ - for(var j = 0; j < colCount; j++){ - if(!pivotedArr[j]){ - pivotedArr[j] = []; - } - - pivotedArr[j][i] = arr[i][j]; - } - } - - return pivotedArr; - -}; - -Handsontable.helper.proxy = function (fun, context) { - return function () { - return fun.apply(context, arguments); - }; -}; - -Handsontable.helper.cellMethodLookupFactory = function (methodName) { - - return function cellMethodLookup (row, col) { - - return (function getMethodFromProperties(properties) { - - if (!properties){ - - return; //method not found - - } - else if (properties.hasOwnProperty(methodName) && properties[methodName]) { //check if it is own and is not empty - - return properties[methodName]; //method defined directly - - } else if (properties.hasOwnProperty('type') && properties.type) { //check if it is own and is not empty - - var type; - - if(typeof properties.type != 'string' ){ - throw new Error('Cell type must be a string '); - } - - type = translateTypeNameToObject(properties.type); - - return type[methodName]; //method defined in type. if does not exist (eg. validator), returns undefined - } - - return getMethodFromProperties(Handsontable.helper.getPrototypeOf(properties)); - - })(typeof row == 'number' ? this.getCellMeta(row, col) : row); - - }; - - function translateTypeNameToObject(typeName) { - var type = Handsontable.cellTypes[typeName]; - - if(typeof type == 'undefined'){ - throw new Error('You declared cell type "' + typeName + '" as a string that is not mapped to a known object. Cell type must be an object or a string mapped to an object in Handsontable.cellTypes'); - } - - return type; - } -}; -Handsontable.SelectionPoint = function () { - this._row = null; //private use intended - this._col = null; -}; - -Handsontable.SelectionPoint.prototype.exists = function () { - return (this._row !== null); -}; - -Handsontable.SelectionPoint.prototype.row = function (val) { - if (val !== void 0) { - this._row = val; - } - return this._row; -}; - -Handsontable.SelectionPoint.prototype.col = function (val) { - if (val !== void 0) { - this._col = val; - } - return this._col; -}; - -Handsontable.SelectionPoint.prototype.coords = function (coords) { - if (coords !== void 0) { - this._row = coords.row; - this._col = coords.col; - } - return { - row: this._row, - col: this._col - } -}; - -Handsontable.SelectionPoint.prototype.arr = function (arr) { - if (arr !== void 0) { - this._row = arr[0]; - this._col = arr[1]; - } - return [this._row, this._col] -}; -(function (Handsontable) { - 'use strict'; - - /* - Adds appropriate CSS class to table cell, based on cellProperties - */ - Handsontable.renderers.cellDecorator = function (instance, TD, row, col, prop, value, cellProperties) { - if (cellProperties.readOnly) { - instance.view.wt.wtDom.addClass(TD, cellProperties.readOnlyCellClassName); - } - - if (cellProperties.valid === false && cellProperties.invalidCellClassName) { - instance.view.wt.wtDom.addClass(TD, cellProperties.invalidCellClassName); - } - - if (!value && cellProperties.placeholder) { - instance.view.wt.wtDom.addClass(TD, cellProperties.placeholderCellClassName); - } - } - -})(Handsontable); -/** - * Default text renderer - * @param {Object} instance Handsontable instance - * @param {Element} TD Table cell where to render - * @param {Number} row - * @param {Number} col - * @param {String|Number} prop Row object property name - * @param value Value to render (remember to escape unsafe HTML before inserting to DOM!) - * @param {Object} cellProperties Cell properites (shared by cell renderer and editor) - */ -(function (Handsontable) { - 'use strict'; - - var TextRenderer = function (instance, TD, row, col, prop, value, cellProperties) { - - Handsontable.renderers.cellDecorator.apply(this, arguments); - - if (!value && cellProperties.placeholder) { - value = cellProperties.placeholder; - } - - var escaped = Handsontable.helper.stringify(value); - - if (cellProperties.rendererTemplate) { - instance.view.wt.wtDom.empty(TD); - var TEMPLATE = document.createElement('TEMPLATE'); - TEMPLATE.setAttribute('bind', '{{}}'); - TEMPLATE.innerHTML = cellProperties.rendererTemplate; - HTMLTemplateElement.decorate(TEMPLATE); - TEMPLATE.model = instance.getDataAtRow(row); - TD.appendChild(TEMPLATE); - } - else { - instance.view.wt.wtDom.fastInnerText(TD, escaped); //this is faster than innerHTML. See: https://github.com/warpech/jquery-handsontable/wiki/JavaScript-&-DOM-performance-tips - } - - }; - - //Handsontable.TextRenderer = TextRenderer; //Left for backward compatibility - Handsontable.renderers.TextRenderer = TextRenderer; - Handsontable.renderers.registerRenderer('text', TextRenderer); - -})(Handsontable); -(function (Handsontable) { - - var clonableWRAPPER = document.createElement('DIV'); - clonableWRAPPER.className = 'htAutocompleteWrapper'; - - var clonableARROW = document.createElement('DIV'); - clonableARROW.className = 'htAutocompleteArrow'; - clonableARROW.appendChild(document.createTextNode('\u25BC')); -//this is faster than innerHTML. See: https://github.com/warpech/jquery-handsontable/wiki/JavaScript-&-DOM-performance-tips - - var wrapTdContentWithWrapper = function(TD, WRAPPER){ - WRAPPER.innerHTML = TD.innerHTML; - Handsontable.Dom.empty(TD); - TD.appendChild(WRAPPER); - }; - - /** - * Autocomplete renderer - * @param {Object} instance Handsontable instance - * @param {Element} TD Table cell where to render - * @param {Number} row - * @param {Number} col - * @param {String|Number} prop Row object property name - * @param value Value to render (remember to escape unsafe HTML before inserting to DOM!) - * @param {Object} cellProperties Cell properites (shared by cell renderer and editor) - */ - var AutocompleteRenderer = function (instance, TD, row, col, prop, value, cellProperties) { - - var WRAPPER = clonableWRAPPER.cloneNode(true); //this is faster than createElement - var ARROW = clonableARROW.cloneNode(true); //this is faster than createElement - - Handsontable.renderers.TextRenderer(instance, TD, row, col, prop, value, cellProperties); - - TD.appendChild(ARROW); - Handsontable.Dom.addClass(TD, 'htAutocomplete'); - - - if (!TD.firstChild) { //http://jsperf.com/empty-node-if-needed - //otherwise empty fields appear borderless in demo/renderers.html (IE) - TD.appendChild(document.createTextNode('\u00A0')); //\u00A0 equals   for a text node - //this is faster than innerHTML. See: https://github.com/warpech/jquery-handsontable/wiki/JavaScript-&-DOM-performance-tips - } - - if (!instance.acArrowListener) { - //not very elegant but easy and fast - instance.acArrowListener = function () { - instance.view.wt.getSetting('onCellDblClick'); - }; - - instance.rootElement.on('mousedown', '.htAutocompleteArrow', instance.acArrowListener); //this way we don't bind event listener to each arrow. We rely on propagation instead - - } - }; - - Handsontable.AutocompleteRenderer = AutocompleteRenderer; - Handsontable.renderers.AutocompleteRenderer = AutocompleteRenderer; - Handsontable.renderers.registerRenderer('autocomplete', AutocompleteRenderer); -})(Handsontable); -/** - * Checkbox renderer - * @param {Object} instance Handsontable instance - * @param {Element} TD Table cell where to render - * @param {Number} row - * @param {Number} col - * @param {String|Number} prop Row object property name - * @param value Value to render (remember to escape unsafe HTML before inserting to DOM!) - * @param {Object} cellProperties Cell properites (shared by cell renderer and editor) - */ -(function (Handsontable) { - - 'use strict'; - - var clonableINPUT = document.createElement('INPUT'); - clonableINPUT.className = 'htCheckboxRendererInput'; - clonableINPUT.type = 'checkbox'; - clonableINPUT.setAttribute('autocomplete', 'off'); - - var CheckboxRenderer = function (instance, TD, row, col, prop, value, cellProperties) { - - if (typeof cellProperties.checkedTemplate === "undefined") { - cellProperties.checkedTemplate = true; - } - if (typeof cellProperties.uncheckedTemplate === "undefined") { - cellProperties.uncheckedTemplate = false; - } - - instance.view.wt.wtDom.empty(TD); //TODO identify under what circumstances this line can be removed - - var INPUT = clonableINPUT.cloneNode(false); //this is faster than createElement - - if (value === cellProperties.checkedTemplate || value === Handsontable.helper.stringify(cellProperties.checkedTemplate)) { - INPUT.checked = true; - TD.appendChild(INPUT); - } - else if (value === cellProperties.uncheckedTemplate || value === Handsontable.helper.stringify(cellProperties.uncheckedTemplate)) { - TD.appendChild(INPUT); - } - else if (value === null) { //default value - INPUT.className += ' noValue'; - TD.appendChild(INPUT); - } - else { - instance.view.wt.wtDom.fastInnerText(TD, '#bad value#'); //this is faster than innerHTML. See: https://github.com/warpech/jquery-handsontable/wiki/JavaScript-&-DOM-performance-tips - } - - var $input = $(INPUT); - - if (cellProperties.readOnly) { - $input.on('click', function (event) { - event.preventDefault(); - }); - } - else { - $input.on('mousedown', function (event) { - event.stopPropagation(); //otherwise can confuse cell mousedown handler - }); - - $input.on('mouseup', function (event) { - event.stopPropagation(); //otherwise can confuse cell dblclick handler - }); - - $input.on('change', function(){ - if (this.checked) { - instance.setDataAtRowProp(row, prop, cellProperties.checkedTemplate); - } - else { - instance.setDataAtRowProp(row, prop, cellProperties.uncheckedTemplate); - } - }); - } - - if(!instance.CheckboxRenderer || !instance.CheckboxRenderer.beforeKeyDownHookBound){ - instance.CheckboxRenderer = { - beforeKeyDownHookBound : true - }; - - instance.addHook('beforeKeyDown', function(event){ - if(event.keyCode == Handsontable.helper.keyCode.SPACE){ - - var selection = instance.getSelected(); - var cell, checkbox, cellProperties; - - var selStart = { - row: Math.min(selection[0], selection[2]), - col: Math.min(selection[1], selection[3]) - }; - - var selEnd = { - row: Math.max(selection[0], selection[2]), - col: Math.max(selection[1], selection[3]) - }; - - for(var row = selStart.row; row <= selEnd.row; row++ ){ - for(var col = selEnd.col; col <= selEnd.col; col++){ - cell = instance.getCell(row, col); - cellProperties = instance.getCellMeta(row, col); - - checkbox = cell.querySelectorAll('input[type=checkbox]'); - - if(checkbox.length > 0 && !cellProperties.readOnly){ - - if(!event.isImmediatePropagationStopped()){ - event.stopImmediatePropagation(); - event.preventDefault(); - } - - for(var i = 0, len = checkbox.length; i < len; i++){ - checkbox[i].checked = !checkbox[i].checked; - $(checkbox[i]).trigger('change'); - } - - } - - } - } - } - }); - } - - }; - - Handsontable.CheckboxRenderer = CheckboxRenderer; - Handsontable.renderers.CheckboxRenderer = CheckboxRenderer; - Handsontable.renderers.registerRenderer('checkbox', CheckboxRenderer); - -})(Handsontable); -/** - * Numeric cell renderer - * @param {Object} instance Handsontable instance - * @param {Element} TD Table cell where to render - * @param {Number} row - * @param {Number} col - * @param {String|Number} prop Row object property name - * @param value Value to render (remember to escape unsafe HTML before inserting to DOM!) - * @param {Object} cellProperties Cell properites (shared by cell renderer and editor) - */ -(function (Handsontable) { - - 'use strict'; - - var NumericRenderer = function (instance, TD, row, col, prop, value, cellProperties) { - if (Handsontable.helper.isNumeric(value)) { - if (typeof cellProperties.language !== 'undefined') { - numeral.language(cellProperties.language) - } - value = numeral(value).format(cellProperties.format || '0'); //docs: http://numeraljs.com/ - instance.view.wt.wtDom.addClass(TD, 'htNumeric'); - } - Handsontable.renderers.TextRenderer(instance, TD, row, col, prop, value, cellProperties); - }; - - Handsontable.NumericRenderer = NumericRenderer; //Left for backward compatibility with versions prior 0.10.0 - Handsontable.renderers.NumericRenderer = NumericRenderer; - Handsontable.renderers.registerRenderer('numeric', NumericRenderer); - -})(Handsontable); -(function(Handosntable){ - - 'use strict'; - - var PasswordRenderer = function (instance, TD, row, col, prop, value, cellProperties) { - Handsontable.renderers.TextRenderer.apply(this, arguments); - - value = TD.innerHTML; - - var hash; - var hashLength = cellProperties.hashLength || value.length; - var hashSymbol = cellProperties.hashSymbol || '*'; - - for( hash = ''; hash.split(hashSymbol).length - 1 < hashLength; hash += hashSymbol); - - instance.view.wt.wtDom.fastInnerHTML(TD, hash); - - }; - - Handosntable.PasswordRenderer = PasswordRenderer; - Handosntable.renderers.PasswordRenderer = PasswordRenderer; - Handosntable.renderers.registerRenderer('password', PasswordRenderer); - -})(Handsontable); -(function (Handsontable) { - - function HtmlRenderer(instance, TD, row, col, prop, value, cellProperties){ - - Handsontable.renderers.cellDecorator.apply(this, arguments); - - Handsontable.Dom.fastInnerHTML(TD, value); - } - - Handsontable.renderers.registerRenderer('html', HtmlRenderer); - Handsontable.renderers.HtmlRenderer = HtmlRenderer; - -})(Handsontable); - -(function (Handsontable) { - 'use strict'; - - Handsontable.EditorState = { - VIRGIN: 'STATE_VIRGIN', //before editing - EDITING: 'STATE_EDITING', - WAITING: 'STATE_WAITING', //waiting for async validation - FINISHED: 'STATE_FINISHED' - }; - - function BaseEditor(instance) { - this.instance = instance; - this.state = Handsontable.EditorState.VIRGIN; - - this._opened = false; - this._closeCallback = null; - - this.init(); - } - - BaseEditor.prototype._fireCallbacks = function(result) { - if(this._closeCallback){ - this._closeCallback(result); - this._closeCallback = null; - } - - }; - - BaseEditor.prototype.init = function(){}; - - BaseEditor.prototype.getValue = function(){ - throw Error('Editor getValue() method unimplemented'); - }; - - BaseEditor.prototype.setValue = function(newValue){ - throw Error('Editor setValue() method unimplemented'); - }; - - BaseEditor.prototype.open = function(){ - throw Error('Editor open() method unimplemented'); - }; - - BaseEditor.prototype.close = function(){ - throw Error('Editor close() method unimplemented'); - }; - - BaseEditor.prototype.prepare = function(row, col, prop, td, originalValue, cellProperties){ - this.TD = td; - this.row = row; - this.col = col; - this.prop = prop; - this.originalValue = originalValue; - this.cellProperties = cellProperties; - - this.state = Handsontable.EditorState.VIRGIN; - }; - - BaseEditor.prototype.extend = function(){ - var baseClass = this.constructor; - function Editor(){ - baseClass.apply(this, arguments); - } - - function inherit(Child, Parent){ - function Bridge() { - } - - Bridge.prototype = Parent.prototype; - Child.prototype = new Bridge(); - Child.prototype.constructor = Child; - return Child; - } - - return inherit(Editor, baseClass); - }; - - BaseEditor.prototype.saveValue = function (val, ctrlDown) { - if (ctrlDown) { //if ctrl+enter and multiple cells selected, behave like Excel (finish editing and apply to all cells) - var sel = this.instance.getSelected(); - this.instance.populateFromArray(sel[0], sel[1], val, sel[2], sel[3], 'edit'); - } - else { - this.instance.populateFromArray(this.row, this.col, val, null, null, 'edit'); - } - }; - - BaseEditor.prototype.beginEditing = function(initialValue){ - if (this.state != Handsontable.EditorState.VIRGIN) { - return; - } - - if (this.cellProperties.readOnly) { - return; - } - - this.instance.view.scrollViewport({row: this.row, col: this.col}); - this.instance.view.render(); - - this.state = Handsontable.EditorState.EDITING; - - initialValue = typeof initialValue == 'string' ? initialValue : this.originalValue; - - this.setValue(Handsontable.helper.stringify(initialValue)); - - this.open(); - this._opened = true; - this.focus(); - - this.instance.view.render(); //only rerender the selections (FillHandle should disappear when beginediting is triggered) - }; - - BaseEditor.prototype.finishEditing = function (restoreOriginalValue, ctrlDown, callback) { - - if (callback) { - var previousCloseCallback = this._closeCallback; - this._closeCallback = function (result) { - if(previousCloseCallback){ - previousCloseCallback(result); - } - - callback(result); - }; - } - - if (this.isWaiting()) { - return; - } - - if (this.state == Handsontable.EditorState.VIRGIN) { - var that = this; - setTimeout(function () { - that._fireCallbacks(true); - }); - return; - } - - if (this.state == Handsontable.EditorState.EDITING) { - - if (restoreOriginalValue) { - - this.cancelChanges(); - return; - - } - - - var val = [ - [String.prototype.trim.call(this.getValue())] //String.prototype.trim is defined in Walkontable polyfill.js - ]; - - this.state = Handsontable.EditorState.WAITING; - - this.saveValue(val, ctrlDown); - - if(this.instance.getCellValidator(this.cellProperties)){ - var that = this; - this.instance.addHookOnce('afterValidate', function (result) { - that.state = Handsontable.EditorState.FINISHED; - that.discardEditor(result); - }); - } else { - this.state = Handsontable.EditorState.FINISHED; - this.discardEditor(true); - } - - } - }; - - BaseEditor.prototype.cancelChanges = function () { - this.state = Handsontable.EditorState.FINISHED; - this.discardEditor(); - }; - - BaseEditor.prototype.discardEditor = function (result) { - if (this.state !== Handsontable.EditorState.FINISHED) { - return; - } - - if (result === false && this.cellProperties.allowInvalid !== true) { //validator was defined and failed - - this.instance.selectCell(this.row, this.col); - this.focus(); - - this.state = Handsontable.EditorState.EDITING; - - this._fireCallbacks(false); - } - else { - this.close(); - this._opened = false; - - this.state = Handsontable.EditorState.VIRGIN; - - this._fireCallbacks(true); - } - - }; - - BaseEditor.prototype.isOpened = function(){ - return this._opened; - }; - - BaseEditor.prototype.isWaiting = function () { - return this.state === Handsontable.EditorState.WAITING; - }; - - Handsontable.editors.BaseEditor = BaseEditor; - -})(Handsontable); - -(function(Handsontable){ - var TextEditor = Handsontable.editors.BaseEditor.prototype.extend(); - - TextEditor.prototype.init = function(){ - this.createElements(); - this.bindEvents(); - }; - - TextEditor.prototype.getValue = function(){ - return this.TEXTAREA.value - }; - - TextEditor.prototype.setValue = function(newValue){ - this.TEXTAREA.value = newValue; - }; - - var onBeforeKeyDown = function onBeforeKeyDown(event){ - - var instance = this; - var that = instance.getActiveEditor(); - - var keyCodes = Handsontable.helper.keyCode; - var ctrlDown = (event.ctrlKey || event.metaKey) && !event.altKey; //catch CTRL but not right ALT (which in some systems triggers ALT+CTRL) - - - //Process only events that have been fired in the editor - if (event.target !== that.TEXTAREA || event.isImmediatePropagationStopped()){ - return; - } - - if (event.keyCode === 17 || event.keyCode === 224 || event.keyCode === 91 || event.keyCode === 93) { - //when CTRL or its equivalent is pressed and cell is edited, don't prepare selectable text in textarea - event.stopImmediatePropagation(); - return; - } - - switch (event.keyCode) { - case keyCodes.ARROW_RIGHT: - if (that.wtDom.getCaretPosition(that.TEXTAREA) !== that.TEXTAREA.value.length) { - event.stopImmediatePropagation(); - } - break; - - case keyCodes.ARROW_LEFT: /* arrow left */ - if (that.wtDom.getCaretPosition(that.TEXTAREA) !== 0) { - event.stopImmediatePropagation(); - } - break; - - case keyCodes.ENTER: - var selected = that.instance.getSelected(); - var isMultipleSelection = !(selected[0] === selected[2] && selected[1] === selected[3]); - if ((ctrlDown && !isMultipleSelection) || event.altKey) { //if ctrl+enter or alt+enter, add new line - if(that.isOpened()){ - that.setValue(that.getValue() + '\n'); - that.focus(); - } else { - that.beginEditing(that.originalValue + '\n') - } - event.stopImmediatePropagation(); - } - event.preventDefault(); //don't add newline to field - break; - - case keyCodes.A: - case keyCodes.X: - case keyCodes.C: - case keyCodes.V: - if(ctrlDown){ - event.stopImmediatePropagation(); //CTRL+A, CTRL+C, CTRL+V, CTRL+X should only work locally when cell is edited (not in table context) - break; - } - case keyCodes.BACKSPACE: - case keyCodes.DELETE: - case keyCodes.HOME: - case keyCodes.END: - event.stopImmediatePropagation(); //backspace, delete, home, end should only work locally when cell is edited (not in table context) - break; - } - - }; - - TextEditor.prototype.open = function(){ - this.refreshDimensions(); //need it instantly, to prevent https://github.com/warpech/jquery-handsontable/issues/348 - - this.instance.addHook('beforeKeyDown', onBeforeKeyDown); - }; - - TextEditor.prototype.close = function(){ - this.textareaParentStyle.display = 'none'; - - if (document.activeElement === this.TEXTAREA) { - this.instance.listen(); //don't refocus the table if user focused some cell outside of HT on purpose - } - - this.instance.removeHook('beforeKeyDown', onBeforeKeyDown); - }; - - TextEditor.prototype.focus = function(){ - this.TEXTAREA.focus(); - this.wtDom.setCaretPosition(this.TEXTAREA, this.TEXTAREA.value.length); - }; - - TextEditor.prototype.createElements = function () { - this.$body = $(document.body); - this.wtDom = new WalkontableDom(); - - this.TEXTAREA = document.createElement('TEXTAREA'); - this.$textarea = $(this.TEXTAREA); - - this.wtDom.addClass(this.TEXTAREA, 'handsontableInput'); - - this.textareaStyle = this.TEXTAREA.style; - this.textareaStyle.width = 0; - this.textareaStyle.height = 0; - - this.TEXTAREA_PARENT = document.createElement('DIV'); - this.wtDom.addClass(this.TEXTAREA_PARENT, 'handsontableInputHolder'); - - this.textareaParentStyle = this.TEXTAREA_PARENT.style; - this.textareaParentStyle.top = 0; - this.textareaParentStyle.left = 0; - this.textareaParentStyle.display = 'none'; - - this.TEXTAREA_PARENT.appendChild(this.TEXTAREA); - - this.instance.rootElement[0].appendChild(this.TEXTAREA_PARENT); - - var that = this; - Handsontable.PluginHooks.add('afterRender', function () { - that.instance.registerTimeout('refresh_editor_dimensions', function () { - that.refreshDimensions(); - }, 0); - }); - }; - - TextEditor.prototype.refreshDimensions = function () { - if (this.state !== Handsontable.EditorState.EDITING) { - return; - } - - ///start prepare textarea position - this.TD = this.instance.getCell(this.row, this.col); - if (!this.TD) { - //TD is outside of the viewport. Otherwise throws exception when scrolling the table while a cell is edited - return; - } - var $td = $(this.TD); //because old td may have been scrolled out with scrollViewport - var currentOffset = this.wtDom.offset(this.TD); - var containerOffset = this.wtDom.offset(this.instance.rootElement[0]); - var scrollTop = this.instance.rootElement.scrollTop(); - var scrollLeft = this.instance.rootElement.scrollLeft(); - var editTop = currentOffset.top - containerOffset.top + scrollTop - 1; - var editLeft = currentOffset.left - containerOffset.left + scrollLeft - 1; - - var settings = this.instance.getSettings(); - var rowHeadersCount = settings.rowHeaders === false ? 0 : 1; - var colHeadersCount = settings.colHeaders === false ? 0 : 1; - - if (editTop < 0) { - editTop = 0; - } - if (editLeft < 0) { - editLeft = 0; - } - - if (rowHeadersCount > 0 && parseInt($td.css('border-top-width'), 10) > 0) { - editTop += 1; - } - if (colHeadersCount > 0 && parseInt($td.css('border-left-width'), 10) > 0) { - editLeft += 1; - } - - this.textareaParentStyle.top = editTop + 'px'; - this.textareaParentStyle.left = editLeft + 'px'; - ///end prepare textarea position - - var width = $td.width() - , maxWidth = this.instance.view.maximumVisibleElementWidth(editLeft) - 10 //10 is TEXTAREAs border and padding - , height = $td.outerHeight() - 4 - , maxHeight = this.instance.view.maximumVisibleElementHeight(editTop) - 5; //10 is TEXTAREAs border and padding - - if (parseInt($td.css('border-top-width'), 10) > 0) { - height -= 1; - } - if (parseInt($td.css('border-left-width'), 10) > 0) { - if (rowHeadersCount > 0) { - width -= 1; - } - } - - //in future may change to pure JS http://stackoverflow.com/questions/454202/creating-a-textarea-with-auto-resize - this.$textarea.autoResize({ - minHeight: Math.min(height, maxHeight), - maxHeight: maxHeight, //TEXTAREA should never be wider than visible part of the viewport (should not cover the scrollbar) - minWidth: Math.min(width, maxWidth), - maxWidth: maxWidth, //TEXTAREA should never be wider than visible part of the viewport (should not cover the scrollbar) - animate: false, - extraSpace: 0 - }); - - this.textareaParentStyle.display = 'block'; - }; - - TextEditor.prototype.bindEvents = function () { - this.$textarea.on('cut.editor', function (event) { - event.stopPropagation(); - }); - - this.$textarea.on('paste.editor', function (event) { - event.stopPropagation(); - }); - }; - - Handsontable.editors.TextEditor = TextEditor; - Handsontable.editors.registerEditor('text', Handsontable.editors.TextEditor); - -})(Handsontable); - -(function(Handsontable){ - - //Blank editor, because all the work is done by renderer - var CheckboxEditor = Handsontable.editors.BaseEditor.prototype.extend(); - - CheckboxEditor.prototype.beginEditing = function () { - this.saveValue([ - [!this.originalValue] - ]); - }; - CheckboxEditor.prototype.finishEditing = function () {}; - - CheckboxEditor.prototype.init = function () {}; - CheckboxEditor.prototype.open = function () {}; - CheckboxEditor.prototype.close = function () {}; - CheckboxEditor.prototype.getValue = function () {}; - CheckboxEditor.prototype.setValue = function () {}; - CheckboxEditor.prototype.focus = function () {}; - - Handsontable.editors.CheckboxEditor = CheckboxEditor; - Handsontable.editors.registerEditor('checkbox', CheckboxEditor); - -})(Handsontable); - - -(function (Handsontable) { - var DateEditor = Handsontable.editors.TextEditor.prototype.extend(); - - DateEditor.prototype.init = function () { - if (!$.datepicker) { - throw new Error("jQuery UI Datepicker dependency not found. Did you forget to include jquery-ui.custom.js or its substitute?"); - } - - Handsontable.editors.TextEditor.prototype.init.apply(this, arguments); - - this.isCellEdited = false; - var that = this; - - this.instance.addHook('afterDestroy', function () { - that.destroyElements(); - }) - - }; - - DateEditor.prototype.createElements = function () { - Handsontable.editors.TextEditor.prototype.createElements.apply(this, arguments); - - this.datePicker = document.createElement('DIV'); - this.instance.view.wt.wtDom.addClass(this.datePicker, 'htDatepickerHolder'); - this.datePickerStyle = this.datePicker.style; - this.datePickerStyle.position = 'absolute'; - this.datePickerStyle.top = 0; - this.datePickerStyle.left = 0; - this.datePickerStyle.zIndex = 99; - document.body.appendChild(this.datePicker); - this.$datePicker = $(this.datePicker); - - var that = this; - var defaultOptions = { - dateFormat: "yy-mm-dd", - showButtonPanel: true, - changeMonth: true, - changeYear: true, - altField: this.$textarea, - onSelect: function () { - that.finishEditing(false); - } - }; - this.$datePicker.datepicker(defaultOptions); - - /** - * Prevent recognizing clicking on jQuery Datepicker as clicking outside of table - */ - this.$datePicker.on('mousedown', function (event) { - event.stopPropagation(); - }); - - this.hideDatepicker(); - }; - - DateEditor.prototype.destroyElements = function () { - this.$datePicker.datepicker('destroy'); - this.$datePicker.remove(); - }; - - DateEditor.prototype.beginEditing = function (row, col, prop, useOriginalValue, suffix) { - Handsontable.editors.TextEditor.prototype.beginEditing.apply(this, arguments); - this.showDatepicker(); - }; - - DateEditor.prototype.finishEditing = function (isCancelled, ctrlDown) { - this.hideDatepicker(); - Handsontable.editors.TextEditor.prototype.finishEditing.apply(this, arguments); - }; - - DateEditor.prototype.showDatepicker = function () { - var $td = $(this.TD); - var offset = $td.offset(); - this.datePickerStyle.top = (offset.top + $td.height()) + 'px'; - this.datePickerStyle.left = offset.left + 'px'; - - var dateOptions = { - defaultDate: this.originalValue || void 0 - }; - $.extend(dateOptions, this.cellProperties); - this.$datePicker.datepicker("option", dateOptions); - if (this.originalValue) { - this.$datePicker.datepicker("setDate", this.originalValue); - } - this.datePickerStyle.display = 'block'; - }; - - DateEditor.prototype.hideDatepicker = function () { - this.datePickerStyle.display = 'none'; - }; - - - Handsontable.editors.DateEditor = DateEditor; - Handsontable.editors.registerEditor('date', DateEditor); -})(Handsontable); -/** - * This is inception. Using Handsontable as Handsontable editor - */ -(function (Handsontable) { - "use strict"; - - var HandsontableEditor = Handsontable.editors.TextEditor.prototype.extend(); - - HandsontableEditor.prototype.createElements = function () { - Handsontable.editors.TextEditor.prototype.createElements.apply(this, arguments); - - var DIV = document.createElement('DIV'); - DIV.className = 'handsontableEditor'; - this.TEXTAREA_PARENT.appendChild(DIV); - - this.$htContainer = $(DIV); - this.$htContainer.handsontable(); - }; - - HandsontableEditor.prototype.prepare = function (td, row, col, prop, value, cellProperties) { - - Handsontable.editors.TextEditor.prototype.prepare.apply(this, arguments); - - var parent = this; - - var options = { - startRows: 0, - startCols: 0, - minRows: 0, - minCols: 0, - className: 'listbox', - copyPaste: false, - cells: function () { - return { - readOnly: true - } - }, - fillHandle: false, - afterOnCellMouseDown: function () { - var value = this.getValue(); - if (value !== void 0) { //if the value is undefined then it means we don't want to set the value - parent.setValue(value); - } - parent.instance.destroyEditor(); - }, - beforeOnKeyDown: function (event) { - var instance = this; - - switch (event.keyCode) { - case Handsontable.helper.keyCode.ESCAPE: - parent.instance.destroyEditor(true); - event.stopImmediatePropagation(); - event.preventDefault(); - break; - - case Handsontable.helper.keyCode.ENTER: //enter - var sel = instance.getSelected(); - var value = this.getDataAtCell(sel[0], sel[1]); - if (value !== void 0) { //if the value is undefined then it means we don't want to set the value - parent.setValue(value); - } - parent.instance.destroyEditor(); - break; - - case Handsontable.helper.keyCode.ARROW_UP: - if (instance.getSelected() && instance.getSelected()[0] == 0 && !parent.cellProperties.strict){ - instance.deselectCell(); - parent.instance.listen(); - parent.focus(); - event.preventDefault(); - event.stopImmediatePropagation(); - } - break; - } - } - }; - - if (this.cellProperties.handsontable) { - options = $.extend(options, cellProperties.handsontable); - } - this.$htContainer.handsontable('destroy'); - this.$htContainer.handsontable(options); - }; - - var onBeforeKeyDown = function (event) { - - if (event.isImmediatePropagationStopped()) { - return; - } - - var editor = this.getActiveEditor(); - var innerHOT = editor.$htContainer.handsontable('getInstance'); - - if (event.keyCode == Handsontable.helper.keyCode.ARROW_DOWN) { - - if (!innerHOT.getSelected()){ - innerHOT.selectCell(0, 0); - } else { - var selectedRow = innerHOT.getSelected()[0]; - var rowToSelect = selectedRow < innerHOT.countRows() - 1 ? selectedRow + 1 : selectedRow; - - innerHOT.selectCell(rowToSelect, 0); - } - - event.preventDefault(); - event.stopImmediatePropagation(); - } - - }; - - HandsontableEditor.prototype.open = function () { - - this.instance.addHook('beforeKeyDown', onBeforeKeyDown); - - Handsontable.editors.TextEditor.prototype.open.apply(this, arguments); - - this.$htContainer.handsontable('render'); - - if (this.cellProperties.strict) { - this.$htContainer.handsontable('selectCell', 0, 0); - this.$textarea[0].style.visibility = 'hidden'; - } else { - this.$htContainer.handsontable('deselectCell'); - this.$textarea[0].style.visibility = 'visible'; - } - - this.wtDom.setCaretPosition(this.$textarea[0], 0, this.$textarea[0].value.length); - - }; - - HandsontableEditor.prototype.close = function () { - - this.instance.removeHook('beforeKeyDown', onBeforeKeyDown); - this.instance.listen(); - - Handsontable.editors.TextEditor.prototype.close.apply(this, arguments); - }; - - HandsontableEditor.prototype.focus = function () { - - this.instance.listen(); - - Handsontable.editors.TextEditor.prototype.focus.apply(this, arguments); - }; - - HandsontableEditor.prototype.beginEditing = function (initialValue) { - var onBeginEditing = this.instance.getSettings().onBeginEditing; - if (onBeginEditing && onBeginEditing() === false) { - return; - } - - Handsontable.editors.TextEditor.prototype.beginEditing.apply(this, arguments); - - }; - - HandsontableEditor.prototype.finishEditing = function (isCancelled, ctrlDown) { - if (this.$htContainer.handsontable('isListening')) { //if focus is still in the HOT editor - this.instance.listen(); //return the focus to the parent HOT instance - } - - if (this.$htContainer.handsontable('getSelected')) { - var value = this.$htContainer.handsontable('getInstance').getValue(); - if (value !== void 0) { //if the value is undefined then it means we don't want to set the value - this.setValue(value); - } - } - - return Handsontable.editors.TextEditor.prototype.finishEditing.apply(this, arguments); - }; - - Handsontable.editors.HandsontableEditor = HandsontableEditor; - Handsontable.editors.registerEditor('handsontable', HandsontableEditor); - -})(Handsontable); - - - - - - -(function (Handsontable) { - var AutocompleteEditor = Handsontable.editors.HandsontableEditor.prototype.extend(); - - AutocompleteEditor.prototype.init = function () { - Handsontable.editors.HandsontableEditor.prototype.init.apply(this, arguments); - - this.query = null; - }; - - AutocompleteEditor.prototype.createElements = function(){ - Handsontable.editors.HandsontableEditor.prototype.createElements.apply(this, arguments); - - this.$htContainer.addClass('autocompleteEditor'); - - }; - - AutocompleteEditor.prototype.bindEvents = function(){ - - var that = this; - this.$textarea.on('keydown.autocompleteEditor', function(event){ - if(!Handsontable.helper.isMetaKey(event.keyCode) || [Handsontable.helper.keyCode.BACKSPACE, Handsontable.helper.keyCode.DELETE].indexOf(event.keyCode) != -1){ - setTimeout(function () { - that.queryChoices(that.$textarea.val()); - }); - } else if (event.keyCode == Handsontable.helper.keyCode.ENTER && that.cellProperties.strict !== true){ - that.$htContainer.handsontable('deselectCell'); - } - - }); - - this.$htContainer.on('mouseenter', function () { - that.$htContainer.handsontable('deselectCell'); - }); - - this.$htContainer.on('mouseleave', function () { - that.queryChoices(that.query); - }); - - Handsontable.editors.HandsontableEditor.prototype.bindEvents.apply(this, arguments); - - }; - - AutocompleteEditor.prototype.beginEditing = function () { - Handsontable.editors.HandsontableEditor.prototype.beginEditing.apply(this, arguments); - - var that = this; - setTimeout(function () { - that.queryChoices(that.TEXTAREA.value); - }); - - var hot = this.$htContainer.handsontable('getInstance'); - - hot.updateSettings({ - 'colWidths': [this.wtDom.outerWidth(this.TEXTAREA) - 2], - afterRenderer: function (TD, row, col, prop, value, cellProperties) { - var match = TD.innerHTML.match(new RegExp(that.query, 'i')); - if(match){ - TD.innerHTML = value.replace(match[0], '' + match[0] + ''); - } - } - }); - - - }; - - var onBeforeKeyDownInner; - - AutocompleteEditor.prototype.open = function () { - - var parent = this; - - onBeforeKeyDownInner = function (event) { - var instance = this; - - if (event.keyCode == Handsontable.helper.keyCode.ARROW_UP){ - if (instance.getSelected() && instance.getSelected()[0] == 0){ - - if(!parent.cellProperties.strict){ - instance.deselectCell(); - } - - parent.instance.listen(); - parent.focus(); - event.preventDefault(); - event.stopImmediatePropagation(); - } - } - - }; - - this.$htContainer.handsontable('getInstance').addHook('beforeKeyDown', onBeforeKeyDownInner); - - Handsontable.editors.HandsontableEditor.prototype.open.apply(this, arguments); - - this.$textarea[0].style.visibility = 'visible'; - parent.focus(); - }; - - AutocompleteEditor.prototype.close = function () { - - this.$htContainer.handsontable('getInstance').removeHook('beforeKeyDown', onBeforeKeyDownInner); - - Handsontable.editors.HandsontableEditor.prototype.close.apply(this, arguments); - }; - - AutocompleteEditor.prototype.queryChoices = function(query){ - - this.query = query; - - if (typeof this.cellProperties.source == 'function'){ - var that = this; - - this.cellProperties.source(query, function(choices){ - that.updateChoicesList(choices) - }); - - } else if (Handsontable.helper.isArray(this.cellProperties.source)) { - - var choices; - - if(!query || this.cellProperties.filter === false){ - choices = this.cellProperties.source; - } else { - - var queryRegex = new RegExp(query, this.cellProperties.filteringCaseSensitive === true ? '' : 'i'); - - choices = this.cellProperties.source.filter(function(choice){ - return queryRegex.test(choice); - }); - } - - this.updateChoicesList(choices) - - } else { - this.updateChoicesList([]); - } - - }; - - function findItemIndexToHighlight(items, value){ - var bestMatch = {}; - var valueLength = value.length; - var currentItem; - var indexOfValue; - var charsLeft; - - - for(var i = 0, len = items.length; i < len; i++){ - currentItem = items[i]; - - if(valueLength > 0){ - indexOfValue = currentItem.indexOf(value) - } else { - indexOfValue = currentItem === value ? 0 : -1; - } - - if(indexOfValue == -1) continue; - - charsLeft = currentItem.length - indexOfValue - valueLength; - - if( typeof bestMatch.indexOfValue == 'undefined' - || bestMatch.indexOfValue > indexOfValue - || ( bestMatch.indexOfValue == indexOfValue && bestMatch.charsLeft > charsLeft ) ){ - - bestMatch.indexOfValue = indexOfValue; - bestMatch.charsLeft = charsLeft; - bestMatch.index = i; - - } - - } - - - return bestMatch.index; - } - - AutocompleteEditor.prototype.updateChoicesList = function (choices) { - this.$htContainer.handsontable('loadData', Handsontable.helper.pivot([choices])); - - var value = this.getValue(); - var rowToHighlight; - - if(this.cellProperties.strict === true){ - - rowToHighlight = findItemIndexToHighlight(choices, value); - - if ( typeof rowToHighlight == 'undefined'){ - rowToHighlight = 0; - } - - } - - if(typeof rowToHighlight == 'undefined'){ - this.$htContainer.handsontable('deselectCell'); - } else { - this.$htContainer.handsontable('selectCell', rowToHighlight, 0); - } - - this.focus(); - }; - - Handsontable.editors.AutocompleteEditor = AutocompleteEditor; - Handsontable.editors.registerEditor('autocomplete', AutocompleteEditor); - -})(Handsontable); - -(function(Handsontable){ - - var PasswordEditor = Handsontable.editors.TextEditor.prototype.extend(); - var wtDom = new WalkontableDom(); - - PasswordEditor.prototype.createElements = function () { - Handsontable.editors.TextEditor.prototype.createElements.apply(this, arguments); - - this.TEXTAREA = document.createElement('input'); - this.TEXTAREA.setAttribute('type', 'password'); - this.TEXTAREA.className = 'handsontableInput'; - this.textareaStyle = this.TEXTAREA.style; - this.textareaStyle.width = 0; - this.textareaStyle.height = 0; - this.$textarea = $(this.TEXTAREA); - - wtDom.empty(this.TEXTAREA_PARENT); - this.TEXTAREA_PARENT.appendChild(this.TEXTAREA); - - }; - - Handsontable.editors.PasswordEditor = PasswordEditor; - Handsontable.editors.registerEditor('password', PasswordEditor); - -})(Handsontable); - -(function (Handsontable) { - - var SelectEditor = Handsontable.editors.BaseEditor.prototype.extend(); - - SelectEditor.prototype.init = function(){ - this.select = $('