diff --git a/README-zh.md b/README-zh.md index 4814428..2c5fe4d 100644 --- a/README-zh.md +++ b/README-zh.md @@ -1,10 +1,10 @@ # Luckysheet 简体中文 | [English](./README.md) -## Introduction - 介绍 +## 介绍 Luckysheet ,一款纯前端类似excel的在线表格,功能强大、配置简单、完全开源。 -## Features - 特性 +## 特性 1. Luckysheet支持表格设置包括冻结行列、合并单元格、筛选、排序、查询、条件格式、批注 2. 支持数据分析功能包括透视表、图表、分列、矩阵操作、内置385个计算函数 3. 支持一键截图、复制为json数据、共享编辑、excel与Luckysheet之间数据的复制粘贴 @@ -15,28 +15,32 @@ Luckysheet ,一款纯前端类似excel的在线表格,功能强大、配置 ![演示](https://minio.cnbabylon.com/public/luckysheet/LuckysheetDemo.gif) -## Plan - 计划 -- 模块化(进行中) -- excel导入/导出 -- 表单 +## 计划 +- 完善图表插件 - 插入图片 +- 数据验证(复选框、下拉列表) +- 打印 +- 单元格分段样式 +- 树形菜单 +- 表格功能:筛选,切片 +- excel导入/导出 - 更多... -## Documentation - 文档 +## 文档 [在线demo](https://mengshukeji.github.io/LuckysheetDemo/) [在线文档](https://mengshukeji.github.io/LuckysheetDocs/) -## Requirements - 环境 +## 环境 [Node.js](https://nodejs.org/en/) Version >= 6 -## Installation - 安装 +## 安装 ``` npm install npm install gulp -g ``` -## Development - 开发 +## 开发 开发 ``` npm run dev @@ -49,7 +53,7 @@ npm run build Luckysheet的核心代码为luckysheet-core.js和luckysheet-function.js,开发者看源码只需要看这两个文件即可,接下来会讨论进行模块化方案,完善这个插件. -## Usage - 用法 +## 用法 #### 第一步 `npm run build`后`dist`文件夹下的所有文件复制到项目目录 @@ -82,10 +86,10 @@ Luckysheet的核心代码为luckysheet-core.js和luckysheet-function.js,开发 ``` -## Contact - 联系 +## 联系 mengshu@office2.cn -## communication - 交流 +## 交流 - 添加小编微信,拉你进Luckysheet开发者交流微信群,备注:加群 @@ -97,11 +101,11 @@ mengshu@office2.cn 微信群 -## Authors and acknowledgment - 贡献者和感谢 -- Bug Pan ([@wpxp123456](https://github.com/wpxp123456)) -- Dushusir ([@Dushusir](https://github.com/Dushusir)) +## 贡献者和感谢 +- [@wpxp123456](https://github.com/wpxp123456) +- [@Dushusir](https://github.com/Dushusir) -## License - 版权信息 +## 版权信息 [MIT](http://opensource.org/licenses/MIT) Copyright (c) 2020-present, mengshukeji diff --git a/README.md b/README.md index 0745dd9..383c666 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,6 @@ # Luckysheet +[![Join the chat at https://gitter.im/mengshukeji/Luckysheet](https://badges.gitter.im/mengshukeji/Luckysheet.svg)](https://gitter.im/mengshukeji/Luckysheet?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) + English| [简体中文](./README-zh.md) ## Introduction @@ -17,10 +19,14 @@ Luckysheet is an online spreadsheet like excel that is powerful, simple to confi ![Demo](https://minio.cnbabylon.com/public/luckysheet/LuckysheetDemo.gif) ## Plan -- modularization (in progress) -- Excel import/export -- Form +- Improve chart plugin - Insert picture +- Data validation (checkbox, drop-down list) +- Print +- Cell segmentation style +- Tree menu +- Table function: filter, slice +- Excel import/export - More... ## Documentation @@ -88,11 +94,11 @@ mengshu@office2.cn ## communication -coming soon! +- [Gitter](https://gitter.im/mengshukeji/Luckysheet) ## Authors and acknowledgment -- Bug Pan ([@wpxp123456](https://github.com/wpxp123456)) -- Dushusir ([@Dushusir](https://github.com/Dushusir)) +- [@wpxp123456](https://github.com/wpxp123456) +- [@Dushusir](https://github.com/Dushusir) ## License [MIT](http://opensource.org/licenses/MIT) diff --git a/src/config.js b/src/config.js index 4847416..045b137 100644 --- a/src/config.js +++ b/src/config.js @@ -22,7 +22,7 @@ export default { config: {}, //表格行高、列宽、合并单元格、公式等设置 fullscreenmode: true, //是否全屏模式,非全屏模式下,标记框不会强制选中。 devicePixelRatio: window.devicePixelRatio, //设备比例,比例越大表格分标率越高 - allowEdit: false, //是否允许前台编辑 + allowEdit: true, //是否允许前台编辑 loadUrl: "", // 配置loadUrl的地址,luckysheet会通过ajax请求表格数据,默认载入status为1的sheet数据中的所有data,其余的sheet载入除data字段外的所有字段 loadSheetUrl: "", //配置loadSheetUrl的地址,参数为gridKey(表格主键) 和 index(sheet主键合集,格式为[1,2,3]),返回的数据为sheet的data字段数据集合 gridKey: "", // 表格唯一标识符 diff --git a/src/controllers/conditionformat.js b/src/controllers/conditionformat.js index 772cad5..29ae399 100644 --- a/src/controllers/conditionformat.js +++ b/src/controllers/conditionformat.js @@ -2064,6 +2064,9 @@ const conditionformat = { $("#luckysheet-editorConditionRule-dialog #isPercent").attr("checked", "checked"); } } + + $("#luckysheet-editorConditionRule-dialog #textcolorshow").spectrum("set", ruleFormat.textColor); + $("#luckysheet-editorConditionRule-dialog #cellcolorshow").spectrum("set", ruleFormat.cellColor); } }, infoDialog: function(title, content){ @@ -3333,8 +3336,9 @@ const conditionformat = { dSmall = genarate(conditionValue0)[2]; } else{ - dBig = genarate(conditionValue0.toString().split("-")[1])[2]; - dSmall = genarate(conditionValue0.toString().split("-")[0])[2]; + let str = conditionValue0.toString().split("-"); + dBig = genarate(str[1].trim())[2]; + dSmall = genarate(str[0].trim())[2]; } //循环应用范围计算 for(let r = cellrange[s].row[0]; r <= cellrange[s].row[1]; r++){ diff --git a/src/controllers/filter.js b/src/controllers/filter.js index 862ab8d..e667cf5 100644 --- a/src/controllers/filter.js +++ b/src/controllers/filter.js @@ -193,14 +193,14 @@ function createFilterOptions(luckysheet_filter_save, filterObj) { $("#luckysheet-filter-selected-sheet" + Store.currentSheetIndex).remove(); $("#luckysheet-filter-options-sheet" + Store.currentSheetIndex).remove(); - if(Store.luckysheet_filter_save == null || JSON.stringify(Store.luckysheet_filter_save) == "{}"){ + if(luckysheet_filter_save == null || JSON.stringify(luckysheet_filter_save) == "{}"){ return; } - let r1 = Store.luckysheet_filter_save.row[0], - r2 = Store.luckysheet_filter_save.row[1]; - let c1 = Store.luckysheet_filter_save.column[0], - c2 = Store.luckysheet_filter_save.column[1]; + let r1 = luckysheet_filter_save.row[0], + r2 = luckysheet_filter_save.row[1]; + let c1 = luckysheet_filter_save.column[0], + c2 = luckysheet_filter_save.column[1]; let row = Store.visibledatarow[r2], row_pre = r1 - 1 == -1 ? 0 : Store.visibledatarow[r1 - 1]; @@ -254,13 +254,13 @@ function createFilterOptions(luckysheet_filter_save, filterObj) { $("#luckysheet-rightclick-menu").hide(); $("#luckysheet-filter-menu, #luckysheet-filter-submenu").hide(); - if ($("#luckysheet-cell-main").scrollTop() > Store.luckysheet_filter_save["top_move"]) { - $("#luckysheet-scrollbar-y").scrollTop(Store.luckysheet_filter_save["top_move"]); + if ($("#luckysheet-cell-main").scrollTop() > luckysheet_filter_save["top_move"]) { + $("#luckysheet-scrollbar-y").scrollTop(luckysheet_filter_save["top_move"]); } let file = Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)]; - file.filter_select = Store.luckysheet_filter_save; + file.filter_select = luckysheet_filter_save; } export { diff --git a/src/controllers/handler.js b/src/controllers/handler.js index fc4f627..07a326c 100644 --- a/src/controllers/handler.js +++ b/src/controllers/handler.js @@ -185,215 +185,6 @@ export default function luckysheetHandler() { } }); - // //禁止前台编辑 - // if(!Store.allowEdit){ - // return; - // } - - //选区拖动替换 - $("#luckysheet-cell-main div.luckysheet-cs-draghandle").mousedown(function (event) { - if(isEditMode()){//此模式下禁用选区拖动 - return; - } - - $("#luckysheet-cell-selected").find(".luckysheet-cs-fillhandle") - .css("cursor","move") - .end() - .find(".luckysheet-cs-draghandle") - .css("cursor","move"); - $("#luckysheet-cell-main, #luckysheetTableContent, #luckysheet-sheettable_0").css("cursor","move"); - - Store.luckysheet_cell_selected_move = true; - Store.luckysheet_scroll_status = true; - - let mouse = mouseposition(event.pageX, event.pageY); - let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft(); - let y = mouse[1] + $("#luckysheet-cell-main").scrollTop(); - - let row_location = rowLocation(y), - row_pre = row_location[0], - row = row_location[1], - row_index = row_location[2]; - let col_location = colLocation(x), - col_pre = col_location[0], - col = col_location[1], - col_index = col_location[2]; - - Store.luckysheet_cell_selected_move_index = [row_index, col_index]; - - $("#luckysheet-cell-selected-move").css({ - "left": col_pre, - "width": col - col_pre - 1, - "top": row_pre, - "height": row - row_pre - 1, - "display": "block" - }); - - event.stopPropagation(); - }); - - //选区下拉 - $("#luckysheet-cell-main div.luckysheet-cs-fillhandle").mousedown(function (event) { - if(isEditMode()){//此模式下禁用选区下拉 - return; - } - - $("#luckysheet-cell-selected").find(".luckysheet-cs-fillhandle") - .css("cursor","crosshair") - .end() - .find(".luckysheet-cs-draghandle") - .css("cursor","crosshair"); - $("#luckysheet-cell-main, #luckysheetTableContent, #luckysheet-sheettable_0").css("cursor","crosshair"); - - Store.luckysheet_cell_selected_extend_time = setTimeout(function () { - Store.luckysheet_cell_selected_extend = true; - Store.luckysheet_scroll_status = true; - - let mouse = mouseposition(event.pageX, event.pageY); - let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft() - 5; - let y = mouse[1] + $("#luckysheet-cell-main").scrollTop() - 5; - - let row_location = rowLocation(y), - row_pre = row_location[0], - row = row_location[1], - row_index = row_location[2]; - let col_location = colLocation(x), - col_pre = col_location[0], - col = col_location[1], - col_index = col_location[2]; - - Store.luckysheet_cell_selected_extend_index = [row_index, col_index]; - - $("#luckysheet-cell-selected-extend").css({ - "left": col_pre, - "width": col - col_pre - 1, - "top": row_pre, - "height": row - row_pre - 1, - "display": "block" - }); - }, 100); - - event.stopPropagation(); - }).click(function () { - clearTimeout(Store.luckysheet_cell_selected_extend_time); - event.stopPropagation(); - }).dblclick(function () { - let last = Store.luckysheet_select_save[0]; - - let r0 = last.row[0], - r1 = last.row[1], - c0 = last.column[0], - c1 = last.column[1]; - - if(pivotTable.isPivotRange(r0, c0)){ - return; - } - - let dropCellState = false; - let step = 0; - - for(let r = r1 + 1; r < Store.flowdata.length; r++){ - if(c0 - 1 >= 0 && c1 + 1 < Store.flowdata[0].length){ - let cell1 = Store.flowdata[r][c0 - 1]; - let cell2 = Store.flowdata[r][c1 + 1]; - - if(r == r1 + 1){ - if((cell1 == null || isRealNull(cell1.v)) && (cell2 == null || isRealNull(cell2.v))){ - dropCellState = false; - break; - } - else{ - dropCellState = true; - step++; - } - } - else{ - if((cell1 == null || isRealNull(cell1.v)) && (cell2 == null || isRealNull(cell2.v))){ - break; - } - - step++; - } - } - else if(c0 - 1 >= 0){ - let cell = Store.flowdata[r][c0 - 1]; - - if(r == r1 + 1){ - if(cell == null || isRealNull(cell.v)){ - dropCellState = false; - break; - } - else{ - dropCellState = true; - step++; - } - } - else{ - if(cell == null || isRealNull(cell.v)){ - break; - } - - step++; - } - } - else if(c1 + 1 < Store.flowdata[0].length){ - let cell = Store.flowdata[r][c1 + 1]; - - if(r == r1 + 1){ - if(cell == null || isRealNull(cell.v)){ - dropCellState = false; - break; - } - else{ - dropCellState = true; - step++; - } - } - else{ - if(cell == null || isRealNull(cell.v)){ - break; - } - - step++; - } - } - } - - if(!dropCellState || step == 0){ - event.stopPropagation(); - return; - } - - //复制范围 - luckysheetDropCell.copyRange = { "row": [r0, r1], "column": [c0, c1] }; - - //applyType - let typeItemHide = luckysheetDropCell.typeItemHide(); - - if(!typeItemHide[0] && !typeItemHide[1] && !typeItemHide[2] && !typeItemHide[3] && !typeItemHide[4] && !typeItemHide[5] && !typeItemHide[6]){ - luckysheetDropCell.applyType = "0"; - } - else{ - luckysheetDropCell.applyType = "1"; - } - - luckysheetDropCell.applyRange = { "row": [r1 + 1, r1 + step], "column": [c0, c1] }; - luckysheetDropCell.direction = "down"; - - Store.luckysheet_select_save = [{ "row": [r0, r1 + step], "column": [c0, c1] }]; - - luckysheetDropCell.update(); - luckysheetDropCell.createIcon(); - - $("#luckysheet-cell-selected-move").hide(); - - $("#luckysheet-sheettable").css("cursor", "default"); - clearTimeout(Store.countfuncTimeout); - Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); - - event.stopPropagation(); - }); - //表格mousedown $("#luckysheet-cell-main, #luckysheetTableContent").mousedown(function (event) { $("#luckysheet-cell-selected").find(".luckysheet-cs-fillhandle") @@ -1071,6 +862,11 @@ export default function luckysheetHandler() { }).mouseup(function (event) { if (event.which == "3") { + //禁止前台编辑(只可 框选单元格、滚动查看表格) + if(!Store.allowEdit){ + return; + } + if(isEditMode()){ //非编辑模式下禁止右键功能框 return; } @@ -1179,6 +975,11 @@ export default function luckysheetHandler() { showrightclickmenu($("#luckysheet-rightclick-menu"), x, y); } }).dblclick(function (event) { + //禁止前台编辑(只可 框选单元格、滚动查看表格) + if(!Store.allowEdit){ + return; + } + if(parseInt($("#luckysheet-input-box").css("top")) > 0){ return; } @@ -1283,2841 +1084,3107 @@ export default function luckysheetHandler() { } }); - // - $("#luckysheet-bottom-add-row, #luckysheet-bottom-add-row-input, #luckysheet-bottom-return-top").on("mousedown dblclick mouseup",function(e){ - e.stopPropagation(); - }); - - //底部添加行按钮 - $("#luckysheet-bottom-add-row").on("click", function(e) { - $("#luckysheet-rightclick-menu").hide(); - $("#" + Store.container).attr("tabindex", 0).focus(); + //表格mousemove + $(document).mousemove(function (event) { + luckysheetPostil.overshow(event); //有批注显示 - let $t = $(this), value = $("#luckysheet-bottom-add-row-input").val(); + clearInterval(Store.jfautoscrollTimeout); - if(value == ""){ - value = 100; - } - - if (isNaN(parseInt(value))) { - if(isEditMode()){ - alert("请输入数字"); + if(formula.functionResizeStatus){ + let y = event.pageY; + let movepx = y - formula.functionResizeData.y; + let mpx = formula.functionResizeData.calculatebarHeight + movepx; + let winh = Math.round($(window).height()/2); + + if(mpx <= 28){ + if(mpx <= 20){ + return; + } + mpx = 28; } - else{ - tooltip.info("增加错误", "请输入数字"); + else if(mpx >= winh){ + if(mpx >= winh + 8){ + return; + } + mpx = winh; } - return; - } - value = parseInt(value); - if (value < 1 || value > 100) { - if(isEditMode()){ - alert("增加范围限制在1-100"); - } - else{ - tooltip.info("增加错误", "增加范围限制在1-100"); - } - return; + Store.calculatebarHeight = mpx; + $("#luckysheet-wa-calculate").css("height", Store.calculatebarHeight - 2); + $("#luckysheet-wa-calculate-size").css({"background":"#5e5e5e", "cursor":"ns-resize"}); + + clearTimeout(formula.functionResizeTimeout); + formula.functionResizeTimeout = setTimeout(function(){ + luckysheetsizeauto(); + }, 15); } + else if (!!luckysheetFreezen.horizontalmovestate) { + let mouse = mouseposition(event.pageX, event.pageY); + let scrollLeft = $("#luckysheet-cell-main").scrollLeft(); + let scrollTop = $("#luckysheet-cell-main").scrollTop(); + let x = mouse[0] + scrollLeft; + let y = mouse[1] + scrollTop; - luckysheetextendtable("row", Store.flowdata.length - 1, value); - }); + let row_location = rowLocation(y), + row = row_location[1], + row_pre = row_location[0], + row_index = row_location[2]; + let top = mouse[1] + Store.columeHeaderHeight; - $("#luckysheet-bottom-return-top").on("click", function(e) { - $("#luckysheet-scrollbar-y").scrollTop(0); - }); + if (top < Store.columeHeaderHeight) { + top = Store.columeHeaderHeight; + } - //单元格编辑输入 - let luckysheet_shiftkeydown = false; + if (top > luckysheetFreezen.windowHeight - 4) { + top = luckysheetFreezen.windowHeight - 4; + } - $("#luckysheet-input-box").click(function () { - formula.rangeHightlightselected($("#luckysheet-rich-text-editor")); - }).add("#" + Store.container).on("keydown", function (event) { - if ($("#luckysheet-modal-dialog-mask").is(":visible") || $(event.target).hasClass("luckysheet-mousedown-cancel") || $(event.target).hasClass("formulaInputFocus")) { - return; - } + $("#luckysheet-freezebar-horizontal").find(".luckysheet-freezebar-horizontal-handle").css({ "top": top }); - let ctrlKey = event.ctrlKey; - let altKey = event.altKey; - let shiftKey = event.shiftKey; - let kcode = event.keyCode; - - if ($("#luckysheet-modal-dialog-mask").is(":visible") || $(event.target).hasClass("luckysheet-mousedown-cancel") || $(event.target).hasClass("sp-input") || (parseInt($("#luckysheet-input-box").css("top")) > 0 && $(event.target).closest(".luckysheet-input-box").length > 0 && kcode != keycode.ENTER && kcode != keycode.TAB && kcode != keycode.UP && kcode != keycode.DOWN && kcode != keycode.LEFT && kcode != keycode.RIGHT)) { - let anchor = $(window.getSelection().anchorNode); - - if(anchor.parent().is("#luckysheet-helpbox-cell") || anchor.is("#luckysheet-helpbox-cell")){ - if(kcode == keycode.ENTER){ - let helpboxValue = $("#luckysheet-helpbox-cell").text(); + if (top + scrollTop - Store.columeHeaderHeight >= row_pre + (row - row_pre) / 2) { + top = row - 2 - scrollTop + Store.columeHeaderHeight; + luckysheetFreezen.freezenhorizontaldata = [row, row_index + 1, scrollTop, luckysheetFreezen.cutVolumn(Store.visibledatarow, row_index + 1), top]; + } + else { + top = row_pre - 2 - scrollTop + Store.columeHeaderHeight; + luckysheetFreezen.freezenhorizontaldata = [row_pre, row_index, scrollTop, luckysheetFreezen.cutVolumn(Store.visibledatarow, row_index), top]; + } - if(formula.iscelldata(helpboxValue)){ - let cellrange = formula.getcellrange(helpboxValue); - - Store.luckysheet_select_save = [{ "row": cellrange["row"], "column": cellrange["column"], "row_focus": cellrange["row"][0], "column_focus": cellrange["column"][0] }]; - selectHightlightShow(); - - $("#luckysheet-helpbox-cell").blur(); + $("#luckysheet-freezebar-horizontal").find(".luckysheet-freezebar-horizontal-drop").css({ "top": top }); + luckysheetFreezen.saveFreezen(luckysheetFreezen.freezenhorizontaldata, top, null, null); + } + else if (!!luckysheetFreezen.verticalmovestate) { + let mouse = mouseposition(event.pageX, event.pageY); + let scrollLeft = $("#luckysheet-cell-main").scrollLeft(); + let scrollTop = $("#luckysheet-cell-main").scrollTop(); + let x = mouse[0] + scrollLeft; + let y = mouse[1] + scrollTop; - let scrollLeft = $("#luckysheet-cell-main").scrollLeft(), - scrollTop = $("#luckysheet-cell-main").scrollTop(); - let winH = $("#luckysheet-cell-main").height(), - winW = $("#luckysheet-cell-main").width(); + let col_location = colLocation(x), + col = col_location[1], + col_pre = col_location[0], + col_index = col_location[2]; - let row = Store.visibledatarow[cellrange["row"][1]], - row_pre = cellrange["row"][0] - 1 == -1 ? 0 : Store.visibledatarow[cellrange["row"][0] - 1]; - let col = Store.visibledatacolumn[cellrange["column"][1]], - col_pre = cellrange["column"][0] - 1 == -1 ? 0 : Store.visibledatacolumn[cellrange["column"][0] - 1]; + let left = mouse[0] + Store.rowHeaderWidth; - if (col - scrollLeft - winW + 20 > 0) { - $("#luckysheet-scrollbar-x").scrollLeft(col - winW + 20); - } - else if (col_pre - scrollLeft - 20 < 0) { - $("#luckysheet-scrollbar-x").scrollLeft(col_pre - 20); - } + if (left < Store.rowHeaderWidth) { + left = Store.rowHeaderWidth; + } - if (row - scrollTop - winH + 20 > 0) { - $("#luckysheet-scrollbar-y").scrollTop(row - winH + 20); - } - else if (row_pre - scrollTop - 20 < 0) { - $("#luckysheet-scrollbar-y").scrollTop(row_pre - 20); - } - } - } + if (left > luckysheetFreezen.windowWidth - 4) { + left = luckysheetFreezen.windowWidth - 4; } - - return; - } - - let $inputbox = $("#luckysheet-input-box"); - - if (kcode == keycode.ENTER && parseInt($inputbox.css("top")) > 0) { - if ($("#luckysheet-formula-search-c").is(":visible") && formula.searchFunctionCell != null) { - formula.searchFunctionEnter($("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item-active")); + + $("#luckysheet-freezebar-vertical").find(".luckysheet-freezebar-vertical-handle").css({ "left": left }); + + if (left + scrollLeft - Store.rowHeaderWidth >= col_pre + (col - col_pre) / 2) { + left = col - 2 - scrollLeft + Store.rowHeaderWidth; + luckysheetFreezen.freezenverticaldata = [col, col_index + 1, scrollLeft, luckysheetFreezen.cutVolumn(Store.visibledatacolumn, col_index + 1), left]; } else { - formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); - Store.luckysheet_select_save = [{ - "row": [Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[0]], - "column": [Store.luckysheetCellUpdate[1], Store.luckysheetCellUpdate[1]], - "row_focus": Store.luckysheetCellUpdate[0], - "column_focus": Store.luckysheetCellUpdate[1] - }]; - luckysheetMoveHighlightCell("down", 1, "rangeOfSelect"); + left = col_pre - 2 - scrollLeft + Store.rowHeaderWidth; + luckysheetFreezen.freezenverticaldata = [col_pre, col_index, scrollLeft, luckysheetFreezen.cutVolumn(Store.visibledatacolumn, col_index), left]; } - //若有参数弹出框,隐藏 - if($("#luckysheet-search-formula-parm").is(":visible")){ - $("#luckysheet-search-formula-parm").hide(); - } - //若有参数选取范围弹出框,隐藏 - if($("#luckysheet-search-formula-parm-select").is(":visible")){ - $("#luckysheet-search-formula-parm-select").hide(); - } - event.preventDefault(); + $("#luckysheet-freezebar-vertical").find(".luckysheet-freezebar-vertical-drop").css({ "left": left }); + luckysheetFreezen.saveFreezen(null, null, luckysheetFreezen.freezenverticaldata, left); + luckysheetsizeauto();//调节选区时下部单元格溢出 } - else if (kcode == keycode.TAB) { - if (parseInt($inputbox.css("top")) > 0) { - return; - } - - luckysheetMoveHighlightCell("right", 1, "rangeOfSelect"); - event.preventDefault(); + else if (!!pivotTable && pivotTable.movestate) { + let x = event.pageX, y = event.pageY; + $("#luckysheet-modal-dialog-slider-pivot-move").css({ + "left": x - pivotTable.movesave.width / 2, + "top": y - pivotTable.movesave.height + }); } - else if(kcode == keycode.F2){ - if (parseInt($inputbox.css("top")) > 0) { + else if (Store.luckysheet_sheet_move_status) { + let scrollLeft = $("#luckysheet-sheet-container-c").scrollLeft(); + let x = event.pageX + scrollLeft; + + if (Math.abs(event.pageX - Store.luckysheet_sheet_move_data.pageX) < 3) { return; } - let last = Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]; + let winW = $("#luckysheet-sheet-container").width(); + let left = x - Store.luckysheet_sheet_move_data.curleft - $("#luckysheet-sheet-container").offset().left; + Store.luckysheet_sheet_move_data.activeobject.css({ "left": left }); - let row_index = last["row_focus"], col_index = last["column_focus"]; - let row = Store.visibledatarow[row_index], - row_pre = row_index - 1 == -1 ? 0 : Store.visibledatarow[row_index - 1]; - let col = Store.visibledatacolumn[col_index], - col_pre = col_index - 1 == -1 ? 0 : Store.visibledatacolumn[col_index - 1]; + let row_index = luckysheet_searcharray(Store.luckysheet_sheet_move_data.widthlist, left + Store.luckysheet_sheet_move_data.curleft); + Store.luckysheet_sheet_move_data.cursorobject.css({ "cursor": "move" }); - luckysheetupdateCell(row, row_pre, row_index, col, col_pre, col_index, Store.flowdata); - event.preventDefault(); - } - else if (kcode == keycode.F4 && parseInt($inputbox.css("top")) > 0) { - formula.setfreezonFuc(event); - event.preventDefault(); - } - else if (kcode == keycode.ESC && parseInt($inputbox.css("top")) > 0) { - formula.dontupdate(); - luckysheetMoveHighlightCell("down", 0, "rangeOfSelect"); - event.preventDefault(); - } - else if (kcode == keycode.ENTER) { - if($(event.target).hasClass("formulaInputFocus") || $("#luckysheet-conditionformat-dialog").is(":visible")){ - return; + if (left - scrollLeft <= 6) { + $("#luckysheet-sheets-leftscroll").click(); } - else if (String.fromCharCode(kcode) != null && $("#luckysheet-cell-selected").is(":visible")) { - let last = Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]; - let row_index = last["row_focus"], col_index = last["column_focus"]; - let row = Store.visibledatarow[row_index], - row_pre = row_index - 1 == -1 ? 0 : Store.visibledatarow[row_index - 1]; - let col = Store.visibledatacolumn[col_index], - col_pre = col_index - 1 == -1 ? 0 : Store.visibledatacolumn[col_index - 1]; + if (left - scrollLeft >= winW - 40) { + $("#luckysheet-sheets-rightscroll").click(); + } - let margeset = menuButton.mergeborer(Store.flowdata, row_index, col_index); - if(!!margeset){ - row = margeset.row[1]; - row_pre = margeset.row[0]; - row_index = margeset.row[2]; - col = margeset.column[1]; - col_pre = margeset.column[0]; - col_index = margeset.column[2]; + if (row_index != Store.luckysheet_sheet_move_data.curindex) { + if (row_index == -1 && left > 0) { + row_index = Store.luckysheet_sheet_move_data.widthlist.length - 1; + $("#luckysheet-sheets-item-clone").insertAfter($("#luckysheet-sheet-area div.luckysheet-sheets-item:visible").eq(row_index)); + } + else if (row_index == -1 && left <= 0) { + $("#luckysheet-sheets-item-clone").insertBefore($("#luckysheet-sheet-area div.luckysheet-sheets-item:visible").eq(0)); + } + else { + $("#luckysheet-sheets-item-clone").insertAfter($("#luckysheet-sheet-area div.luckysheet-sheets-item:visible").eq(row_index)); } - luckysheetupdateCell(row, row_pre, row_index, col, col_pre, col_index, Store.flowdata); - event.preventDefault(); - } - } - else { - if (ctrlKey || event.metaKey) { - if (shiftKey) { - if (!luckysheet_shiftkeydown) { - Store.luckysheet_shiftpositon = $.extend(true, {}, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]); - Store.luckysheet_shiftkeydown = true; + Store.luckysheet_sheet_move_data.widthlist = []; + $("#luckysheet-sheet-area div.luckysheet-sheets-item:visible").each(function (i) { + if (i == 0) { + Store.luckysheet_sheet_move_data.widthlist.push(parseInt($(this).outerWidth())); } - - //Ctrl + shift + 方向键 调整选区 - if (kcode == keycode.UP) { - if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; - } - - luckysheetMoveHighlightRange2("up", "rangeOfSelect"); + else { + Store.luckysheet_sheet_move_data.widthlist.push(parseInt($(this).outerWidth()) + Store.luckysheet_sheet_move_data.widthlist[i - 1]); } - else if (kcode == keycode.DOWN) { - if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; - } + }); - luckysheetMoveHighlightRange2("down", "rangeOfSelect"); - } - else if (kcode == keycode.LEFT) { - if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; - } + Store.luckysheet_sheet_move_data.curindex = $("#luckysheet-sheet-area div.luckysheet-sheets-item:visible").index($("#luckysheet-sheets-item-clone")); + } + } + else if (Store.luckysheet_model_move_state) { + let scrollTop = $(document).scrollTop(), scrollLeft = $(document).scrollLeft(); + let y = event.pageY + scrollTop, x = event.pageX + scrollLeft; + let winH = $(window).height(), winW = $(window).width(); + let myh = Store.luckysheet_model_move_obj.height(), + myw = Store.luckysheet_model_move_obj.width(); + let top = y - Store.luckysheet_model_xy[1], + left = x - Store.luckysheet_model_xy[0]; - luckysheetMoveHighlightRange2("left", "rangeOfSelect"); - } - else if (kcode == keycode.RIGHT) { - if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; - } + if (top < 0) { + top = 0; + } - luckysheetMoveHighlightRange2("right", "rangeOfSelect"); - } - } - else if (kcode == 66) {//Ctrl + B 加粗 - $("#luckysheet-icon-bold").click(); - } - else if (kcode == 67) {//Ctrl + C 复制 - //复制时存在格式刷状态,取消格式刷 - if(menuButton.luckysheetPaintModelOn){ - menuButton.cancelPaintModel(); - } - - if(Store.luckysheet_select_save.length == 0){ - return; - } + if (top + myh + 62 > winH) { + top = winH - myh - 62; + } - //复制范围内包含部分合并单元格,提示 - if(Store.config["merge"] != null){ - let has_PartMC = false; + if (left < 0) { + left = 0; + } - for(let s = 0; s < Store.luckysheet_select_save.length; s++){ - let r1 = Store.luckysheet_select_save[s].row[0], - r2 = Store.luckysheet_select_save[s].row[1]; - let c1 = Store.luckysheet_select_save[s].column[0], - c2 = Store.luckysheet_select_save[s].column[1]; + if (left + myw + 86 > winW) { + left = winW - myw - 86; + } - has_PartMC = hasPartMC(Store.config, r1, r2, c1, c2); + Store.luckysheet_model_move_obj.css({ "top": top, "left": left }); + event.preventDefault(); + } + else if (!!Store.luckysheet_scroll_status || !!Store.luckysheet_select_status || !!Store.luckysheet_rows_selected_status || !!Store.luckysheet_cols_selected_status || !!Store.luckysheet_cell_selected_move || !!Store.luckysheet_cell_selected_extend || !!Store.luckysheet_cols_change_size || !!Store.luckysheet_rows_change_size || !!formula.rangeResize || !!formula.rangeMove) { + if (Store.luckysheet_select_status) { + clearTimeout(Store.countfuncTimeout); + Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); + } + + Store.jfautoscrollTimeout = setInterval(function () { + if (Store.luckysheet_scroll_status && !Store.luckysheet_cols_change_size && !Store.luckysheet_rows_change_size) { + let mouse = mouseposition(event.pageX, event.pageY); + let left = $("#luckysheet-scrollbar-x").scrollLeft(), + top = $("#luckysheet-scrollbar-y").scrollTop(); + let x = mouse[0]; + let y = mouse[1]; + let winH = $("#luckysheet-cell-main").height() - 20, + winW = $("#luckysheet-cell-main").width() - 60; - if(has_PartMC){ - break; - } + if (y < 0 || y > winH) { + let stop; + if (y < 0) { + stop = top + y/2; + } + else { + stop = top + (y - winH)/2; } + $("#luckysheet-scrollbar-y").scrollTop(stop); + } - if(has_PartMC){ - if(isEditMode()){ - alert("无法对部分合并单元格执行此操作"); - } - else{ - tooltip.info("无法对部分合并单元格执行此操作", ""); - } - return; + if (x < 0 || x > winW) { + let sleft; + if (x < 0) { + sleft = left + x/2; + } + else { + sleft = left + (x - winW)/2; } + $("#luckysheet-scrollbar-x").scrollLeft(sleft); } + } + if (Store.luckysheet_select_status) { + let mouse = mouseposition(event.pageX, event.pageY); + let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft(); + let y = mouse[1] + $("#luckysheet-cell-main").scrollTop(); - //多重选区 有条件格式时 提示 - let cdformat = Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)].luckysheet_conditionformat_save; - if(Store.luckysheet_select_save.length > 1 && cdformat != null && cdformat.length > 0){ - let hasCF = false; + let row_location = rowLocation(y), + row = row_location[1], + row_pre = row_location[0], + row_index = row_location[2]; + let col_location = colLocation(x), + col = col_location[1], + col_pre = col_location[0], + col_index = col_location[2]; - let cf_compute = conditionformat.getComputeMap(); + let last = $.extend(true, {}, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]); - label: - for(let s = 0; s < Store.luckysheet_select_save.length; s++){ - if(hasCF){ - break; - } - - let r1 = Store.luckysheet_select_save[s].row[0], - r2 = Store.luckysheet_select_save[s].row[1]; - let c1 = Store.luckysheet_select_save[s].column[0], - c2 = Store.luckysheet_select_save[s].column[1]; + let top = 0, height = 0, rowseleted = []; + if (last.top > row_pre) { + top = row_pre; + height = last.top + last.height - row_pre; - for(let r = r1; r <= r2; r++){ - for(let c = c1; c <= c2; c++){ - if(conditionformat.checksCF(r, c, cf_compute) != null){ - hasCF = true; - continue label; - } - } - } + if(last.row[1] > last.row_focus){ + last.row[1] = last.row_focus; } - if(hasCF){ - if(isEditMode()){ - alert("无法对多重选择区域执行此操作"); - } - else{ - tooltip.info("无法对多重选择区域执行此操作", ""); - } - return; - } + rowseleted = [row_index, last.row[1]]; + } + else if (last.top == row_pre) { + top = row_pre; + height = last.top + last.height - row_pre; + rowseleted = [row_index, last.row[0]]; } + else { + top = last.top; + height = row - last.top - 1; - //多重选区 行不一样且列不一样时 提示 - if(Store.luckysheet_select_save.length > 1){ - let isSameRow = true, - str_r = luckysheet_select_save[0].row[0], - end_r = luckysheet_select_save[0].row[1]; - let isSameCol = true, - str_c = luckysheet_select_save[0].column[0], - end_c = luckysheet_select_save[0].column[1]; - - for(let s = 1; s < luckysheet_select_save.length; s++){ - if(luckysheet_select_save[s].row[0] != str_r || luckysheet_select_save[s].row[1] != end_r){ - isSameRow = false; - } - if(luckysheet_select_save[s].column[0] != str_c || luckysheet_select_save[s].column[1] != end_c){ - isSameCol = false; - } + if(last.row[0] < last.row_focus){ + last.row[0] = last.row_focus; } - if((!isSameRow && !isSameCol) || selectIsOverlap()){ - if(isEditMode()){ - alert("无法对多重选择区域执行此操作"); - } - else{ - tooltip.info("无法对多重选择区域执行此操作", ""); - } - return; - } + rowseleted = [last.row[0], row_index]; } - selection.copy(event); - - Store.luckysheet_paste_iscut = false; - luckysheetactiveCell(); - - event.stopPropagation(); - return; - } - else if (kcode == 70) {//Ctrl + F 查找 - searchReplace.createDialog(0); - searchReplace.init(); + let left = 0, width = 0, columnseleted = []; + if (last.left > col_pre) { + left = col_pre; + width = last.left + last.width - col_pre; - $("#luckysheet-search-replace #searchInput input").focus(); - } - else if (kcode == 72) {//Ctrl + H 替换 - searchReplace.createDialog(1); - searchReplace.init(); + if(last.column[1] > last.column_focus){ + last.column[1] = last.column_focus; + } - $("#luckysheet-search-replace #searchInput input").focus(); - } - else if (kcode == 73) {//Ctrl + I 斜体 - $("#luckysheet-icon-italic").click(); - } - else if (kcode == 86) {//Ctrl + V 粘贴 - if(isEditMode()){//此模式下禁用粘贴 - return; + columnseleted = [col_index, last.column[1]]; } - - if($(event.target).hasClass("formulaInputFocus")){ - return; + else if (last.left == col_pre) { + left = col_pre; + width = last.left + last.width - col_pre; + columnseleted = [col_index, last.column[0]]; } + else { + left = last.left; + width = col - last.left - 1; - if(Store.luckysheet_select_save.length > 1){ - if(isEditMode()){ - alert("无法在此处粘贴此内容,请选择粘贴区域的一个单元格,然后再次尝试粘贴"); - } - else{ - tooltip.info("无法在此处粘贴此内容,请选择粘贴区域的一个单元格,然后再次尝试粘贴", ""); + if(last.column[0] < last.column_focus){ + last.column[0] = last.column_focus; } - return; - } - - selection.isPasteAction = true; - luckysheetactiveCell(); - event.stopPropagation(); - return; - } - else if (kcode == 88) {//Ctrl + X 剪切 - //复制时存在格式刷状态,取消格式刷 - if(menuButton.luckysheetPaintModelOn){ - menuButton.cancelPaintModel(); + columnseleted = [last.column[0], col_index]; } - if(Store.luckysheet_select_save.length == 0){ - return; + let changeparam = menuButton.mergeMoveMain(columnseleted, rowseleted, last, top, height, left, width); + if(changeparam != null){ + columnseleted = changeparam[0]; + rowseleted= changeparam[1]; + top = changeparam[2]; + height = changeparam[3]; + left = changeparam[4]; + width = changeparam[5]; } - //复制范围内包含部分合并单元格,提示 - if(Store.config["merge"] != null){ - let has_PartMC = false; + last["row"] = rowseleted; + last["column"] = columnseleted; - for(let s = 0; s < Store.luckysheet_select_save.length; s++){ - let r1 = Store.luckysheet_select_save[s].row[0], - r2 = Store.luckysheet_select_save[s].row[1]; - let c1 = Store.luckysheet_select_save[s].column[0], - c2 = Store.luckysheet_select_save[s].column[1]; + last["left_move"] = left; + last["width_move"] = width; + last["top_move"] = top; + last["height_move"] = height; - has_PartMC = hasPartMC(Store.config, r1, r2, c1, c2); + Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1] = last; - if(has_PartMC){ - break; - } - } + selectHightlightShow(); + + luckysheetFreezen.scrollFreezen(); - if(has_PartMC){ - if(luckysheetConfigsetting.editMode){ - alert("无法对合并单元格执行此操作"); - } - else{ - tooltip.info("无法对合并单元格执行此操作", ""); - } - return; - } + $("#luckysheet-helpbox-cell").text(getRangetxt(Store.currentSheetIndex, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1])); + + //交替颜色选择范围 + if($("#luckysheet-alternateformat-rangeDialog").is(":visible")){ + $("#luckysheet-alternateformat-rangeDialog input").val(getRangetxt(Store.currentSheetIndex, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1])); } - //多重选区时 提示 - if(Store.luckysheet_select_save.length > 1){ - if(isEditMode()){ - alert("不能对多重选择区域执行此操作,请选择单个区域,然后再试"); - } - else{ - tooltip.info("不能对多重选择区域执行此操作,请选择单个区域,然后再试", ""); - } - return; + if (pivotTable.luckysheet_pivotTable_select_state) { + $("#luckysheet-pivotTable-range-selection-input").val(Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)].name + "!" + chatatABC(Store.luckysheet_select_save[0]["column"][0]) + (Store.luckysheet_select_save[0]["row"][0] + 1) + ":" + chatatABC(Store.luckysheet_select_save[0]["column"][1]) + (Store.luckysheet_select_save[0]["row"][1] + 1)); } + } + else if(conditionformat.selectStatus){ + let mouse = mouseposition(event.pageX, event.pageY); + let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft(); + let y = mouse[1] + $("#luckysheet-cell-main").scrollTop(); - selection.copy(event); + let row_location = rowLocation(y), + row = row_location[1], + row_pre = row_location[0], + row_index = row_location[2]; + let col_location = colLocation(x), + col = col_location[1], + col_pre = col_location[0], + col_index = col_location[2]; - Store.luckysheet_paste_iscut = true; - luckysheetactiveCell(); - - event.stopPropagation(); - return; - } - else if (kcode == 90) {//Ctrl + Z 撤销 - controlHistory.redo(event); - luckysheetactiveCell(); - event.stopPropagation(); - return; - } - else if (kcode == 89) {//Ctrl + Y 重做 - controlHistory.undo(event); - luckysheetactiveCell(); - event.stopPropagation(); - return; - } - else if (kcode == keycode.UP) {//Ctrl + up 调整单元格 - if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; - } + let last = conditionformat.selectRange[conditionformat.selectRange.length - 1]; - luckysheetMoveHighlightCell2("up", "rangeOfSelect"); - } - else if (kcode == keycode.DOWN) {//Ctrl + down 调整单元格 - if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; - } + let top = 0, height = 0, rowseleted = []; + if (last.top > row_pre) { + top = row_pre; + height = last.top + last.height - row_pre; - luckysheetMoveHighlightCell2("down", "rangeOfSelect"); - } - else if (kcode == keycode.LEFT) {//Ctrl + top 调整单元格 - if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; - } + if(last.row[1] > last.row_focus){ + last.row[1] = last.row_focus; + } - luckysheetMoveHighlightCell2("left", "rangeOfSelect"); - } - else if (kcode == keycode.RIGHT) {//Ctrl + right 调整单元格 - if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; + rowseleted = [row_index, last.row[1]]; + } + else if (last.top == row_pre) { + top = row_pre; + height = last.top + last.height - row_pre; + rowseleted = [row_index, last.row[0]]; } + else { + top = last.top; + height = row - last.top - 1; - luckysheetMoveHighlightCell2("right", "rangeOfSelect"); - } - else if (String.fromCharCode(kcode).toLocaleUpperCase() == "A") {//Ctrl + A 全选 - $("#luckysheet-left-top").trigger("mousedown"); - $(document).trigger("mouseup"); - } + if(last.row[0] < last.row_focus){ + last.row[0] = last.row_focus; + } - event.preventDefault(); - return; - } - else if (shiftKey && (kcode == keycode.UP || kcode == keycode.DOWN || kcode == keycode.LEFT || kcode == keycode.RIGHT || (altKey && (kcode == 53 || kcode == 101)))) { - if (parseInt($inputbox.css("top")) > 0 || $(event.target).hasClass("formulaInputFocus")) { - return; - } + rowseleted = [last.row[0], row_index]; + } - if (!luckysheet_shiftkeydown) { - Store.luckysheet_shiftpositon = $.extend(true, {}, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]); - Store.luckysheet_shiftkeydown = true; - } + let left = 0, width = 0, columnseleted = []; + if (last.left > col_pre) { + left = col_pre; + width = last.left + last.width - col_pre; - //shift + 方向键 调整选区 - if (kcode == keycode.UP) { - if($("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")){ - return; - } + if(last.column[1] > last.column_focus){ + last.column[1] = last.column_focus; + } - luckysheetMoveHighlightRange("down", -1, "rangeOfSelect"); - } - else if (kcode == keycode.DOWN) { - if($("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")){ - return; + columnseleted = [col_index, last.column[1]]; + } + else if (last.left == col_pre) { + left = col_pre; + width = last.left + last.width - col_pre; + columnseleted = [col_index, last.column[0]]; } + else { + left = last.left; + width = col - last.left - 1; - luckysheetMoveHighlightRange("down", 1, "rangeOfSelect"); - } - else if (kcode == keycode.LEFT) { - if($("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")){ - return; + if(last.column[0] < last.column_focus){ + last.column[0] = last.column_focus; + } + + columnseleted = [last.column[0], col_index]; } - luckysheetMoveHighlightRange("right", -1, "rangeOfSelect"); - } - else if (kcode == keycode.RIGHT) { - if($("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")){ - return; + let changeparam = menuButton.mergeMoveMain(columnseleted, rowseleted, last, top, height, left, width); + if(changeparam != null){ + columnseleted = changeparam[0]; + rowseleted= changeparam[1]; + top = changeparam[2]; + height = changeparam[3]; + left = changeparam[4]; + width = changeparam[5]; } - - luckysheetMoveHighlightRange("right", 1, "rangeOfSelect"); - } - else if (altKey && (kcode == 53 || kcode == 101)) { - //Alt + Shift + 5(删除线) - $("#luckysheet-icon-strikethrough").click(); - } - event.preventDefault(); - } - else if (kcode == keycode.ESC) { - if(menuButton.luckysheetPaintModelOn){ - menuButton.cancelPaintModel(); - } - else{ - cleargridelement(event); - event.preventDefault(); - } + last["row"] = rowseleted; + last["column"] = columnseleted; - selectHightlightShow(); - } - else if (kcode == keycode.DELETE) { - $("#luckysheet-delete-text").click(); + last["left_move"] = left; + last["width_move"] = width; + last["top_move"] = top; + last["height_move"] = height; - event.preventDefault(); - } - else if (kcode == keycode.UP) { - if (parseInt($inputbox.css("top")) > 0 || $(event.target).hasClass("formulaInputFocus") || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; - } + conditionformat.selectRange[conditionformat.selectRange.length - 1] = last; - luckysheetMoveHighlightCell("down", -1, "rangeOfSelect"); - event.preventDefault(); - } - else if (kcode == keycode.DOWN) { - if (parseInt($inputbox.css("top")) > 0 || $(event.target).hasClass("formulaInputFocus") || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; - } + selectionCopyShow(conditionformat.selectRange); - luckysheetMoveHighlightCell("down", 1, "rangeOfSelect"); - event.preventDefault(); - } - else if (kcode == keycode.LEFT) { - if (parseInt($inputbox.css("top")) > 0 || $(event.target).hasClass("formulaInputFocus") || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; + let range = conditionformat.getTxtByRange(conditionformat.selectRange); + $("#luckysheet-multiRange-dialog input").val(range); } - - luckysheetMoveHighlightCell("right", -1, "rangeOfSelect"); - event.preventDefault(); - } - else if (kcode == keycode.RIGHT) { - if (parseInt($inputbox.css("top")) > 0 || $(event.target).hasClass("formulaInputFocus") || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { - return; + else if (formula.rangestart) { + formula.rangedrag(event); } + else if (formula.rangedrag_row_start) { + formula.rangedrag_row(event); + } + else if (formula.rangedrag_column_start) { + formula.rangedrag_column(event); + } + else if (Store.luckysheet_rows_selected_status) { + let mouse = mouseposition(event.pageX, event.pageY); + let y = mouse[1] + $("#luckysheet-rows-h").scrollTop(); + if (y < 0) { + return false; + } - luckysheetMoveHighlightCell("right", 1, "rangeOfSelect"); - event.preventDefault(); - } - else if (!((kcode >= 112 && kcode <= 123) || kcode <= 46 || kcode == 144 || kcode == 108 || event.ctrlKey || event.altKey || (event.shiftKey && (kcode == 37 || kcode == 38 || kcode == 39 || kcode == 40))) || kcode == 8 || kcode == 32 || kcode == 46 || kcode == 0 || (event.ctrlKey && kcode == 86)) { - if (String.fromCharCode(kcode) != null && $("#luckysheet-cell-selected").is(":visible") && (kcode != keycode.CAPSLOCK && kcode != keycode.WIN && kcode != 18)) { - let last = Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]; + let row_location = rowLocation(y), + row = row_location[1], + row_pre = row_location[0], + row_index = row_location[2]; + let col_index = Store.visibledatacolumn.length - 1, + col = Store.visibledatacolumn[col_index], + col_pre = 0; - let row_index = last["row_focus"], col_index = last["column_focus"]; - let row = Store.visibledatarow[row_index], - row_pre = row_index - 1 == -1 ? 0 : Store.visibledatarow[row_index - 1]; - let col = Store.visibledatacolumn[col_index], - col_pre = col_index - 1 == -1 ? 0 : Store.visibledatacolumn[col_index - 1]; - - let margeset = menuButton.mergeborer(Store.flowdata, row_index, col_index); - if(!!margeset){ - row = margeset.row[1]; - row_pre = margeset.row[0]; - row_index = margeset.row[2]; - col = margeset.column[1]; - col_pre = margeset.column[0]; - col_index = margeset.column[2]; - } + let last = $.extend(true, {}, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]); - luckysheetupdateCell(row, row_pre, row_index, col, col_pre, col_index, Store.flowdata, true); - if(kcode == 8){ - $("#luckysheet-rich-text-editor").html("
"); - } - formula.functionInputHanddler($("#luckysheet-functionbox-cell"), $("#luckysheet-rich-text-editor"), kcode); - } - } - } - - luckysheetactiveCell(); + let top = 0, height = 0, rowseleted = []; + if (last.top > row_pre) { + top = row_pre; + height = last.top + last.height - row_pre; - event.stopPropagation(); - }); + if(last.row[1] > last.row_focus){ + last.row[1] = last.row_focus; + } - //右键菜单 复制按钮 - $("#luckysheet-copy-btn, #luckysheet-cols-copy-btn, #luckysheet-paste-btn-title").click(function (event) { - $(this).parent().hide(); + rowseleted = [row_index, last.row[1]]; + } + else if (last.top == row_pre) { + top = row_pre; + height = last.top + last.height - row_pre; + rowseleted = [row_index, last.row[0]]; + } + else { + top = last.top; + height = row - last.top - 1; - //复制范围内包含部分合并单元格,提示 - if(Store.config["merge"] != null){ - let has_PartMC = false; + if(last.row[0] < last.row_focus){ + last.row[0] = last.row_focus; + } - for(let s = 0; s < Store.luckysheet_select_save.length; s++){ - let r1 = Store.luckysheet_select_save[s].row[0], - r2 = Store.luckysheet_select_save[s].row[1]; - let c1 = Store.luckysheet_select_save[s].column[0], - c2 = Store.luckysheet_select_save[s].column[1]; + rowseleted = [last.row[0], row_index]; + } - has_PartMC = hasPartMC(Store.config, r1, r2, c1, c2); + last["row"] = rowseleted; - if(has_PartMC){ - break; - } - } + last["top_move"] = top; + last["height_move"] = height; - if(has_PartMC){ - if(isEditMode()){ - alert("无法对部分合并单元格执行此操作"); - } - else{ - tooltip.info("无法对部分合并单元格执行此操作", ""); + Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1] = last; + + selectHightlightShow(); + + clearTimeout(Store.countfuncTimeout); + Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); } - return; - } - } + else if (Store.luckysheet_cols_selected_status) { + let mouse = mouseposition(event.pageX, event.pageY); + let x = mouse[0] + $("#luckysheet-cols-h-c").scrollLeft(); + if (x < 0) { + return false; + } - //多重选区 有条件格式时 提示 - let cdformat = Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)].luckysheet_conditionformat_save; - if(Store.luckysheet_select_save.length > 1 && cdformat != null && cdformat.length > 0){ - let hasCF = false; + let row_index = Store.visibledatarow.length - 1, + row = Store.visibledatarow[row_index], + row_pre = 0; + let col_location = colLocation(x), + col = col_location[1], + col_pre = col_location[0], + col_index = col_location[2]; - let cf_compute = conditionformat.getComputeMap(); + let last = $.extend(true, {}, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]); - label: - for(let s = 0; s < Store.luckysheet_select_save.length; s++){ - if(hasCF){ - break; - } - - let r1 = Store.luckysheet_select_save[s].row[0], - r2 = Store.luckysheet_select_save[s].row[1]; - let c1 = Store.luckysheet_select_save[s].column[0], - c2 = Store.luckysheet_select_save[s].column[1]; + let left = 0, width = 0, columnseleted = []; + if (last.left > col_pre) { + left = col_pre; + width = last.left + last.width - col_pre; - for(let r = r1; r <= r2; r++){ - for(let c = c1; c <= c2; c++){ - if(conditionformat.checksCF(r, c, cf_compute) != null){ - hasCF = true; - continue label; + if(last.column[1] > last.column_focus){ + last.column[1] = last.column_focus; } + + columnseleted = [col_index, last.column[1]]; } - } - } + else if (last.left == col_pre) { + left = col_pre; + width = last.left + last.width - col_pre; + columnseleted = [col_index, last.column[0]]; + } + else { + left = last.left; + width = col - last.left - 1; - if(hasCF){ - if(isEditMode()){ - alert("无法对多重选择区域执行此操作"); - } - else{ - tooltip.info("无法对多重选择区域执行此操作", ""); - } - return; - } - } + if(last.column[0] < last.column_focus){ + last.column[0] = last.column_focus; + } - //多重选区 行不一样且列不一样时 提示 - if(Store.luckysheet_select_save.length > 1){ - let isSameRow = true, - str_r = Store.luckysheet_select_save[0].row[0], - end_r = Store.luckysheet_select_save[0].row[1]; - let isSameCol = true, - str_c = Store.luckysheet_select_save[0].column[0], - end_c = Store.luckysheet_select_save[0].column[1]; - - for(let s = 1; s < Store.luckysheet_select_save.length; s++){ - if(Store.luckysheet_select_save[s].row[0] != str_r || Store.luckysheet_select_save[s].row[1] != end_r){ - isSameRow = false; - } - if(Store.luckysheet_select_save[s].column[0] != str_c || Store.luckysheet_select_save[s].column[1] != end_c){ - isSameCol = false; - } - } + columnseleted = [last.column[0], col_index]; + } - if((!isSameRow && !isSameCol) || selectIsOverlap()){ - if(isEditMode()){ - alert("无法对多重选择区域执行此操作"); - } - else{ - tooltip.info("无法对多重选择区域执行此操作", ""); - } - return; - } - } - - selection.copy(event); - }); + last["column"] = columnseleted; - //右键菜单 粘贴按钮 - $("#luckysheet-copy-paste, #luckysheet-cols-paste-btn, #luckysheet-paste-btn-title").click(function (event) { - selection.paste(event, "btn"); - $(this).parent().hide(); - }); + last["left_move"] = left; + last["width_move"] = width; - //菜单栏 图表按钮 - $("#luckysheet-chart-btn-title").click(function () { - $("#luckysheetdatavisual").click(); - }); + Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1] = last; - //菜单栏 数据透视表 - $("#luckysheet-pivot-btn-title").click(function (e) { - pivotTable.createPivotTable(e); - }); + selectHightlightShow(); + + clearTimeout(Store.countfuncTimeout); + Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); + } + else if (Store.luckysheet_cell_selected_move) { + let mouse = mouseposition(event.pageX, event.pageY); - //菜单栏 截图按钮 - $("#luckysheet-chart-btn-screenshot").click(function () { - if(Store.luckysheet_select_save.length == 0){ - if(isEditMode()){ - alert("请框选需要截图的范围"); - } - else{ - tooltip.info("提示!", "请框选需要截图的范围"); - } - return; - } + let scrollLeft = $("#luckysheet-cell-main").scrollLeft(); + let scrollTop = $("#luckysheet-cell-main").scrollTop(); - if(Store.luckysheet_select_save.length > 1){ - if(isEditMode()){ - alert("无法对多重选择区域执行此操作"); - } - else{ - tooltip.info("提示!", "无法对多重选择区域执行此操作"); - } + let x = mouse[0] + scrollLeft; + let y = mouse[1] + scrollTop; - return; - } + let winH = $(window).height() + scrollTop - Store.sheetBarHeight - Store.statisticBarHeight, + winW = $(window).width() + scrollLeft; - //复制范围内包含部分合并单元格,提示 - if(Store.config["merge"] != null){ - let has_PartMC = false; + let row_location = rowLocation(y), + row = row_location[1], + row_pre = row_location[0], + row_index = row_location[2]; + let col_location = colLocation(x), + col = col_location[1], + col_pre = col_location[0], + col_index = col_location[2]; - for(let s = 0; s < Store.luckysheet_select_save.length; s++){ - let r1 = Store.luckysheet_select_save[s].row[0], - r2 = Store.luckysheet_select_save[s].row[1]; - let c1 = Store.luckysheet_select_save[s].column[0], - c2 = Store.luckysheet_select_save[s].column[1]; + let row_index_original = Store.luckysheet_cell_selected_move_index[0], + col_index_original = Store.luckysheet_cell_selected_move_index[1]; - has_PartMC = hasPartMC(Store.config, r1, r2, c1, c2); + let row_s = Store.luckysheet_select_save[0]["row"][0] - row_index_original + row_index, + row_e = Store.luckysheet_select_save[0]["row"][1] - row_index_original + row_index; - if(has_PartMC){ - break; - } - } + let col_s = Store.luckysheet_select_save[0]["column"][0] - col_index_original + col_index, + col_e = Store.luckysheet_select_save[0]["column"][1] - col_index_original + col_index; - if(has_PartMC){ - if(isEditMode()){ - alert("无法对合并单元格执行此操作"); - } - else{ - tooltip.info("提示!", "无法对合并单元格执行此操作"); - } - return; - } - } + if (row_s < 0 || y < 0) { + row_s = 0; + row_e = Store.luckysheet_select_save[0]["row"][1] - Store.luckysheet_select_save[0]["row"][0]; + } - let st_r = Store.luckysheet_select_save[0].row[0], - ed_r = Store.luckysheet_select_save[0].row[1]; - let st_c = Store.luckysheet_select_save[0].column[0], - ed_c = Store.luckysheet_select_save[0].column[1]; + if (col_s < 0 || x < 0) { + col_s = 0; + col_e = Store.luckysheet_select_save[0]["column"][1] - Store.luckysheet_select_save[0]["column"][0]; + } - let shotData = datagridgrowth([], ed_r + 1, ed_c + 1); + if (row_e >= Store.visibledatarow[Store.visibledatarow.length - 1] || y > winH) { + row_s = Store.visibledatarow.length - 1 - Store.luckysheet_select_save[0]["row"][1] + Store.luckysheet_select_save[0]["row"][0]; + row_e = Store.visibledatarow.length - 1; + } - for(let r = st_r; r <= ed_r; r++){ - for(let c = st_c; c <= ed_c; c++){ - shotData[r][c] = Store.flowdata[r][c]; - } - } + if (col_e >= Store.visibledatacolumn[Store.visibledatacolumn.length - 1] || x > winW) { + col_s = Store.visibledatacolumn.length - 1 - Store.luckysheet_select_save[0]["column"][1] + Store.luckysheet_select_save[0]["column"][0]; + col_e = Store.visibledatacolumn.length - 1; + } - let scrollHeight, rh_height; - if(st_r - 1 < 0){ - scrollHeight = 0; - rh_height = Store.visibledatarow[ed_r]; - } - else{ - scrollHeight = Store.visibledatarow[st_r - 1]; - rh_height = Store.visibledatarow[ed_r] - Store.visibledatarow[st_r - 1]; - } + col_pre = col_s - 1 == -1 ? 0 : Store.visibledatacolumn[col_s - 1]; + col = Store.visibledatacolumn[col_e]; + row_pre = row_s - 1 == -1 ? 0 : Store.visibledatarow[row_s - 1]; + row = Store.visibledatarow[row_e]; - let scrollWidth, ch_width; - if(st_c - 1 < 0){ - scrollWidth = 0; - ch_width = Store.visibledatacolumn[ed_c]; - } - else{ - scrollWidth = Store.visibledatacolumn[st_c - 1]; - ch_width = Store.visibledatacolumn[ed_c] - Store.visibledatacolumn[st_c - 1]; - } + $("#luckysheet-cell-selected-move").css({ + "left": col_pre, + "width": col - col_pre - 2, + "top": row_pre, + "height": row - row_pre - 2, + "display": "block" + }); + } + else if (Store.luckysheet_cell_selected_extend) { + let mouse = mouseposition(event.pageX, event.pageY); + let scrollLeft = $("#luckysheet-cell-main").scrollLeft() - 5; + let scrollTop = $("#luckysheet-cell-main").scrollTop() - 5; - let newCanvas = $("").attr({ - width: Math.ceil(ch_width * devicePixelRatio), - height: Math.ceil(rh_height * devicePixelRatio) - }).css({ width: ch_width, height: rh_height }); + let x = mouse[0] + scrollLeft; + let y = mouse[1] + scrollTop; - let d = Store.flowdata; - Store.flowdata = shotData; + let winH = $(window).height() + scrollTop - Store.sheetBarHeight - Store.statisticBarHeight, + winW = $(window).width() + scrollLeft; - luckysheetDrawMain(scrollWidth, scrollHeight, ch_width, rh_height, 1, 1, null, null, newCanvas); + let row_location = rowLocation(y), + row = row_location[1], + row_pre = row_location[0], + row_index = row_location[2]; + let col_location = colLocation(x), + col = col_location[1], + col_pre = col_location[0], + col_index = col_location[2]; - Store.flowdata = d; - editor.webWorkerFlowDataCache(Store.flowdata);//worker存数据 + let row_index_original = Store.luckysheet_cell_selected_extend_index[0], + col_index_original = Store.luckysheet_cell_selected_extend_index[1]; - let image = new Image(); - let url = newCanvas.get(0).toDataURL("image/png"); - image.src = url; + let row_s = Store.luckysheet_select_save[0]["row"][0], + row_e = Store.luckysheet_select_save[0]["row"][1]; + let col_s = Store.luckysheet_select_save[0]["column"][0], + col_e = Store.luckysheet_select_save[0]["column"][1]; - if(ch_width > rh_height){ - image.style.width = "100%"; - } - else{ - image.style.height = "100%"; - } + if (row_s < 0 || y < 0) { + row_s = 0; + row_e = Store.luckysheet_select_save[0]["row"][1] - Store.luckysheet_select_save[0]["row"][0]; + } - let maxHeight = $(window).height() - 200; - tooltip.screenshot("截取成功!", '
', url); - $("#luckysheet-confirm-screenshot-save").append(image); - newCanvas.remove(); - }); + if (col_s < 0 || x < 0) { + col_s = 0; + col_e = Store.luckysheet_select_save[0]["column"][1] - Store.luckysheet_select_save[0]["column"][0]; + } - //截图下载 - $(document).on("click", "a.download", function(){ - let dataURI = $("#luckysheet-confirm-screenshot-save img").attr("src"); + if (row_e >= Store.visibledatarow[Store.visibledatarow.length - 1] || y > winH) { + row_s = Store.visibledatarow.length - 1 - Store.luckysheet_select_save[0]["row"][1] + Store.luckysheet_select_save[0]["row"][0]; + row_e = Store.visibledatarow.length - 1; + } - let binStr = atob(dataURI.split(",")[1]), - len = binStr.length, - arr = new Uint8Array(len); + if (col_e >= Store.visibledatacolumn[Store.visibledatacolumn.length - 1] || x > winW) { + col_s = Store.visibledatacolumn.length - 1 - Store.luckysheet_select_save[0]["column"][1] + Store.luckysheet_select_save[0]["column"][0]; + col_e = Store.visibledatacolumn.length - 1; + } - for(let i = 0; i < len; i++){ - arr[i] = binStr.charCodeAt(i); - } + let top = Store.luckysheet_select_save[0].top_move, + height = Store.luckysheet_select_save[0].height_move; + let left = Store.luckysheet_select_save[0].left_move, + width = Store.luckysheet_select_save[0].width_move; - let blob = new Blob([arr]); + if (Math.abs(row_index_original - row_index) > Math.abs(col_index_original - col_index)) { + if (!(row_index >= row_s && row_index <= row_e)) { + if (Store.luckysheet_select_save[0].top_move >= row_pre) { + top = row_pre; + height = Store.luckysheet_select_save[0].top_move + Store.luckysheet_select_save[0].height_move - row_pre; + } + else { + top = Store.luckysheet_select_save[0].top_move; + height = row - Store.luckysheet_select_save[0].top_move - 1; + } + } + } + else { + if (!(col_index >= col_s && col_index <= col_e)) { + if (Store.luckysheet_select_save[0].left_move >= col_pre) { + left = col_pre; + width = Store.luckysheet_select_save[0].left_move + Store.luckysheet_select_save[0].width_move - col_pre; + } + else { + left = Store.luckysheet_select_save[0].left_move; + width = col - Store.luckysheet_select_save[0].left_move - 1; + } + } + } - let element = document.createElement('a'); - element.setAttribute('href', URL.createObjectURL(blob)); - element.setAttribute('download', '截图.png'); + $("#luckysheet-cell-selected-extend").css({ + "left": left, + "width": width, + "top": top, + "height": height, + "display": "block" + }); + } + else if (Store.luckysheet_cols_change_size) { + let mouse = mouseposition(event.pageX, event.pageY); + let scrollLeft = $("#luckysheet-cols-h-c").scrollLeft(); + let x = mouse[0] + scrollLeft; + let winW = $(window).width(); - element.style.display = 'none'; - document.body.appendChild(element); + let row_index = Store.visibledatarow.length - 1, + row = Store.visibledatarow[row_index], + row_pre = 0; + let col_location = colLocation(x), + col = col_location[1], + col_pre = col_location[0], + col_index = col_location[2]; + + if ((x + 3) - Store.luckysheet_cols_change_size_start[0] > 30 && x < winW + scrollLeft - 100) { + $("#luckysheet-change-size-line").css({ "left": x }); + $("#luckysheet-cols-change-size").css({ "left": x - 2 }); + } + } + else if (Store.luckysheet_rows_change_size) { + let mouse = mouseposition(event.pageX, event.pageY); + let scrollTop = $("#luckysheet-rows-h").scrollTop(); + let y = mouse[1] + scrollTop; + let winH = $(window).height(); - element.click(); + let row_location = rowLocation(y), + row = row_location[1], + row_pre = row_location[0], + row_index = row_location[2]; + + if ((y + 3) - Store.luckysheet_rows_change_size_start[0] > 19 && y < winH + scrollTop - 200) { + $("#luckysheet-change-size-line").css({ "top": y }); + $("#luckysheet-rows-change-size").css({ "top": y }); + } + } + else if (luckysheetPostil.move){ + let mouse = mouseposition(event.pageX, event.pageY); + let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft(); + let y = mouse[1] + $("#luckysheet-cell-main").scrollTop(); - let clickHandler; - element.addEventListener('click', clickHandler = function(){ - requestAnimationFrame(function(){ - URL.revokeObjectURL(element.href); - }); + let myh = luckysheetPostil.currentObj.outerHeight(), + myw = luckysheetPostil.currentObj.outerWidth(); + + let top = y - luckysheetPostil.moveXY[1], + left = x - luckysheetPostil.moveXY[0]; - element.removeAttribute('href'); - element.removeEventListener('click', clickHandler); - }) + if (top < 0) { + top = 0; + } - document.body.removeChild(element); - }) - - //菜单栏 分列按钮 - $("#luckysheet-splitColumn-btn-title").click(function(){ - if(Store.luckysheet_select_save == null || Store.luckysheet_select_save.length == 0){ - return; - } + if (top + myh + 42 + 6 > luckysheetPostil.currentWinH) { + top = luckysheetPostil.currentWinH - myh - 42 - 6; + } - if(Store.luckysheet_select_save.length > 1){ - tooltip.info("不能对多重选择区域执行此操作,请选择单个区域,然后再试", ""); - return; - } + if (left < 0) { + left = 0; + } - if(Store.luckysheet_select_save[0].column[0] != Store.luckysheet_select_save[0].column[1]){ - tooltip.info("一次只能转换一列数据,选定区域可以有多行,但不能有多列,请在选定单列区域以后再试", ""); - return; - } + if (left + myw + 22 + 36 > luckysheetPostil.currentWinW) { + left = luckysheetPostil.currentWinW - myw - 22 - 36; + } - splitColumn.createDialog(); - splitColumn.init(); - }); + luckysheetPostil.currentObj.css({ "left": left, "top": top }); + } + else if (!!luckysheetPostil.resize){ + let mouse = mouseposition(event.pageX, event.pageY); + let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft(); + let y = mouse[1] + $("#luckysheet-cell-main").scrollTop(); - //冻结行列 - $("#luckysheet-freezen-btn-horizontal").click(function () { - if($.trim($(this).text())=="取消冻结"){ - if (luckysheetFreezen.freezenverticaldata != null) { - luckysheetFreezen.cancelFreezenVertical(); - luckysheetFreezen.createAssistCanvas(); - luckysheetrefreshgrid(); - } + if (x < 0 || y < 0) { + return false; + } - if (luckysheetFreezen.freezenhorizontaldata != null) { - luckysheetFreezen.cancelFreezenHorizontal(); - luckysheetFreezen.createAssistCanvas(); - luckysheetrefreshgrid(); - } + let resizeXY = luckysheetPostil.resizeXY; - luckysheetFreezen.scrollAdapt(); - } - else{ - if (luckysheetFreezen.freezenverticaldata != null) { - luckysheetFreezen.cancelFreezenVertical(); - luckysheetFreezen.createAssistCanvas(); - luckysheetrefreshgrid(); - } + let topchange = y - resizeXY[1], + leftchange = x - resizeXY[0]; + + let top = resizeXY[5], + height = resizeXY[3], + left = resizeXY[4], + width = resizeXY[2]; - if (luckysheetFreezen.freezenhorizontaldata == null) { - luckysheetFreezen.createFreezenHorizontal(); - luckysheetFreezen.createAssistCanvas(); - } - } - }); + let resize = luckysheetPostil.resize; - $("#luckysheet-freezen-btn-vertical").click(function () { - if (luckysheetFreezen.freezenverticaldata != null) { - luckysheetFreezen.cancelFreezenVertical(); - luckysheetrefreshgrid(); - } - else { - luckysheetFreezen.createFreezenVertical(); - } - luckysheetFreezen.createAssistCanvas(); - }); + if(resize == "lm" || resize == "lt" || resize == "lb"){ + left = x; + width = resizeXY[2] - leftchange; - //右键菜单 菜单项hover - let submenuhide = null, rightclickmenu = null; - $(".luckysheet-cols-menu .luckysheet-cols-submenu").hover( - function () { - let $t = $(this), attrid = $t.attr("id"), $attr = $("#" + attrid + "_sub"), $con = $t.parent(); - let winW = $(window).width(), winH = $(window).height(); - let menuW = $con.width(), attrH = $attr.height() + 25, attrW = $attr.width() + 5; - let offset = $t.offset(); - let top = offset.top, left = offset.left + menuW; + if(left > resizeXY[2] + resizeXY[4] - 60){ + left = resizeXY[2] + resizeXY[4] - 60; + width = resizeXY[2] - (resizeXY[2] + resizeXY[4] - 60 - resizeXY[0]); + } + else if(left <= 0){ + left = 0; + width = resizeXY[2] + resizeXY[0]; + } + } - if (left + attrW > winW) { - left = offset.left - attrW; - } + if(resize == "rm" || resize == "rt" || resize == "rb"){ + width = resizeXY[2] + leftchange; - if (top + attrH > winH) { - top = winH - attrH; - } + if(width < 60){ + width = 60; + } + else if(width >= luckysheetPostil.currentWinW - resizeXY[4] - 22 - 36){ + width = luckysheetPostil.currentWinW - resizeXY[4] - 22 - 36; + } + } - $attr.css({ "top": top, "left": left }).show(); - rightclickmenu = $t; - }, - function () { - let $t = $(this), attrid = $t.attr("id"), $attr = $("#" + attrid + "_sub"); - submenuhide = setTimeout(function () { $attr.hide(); }, 200); - } - ); + if(resize == "mt" || resize == "lt" || resize == "rt"){ + top = y; + height = resizeXY[3] - topchange; - $(".luckysheet-rightgclick-menu-sub").hover( - function () { - rightclickmenu.addClass("luckysheet-cols-menuitem-hover"); - clearTimeout(submenuhide); - }, - function () { - rightclickmenu.removeClass("luckysheet-cols-menuitem-hover"); - $(this).hide(); - } - ); + if(top > resizeXY[3] + resizeXY[5] - 60){ + top = resizeXY[3] + resizeXY[5] - 60; + height = resizeXY[3] - (resizeXY[3] + resizeXY[5] - 60 - resizeXY[1]); + } + else if(top <= 0){ + top = 0; + height = resizeXY[3] + resizeXY[1]; + } + } - $(".luckysheet-grid-container, #luckysheet-rightclick-menu").on("contextmenu", function (e) { - e.preventDefault(); - }); + if(resize == "mb" || resize == "lb" || resize == "rb"){ + height = resizeXY[3] + topchange; - $("#luckysheet-rightclick-menu input").on("keydown", function (e) { - e.stopPropagation(); - }); + if(height < 60){ + height = 60; + } + else if(height >= luckysheetPostil.currentWinH - resizeXY[5] - 42 - 6){ + height = luckysheetPostil.currentWinH - resizeXY[5] - 42 - 6; + } + } - $("#luckysheet-modal-dialog-mask").on("click dbclick mousedown mousemove mouseup", function (e) { - e.stopPropagation(); - e.preventDefault(); + luckysheetPostil.currentObj.css({ "width": width, "height": height, "left": left, "top": top }); + } + else if (!!formula.rangeResize) { + formula.rangeResizeDraging(event, formula.rangeResizeObj, formula.rangeResizexy, formula.rangeResize, formula.rangeResizeWinW, formula.rangeResizeWinH, Store.ch_width, Store.rh_height); + } + else if (!!formula.rangeMove) { + formula.rangeMoveDraging(event, formula.rangeMovexy, formula.rangeMoveObj.data("range"), formula.rangeMoveObj, Store.sheetBarHeight, Store.statisticBarHeight); + } + }, 1); + } }); + + //表格mouseup + $(document).mouseup(function (event) { + //数据窗格主体 + if (Store.luckysheet_select_status) { + clearTimeout(Store.countfuncTimeout); + Store.countfuncTimeout = setTimeout(function(){ + countfunc(); + }, 0); - let copychange = function () { - if (document.hidden || document.webkitHidden || document.msHidden) { - Store.iscopyself = false; + //格式刷 + if(menuButton.luckysheetPaintModelOn){ + selection.pasteHandlerOfPaintModel(Store.luckysheet_copy_save); + + if(menuButton.luckysheetPaintSingle){ + //单次 格式刷 + menuButton.cancelPaintModel(); + } + } } - } - $(document).on("visibilitychange webkitvisibilitychange msvisibilitychange", copychange).mouseleave(function () { - Store.iscopyself = false; - }).mousedown(function (event) { - //有批注在编辑时 - luckysheetPostil.removeActivePs(); + Store.luckysheet_select_status = false; + clearTimeout(Store.jfautoscrollTimeout); + Store.luckysheet_scroll_status = false; - if (!$(event.target).hasClass("luckysheet-mousedown-cancel") && $(event.target).filter("[class*='sp-palette']").length == 0 && $(event.target).filter("[class*='sp-thumb']").length == 0 && $(event.target).filter("[class*='sp-']").length == 0) { - $("#luckysheet-rightclick-menu").hide(); - $("#luckysheet-cols-h-hover").hide(); - $("#luckysheet-cols-menu-btn").hide(); - $("#luckysheet-rightclick-menu").hide(); - $("#luckysheet-sheet-list, #luckysheet-rightclick-sheet-menu, #luckysheet-user-menu").hide(); - $("body > .luckysheet-filter-menu, body > .luckysheet-filter-submenu, body > .luckysheet-cols-menu").hide(); - //$("body > luckysheet-menuButton").hide(); - Store.luckysheet_cols_menu_status = false; - } + $("#luckysheet-cell-selected").find(".luckysheet-cs-fillhandle").css("cursor","crosshair").end().find(".luckysheet-cs-draghandle").css("cursor","move"); + $("#luckysheet-cell-main, #luckysheetTableContent, #luckysheet-sheettable_0").css("cursor","default"); - //点击功能栏时 如果是单元格编辑模式 则退出编辑模式 - if($(event.target).closest("#luckysheet-wa-editor").length > 0 && parseInt($("#luckysheet-input-box").css("top")) > 0){ - formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); - luckysheetMoveHighlightCell("down", 0, "rangeOfSelect"); - } - }); + //行标题窗格主体 + Store.luckysheet_rows_selected_status = false; - //单元格编辑 keydown (公式 上下左右键移动) - $("#" + Store.container).add("#luckysheet-input-box").keydown(function (event) { - if ($("#luckysheet-modal-dialog-mask").is(":visible") || $(event.target).hasClass("luckysheet-mousedown-cancel") || $(event.target).hasClass("formulaInputFocus")) { - return; - } + //列标题窗格主体 + Store.luckysheet_cols_selected_status = false; - let ctrlKey = event.ctrlKey; - let altKey = event.altKey; - let shiftKey = event.shiftKey; - let kcode = event.keyCode; + Store.luckysheet_model_move_state = false; - let $inputbox = $("#luckysheet-input-box"); - if (kcode == keycode.ESC && parseInt($("#luckysheet-input-box").css("top")) > 0) { - formula.dontupdate(); - luckysheetMoveHighlightCell("down", 0, "rangeOfSelect"); - event.preventDefault(); - } - else if (kcode == keycode.ENTER && parseInt($inputbox.css("top")) > 0) { - if ($("#luckysheet-formula-search-c").is(":visible") && formula.searchFunctionCell != null) { - formula.searchFunctionEnter($("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item-active")); - event.preventDefault(); - } + if(formula.functionResizeStatus){ + formula.functionResizeStatus = false; + $("#luckysheet-wa-calculate-size").removeAttr("style"); } - else if(kcode == keycode.TAB && parseInt($inputbox.css("top")) > 0){ - if ($("#luckysheet-formula-search-c").is(":visible") && formula.searchFunctionCell != null) { - formula.searchFunctionEnter($("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item-active")); - } - else{ - formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); - luckysheetMoveHighlightCell("right", 1, "rangeOfSelect"); - } - event.preventDefault(); - } - else if (kcode == keycode.F4 && parseInt($inputbox.css("top")) > 0) { - formula.setfreezonFuc(event); - event.preventDefault(); - } - else if (kcode == keycode.UP && parseInt($inputbox.css("top")) > 0) { - formulaMoveEvent("up", ctrlKey, shiftKey); - } - else if (kcode == keycode.DOWN && parseInt($inputbox.css("top")) > 0) { - formulaMoveEvent("down", ctrlKey, shiftKey); - } - else if (kcode == keycode.LEFT && parseInt($inputbox.css("top")) > 0) { - formulaMoveEvent("left", ctrlKey, shiftKey); - } - else if (kcode == keycode.RIGHT && parseInt($inputbox.css("top")) > 0) { - formulaMoveEvent("right", ctrlKey, shiftKey); - } - else if (!((kcode >= 112 && kcode <= 123) || kcode <= 46 || kcode == 144 || kcode == 108 || event.ctrlKey || event.altKey || (event.shiftKey && (kcode == 37 || kcode == 38 || kcode == 39 || kcode == 40))) || kcode == 8 || kcode == 32 || kcode == 46 || (event.ctrlKey && kcode == 86)) { - formula.functionInputHanddler($("#luckysheet-functionbox-cell"), $("#luckysheet-rich-text-editor"), kcode); - } - }).keyup(function (e) { - let kcode = e.keyCode; - - if (!e.shiftKey && kcode == 16) { - Store.luckysheet_shiftkeydown = false; - Store.luckysheet_shiftpositon = null; + if (!!luckysheetFreezen.horizontalmovestate) { + luckysheetFreezen.horizontalmovestate = false; + $("#luckysheet-freezebar-horizontal").removeClass("luckysheet-freezebar-active"); + $("#luckysheet-freezebar-horizontal").find(".luckysheet-freezebar-horizontal-handle").css("cursor", "-webkit-grab"); + if (luckysheetFreezen.freezenhorizontaldata[4] <= Store.columeHeaderHeight) { + luckysheetFreezen.cancelFreezenHorizontal(); + } + luckysheetFreezen.createAssistCanvas(); + luckysheetrefreshgrid(); } - //输入框中文输入后 shift 和 空格 处理 - if(parseInt($("#luckysheet-input-box").css("top")) > 0 && (kcode == 13 || kcode == 16 || kcode == 32)){ - formula.functionInputHanddler($("#luckysheet-functionbox-cell"), $("#luckysheet-rich-text-editor"), kcode); + if (!!luckysheetFreezen.verticalmovestate) { + luckysheetFreezen.verticalmovestate = false; + $("#luckysheet-freezebar-vertical").removeClass("luckysheet-freezebar-active"); + $("#luckysheet-freezebar-vertical").find(".luckysheet-freezebar-vertical-handle").css("cursor", "-webkit-grab"); + if (luckysheetFreezen.freezenverticaldata[4] <= Store.rowHeaderWidth) { + luckysheetFreezen.cancelFreezenVertical(); + } + luckysheetFreezen.createAssistCanvas(); + luckysheetrefreshgrid(); } - e.preventDefault(); - }); + if (!!pivotTable && pivotTable.movestate) { + $("#luckysheet-modal-dialog-slider-pivot-move").remove(); + pivotTable.movestate = false; + $("#luckysheet-modal-dialog-pivotTable-list, #luckysheet-modal-dialog-config-filter, #luckysheet-modal-dialog-config-row, #luckysheet-modal-dialog-config-column, #luckysheet-modal-dialog-config-value").css("cursor", "default"); + + if (pivotTable.movesave.containerid != "luckysheet-modal-dialog-pivotTable-list") { + let $cur = $(event.target).closest(".luckysheet-modal-dialog-slider-config-list"); + if ($cur.length == 0) { + if (pivotTable.movesave.containerid == "luckysheet-modal-dialog-config-value") { + pivotTable.resetOrderby(pivotTable.movesave.obj); + } - function formulaMoveEvent(dir, ctrlKey, shiftKey){ - if ($("#luckysheet-formula-search-c").is(":visible")) { - let $up = $("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item-active").next(); - if ($up.length == 0) { - $up = $("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item").first(); - } + pivotTable.movesave.obj.remove(); + pivotTable.showvaluecolrow(); + + $("#luckysheet-modal-dialog-pivotTable-list").find(".luckysheet-modal-dialog-slider-list-item").each(function () { + $(this).find(".luckysheet-slider-list-item-selected").find("i").remove(); + }); - $("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item").removeClass("luckysheet-formula-search-item-active"); - $up.addClass("luckysheet-formula-search-item-active"); + $("#luckysheet-modal-dialog-config-filter, #luckysheet-modal-dialog-config-row, #luckysheet-modal-dialog-config-column, #luckysheet-modal-dialog-config-value").find(".luckysheet-modal-dialog-slider-config-item").each(function () { + let index = $(this).data("index"); - event.preventDefault(); - } - else{ - if($("#luckysheet-formula-functionrange-select").is(":visible")){ - if(ctrlKey && shiftKey){ - luckysheetMoveHighlightRange2(dir, "rangeOfFormula"); - } - else if(ctrlKey){ - luckysheetMoveHighlightCell2(dir, "rangeOfFormula"); - } - else if(shiftKey){ - let dir_n = dir, step = 1; - if(dir == 'up'){ - dir_n = 'down'; - step = -1; - } - if(dir == 'left'){ - dir_n = 'right'; - step = -1; - } + $("#luckysheet-modal-dialog-pivotTable-list").find(".luckysheet-modal-dialog-slider-list-item").each(function () { + let $seleted = $(this).find(".luckysheet-slider-list-item-selected"); + if ($(this).data("index") == index && $seleted.find("i").length == 0) { + $seleted.append(''); + } + }); - luckysheetMoveHighlightRange(dir_n, step, "rangeOfFormula"); - } - else{ - let dir_n = dir, step = 1; - if(dir == 'up'){ - dir_n = 'down'; - step = -1; - } - if(dir == 'left'){ - dir_n = 'right'; - step = -1; - } + }); - luckysheetMoveHighlightCell(dir_n, step, "rangeOfFormula"); - } + pivotTable.refreshPivotTable(); + } } - else if(formula.israngeseleciton()){ - let anchor = $(window.getSelection().anchorNode); - - if(anchor.parent().next().text() == null || anchor.parent().next().text() == ""){ - let vText = $("#luckysheet-input-box #luckysheet-input-box-index").text(); - let range = formula.getcellrange(vText); + } - if(range == null){ - range = formula.getcellrange($("#luckysheet-input-box-index").text()); - } + if (Store.luckysheet_sheet_move_status) { + Store.luckysheet_sheet_move_status = false; + Store.luckysheet_sheet_move_data.activeobject.insertBefore($("#luckysheet-sheets-item-clone")); + Store.luckysheet_sheet_move_data.activeobject.removeAttr("style"); + $("#luckysheet-sheets-item-clone").remove(); + Store.luckysheet_sheet_move_data.cursorobject.css({ "cursor": "pointer" }); + Store.luckysheet_sheet_move_data = {}; + sheetmanage.reOrderAllSheet(); + } - let r1 = range["row"][0], r2 = range["row"][1]; - let c1 = range["column"][0], c2 = range["column"][1]; + if (!!formula.rangeResize) { + formula.rangeResizeDragged(event, formula.rangeResizeObj, formula.rangeResize, formula.rangeResizexy, formula.rangeResizeWinW, formula.rangeResizeWinH); + } - let row = Store.visibledatarow[r2], - row_pre = r1 - 1 == -1 ? 0 : Store.visibledatarow[r1 - 1]; - let col = Store.visibledatacolumn[c2], - col_pre = c1 - 1 == -1 ? 0 : Store.visibledatacolumn[c1 - 1]; + //批注框 移动 + if (luckysheetPostil.move) { + luckysheetPostil.move = false; - formula.func_selectedrange = { - "left": col_pre, - "width": col - col_pre - 1, - "top": row_pre, - "height": row - row_pre - 1, - "left_move": col_pre, - "width_move": col - col_pre - 1, - "top_move": row_pre, - "height_move": row - row_pre - 1, - "row": [r1, r2], - "column": [c1, c2], - "row_focus": r1, - "column_focus": c1 - }; + let ps_id = luckysheetPostil.currentObj.closest(".luckysheet-postil-show").attr("id"); - formula.rangeSetValue({ "row": [r1, r2], "column": [c1, c2] }); + let ps_r = ps_id.split("luckysheet-postil-show_")[1].split("_")[0]; + let ps_c = ps_id.split("luckysheet-postil-show_")[1].split("_")[1]; - formula.rangestart = true; - formula.rangedrag_column_start = false; - formula.rangedrag_row_start = false; - - if(ctrlKey && shiftKey){ - luckysheetMoveHighlightRange2(dir, "rangeOfFormula"); - } - else if(ctrlKey){ - luckysheetMoveHighlightCell2(dir, "rangeOfFormula"); - } - else if(shiftKey){ - let dir_n = dir, step = 1; - if(dir == 'up'){ - dir_n = 'down'; - step = -1; - } - if(dir == 'left'){ - dir_n = 'right'; - step = -1; - } - - luckysheetMoveHighlightRange(dir_n, step, "rangeOfFormula"); - } - else{ - let dir_n = dir, step = 1; - if(dir == 'up'){ - dir_n = 'down'; - step = -1; - } - if(dir == 'left'){ - dir_n = 'right'; - step = -1; - } - - luckysheetMoveHighlightCell(dir_n, step, "rangeOfFormula"); - } - } - } - else if(!ctrlKey && !shiftKey){ - let anchor = $(window.getSelection().anchorNode); - let anchorOffset = window.getSelection().anchorOffset; + let d = editor.deepCopyFlowData(Store.flowdata); + let rc = []; - let dir_n = dir, step = 1; - if(dir == 'up'){ - dir_n = 'down'; - step = -1; - } - if(dir == 'left'){ - dir_n = 'right'; - step = -1; - } + d[ps_r][ps_c].ps.left = luckysheetPostil.currentObj.position().left; + d[ps_r][ps_c].ps.top = luckysheetPostil.currentObj.position().top; + d[ps_r][ps_c].ps.value = luckysheetPostil.currentObj.find(".formulaInputFocus").text(); - if(anchor.parent().is("span") && anchor.parent().next().length == 0 && anchorOffset > 0){ - formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); - luckysheetMoveHighlightCell(dir_n, step, "rangeOfSelect"); - } - else if(anchor.is("#luckysheet-rich-text-editor") && anchor.context.childElementCount == anchorOffset){ - formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); - luckysheetMoveHighlightCell(dir_n, step, "rangeOfSelect"); - } - else if(anchor.parent().is("#luckysheet-rich-text-editor") && anchor.context.length == anchorOffset){ - formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); - luckysheetMoveHighlightCell(dir_n, step, "rangeOfSelect"); - } - } + rc.push(ps_r + "_" + ps_c); - event.preventDefault(); - } - } + luckysheetPostil.ref(d, rc); - //表格mousemove - $(document).mousemove(function (event) { - luckysheetPostil.overshow(event); //有批注显示 + $("#" + ps_id).remove(); - clearInterval(Store.jfautoscrollTimeout); - - if(formula.functionResizeStatus){ - let y = event.pageY; - let movepx = y - formula.functionResizeData.y; - let mpx = formula.functionResizeData.calculatebarHeight + movepx; - let winh = Math.round($(window).height()/2); - - if(mpx <= 28){ - if(mpx <= 20){ - return; - } - mpx = 28; + if(d[ps_r][ps_c].ps.isshow){ + luckysheetPostil.buildPs(ps_r, ps_c, d[ps_r][ps_c].ps); + $("#" + ps_id).addClass("luckysheet-postil-show-active"); + $("#" + ps_id).find(".luckysheet-postil-dialog-resize").show(); } - else if(mpx >= winh){ - if(mpx >= winh + 8){ - return; - } - mpx = winh; + else{ + luckysheetPostil.editPs(ps_r, ps_c); } + } - Store.calculatebarHeight = mpx; - $("#luckysheet-wa-calculate").css("height", Store.calculatebarHeight - 2); - $("#luckysheet-wa-calculate-size").css({"background":"#5e5e5e", "cursor":"ns-resize"}); - - clearTimeout(formula.functionResizeTimeout); - formula.functionResizeTimeout = setTimeout(function(){ - luckysheetsizeauto(); - }, 15); + //批注框 改变大小 + if (!!luckysheetPostil.resize) { + luckysheetPostil.resize = null; + + let ps_id = luckysheetPostil.currentObj.closest(".luckysheet-postil-show").attr("id"); + + let ps_r = ps_id.split("luckysheet-postil-show_")[1].split("_")[0]; + let ps_c = ps_id.split("luckysheet-postil-show_")[1].split("_")[1]; + + let d = editor.deepCopyFlowData(Store.flowdata); + let rc = []; + + d[ps_r][ps_c].ps.left = luckysheetPostil.currentObj.position().left; + d[ps_r][ps_c].ps.top = luckysheetPostil.currentObj.position().top; + d[ps_r][ps_c].ps.width = luckysheetPostil.currentObj.outerWidth(); + d[ps_r][ps_c].ps.height = luckysheetPostil.currentObj.outerHeight(); + d[ps_r][ps_c].ps.value = luckysheetPostil.currentObj.find(".formulaInputFocus").text(); + + rc.push(ps_r + "_" + ps_c); + + luckysheetPostil.ref(d, rc); + + $("#" + ps_id).remove(); + + if(d[ps_r][ps_c].ps.isshow){ + luckysheetPostil.buildPs(ps_r, ps_c, d[ps_r][ps_c].ps); + $("#" + ps_id).addClass("luckysheet-postil-show-active"); + $("#" + ps_id).find(".luckysheet-postil-dialog-resize").show(); + } + else{ + luckysheetPostil.editPs(ps_r, ps_c); + } } - else if (!!luckysheetFreezen.horizontalmovestate) { + + //改变行高 + if (Store.luckysheet_rows_change_size) { + Store.luckysheet_rows_change_size = false; + + $("#luckysheet-change-size-line").hide(); + $("#luckysheet-rows-change-size").css("opacity", 0); + $("#luckysheet-sheettable, #luckysheet-rows-h, #luckysheet-rows-h canvas").css("cursor", "default"); + let mouse = mouseposition(event.pageX, event.pageY); - let scrollLeft = $("#luckysheet-cell-main").scrollLeft(); - let scrollTop = $("#luckysheet-cell-main").scrollTop(); - let x = mouse[0] + scrollLeft; + let scrollTop = $("#luckysheet-rows-h").scrollTop(); let y = mouse[1] + scrollTop; + let winH = $(window).height(); let row_location = rowLocation(y), row = row_location[1], row_pre = row_location[0], row_index = row_location[2]; - let top = mouse[1] + Store.columeHeaderHeight; + + let size = (y + 3) - Store.luckysheet_rows_change_size_start[0]; - if (top < Store.columeHeaderHeight) { - top = Store.columeHeaderHeight; + if ((y + 3) - Store.luckysheet_rows_change_size_start[0] < 19) { + size = 19; } - if (top > luckysheetFreezen.windowHeight - 4) { - top = luckysheetFreezen.windowHeight - 4; + if (y >= winH - 200 + scrollTop) { + size = winW - 200 - Store.luckysheet_rows_change_size_start[0] + scrollTop; } - $("#luckysheet-freezebar-horizontal").find(".luckysheet-freezebar-horizontal-handle").css({ "top": top }); - - if (top + scrollTop - Store.columeHeaderHeight >= row_pre + (row - row_pre) / 2) { - top = row - 2 - scrollTop + Store.columeHeaderHeight; - luckysheetFreezen.freezenhorizontaldata = [row, row_index + 1, scrollTop, luckysheetFreezen.cutVolumn(Store.visibledatarow, row_index + 1), top]; + let cfg = $.extend(true, {}, Store.config); + if (cfg["rowlen"] == null) { + cfg["rowlen"] = {}; } - else { - top = row_pre - 2 - scrollTop + Store.columeHeaderHeight; - luckysheetFreezen.freezenhorizontaldata = [row_pre, row_index, scrollTop, luckysheetFreezen.cutVolumn(Store.visibledatarow, row_index), top]; + + cfg["rowlen"][Store.luckysheet_rows_change_size_start[1]] = Math.ceil(size); + + if (Store.clearjfundo) { + Store.jfundo = []; + + Store.jfredo.push({ + "type": "resize", + "ctrlType": "resizeR", + "config": $.extend(true, {}, Store.config), + "curconfig": $.extend(true, {}, cfg), + "sheetIndex": Store.currentSheetIndex + }); } - $("#luckysheet-freezebar-horizontal").find(".luckysheet-freezebar-horizontal-drop").css({ "top": top }); - luckysheetFreezen.saveFreezen(luckysheetFreezen.freezenhorizontaldata, top, null, null); + //config + Store.config = cfg; + Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)].config = Store.config; + + server.saveParam("cg", Store.currentSheetIndex, cfg["rowlen"], { "k": "rowlen" }); + + jfrefreshgrid_rhcw(Store.flowdata.length, null); } - else if (!!luckysheetFreezen.verticalmovestate) { + + //改变列宽 + if (Store.luckysheet_cols_change_size) { + Store.luckysheet_cols_change_size = false; + + $("#luckysheet-change-size-line").hide(); + $("#luckysheet-cols-change-size").css("opacity", 0); + $("#luckysheet-sheettable, #luckysheet-cols-h-c, .luckysheet-cols-h-cells, .luckysheet-cols-h-cells canvas").css("cursor", "default"); + let mouse = mouseposition(event.pageX, event.pageY); - let scrollLeft = $("#luckysheet-cell-main").scrollLeft(); - let scrollTop = $("#luckysheet-cell-main").scrollTop(); + let scrollLeft = $("#luckysheet-cols-h-c").scrollLeft(); let x = mouse[0] + scrollLeft; - let y = mouse[1] + scrollTop; + let winW = $(window).width(); + let row_index = Store.visibledatarow.length - 1, + row = Store.visibledatarow[row_index], + row_pre = 0; let col_location = colLocation(x), col = col_location[1], col_pre = col_location[0], col_index = col_location[2]; + + let size = (x + 3) - Store.luckysheet_cols_change_size_start[0]; - let left = mouse[0] + Store.rowHeaderWidth; - - if (left < Store.rowHeaderWidth) { - left = Store.rowHeaderWidth; - } - - if (left > luckysheetFreezen.windowWidth - 4) { - left = luckysheetFreezen.windowWidth - 4; + let firstcolumlen = Store.defaultcollen; + if (Store.config["columlen"] != null && Store.config["columlen"][Store.luckysheet_cols_change_size_start[1]] != null) { + firstcolumlen = Store.config["columlen"][Store.luckysheet_cols_change_size_start[1]]; } - $("#luckysheet-freezebar-vertical").find(".luckysheet-freezebar-vertical-handle").css({ "left": left }); - - if (left + scrollLeft - Store.rowHeaderWidth >= col_pre + (col - col_pre) / 2) { - left = col - 2 - scrollLeft + Store.rowHeaderWidth; - luckysheetFreezen.freezenverticaldata = [col, col_index + 1, scrollLeft, luckysheetFreezen.cutVolumn(Store.visibledatacolumn, col_index + 1), left]; + if (Math.abs(size - firstcolumlen) < 3) { + return; } - else { - left = col_pre - 2 - scrollLeft + Store.rowHeaderWidth; - luckysheetFreezen.freezenverticaldata = [col_pre, col_index, scrollLeft, luckysheetFreezen.cutVolumn(Store.visibledatacolumn, col_index), left]; + + if ((x + 3) - Store.luckysheet_cols_change_size_start[0] < 30) { + size = 30; } - $("#luckysheet-freezebar-vertical").find(".luckysheet-freezebar-vertical-drop").css({ "left": left }); - luckysheetFreezen.saveFreezen(null, null, luckysheetFreezen.freezenverticaldata, left); - luckysheetsizeauto();//调节选区时下部单元格溢出 - } - else if (!!pivotTable && pivotTable.movestate) { - let x = event.pageX, y = event.pageY; - $("#luckysheet-modal-dialog-slider-pivot-move").css({ - "left": x - pivotTable.movesave.width / 2, - "top": y - pivotTable.movesave.height - }); - } - else if (Store.luckysheet_sheet_move_status) { - let scrollLeft = $("#luckysheet-sheet-container-c").scrollLeft(); - let x = event.pageX + scrollLeft; + if (x >= winW - 100 + scrollLeft) { + size = winW - 100 - Store.luckysheet_cols_change_size_start[0] + scrollLeft; + } - if (Math.abs(event.pageX - Store.luckysheet_sheet_move_data.pageX) < 3) { - return; + let cfg = $.extend(true, {}, Store.config); + if (cfg["columlen"] == null) { + cfg["columlen"] = {}; } - let winW = $("#luckysheet-sheet-container").width(); - let left = x - Store.luckysheet_sheet_move_data.curleft - $("#luckysheet-sheet-container").offset().left; - Store.luckysheet_sheet_move_data.activeobject.css({ "left": left }); + cfg["columlen"][Store.luckysheet_cols_change_size_start[1]] = Math.ceil(size); - let row_index = luckysheet_searcharray(Store.luckysheet_sheet_move_data.widthlist, left + Store.luckysheet_sheet_move_data.curleft); - Store.luckysheet_sheet_move_data.cursorobject.css({ "cursor": "move" }); + if (Store.clearjfundo) { + Store.jfundo = []; - if (left - scrollLeft <= 6) { - $("#luckysheet-sheets-leftscroll").click(); + Store.jfredo.push({ + "type": "resize", + "ctrlType": "resizeC", + "config": $.extend(true, {}, Store.config), + "curconfig": $.extend(true, {}, cfg), + "sheetIndex": Store.currentSheetIndex + }); } - if (left - scrollLeft >= winW - 40) { - $("#luckysheet-sheets-rightscroll").click(); - } + //config + Store.config = cfg; + Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)].config = Store.config; - if (row_index != Store.luckysheet_sheet_move_data.curindex) { - if (row_index == -1 && left > 0) { - row_index = Store.luckysheet_sheet_move_data.widthlist.length - 1; - $("#luckysheet-sheets-item-clone").insertAfter($("#luckysheet-sheet-area div.luckysheet-sheets-item:visible").eq(row_index)); - } - else if (row_index == -1 && left <= 0) { - $("#luckysheet-sheets-item-clone").insertBefore($("#luckysheet-sheet-area div.luckysheet-sheets-item:visible").eq(0)); - } - else { - $("#luckysheet-sheets-item-clone").insertAfter($("#luckysheet-sheet-area div.luckysheet-sheets-item:visible").eq(row_index)); - } + server.saveParam("cg", Store.currentSheetIndex, cfg["columlen"], { "k": "columlen" }); - Store.luckysheet_sheet_move_data.widthlist = []; - $("#luckysheet-sheet-area div.luckysheet-sheets-item:visible").each(function (i) { - if (i == 0) { - Store.luckysheet_sheet_move_data.widthlist.push(parseInt($(this).outerWidth())); - } - else { - Store.luckysheet_sheet_move_data.widthlist.push(parseInt($(this).outerWidth()) + Store.luckysheet_sheet_move_data.widthlist[i - 1]); - } - }); + jfrefreshgrid_rhcw(null, Store.flowdata[0].length); - Store.luckysheet_sheet_move_data.curindex = $("#luckysheet-sheet-area div.luckysheet-sheets-item:visible").index($("#luckysheet-sheets-item-clone")); - } + setTimeout(function () { + luckysheetrefreshgrid(); + }, 1); } - else if (Store.luckysheet_model_move_state) { - let scrollTop = $(document).scrollTop(), scrollLeft = $(document).scrollLeft(); - let y = event.pageY + scrollTop, x = event.pageX + scrollLeft; - let winH = $(window).height(), winW = $(window).width(); - let myh = Store.luckysheet_model_move_obj.height(), - myw = Store.luckysheet_model_move_obj.width(); - let top = y - Store.luckysheet_model_xy[1], - left = x - Store.luckysheet_model_xy[0]; - if (top < 0) { - top = 0; - } + if (formula.rangeMove) { + formula.rangeMoveDragged(formula.rangeMoveObj); + } - if (top + myh + 62 > winH) { - top = winH - myh - 62; - } + //改变选择框的位置并替换目标单元格 + if (Store.luckysheet_cell_selected_move) { + $("#luckysheet-cell-selected-move").hide(); - if (left < 0) { - left = 0; - } + Store.luckysheet_cell_selected_move = false; + let mouse = mouseposition(event.pageX, event.pageY); - if (left + myw + 86 > winW) { - left = winW - myw - 86; - } + let scrollLeft = $("#luckysheet-cell-main").scrollLeft(); + let scrollTop = $("#luckysheet-cell-main").scrollTop(); - Store.luckysheet_model_move_obj.css({ "top": top, "left": left }); - event.preventDefault(); - } - else if (!!Store.luckysheet_scroll_status || !!Store.luckysheet_select_status || !!Store.luckysheet_rows_selected_status || !!Store.luckysheet_cols_selected_status || !!Store.luckysheet_cell_selected_move || !!Store.luckysheet_cell_selected_extend || !!Store.luckysheet_cols_change_size || !!Store.luckysheet_rows_change_size || !!formula.rangeResize || !!formula.rangeMove) { - if (Store.luckysheet_select_status) { - clearTimeout(Store.countfuncTimeout); - Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); - } - - Store.jfautoscrollTimeout = setInterval(function () { - if (Store.luckysheet_scroll_status && !Store.luckysheet_cols_change_size && !Store.luckysheet_rows_change_size) { - let mouse = mouseposition(event.pageX, event.pageY); - let left = $("#luckysheet-scrollbar-x").scrollLeft(), - top = $("#luckysheet-scrollbar-y").scrollTop(); - let x = mouse[0]; - let y = mouse[1]; - let winH = $("#luckysheet-cell-main").height() - 20, - winW = $("#luckysheet-cell-main").width() - 60; - - if (y < 0 || y > winH) { - let stop; - if (y < 0) { - stop = top + y/2; - } - else { - stop = top + (y - winH)/2; - } - $("#luckysheet-scrollbar-y").scrollTop(stop); - } - - if (x < 0 || x > winW) { - let sleft; - if (x < 0) { - sleft = left + x/2; - } - else { - sleft = left + (x - winW)/2; - } - $("#luckysheet-scrollbar-x").scrollLeft(sleft); - } - } - if (Store.luckysheet_select_status) { - let mouse = mouseposition(event.pageX, event.pageY); - let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft(); - let y = mouse[1] + $("#luckysheet-cell-main").scrollTop(); - - let row_location = rowLocation(y), - row = row_location[1], - row_pre = row_location[0], - row_index = row_location[2]; - let col_location = colLocation(x), - col = col_location[1], - col_pre = col_location[0], - col_index = col_location[2]; - - let last = $.extend(true, {}, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]); - - let top = 0, height = 0, rowseleted = []; - if (last.top > row_pre) { - top = row_pre; - height = last.top + last.height - row_pre; + let x = mouse[0] + scrollLeft; + let y = mouse[1] + scrollTop; - if(last.row[1] > last.row_focus){ - last.row[1] = last.row_focus; - } + let winH = $(window).height() + scrollTop - Store.sheetBarHeight - Store.statisticBarHeight, + winW = $(window).width() + scrollLeft; - rowseleted = [row_index, last.row[1]]; - } - else if (last.top == row_pre) { - top = row_pre; - height = last.top + last.height - row_pre; - rowseleted = [row_index, last.row[0]]; - } - else { - top = last.top; - height = row - last.top - 1; + let row_index = rowLocation(y)[2]; + let col_index = colLocation(x)[2]; - if(last.row[0] < last.row_focus){ - last.row[0] = last.row_focus; - } + let row_index_original = Store.luckysheet_cell_selected_move_index[0], + col_index_original = Store.luckysheet_cell_selected_move_index[1]; - rowseleted = [last.row[0], row_index]; - } + if(row_index == row_index_original && col_index == col_index_original){ + return; + } - let left = 0, width = 0, columnseleted = []; - if (last.left > col_pre) { - left = col_pre; - width = last.left + last.width - col_pre; + let d = editor.deepCopyFlowData(Store.flowdata); + let last = Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]; + + let data = getdatabyselection(last); - if(last.column[1] > last.column_focus){ - last.column[1] = last.column_focus; - } + let cfg = $.extend(true, {}, Store.config); + if(cfg["merge"] == null){ + cfg["merge"] = {}; + } + if(cfg["rowlen"] == null){ + cfg["rowlen"] = {}; + } - columnseleted = [col_index, last.column[1]]; - } - else if (last.left == col_pre) { - left = col_pre; - width = last.left + last.width - col_pre; - columnseleted = [col_index, last.column[0]]; - } - else { - left = last.left; - width = col - last.left - 1; + //选区包含部分单元格 + if(hasPartMC(cfg, last["row"][0], last["row"][1], last["column"][0], last["column"][1])){ + if(isEditMode()){ + alert("无法对合并单元格执行此操作"); + } + else{ + tooltip.info('提示',"无法对合并单元格执行此操作"); + } + return; + } - if(last.column[0] < last.column_focus){ - last.column[0] = last.column_focus; - } + let row_s = last["row"][0] - row_index_original + row_index, + row_e = last["row"][1] - row_index_original + row_index; + let col_s = last["column"][0] - col_index_original + col_index, + col_e = last["column"][1] - col_index_original + col_index; + + if (row_s < 0 || y < 0) { + row_s = 0; + row_e = last["row"][1] - last["row"][0]; + } - columnseleted = [last.column[0], col_index]; - } + if (col_s < 0 || x < 0) { + col_s = 0; + col_e = last["column"][1] - last["column"][0]; + } - let changeparam = menuButton.mergeMoveMain(columnseleted, rowseleted, last, top, height, left, width); - if(changeparam != null){ - columnseleted = changeparam[0]; - rowseleted= changeparam[1]; - top = changeparam[2]; - height = changeparam[3]; - left = changeparam[4]; - width = changeparam[5]; - } + if (row_e >= Store.visibledatarow[Store.visibledatarow.length - 1] || y > winH) { + row_s = Store.visibledatarow.length - 1 - last["row"][1] + last["row"][0]; + row_e = Store.visibledatarow.length - 1; + } - last["row"] = rowseleted; - last["column"] = columnseleted; + if (col_e >= Store.visibledatacolumn[Store.visibledatacolumn.length - 1] || x > winW) { + col_s = Store.visibledatacolumn.length - 1 - last["column"][1] + last["column"][0]; + col_e = Store.visibledatacolumn.length - 1; + } - last["left_move"] = left; - last["width_move"] = width; - last["top_move"] = top; - last["height_move"] = height; + //替换的位置包含部分单元格 + if(hasPartMC(cfg, row_s, row_e, col_s, col_e)){ + if(isEditMode()){ + alert("无法对合并单元格执行此操作"); + } + else{ + tooltip.info('提示',"无法对合并单元格执行此操作"); + } + return; + } - Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1] = last; + let borderInfoCompute = getBorderInfoCompute(Store.currentSheetIndex); - selectHightlightShow(); - - luckysheetFreezen.scrollFreezen(); + //删除原本位置的数据 + let RowlChange = null; + for (let r = last["row"][0]; r <= last["row"][1]; r++) { + if(r in cfg["rowlen"]){ + RowlChange = true; + } - $("#luckysheet-helpbox-cell").text(getRangetxt(Store.currentSheetIndex, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1])); + for (let c = last["column"][0]; c <= last["column"][1]; c++) { + let cell = d[r][c]; - //交替颜色选择范围 - if($("#luckysheet-alternateformat-rangeDialog").is(":visible")){ - $("#luckysheet-alternateformat-rangeDialog input").val(getRangetxt(Store.currentSheetIndex, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1])); + if(getObjType(cell) == "object" && ("mc" in cell)){ + if((cell["mc"].r + "_" + cell["mc"].c) in cfg["merge"]){ + delete cfg["merge"][cell["mc"].r + "_" + cell["mc"].c]; + } } - if (pivotTable.luckysheet_pivotTable_select_state) { - $("#luckysheet-pivotTable-range-selection-input").val(Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)].name + "!" + chatatABC(Store.luckysheet_select_save[0]["column"][0]) + (Store.luckysheet_select_save[0]["row"][0] + 1) + ":" + chatatABC(Store.luckysheet_select_save[0]["column"][1]) + (Store.luckysheet_select_save[0]["row"][1] + 1)); - } + d[r][c] = null; } - else if(conditionformat.selectStatus){ - let mouse = mouseposition(event.pageX, event.pageY); - let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft(); - let y = mouse[1] + $("#luckysheet-cell-main").scrollTop(); + } - let row_location = rowLocation(y), - row = row_location[1], - row_pre = row_location[0], - row_index = row_location[2]; - let col_location = colLocation(x), - col = col_location[1], - col_pre = col_location[0], - col_index = col_location[2]; + //边框 + if(cfg["borderInfo"] && cfg["borderInfo"].length > 0){ + let borderInfo = []; - let last = conditionformat.selectRange[conditionformat.selectRange.length - 1]; + for(let i = 0; i < cfg["borderInfo"].length; i++){ + let bd_rangeType = cfg["borderInfo"][i].rangeType; - let top = 0, height = 0, rowseleted = []; - if (last.top > row_pre) { - top = row_pre; - height = last.top + last.height - row_pre; + if(bd_rangeType == "range"){ + let bd_range = cfg["borderInfo"][i].range; + let bd_emptyRange = []; - if(last.row[1] > last.row_focus){ - last.row[1] = last.row_focus; + for(let j = 0; j < bd_range.length; j++){ + bd_emptyRange = bd_emptyRange.concat(conditionformat.CFSplitRange(bd_range[j], {"row": last["row"], "column": last["column"]}, {"row": [row_s, row_e], "column": [col_s, col_e]}, "restPart")); } - rowseleted = [row_index, last.row[1]]; - } - else if (last.top == row_pre) { - top = row_pre; - height = last.top + last.height - row_pre; - rowseleted = [row_index, last.row[0]]; + cfg["borderInfo"][i].range = bd_emptyRange; + + borderInfo.push(cfg["borderInfo"][i]); } - else { - top = last.top; - height = row - last.top - 1; + else if(bd_rangeType == "cell"){ + let bd_r = cfg["borderInfo"][i].value.row_index; + let bd_c = cfg["borderInfo"][i].value.col_index; - if(last.row[0] < last.row_focus){ - last.row[0] = last.row_focus; + if(!(bd_r >= last["row"][0] && bd_r <= last["row"][1] && bd_c >= last["column"][0] && bd_c <= last["column"][1])){ + borderInfo.push(cfg["borderInfo"][i]); } - - rowseleted = [last.row[0], row_index]; } + } - let left = 0, width = 0, columnseleted = []; - if (last.left > col_pre) { - left = col_pre; - width = last.left + last.width - col_pre; - - if(last.column[1] > last.column_focus){ - last.column[1] = last.column_focus; + cfg["borderInfo"] = borderInfo; + } + + //替换位置数据更新 + let offsetMC = {}; + for (let r = 0; r < data.length; r++) { + for (let c = 0; c < data[0].length; c++) { + if(borderInfoCompute[(r + last["row"][0]) + "_" + (c + last["column"][0])]){ + let bd_obj = { + "rangeType": "cell", + "value": { + "row_index": r + row_s, + "col_index": c + col_s, + "l": borderInfoCompute[(r + last["row"][0]) + "_" + (c + last["column"][0])].l, + "r": borderInfoCompute[(r + last["row"][0]) + "_" + (c + last["column"][0])].r, + "t": borderInfoCompute[(r + last["row"][0]) + "_" + (c + last["column"][0])].t, + "b": borderInfoCompute[(r + last["row"][0]) + "_" + (c + last["column"][0])].b + } } - columnseleted = [col_index, last.column[1]]; - } - else if (last.left == col_pre) { - left = col_pre; - width = last.left + last.width - col_pre; - columnseleted = [col_index, last.column[0]]; - } - else { - left = last.left; - width = col - last.left - 1; - - if(last.column[0] < last.column_focus){ - last.column[0] = last.column_focus; + if(cfg["borderInfo"] == null){ + cfg["borderInfo"] = []; } - columnseleted = [last.column[0], col_index]; + cfg["borderInfo"].push(bd_obj); } - let changeparam = menuButton.mergeMoveMain(columnseleted, rowseleted, last, top, height, left, width); - if(changeparam != null){ - columnseleted = changeparam[0]; - rowseleted= changeparam[1]; - top = changeparam[2]; - height = changeparam[3]; - left = changeparam[4]; - width = changeparam[5]; + let value = ""; + if (data[r] != null && data[r][c] != null) { + value = data[r][c]; } - last["row"] = rowseleted; - last["column"] = columnseleted; - - last["left_move"] = left; - last["width_move"] = width; - last["top_move"] = top; - last["height_move"] = height; - - conditionformat.selectRange[conditionformat.selectRange.length - 1] = last; + if(getObjType(value) == "object" && ("mc" in value)){ + let mc = $.extend(true, {}, value["mc"]); + if("rs" in value["mc"]){ + offsetMC[mc.r + "_" + mc.c] = [r + row_s, c + col_s]; - selectionCopyShow(conditionformat.selectRange); + value["mc"].r = r + row_s; + value["mc"].c = c + col_s; - let range = conditionformat.getTxtByRange(conditionformat.selectRange); - $("#luckysheet-multiRange-dialog input").val(range); - } - else if (formula.rangestart) { - formula.rangedrag(event); - } - else if (formula.rangedrag_row_start) { - formula.rangedrag_row(event); - } - else if (formula.rangedrag_column_start) { - formula.rangedrag_column(event); - } - else if (Store.luckysheet_rows_selected_status) { - let mouse = mouseposition(event.pageX, event.pageY); - let y = mouse[1] + $("#luckysheet-rows-h").scrollTop(); - if (y < 0) { - return false; + cfg["merge"][(r + row_s) + "_" + (c + col_s)] = value["mc"]; + } + else{ + value["mc"].r = offsetMC[mc.r + "_" + mc.c][0]; + value["mc"].c = offsetMC[mc.r + "_" + mc.c][1]; + } } + d[r + row_s][c + col_s] = value; + } + } - let row_location = rowLocation(y), - row = row_location[1], - row_pre = row_location[0], - row_index = row_location[2]; - let col_index = Store.visibledatacolumn.length - 1, - col = Store.visibledatacolumn[col_index], - col_pre = 0; - - let last = $.extend(true, {}, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]); + if(RowlChange){ + cfg = rowlenByRange(d, last["row"][0], last["row"][1], cfg); + cfg = rowlenByRange(d, row_s, row_e, cfg); + } - let top = 0, height = 0, rowseleted = []; - if (last.top > row_pre) { - top = row_pre; - height = last.top + last.height - row_pre; + //条件格式 + let cdformat = $.extend(true, [], Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)]["luckysheet_conditionformat_save"]); + if(cdformat != null && cdformat.length > 0){ + for(let i = 0; i < cdformat.length; i++){ + let cdformat_cellrange = cdformat[i].cellrange; + let emptyRange = []; + for(let j = 0; j < cdformat_cellrange.length; j++){ + let range = conditionformat.CFSplitRange(cdformat_cellrange[j], {"row": last["row"], "column": last["column"]}, {"row": [row_s, row_e], "column": [col_s, col_e]}, "allPart"); + emptyRange = emptyRange.concat(range); + } + cdformat[i].cellrange = emptyRange; + } + } - if(last.row[1] > last.row_focus){ - last.row[1] = last.row_focus; - } + let rf; + if(Store.luckysheet_select_save[0].row_focus == Store.luckysheet_select_save[0].row[0]){ + rf = row_s; + } + else{ + rf = row_e; + } - rowseleted = [row_index, last.row[1]]; - } - else if (last.top == row_pre) { - top = row_pre; - height = last.top + last.height - row_pre; - rowseleted = [row_index, last.row[0]]; - } - else { - top = last.top; - height = row - last.top - 1; + let cf; + if(Store.luckysheet_select_save[0].column_focus == Store.luckysheet_select_save[0].column[0]){ + cf = col_s; + } + else{ + cf = col_e; + } - if(last.row[0] < last.row_focus){ - last.row[0] = last.row_focus; - } + let range = []; + range.push({ "row": last["row"], "column": last["column"] }); + range.push({ "row": [row_s, row_e], "column": [col_s, col_e] }); - rowseleted = [last.row[0], row_index]; - } + last["row"] = [row_s, row_e]; + last["column"] = [col_s, col_e]; + last["row_focus"] = rf; + last["column_focus"] = cf; - last["row"] = rowseleted; + jfrefreshgrid(d, range, cfg, cdformat, RowlChange); - last["top_move"] = top; - last["height_move"] = height; + selectHightlightShow(); - Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1] = last; + $("#luckysheet-sheettable").css("cursor", "default"); + clearTimeout(Store.countfuncTimeout); + Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); + } - selectHightlightShow(); - - clearTimeout(Store.countfuncTimeout); - Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); - } - else if (Store.luckysheet_cols_selected_status) { - let mouse = mouseposition(event.pageX, event.pageY); - let x = mouse[0] + $("#luckysheet-cols-h-c").scrollLeft(); - if (x < 0) { - return false; - } + //选区下拉 + if (Store.luckysheet_cell_selected_extend) { + Store.luckysheet_cell_selected_extend = false; + $("#luckysheet-cell-selected-extend").hide(); - let row_index = Store.visibledatarow.length - 1, - row = Store.visibledatarow[row_index], - row_pre = 0; - let col_location = colLocation(x), - col = col_location[1], - col_pre = col_location[0], - col_index = col_location[2]; + let mouse = mouseposition(event.pageX, event.pageY); + let scrollLeft = $("#luckysheet-cell-main").scrollLeft(); + let scrollTop = $("#luckysheet-cell-main").scrollTop(); - let last = $.extend(true, {}, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]); + let x = mouse[0] + scrollLeft - 5; + let y = mouse[1] + scrollTop - 5; - let left = 0, width = 0, columnseleted = []; - if (last.left > col_pre) { - left = col_pre; - width = last.left + last.width - col_pre; + let winH = $(window).height() + scrollTop - Store.sheetBarHeight - Store.statisticBarHeight, + winW = $(window).width() + scrollLeft; - if(last.column[1] > last.column_focus){ - last.column[1] = last.column_focus; - } + let row_location = rowLocation(y), + row = row_location[1], + row_pre = row_location[0], + row_index = row_location[2]; + let col_location = colLocation(x), + col = col_location[1], + col_pre = col_location[0], + col_index = col_location[2]; - columnseleted = [col_index, last.column[1]]; - } - else if (last.left == col_pre) { - left = col_pre; - width = last.left + last.width - col_pre; - columnseleted = [col_index, last.column[0]]; - } - else { - left = last.left; - width = col - last.left - 1; + let row_index_original = Store.luckysheet_cell_selected_extend_index[0], + col_index_original = Store.luckysheet_cell_selected_extend_index[1]; - if(last.column[0] < last.column_focus){ - last.column[0] = last.column_focus; - } + let last = Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]; + let row_s = last["row"][0], row_e = last["row"][1]; + let col_s = last["column"][0], col_e = last["column"][1]; - columnseleted = [last.column[0], col_index]; - } + if (row_s < 0 || y < 0) { + row_s = 0; + row_e = last["row"][1] - last["row"][0]; + } - last["column"] = columnseleted; + if (col_s < 0 || x < 0) { + col_s = 0; + col_e = last["column"][1] - last["column"][0]; + } - last["left_move"] = left; - last["width_move"] = width; + if (row_e >= Store.visibledatarow[Store.visibledatarow.length - 1] || y > winH) { + row_s = Store.visibledatarow.length - 1 - last["row"][1] + last["row"][0]; + row_e = Store.visibledatarow.length - 1; + } - Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1] = last; + if (col_e >= Store.visibledatacolumn[Store.visibledatacolumn.length - 1] || x > winW) { + col_s = Store.visibledatacolumn.length - 1 - last["column"][1] + last["column"][0]; + col_e = Store.visibledatacolumn.length - 1; + } - selectHightlightShow(); - - clearTimeout(Store.countfuncTimeout); - Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); - } - else if (Store.luckysheet_cell_selected_move) { - let mouse = mouseposition(event.pageX, event.pageY); - - let scrollLeft = $("#luckysheet-cell-main").scrollLeft(); - let scrollTop = $("#luckysheet-cell-main").scrollTop(); + //复制范围 + luckysheetDropCell.copyRange = {"row": $.extend(true, [], last["row"]), "column": $.extend(true, [], last["column"])}; + //applyType + let typeItemHide = luckysheetDropCell.typeItemHide(); + + if(!typeItemHide[0] && !typeItemHide[1] && !typeItemHide[2] && !typeItemHide[3] && !typeItemHide[4] && !typeItemHide[5] && !typeItemHide[6]){ + luckysheetDropCell.applyType = "0"; + } + else{ + luckysheetDropCell.applyType = "1"; + } - let x = mouse[0] + scrollLeft; - let y = mouse[1] + scrollTop; + if (Math.abs(row_index_original - row_index) > Math.abs(col_index_original - col_index)) { + if (!(row_index >= row_s && row_index <= row_e)) { + if (Store.luckysheet_select_save[0].top_move >= row_pre) {//当往上拖拽时 + luckysheetDropCell.applyRange = {"row": [row_index, last["row"][0] - 1], "column": last["column"]}; + luckysheetDropCell.direction = "up"; - let winH = $(window).height() + scrollTop - Store.sheetBarHeight - Store.statisticBarHeight, - winW = $(window).width() + scrollLeft; + row_s -= last["row"][0] - row_index; - let row_location = rowLocation(y), - row = row_location[1], - row_pre = row_location[0], - row_index = row_location[2]; - let col_location = colLocation(x), - col = col_location[1], - col_pre = col_location[0], - col_index = col_location[2]; + //是否有数据透视表范围 + if(pivotTable.isPivotRange(row_s, col_e)){ + tooltip.info("无法对所选单元格进行此更改,因为它会影响数据透视表!",""); + return; + } + } + else {//当往下拖拽时 + luckysheetDropCell.applyRange = {"row": [last["row"][1] + 1, row_index], "column": last["column"]}; + luckysheetDropCell.direction = "down"; - let row_index_original = Store.luckysheet_cell_selected_move_index[0], - col_index_original = Store.luckysheet_cell_selected_move_index[1]; + row_e += row_index - last["row"][1]; - let row_s = Store.luckysheet_select_save[0]["row"][0] - row_index_original + row_index, - row_e = Store.luckysheet_select_save[0]["row"][1] - row_index_original + row_index; + //是否有数据透视表范围 + if(pivotTable.isPivotRange(row_e, col_e)){ + tooltip.info("无法对所选单元格进行此更改,因为它会影响数据透视表!",""); + return; + } + } + } + else{ + return; + } + } + else { + if (!(col_index >= col_s && col_index <= col_e)) { + if (Store.luckysheet_select_save[0].left_move >= col_pre) {//当往左拖拽时 + luckysheetDropCell.applyRange = {"row": last["row"], "column": [col_index, last["column"][0] - 1]}; + luckysheetDropCell.direction = "left"; - let col_s = Store.luckysheet_select_save[0]["column"][0] - col_index_original + col_index, - col_e = Store.luckysheet_select_save[0]["column"][1] - col_index_original + col_index; + col_s -= last["column"][0] - col_index; - if (row_s < 0 || y < 0) { - row_s = 0; - row_e = Store.luckysheet_select_save[0]["row"][1] - Store.luckysheet_select_save[0]["row"][0]; + //是否有数据透视表范围 + if(pivotTable.isPivotRange(row_e, col_s)){ + tooltip.info("无法对所选单元格进行此更改,因为它会影响数据透视表!",""); + return; + } } + else {//当往右拖拽时 + luckysheetDropCell.applyRange = {"row": last["row"], "column": [last["column"][1] + 1, col_index]}; + luckysheetDropCell.direction = "right"; - if (col_s < 0 || x < 0) { - col_s = 0; - col_e = Store.luckysheet_select_save[0]["column"][1] - Store.luckysheet_select_save[0]["column"][0]; + col_e += col_index - last["column"][1]; + + //是否有数据透视表范围 + if(pivotTable.isPivotRange(row_e, col_e)){ + tooltip.info("无法对所选单元格进行此更改,因为它会影响数据透视表!",""); + return; + } } + } + else{ + return; + } + } - if (row_e >= Store.visibledatarow[Store.visibledatarow.length - 1] || y > winH) { - row_s = Store.visibledatarow.length - 1 - Store.luckysheet_select_save[0]["row"][1] + Store.luckysheet_select_save[0]["row"][0]; - row_e = Store.visibledatarow.length - 1; + if(Store.config["merge"] != null){ + let hasMc = false; + + for(let r = last["row"][0]; r <= last["row"][1]; r++){ + for(let c = last["column"][0]; c <= last["column"][1]; c++){ + let cell = Store.flowdata[r][c]; + + if(cell != null && cell.mc != null){ + hasMc = true; + break; + } } + } - if (col_e >= Store.visibledatacolumn[Store.visibledatacolumn.length - 1] || x > winW) { - col_s = Store.visibledatacolumn.length - 1 - Store.luckysheet_select_save[0]["column"][1] + Store.luckysheet_select_save[0]["column"][0]; - col_e = Store.visibledatacolumn.length - 1; + if(hasMc){ + if(isEditMode()){ + alert("无法对合并单元格执行此操作"); + } + else{ + tooltip.info("无法对合并单元格执行此操作", ""); } - col_pre = col_s - 1 == -1 ? 0 : Store.visibledatacolumn[col_s - 1]; - col = Store.visibledatacolumn[col_e]; - row_pre = row_s - 1 == -1 ? 0 : Store.visibledatarow[row_s - 1]; - row = Store.visibledatarow[row_e]; + return; + } - $("#luckysheet-cell-selected-move").css({ - "left": col_pre, - "width": col - col_pre - 2, - "top": row_pre, - "height": row - row_pre - 2, - "display": "block" - }); + for(let r = row_s; r <= row_e; r++){ + for(let c = col_s; c <= col_e; c++){ + let cell = Store.flowdata[r][c]; + + if(cell != null && cell.mc != null){ + hasMc = true; + break; + } + } } - else if (Store.luckysheet_cell_selected_extend) { - let mouse = mouseposition(event.pageX, event.pageY); - let scrollLeft = $("#luckysheet-cell-main").scrollLeft() - 5; - let scrollTop = $("#luckysheet-cell-main").scrollTop() - 5; - let x = mouse[0] + scrollLeft; - let y = mouse[1] + scrollTop; + if(hasMc){ + if(isEditMode()){ + alert("无法对合并单元格执行此操作"); + } + else{ + tooltip.info("无法对合并单元格执行此操作", ""); + } - let winH = $(window).height() + scrollTop - Store.sheetBarHeight - Store.statisticBarHeight, - winW = $(window).width() + scrollLeft; + return; + } + } - let row_location = rowLocation(y), - row = row_location[1], - row_pre = row_location[0], - row_index = row_location[2]; - let col_location = colLocation(x), - col = col_location[1], - col_pre = col_location[0], - col_index = col_location[2]; + last["row"] = [row_s, row_e]; + last["column"] = [col_s, col_e]; - let row_index_original = Store.luckysheet_cell_selected_extend_index[0], - col_index_original = Store.luckysheet_cell_selected_extend_index[1]; + luckysheetDropCell.update(); + luckysheetDropCell.createIcon(); - let row_s = Store.luckysheet_select_save[0]["row"][0], - row_e = Store.luckysheet_select_save[0]["row"][1]; - let col_s = Store.luckysheet_select_save[0]["column"][0], - col_e = Store.luckysheet_select_save[0]["column"][1]; + $("#luckysheet-cell-selected-move").hide(); - if (row_s < 0 || y < 0) { - row_s = 0; - row_e = Store.luckysheet_select_save[0]["row"][1] - Store.luckysheet_select_save[0]["row"][0]; - } + $("#luckysheet-sheettable").css("cursor", "default"); + clearTimeout(Store.countfuncTimeout); + Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); + } + }); - if (col_s < 0 || x < 0) { - col_s = 0; - col_e = Store.luckysheet_select_save[0]["column"][1] - Store.luckysheet_select_save[0]["column"][0]; - } + //禁止浏览器 右键默认菜单 + $(".luckysheet-grid-container, #luckysheet-rightclick-menu").on("contextmenu", function (e) { + e.preventDefault(); + }); - if (row_e >= Store.visibledatarow[Store.visibledatarow.length - 1] || y > winH) { - row_s = Store.visibledatarow.length - 1 - Store.luckysheet_select_save[0]["row"][1] + Store.luckysheet_select_save[0]["row"][0]; - row_e = Store.visibledatarow.length - 1; - } + //禁止前台编辑(只可 框选单元格、滚动查看表格) + if(!Store.allowEdit){ + return; + } - if (col_e >= Store.visibledatacolumn[Store.visibledatacolumn.length - 1] || x > winW) { - col_s = Store.visibledatacolumn.length - 1 - Store.luckysheet_select_save[0]["column"][1] + Store.luckysheet_select_save[0]["column"][0]; - col_e = Store.visibledatacolumn.length - 1; - } + //选区拖动替换 + $("#luckysheet-cell-main div.luckysheet-cs-draghandle").mousedown(function (event) { + if(isEditMode()){//此模式下禁用选区拖动 + return; + } - let top = Store.luckysheet_select_save[0].top_move, - height = Store.luckysheet_select_save[0].height_move; - let left = Store.luckysheet_select_save[0].left_move, - width = Store.luckysheet_select_save[0].width_move; + $("#luckysheet-cell-selected").find(".luckysheet-cs-fillhandle") + .css("cursor","move") + .end() + .find(".luckysheet-cs-draghandle") + .css("cursor","move"); + $("#luckysheet-cell-main, #luckysheetTableContent, #luckysheet-sheettable_0").css("cursor","move"); - if (Math.abs(row_index_original - row_index) > Math.abs(col_index_original - col_index)) { - if (!(row_index >= row_s && row_index <= row_e)) { - if (Store.luckysheet_select_save[0].top_move >= row_pre) { - top = row_pre; - height = Store.luckysheet_select_save[0].top_move + Store.luckysheet_select_save[0].height_move - row_pre; - } - else { - top = Store.luckysheet_select_save[0].top_move; - height = row - Store.luckysheet_select_save[0].top_move - 1; - } - } - } - else { - if (!(col_index >= col_s && col_index <= col_e)) { - if (Store.luckysheet_select_save[0].left_move >= col_pre) { - left = col_pre; - width = Store.luckysheet_select_save[0].left_move + Store.luckysheet_select_save[0].width_move - col_pre; - } - else { - left = Store.luckysheet_select_save[0].left_move; - width = col - Store.luckysheet_select_save[0].left_move - 1; - } - } - } + Store.luckysheet_cell_selected_move = true; + Store.luckysheet_scroll_status = true; - $("#luckysheet-cell-selected-extend").css({ - "left": left, - "width": width, - "top": top, - "height": height, - "display": "block" - }); - } - else if (Store.luckysheet_cols_change_size) { - let mouse = mouseposition(event.pageX, event.pageY); - let scrollLeft = $("#luckysheet-cols-h-c").scrollLeft(); - let x = mouse[0] + scrollLeft; - let winW = $(window).width(); + let mouse = mouseposition(event.pageX, event.pageY); + let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft(); + let y = mouse[1] + $("#luckysheet-cell-main").scrollTop(); - let row_index = Store.visibledatarow.length - 1, - row = Store.visibledatarow[row_index], - row_pre = 0; - let col_location = colLocation(x), - col = col_location[1], - col_pre = col_location[0], - col_index = col_location[2]; - - if ((x + 3) - Store.luckysheet_cols_change_size_start[0] > 30 && x < winW + scrollLeft - 100) { - $("#luckysheet-change-size-line").css({ "left": x }); - $("#luckysheet-cols-change-size").css({ "left": x - 2 }); + let row_location = rowLocation(y), + row_pre = row_location[0], + row = row_location[1], + row_index = row_location[2]; + let col_location = colLocation(x), + col_pre = col_location[0], + col = col_location[1], + col_index = col_location[2]; + + Store.luckysheet_cell_selected_move_index = [row_index, col_index]; + + $("#luckysheet-cell-selected-move").css({ + "left": col_pre, + "width": col - col_pre - 1, + "top": row_pre, + "height": row - row_pre - 1, + "display": "block" + }); + + event.stopPropagation(); + }); + + //选区下拉 + $("#luckysheet-cell-main div.luckysheet-cs-fillhandle").mousedown(function (event) { + if(isEditMode()){//此模式下禁用选区下拉 + return; + } + + $("#luckysheet-cell-selected").find(".luckysheet-cs-fillhandle") + .css("cursor","crosshair") + .end() + .find(".luckysheet-cs-draghandle") + .css("cursor","crosshair"); + $("#luckysheet-cell-main, #luckysheetTableContent, #luckysheet-sheettable_0").css("cursor","crosshair"); + + Store.luckysheet_cell_selected_extend_time = setTimeout(function () { + Store.luckysheet_cell_selected_extend = true; + Store.luckysheet_scroll_status = true; + + let mouse = mouseposition(event.pageX, event.pageY); + let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft() - 5; + let y = mouse[1] + $("#luckysheet-cell-main").scrollTop() - 5; + + let row_location = rowLocation(y), + row_pre = row_location[0], + row = row_location[1], + row_index = row_location[2]; + let col_location = colLocation(x), + col_pre = col_location[0], + col = col_location[1], + col_index = col_location[2]; + + Store.luckysheet_cell_selected_extend_index = [row_index, col_index]; + + $("#luckysheet-cell-selected-extend").css({ + "left": col_pre, + "width": col - col_pre - 1, + "top": row_pre, + "height": row - row_pre - 1, + "display": "block" + }); + }, 100); + + event.stopPropagation(); + }).click(function () { + clearTimeout(Store.luckysheet_cell_selected_extend_time); + event.stopPropagation(); + }).dblclick(function () { + let last = Store.luckysheet_select_save[0]; + + let r0 = last.row[0], + r1 = last.row[1], + c0 = last.column[0], + c1 = last.column[1]; + + if(pivotTable.isPivotRange(r0, c0)){ + return; + } + + let dropCellState = false; + let step = 0; + + for(let r = r1 + 1; r < Store.flowdata.length; r++){ + if(c0 - 1 >= 0 && c1 + 1 < Store.flowdata[0].length){ + let cell1 = Store.flowdata[r][c0 - 1]; + let cell2 = Store.flowdata[r][c1 + 1]; + + if(r == r1 + 1){ + if((cell1 == null || isRealNull(cell1.v)) && (cell2 == null || isRealNull(cell2.v))){ + dropCellState = false; + break; + } + else{ + dropCellState = true; + step++; } } - else if (Store.luckysheet_rows_change_size) { - let mouse = mouseposition(event.pageX, event.pageY); - let scrollTop = $("#luckysheet-rows-h").scrollTop(); - let y = mouse[1] + scrollTop; - let winH = $(window).height(); + else{ + if((cell1 == null || isRealNull(cell1.v)) && (cell2 == null || isRealNull(cell2.v))){ + break; + } + + step++; + } + } + else if(c0 - 1 >= 0){ + let cell = Store.flowdata[r][c0 - 1]; + + if(r == r1 + 1){ + if(cell == null || isRealNull(cell.v)){ + dropCellState = false; + break; + } + else{ + dropCellState = true; + step++; + } + } + else{ + if(cell == null || isRealNull(cell.v)){ + break; + } + + step++; + } + } + else if(c1 + 1 < Store.flowdata[0].length){ + let cell = Store.flowdata[r][c1 + 1]; + + if(r == r1 + 1){ + if(cell == null || isRealNull(cell.v)){ + dropCellState = false; + break; + } + else{ + dropCellState = true; + step++; + } + } + else{ + if(cell == null || isRealNull(cell.v)){ + break; + } + + step++; + } + } + } + + if(!dropCellState || step == 0){ + event.stopPropagation(); + return; + } + + //复制范围 + luckysheetDropCell.copyRange = { "row": [r0, r1], "column": [c0, c1] }; + + //applyType + let typeItemHide = luckysheetDropCell.typeItemHide(); + + if(!typeItemHide[0] && !typeItemHide[1] && !typeItemHide[2] && !typeItemHide[3] && !typeItemHide[4] && !typeItemHide[5] && !typeItemHide[6]){ + luckysheetDropCell.applyType = "0"; + } + else{ + luckysheetDropCell.applyType = "1"; + } + + luckysheetDropCell.applyRange = { "row": [r1 + 1, r1 + step], "column": [c0, c1] }; + luckysheetDropCell.direction = "down"; + + Store.luckysheet_select_save = [{ "row": [r0, r1 + step], "column": [c0, c1] }]; + + luckysheetDropCell.update(); + luckysheetDropCell.createIcon(); + + $("#luckysheet-cell-selected-move").hide(); + + $("#luckysheet-sheettable").css("cursor", "default"); + clearTimeout(Store.countfuncTimeout); + Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); + + event.stopPropagation(); + }); + + // + $("#luckysheet-bottom-add-row, #luckysheet-bottom-add-row-input, #luckysheet-bottom-return-top").on("mousedown dblclick mouseup",function(e){ + e.stopPropagation(); + }); + + //底部添加行按钮 + $("#luckysheet-bottom-add-row").on("click", function(e) { + $("#luckysheet-rightclick-menu").hide(); + $("#" + Store.container).attr("tabindex", 0).focus(); + + let $t = $(this), value = $("#luckysheet-bottom-add-row-input").val(); + + if(value == ""){ + value = 100; + } + + if (isNaN(parseInt(value))) { + if(isEditMode()){ + alert("请输入数字"); + } + else{ + tooltip.info("增加错误", "请输入数字"); + } + return; + } + + value = parseInt(value); + if (value < 1 || value > 100) { + if(isEditMode()){ + alert("增加范围限制在1-100"); + } + else{ + tooltip.info("增加错误", "增加范围限制在1-100"); + } + return; + } + + luckysheetextendtable("row", Store.flowdata.length - 1, value); + }); + + $("#luckysheet-bottom-return-top").on("click", function(e) { + $("#luckysheet-scrollbar-y").scrollTop(0); + }); + + //单元格编辑输入 + let luckysheet_shiftkeydown = false; + + $("#luckysheet-input-box").click(function () { + formula.rangeHightlightselected($("#luckysheet-rich-text-editor")); + }).add("#" + Store.container).on("keydown", function (event) { + if ($("#luckysheet-modal-dialog-mask").is(":visible") || $(event.target).hasClass("luckysheet-mousedown-cancel") || $(event.target).hasClass("formulaInputFocus")) { + return; + } + + let ctrlKey = event.ctrlKey; + let altKey = event.altKey; + let shiftKey = event.shiftKey; + let kcode = event.keyCode; + + if ($("#luckysheet-modal-dialog-mask").is(":visible") || $(event.target).hasClass("luckysheet-mousedown-cancel") || $(event.target).hasClass("sp-input") || (parseInt($("#luckysheet-input-box").css("top")) > 0 && $(event.target).closest(".luckysheet-input-box").length > 0 && kcode != keycode.ENTER && kcode != keycode.TAB && kcode != keycode.UP && kcode != keycode.DOWN && kcode != keycode.LEFT && kcode != keycode.RIGHT)) { + let anchor = $(window.getSelection().anchorNode); + + if(anchor.parent().is("#luckysheet-helpbox-cell") || anchor.is("#luckysheet-helpbox-cell")){ + if(kcode == keycode.ENTER){ + let helpboxValue = $("#luckysheet-helpbox-cell").text(); + + if(formula.iscelldata(helpboxValue)){ + let cellrange = formula.getcellrange(helpboxValue); + + Store.luckysheet_select_save = [{ "row": cellrange["row"], "column": cellrange["column"], "row_focus": cellrange["row"][0], "column_focus": cellrange["column"][0] }]; + selectHightlightShow(); + + $("#luckysheet-helpbox-cell").blur(); + + let scrollLeft = $("#luckysheet-cell-main").scrollLeft(), + scrollTop = $("#luckysheet-cell-main").scrollTop(); + let winH = $("#luckysheet-cell-main").height(), + winW = $("#luckysheet-cell-main").width(); + + let row = Store.visibledatarow[cellrange["row"][1]], + row_pre = cellrange["row"][0] - 1 == -1 ? 0 : Store.visibledatarow[cellrange["row"][0] - 1]; + let col = Store.visibledatacolumn[cellrange["column"][1]], + col_pre = cellrange["column"][0] - 1 == -1 ? 0 : Store.visibledatacolumn[cellrange["column"][0] - 1]; + + if (col - scrollLeft - winW + 20 > 0) { + $("#luckysheet-scrollbar-x").scrollLeft(col - winW + 20); + } + else if (col_pre - scrollLeft - 20 < 0) { + $("#luckysheet-scrollbar-x").scrollLeft(col_pre - 20); + } + + if (row - scrollTop - winH + 20 > 0) { + $("#luckysheet-scrollbar-y").scrollTop(row - winH + 20); + } + else if (row_pre - scrollTop - 20 < 0) { + $("#luckysheet-scrollbar-y").scrollTop(row_pre - 20); + } + } + } + } + + return; + } + + let $inputbox = $("#luckysheet-input-box"); + + if (kcode == keycode.ENTER && parseInt($inputbox.css("top")) > 0) { + if ($("#luckysheet-formula-search-c").is(":visible") && formula.searchFunctionCell != null) { + formula.searchFunctionEnter($("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item-active")); + } + else { + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + Store.luckysheet_select_save = [{ + "row": [Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[0]], + "column": [Store.luckysheetCellUpdate[1], Store.luckysheetCellUpdate[1]], + "row_focus": Store.luckysheetCellUpdate[0], + "column_focus": Store.luckysheetCellUpdate[1] + }]; + luckysheetMoveHighlightCell("down", 1, "rangeOfSelect"); + } + + //若有参数弹出框,隐藏 + if($("#luckysheet-search-formula-parm").is(":visible")){ + $("#luckysheet-search-formula-parm").hide(); + } + //若有参数选取范围弹出框,隐藏 + if($("#luckysheet-search-formula-parm-select").is(":visible")){ + $("#luckysheet-search-formula-parm-select").hide(); + } + event.preventDefault(); + } + else if (kcode == keycode.TAB) { + if (parseInt($inputbox.css("top")) > 0) { + return; + } + + luckysheetMoveHighlightCell("right", 1, "rangeOfSelect"); + event.preventDefault(); + } + else if(kcode == keycode.F2){ + if (parseInt($inputbox.css("top")) > 0) { + return; + } + + let last = Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]; + + let row_index = last["row_focus"], col_index = last["column_focus"]; + let row = Store.visibledatarow[row_index], + row_pre = row_index - 1 == -1 ? 0 : Store.visibledatarow[row_index - 1]; + let col = Store.visibledatacolumn[col_index], + col_pre = col_index - 1 == -1 ? 0 : Store.visibledatacolumn[col_index - 1]; + + luckysheetupdateCell(row, row_pre, row_index, col, col_pre, col_index, Store.flowdata); + event.preventDefault(); + } + else if (kcode == keycode.F4 && parseInt($inputbox.css("top")) > 0) { + formula.setfreezonFuc(event); + event.preventDefault(); + } + else if (kcode == keycode.ESC && parseInt($inputbox.css("top")) > 0) { + formula.dontupdate(); + luckysheetMoveHighlightCell("down", 0, "rangeOfSelect"); + event.preventDefault(); + } + else if (kcode == keycode.ENTER) { + if($(event.target).hasClass("formulaInputFocus") || $("#luckysheet-conditionformat-dialog").is(":visible")){ + return; + } + else if (String.fromCharCode(kcode) != null && $("#luckysheet-cell-selected").is(":visible")) { + let last = Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]; + + let row_index = last["row_focus"], col_index = last["column_focus"]; + let row = Store.visibledatarow[row_index], + row_pre = row_index - 1 == -1 ? 0 : Store.visibledatarow[row_index - 1]; + let col = Store.visibledatacolumn[col_index], + col_pre = col_index - 1 == -1 ? 0 : Store.visibledatacolumn[col_index - 1]; + + let margeset = menuButton.mergeborer(Store.flowdata, row_index, col_index); + if(!!margeset){ + row = margeset.row[1]; + row_pre = margeset.row[0]; + row_index = margeset.row[2]; + col = margeset.column[1]; + col_pre = margeset.column[0]; + col_index = margeset.column[2]; + } - let row_location = rowLocation(y), - row = row_location[1], - row_pre = row_location[0], - row_index = row_location[2]; - - if ((y + 3) - Store.luckysheet_rows_change_size_start[0] > 19 && y < winH + scrollTop - 200) { - $("#luckysheet-change-size-line").css({ "top": y }); - $("#luckysheet-rows-change-size").css({ "top": y }); + luckysheetupdateCell(row, row_pre, row_index, col, col_pre, col_index, Store.flowdata); + event.preventDefault(); + } + } + else { + if (ctrlKey || event.metaKey) { + if (shiftKey) { + if (!luckysheet_shiftkeydown) { + Store.luckysheet_shiftpositon = $.extend(true, {}, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]); + Store.luckysheet_shiftkeydown = true; } - } - else if (luckysheetPostil.move){ - let mouse = mouseposition(event.pageX, event.pageY); - let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft(); - let y = mouse[1] + $("#luckysheet-cell-main").scrollTop(); - let myh = luckysheetPostil.currentObj.outerHeight(), - myw = luckysheetPostil.currentObj.outerWidth(); - - let top = y - luckysheetPostil.moveXY[1], - left = x - luckysheetPostil.moveXY[0]; + //Ctrl + shift + 方向键 调整选区 + if (kcode == keycode.UP) { + if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - if (top < 0) { - top = 0; + luckysheetMoveHighlightRange2("up", "rangeOfSelect"); } + else if (kcode == keycode.DOWN) { + if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - if (top + myh + 42 + 6 > luckysheetPostil.currentWinH) { - top = luckysheetPostil.currentWinH - myh - 42 - 6; + luckysheetMoveHighlightRange2("down", "rangeOfSelect"); } + else if (kcode == keycode.LEFT) { + if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - if (left < 0) { - left = 0; + luckysheetMoveHighlightRange2("left", "rangeOfSelect"); } + else if (kcode == keycode.RIGHT) { + if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - if (left + myw + 22 + 36 > luckysheetPostil.currentWinW) { - left = luckysheetPostil.currentWinW - myw - 22 - 36; + luckysheetMoveHighlightRange2("right", "rangeOfSelect"); } - - luckysheetPostil.currentObj.css({ "left": left, "top": top }); } - else if (!!luckysheetPostil.resize){ - let mouse = mouseposition(event.pageX, event.pageY); - let x = mouse[0] + $("#luckysheet-cell-main").scrollLeft(); - let y = mouse[1] + $("#luckysheet-cell-main").scrollTop(); - - if (x < 0 || y < 0) { - return false; + else if (kcode == 66) {//Ctrl + B 加粗 + $("#luckysheet-icon-bold").click(); + } + else if (kcode == 67) {//Ctrl + C 复制 + //复制时存在格式刷状态,取消格式刷 + if(menuButton.luckysheetPaintModelOn){ + menuButton.cancelPaintModel(); } - - let resizeXY = luckysheetPostil.resizeXY; - - let topchange = y - resizeXY[1], - leftchange = x - resizeXY[0]; - let top = resizeXY[5], - height = resizeXY[3], - left = resizeXY[4], - width = resizeXY[2]; - - let resize = luckysheetPostil.resize; - - if(resize == "lm" || resize == "lt" || resize == "lb"){ - left = x; - width = resizeXY[2] - leftchange; - - if(left > resizeXY[2] + resizeXY[4] - 60){ - left = resizeXY[2] + resizeXY[4] - 60; - width = resizeXY[2] - (resizeXY[2] + resizeXY[4] - 60 - resizeXY[0]); - } - else if(left <= 0){ - left = 0; - width = resizeXY[2] + resizeXY[0]; - } + if(Store.luckysheet_select_save.length == 0){ + return; } - if(resize == "rm" || resize == "rt" || resize == "rb"){ - width = resizeXY[2] + leftchange; + //复制范围内包含部分合并单元格,提示 + if(Store.config["merge"] != null){ + let has_PartMC = false; - if(width < 60){ - width = 60; - } - else if(width >= luckysheetPostil.currentWinW - resizeXY[4] - 22 - 36){ - width = luckysheetPostil.currentWinW - resizeXY[4] - 22 - 36; - } - } + for(let s = 0; s < Store.luckysheet_select_save.length; s++){ + let r1 = Store.luckysheet_select_save[s].row[0], + r2 = Store.luckysheet_select_save[s].row[1]; + let c1 = Store.luckysheet_select_save[s].column[0], + c2 = Store.luckysheet_select_save[s].column[1]; - if(resize == "mt" || resize == "lt" || resize == "rt"){ - top = y; - height = resizeXY[3] - topchange; + has_PartMC = hasPartMC(Store.config, r1, r2, c1, c2); - if(top > resizeXY[3] + resizeXY[5] - 60){ - top = resizeXY[3] + resizeXY[5] - 60; - height = resizeXY[3] - (resizeXY[3] + resizeXY[5] - 60 - resizeXY[1]); - } - else if(top <= 0){ - top = 0; - height = resizeXY[3] + resizeXY[1]; + if(has_PartMC){ + break; + } } - } - - if(resize == "mb" || resize == "lb" || resize == "rb"){ - height = resizeXY[3] + topchange; - if(height < 60){ - height = 60; - } - else if(height >= luckysheetPostil.currentWinH - resizeXY[5] - 42 - 6){ - height = luckysheetPostil.currentWinH - resizeXY[5] - 42 - 6; + if(has_PartMC){ + if(isEditMode()){ + alert("无法对部分合并单元格执行此操作"); + } + else{ + tooltip.info("无法对部分合并单元格执行此操作", ""); + } + return; } } - luckysheetPostil.currentObj.css({ "width": width, "height": height, "left": left, "top": top }); - } - else if (!!formula.rangeResize) { - formula.rangeResizeDraging(event, formula.rangeResizeObj, formula.rangeResizexy, formula.rangeResize, formula.rangeResizeWinW, formula.rangeResizeWinH, Store.ch_width, Store.rh_height); - } - else if (!!formula.rangeMove) { - formula.rangeMoveDraging(event, formula.rangeMovexy, formula.rangeMoveObj.data("range"), formula.rangeMoveObj, Store.sheetBarHeight, Store.statisticBarHeight); - } - }, 1); - } - }); - - //表格mouseup - $(document).mouseup(function (event) { - //数据窗格主体 - if (Store.luckysheet_select_status) { - clearTimeout(Store.countfuncTimeout); - Store.countfuncTimeout = setTimeout(function(){ - countfunc(); - }, 0); - - //格式刷 - if(menuButton.luckysheetPaintModelOn){ - selection.pasteHandlerOfPaintModel(Store.luckysheet_copy_save); - - if(menuButton.luckysheetPaintSingle){ - //单次 格式刷 - menuButton.cancelPaintModel(); - } - } - } - - Store.luckysheet_select_status = false; - clearTimeout(Store.jfautoscrollTimeout); - Store.luckysheet_scroll_status = false; - - $("#luckysheet-cell-selected").find(".luckysheet-cs-fillhandle").css("cursor","crosshair").end().find(".luckysheet-cs-draghandle").css("cursor","move"); - $("#luckysheet-cell-main, #luckysheetTableContent, #luckysheet-sheettable_0").css("cursor","default"); - - //行标题窗格主体 - Store.luckysheet_rows_selected_status = false; - - //列标题窗格主体 - Store.luckysheet_cols_selected_status = false; - - Store.luckysheet_model_move_state = false; + //多重选区 有条件格式时 提示 + let cdformat = Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)].luckysheet_conditionformat_save; + if(Store.luckysheet_select_save.length > 1 && cdformat != null && cdformat.length > 0){ + let hasCF = false; - if(formula.functionResizeStatus){ - formula.functionResizeStatus = false; - $("#luckysheet-wa-calculate-size").removeAttr("style"); - } + let cf_compute = conditionformat.getComputeMap(); - if (!!luckysheetFreezen.horizontalmovestate) { - luckysheetFreezen.horizontalmovestate = false; - $("#luckysheet-freezebar-horizontal").removeClass("luckysheet-freezebar-active"); - $("#luckysheet-freezebar-horizontal").find(".luckysheet-freezebar-horizontal-handle").css("cursor", "-webkit-grab"); - if (luckysheetFreezen.freezenhorizontaldata[4] <= Store.columeHeaderHeight) { - luckysheetFreezen.cancelFreezenHorizontal(); - } - luckysheetFreezen.createAssistCanvas(); - luckysheetrefreshgrid(); - } + label: + for(let s = 0; s < Store.luckysheet_select_save.length; s++){ + if(hasCF){ + break; + } + + let r1 = Store.luckysheet_select_save[s].row[0], + r2 = Store.luckysheet_select_save[s].row[1]; + let c1 = Store.luckysheet_select_save[s].column[0], + c2 = Store.luckysheet_select_save[s].column[1]; - if (!!luckysheetFreezen.verticalmovestate) { - luckysheetFreezen.verticalmovestate = false; - $("#luckysheet-freezebar-vertical").removeClass("luckysheet-freezebar-active"); - $("#luckysheet-freezebar-vertical").find(".luckysheet-freezebar-vertical-handle").css("cursor", "-webkit-grab"); - if (luckysheetFreezen.freezenverticaldata[4] <= Store.rowHeaderWidth) { - luckysheetFreezen.cancelFreezenVertical(); - } - luckysheetFreezen.createAssistCanvas(); - luckysheetrefreshgrid(); - } + for(let r = r1; r <= r2; r++){ + for(let c = c1; c <= c2; c++){ + if(conditionformat.checksCF(r, c, cf_compute) != null){ + hasCF = true; + continue label; + } + } + } + } - if (!!pivotTable && pivotTable.movestate) { - $("#luckysheet-modal-dialog-slider-pivot-move").remove(); - pivotTable.movestate = false; - $("#luckysheet-modal-dialog-pivotTable-list, #luckysheet-modal-dialog-config-filter, #luckysheet-modal-dialog-config-row, #luckysheet-modal-dialog-config-column, #luckysheet-modal-dialog-config-value").css("cursor", "default"); - - if (pivotTable.movesave.containerid != "luckysheet-modal-dialog-pivotTable-list") { - let $cur = $(event.target).closest(".luckysheet-modal-dialog-slider-config-list"); - if ($cur.length == 0) { - if (pivotTable.movesave.containerid == "luckysheet-modal-dialog-config-value") { - pivotTable.resetOrderby(pivotTable.movesave.obj); + if(hasCF){ + if(isEditMode()){ + alert("无法对多重选择区域执行此操作"); + } + else{ + tooltip.info("无法对多重选择区域执行此操作", ""); + } + return; + } } - pivotTable.movesave.obj.remove(); - pivotTable.showvaluecolrow(); - - $("#luckysheet-modal-dialog-pivotTable-list").find(".luckysheet-modal-dialog-slider-list-item").each(function () { - $(this).find(".luckysheet-slider-list-item-selected").find("i").remove(); - }); - - $("#luckysheet-modal-dialog-config-filter, #luckysheet-modal-dialog-config-row, #luckysheet-modal-dialog-config-column, #luckysheet-modal-dialog-config-value").find(".luckysheet-modal-dialog-slider-config-item").each(function () { - let index = $(this).data("index"); + //多重选区 行不一样且列不一样时 提示 + if(Store.luckysheet_select_save.length > 1){ + let isSameRow = true, + str_r = luckysheet_select_save[0].row[0], + end_r = luckysheet_select_save[0].row[1]; + let isSameCol = true, + str_c = luckysheet_select_save[0].column[0], + end_c = luckysheet_select_save[0].column[1]; + + for(let s = 1; s < luckysheet_select_save.length; s++){ + if(luckysheet_select_save[s].row[0] != str_r || luckysheet_select_save[s].row[1] != end_r){ + isSameRow = false; + } + if(luckysheet_select_save[s].column[0] != str_c || luckysheet_select_save[s].column[1] != end_c){ + isSameCol = false; + } + } - $("#luckysheet-modal-dialog-pivotTable-list").find(".luckysheet-modal-dialog-slider-list-item").each(function () { - let $seleted = $(this).find(".luckysheet-slider-list-item-selected"); - if ($(this).data("index") == index && $seleted.find("i").length == 0) { - $seleted.append(''); + if((!isSameRow && !isSameCol) || selectIsOverlap()){ + if(isEditMode()){ + alert("无法对多重选择区域执行此操作"); } - }); + else{ + tooltip.info("无法对多重选择区域执行此操作", ""); + } + return; + } + } - }); + selection.copy(event); - pivotTable.refreshPivotTable(); + Store.luckysheet_paste_iscut = false; + luckysheetactiveCell(); + + event.stopPropagation(); + return; } - } - } + else if (kcode == 70) {//Ctrl + F 查找 + searchReplace.createDialog(0); + searchReplace.init(); - if (Store.luckysheet_sheet_move_status) { - Store.luckysheet_sheet_move_status = false; - Store.luckysheet_sheet_move_data.activeobject.insertBefore($("#luckysheet-sheets-item-clone")); - Store.luckysheet_sheet_move_data.activeobject.removeAttr("style"); - $("#luckysheet-sheets-item-clone").remove(); - Store.luckysheet_sheet_move_data.cursorobject.css({ "cursor": "pointer" }); - Store.luckysheet_sheet_move_data = {}; - sheetmanage.reOrderAllSheet(); - } + $("#luckysheet-search-replace #searchInput input").focus(); + } + else if (kcode == 72) {//Ctrl + H 替换 + searchReplace.createDialog(1); + searchReplace.init(); - if (!!formula.rangeResize) { - formula.rangeResizeDragged(event, formula.rangeResizeObj, formula.rangeResize, formula.rangeResizexy, formula.rangeResizeWinW, formula.rangeResizeWinH); - } + $("#luckysheet-search-replace #searchInput input").focus(); + } + else if (kcode == 73) {//Ctrl + I 斜体 + $("#luckysheet-icon-italic").click(); + } + else if (kcode == 86) {//Ctrl + V 粘贴 + if(isEditMode()){//此模式下禁用粘贴 + return; + } - //批注框 移动 - if (luckysheetPostil.move) { - luckysheetPostil.move = false; + if($(event.target).hasClass("formulaInputFocus")){ + return; + } - let ps_id = luckysheetPostil.currentObj.closest(".luckysheet-postil-show").attr("id"); + if(Store.luckysheet_select_save.length > 1){ + if(isEditMode()){ + alert("无法在此处粘贴此内容,请选择粘贴区域的一个单元格,然后再次尝试粘贴"); + } + else{ + tooltip.info("无法在此处粘贴此内容,请选择粘贴区域的一个单元格,然后再次尝试粘贴", ""); + } + return; + } - let ps_r = ps_id.split("luckysheet-postil-show_")[1].split("_")[0]; - let ps_c = ps_id.split("luckysheet-postil-show_")[1].split("_")[1]; + selection.isPasteAction = true; + luckysheetactiveCell(); - let d = editor.deepCopyFlowData(Store.flowdata); - let rc = []; + event.stopPropagation(); + return; + } + else if (kcode == 88) {//Ctrl + X 剪切 + //复制时存在格式刷状态,取消格式刷 + if(menuButton.luckysheetPaintModelOn){ + menuButton.cancelPaintModel(); + } - d[ps_r][ps_c].ps.left = luckysheetPostil.currentObj.position().left; - d[ps_r][ps_c].ps.top = luckysheetPostil.currentObj.position().top; - d[ps_r][ps_c].ps.value = luckysheetPostil.currentObj.find(".formulaInputFocus").text(); + if(Store.luckysheet_select_save.length == 0){ + return; + } - rc.push(ps_r + "_" + ps_c); + //复制范围内包含部分合并单元格,提示 + if(Store.config["merge"] != null){ + let has_PartMC = false; - luckysheetPostil.ref(d, rc); + for(let s = 0; s < Store.luckysheet_select_save.length; s++){ + let r1 = Store.luckysheet_select_save[s].row[0], + r2 = Store.luckysheet_select_save[s].row[1]; + let c1 = Store.luckysheet_select_save[s].column[0], + c2 = Store.luckysheet_select_save[s].column[1]; - $("#" + ps_id).remove(); + has_PartMC = hasPartMC(Store.config, r1, r2, c1, c2); - if(d[ps_r][ps_c].ps.isshow){ - luckysheetPostil.buildPs(ps_r, ps_c, d[ps_r][ps_c].ps); - $("#" + ps_id).addClass("luckysheet-postil-show-active"); - $("#" + ps_id).find(".luckysheet-postil-dialog-resize").show(); - } - else{ - luckysheetPostil.editPs(ps_r, ps_c); - } - } + if(has_PartMC){ + break; + } + } - //批注框 改变大小 - if (!!luckysheetPostil.resize) { - luckysheetPostil.resize = null; + if(has_PartMC){ + if(luckysheetConfigsetting.editMode){ + alert("无法对合并单元格执行此操作"); + } + else{ + tooltip.info("无法对合并单元格执行此操作", ""); + } + return; + } + } - let ps_id = luckysheetPostil.currentObj.closest(".luckysheet-postil-show").attr("id"); + //多重选区时 提示 + if(Store.luckysheet_select_save.length > 1){ + if(isEditMode()){ + alert("不能对多重选择区域执行此操作,请选择单个区域,然后再试"); + } + else{ + tooltip.info("不能对多重选择区域执行此操作,请选择单个区域,然后再试", ""); + } + return; + } - let ps_r = ps_id.split("luckysheet-postil-show_")[1].split("_")[0]; - let ps_c = ps_id.split("luckysheet-postil-show_")[1].split("_")[1]; + selection.copy(event); - let d = editor.deepCopyFlowData(Store.flowdata); - let rc = []; + Store.luckysheet_paste_iscut = true; + luckysheetactiveCell(); + + event.stopPropagation(); + return; + } + else if (kcode == 90) {//Ctrl + Z 撤销 + controlHistory.redo(event); + luckysheetactiveCell(); + event.stopPropagation(); + return; + } + else if (kcode == 89) {//Ctrl + Y 重做 + controlHistory.undo(event); + luckysheetactiveCell(); + event.stopPropagation(); + return; + } + else if (kcode == keycode.UP) {//Ctrl + up 调整单元格 + if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - d[ps_r][ps_c].ps.left = luckysheetPostil.currentObj.position().left; - d[ps_r][ps_c].ps.top = luckysheetPostil.currentObj.position().top; - d[ps_r][ps_c].ps.width = luckysheetPostil.currentObj.outerWidth(); - d[ps_r][ps_c].ps.height = luckysheetPostil.currentObj.outerHeight(); - d[ps_r][ps_c].ps.value = luckysheetPostil.currentObj.find(".formulaInputFocus").text(); + luckysheetMoveHighlightCell2("up", "rangeOfSelect"); + } + else if (kcode == keycode.DOWN) {//Ctrl + down 调整单元格 + if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - rc.push(ps_r + "_" + ps_c); + luckysheetMoveHighlightCell2("down", "rangeOfSelect"); + } + else if (kcode == keycode.LEFT) {//Ctrl + top 调整单元格 + if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - luckysheetPostil.ref(d, rc); + luckysheetMoveHighlightCell2("left", "rangeOfSelect"); + } + else if (kcode == keycode.RIGHT) {//Ctrl + right 调整单元格 + if (parseInt($inputbox.css("top")) > 0 || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - $("#" + ps_id).remove(); + luckysheetMoveHighlightCell2("right", "rangeOfSelect"); + } + else if (String.fromCharCode(kcode).toLocaleUpperCase() == "A") {//Ctrl + A 全选 + $("#luckysheet-left-top").trigger("mousedown"); + $(document).trigger("mouseup"); + } - if(d[ps_r][ps_c].ps.isshow){ - luckysheetPostil.buildPs(ps_r, ps_c, d[ps_r][ps_c].ps); - $("#" + ps_id).addClass("luckysheet-postil-show-active"); - $("#" + ps_id).find(".luckysheet-postil-dialog-resize").show(); - } - else{ - luckysheetPostil.editPs(ps_r, ps_c); + event.preventDefault(); + return; } - } + else if (shiftKey && (kcode == keycode.UP || kcode == keycode.DOWN || kcode == keycode.LEFT || kcode == keycode.RIGHT || (altKey && (kcode == 53 || kcode == 101)))) { + if (parseInt($inputbox.css("top")) > 0 || $(event.target).hasClass("formulaInputFocus")) { + return; + } - //改变行高 - if (Store.luckysheet_rows_change_size) { - Store.luckysheet_rows_change_size = false; + if (!luckysheet_shiftkeydown) { + Store.luckysheet_shiftpositon = $.extend(true, {}, Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]); + Store.luckysheet_shiftkeydown = true; + } + + //shift + 方向键 调整选区 + if (kcode == keycode.UP) { + if($("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")){ + return; + } - $("#luckysheet-change-size-line").hide(); - $("#luckysheet-rows-change-size").css("opacity", 0); - $("#luckysheet-sheettable, #luckysheet-rows-h, #luckysheet-rows-h canvas").css("cursor", "default"); + luckysheetMoveHighlightRange("down", -1, "rangeOfSelect"); + } + else if (kcode == keycode.DOWN) { + if($("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")){ + return; + } - let mouse = mouseposition(event.pageX, event.pageY); - let scrollTop = $("#luckysheet-rows-h").scrollTop(); - let y = mouse[1] + scrollTop; - let winH = $(window).height(); + luckysheetMoveHighlightRange("down", 1, "rangeOfSelect"); + } + else if (kcode == keycode.LEFT) { + if($("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")){ + return; + } - let row_location = rowLocation(y), - row = row_location[1], - row_pre = row_location[0], - row_index = row_location[2]; - - let size = (y + 3) - Store.luckysheet_rows_change_size_start[0]; + luckysheetMoveHighlightRange("right", -1, "rangeOfSelect"); + } + else if (kcode == keycode.RIGHT) { + if($("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")){ + return; + } + + luckysheetMoveHighlightRange("right", 1, "rangeOfSelect"); + } + else if (altKey && (kcode == 53 || kcode == 101)) { + //Alt + Shift + 5(删除线) + $("#luckysheet-icon-strikethrough").click(); + } - if ((y + 3) - Store.luckysheet_rows_change_size_start[0] < 19) { - size = 19; + event.preventDefault(); } + else if (kcode == keycode.ESC) { + if(menuButton.luckysheetPaintModelOn){ + menuButton.cancelPaintModel(); + } + else{ + cleargridelement(event); + event.preventDefault(); + } - if (y >= winH - 200 + scrollTop) { - size = winW - 200 - Store.luckysheet_rows_change_size_start[0] + scrollTop; + selectHightlightShow(); } + else if (kcode == keycode.DELETE) { + $("#luckysheet-delete-text").click(); - let cfg = $.extend(true, {}, Store.config); - if (cfg["rowlen"] == null) { - cfg["rowlen"] = {}; + event.preventDefault(); } + else if (kcode == keycode.UP) { + if (parseInt($inputbox.css("top")) > 0 || $(event.target).hasClass("formulaInputFocus") || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - cfg["rowlen"][Store.luckysheet_rows_change_size_start[1]] = Math.ceil(size); + luckysheetMoveHighlightCell("down", -1, "rangeOfSelect"); + event.preventDefault(); + } + else if (kcode == keycode.DOWN) { + if (parseInt($inputbox.css("top")) > 0 || $(event.target).hasClass("formulaInputFocus") || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - if (Store.clearjfundo) { - Store.jfundo = []; + luckysheetMoveHighlightCell("down", 1, "rangeOfSelect"); + event.preventDefault(); + } + else if (kcode == keycode.LEFT) { + if (parseInt($inputbox.css("top")) > 0 || $(event.target).hasClass("formulaInputFocus") || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - Store.jfredo.push({ - "type": "resize", - "ctrlType": "resizeR", - "config": $.extend(true, {}, Store.config), - "curconfig": $.extend(true, {}, cfg), - "sheetIndex": Store.currentSheetIndex - }); + luckysheetMoveHighlightCell("right", -1, "rangeOfSelect"); + event.preventDefault(); } + else if (kcode == keycode.RIGHT) { + if (parseInt($inputbox.css("top")) > 0 || $(event.target).hasClass("formulaInputFocus") || $("#luckysheet-singleRange-dialog").is(":visible") || $("#luckysheet-multiRange-dialog").is(":visible")) { + return; + } - //config - Store.config = cfg; - Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)].config = Store.config; + luckysheetMoveHighlightCell("right", 1, "rangeOfSelect"); + event.preventDefault(); + } + else if (!((kcode >= 112 && kcode <= 123) || kcode <= 46 || kcode == 144 || kcode == 108 || event.ctrlKey || event.altKey || (event.shiftKey && (kcode == 37 || kcode == 38 || kcode == 39 || kcode == 40))) || kcode == 8 || kcode == 32 || kcode == 46 || kcode == 0 || (event.ctrlKey && kcode == 86)) { + if (String.fromCharCode(kcode) != null && $("#luckysheet-cell-selected").is(":visible") && (kcode != keycode.CAPSLOCK && kcode != keycode.WIN && kcode != 18)) { + let last = Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]; - server.saveParam("cg", Store.currentSheetIndex, cfg["rowlen"], { "k": "rowlen" }); + let row_index = last["row_focus"], col_index = last["column_focus"]; + let row = Store.visibledatarow[row_index], + row_pre = row_index - 1 == -1 ? 0 : Store.visibledatarow[row_index - 1]; + let col = Store.visibledatacolumn[col_index], + col_pre = col_index - 1 == -1 ? 0 : Store.visibledatacolumn[col_index - 1]; + + let margeset = menuButton.mergeborer(Store.flowdata, row_index, col_index); + if(!!margeset){ + row = margeset.row[1]; + row_pre = margeset.row[0]; + row_index = margeset.row[2]; + col = margeset.column[1]; + col_pre = margeset.column[0]; + col_index = margeset.column[2]; + } - jfrefreshgrid_rhcw(Store.flowdata.length, null); + luckysheetupdateCell(row, row_pre, row_index, col, col_pre, col_index, Store.flowdata, true); + if(kcode == 8){ + $("#luckysheet-rich-text-editor").html("
"); + } + formula.functionInputHanddler($("#luckysheet-functionbox-cell"), $("#luckysheet-rich-text-editor"), kcode); + } + } } + + luckysheetactiveCell(); - //改变列宽 - if (Store.luckysheet_cols_change_size) { - Store.luckysheet_cols_change_size = false; - - $("#luckysheet-change-size-line").hide(); - $("#luckysheet-cols-change-size").css("opacity", 0); - $("#luckysheet-sheettable, #luckysheet-cols-h-c, .luckysheet-cols-h-cells, .luckysheet-cols-h-cells canvas").css("cursor", "default"); + event.stopPropagation(); + }); - let mouse = mouseposition(event.pageX, event.pageY); - let scrollLeft = $("#luckysheet-cols-h-c").scrollLeft(); - let x = mouse[0] + scrollLeft; - let winW = $(window).width(); + //右键菜单 复制按钮 + $("#luckysheet-copy-btn, #luckysheet-cols-copy-btn, #luckysheet-paste-btn-title").click(function (event) { + $(this).parent().hide(); - let row_index = Store.visibledatarow.length - 1, - row = Store.visibledatarow[row_index], - row_pre = 0; - let col_location = colLocation(x), - col = col_location[1], - col_pre = col_location[0], - col_index = col_location[2]; - - let size = (x + 3) - Store.luckysheet_cols_change_size_start[0]; + //复制范围内包含部分合并单元格,提示 + if(Store.config["merge"] != null){ + let has_PartMC = false; - let firstcolumlen = Store.defaultcollen; - if (Store.config["columlen"] != null && Store.config["columlen"][Store.luckysheet_cols_change_size_start[1]] != null) { - firstcolumlen = Store.config["columlen"][Store.luckysheet_cols_change_size_start[1]]; - } + for(let s = 0; s < Store.luckysheet_select_save.length; s++){ + let r1 = Store.luckysheet_select_save[s].row[0], + r2 = Store.luckysheet_select_save[s].row[1]; + let c1 = Store.luckysheet_select_save[s].column[0], + c2 = Store.luckysheet_select_save[s].column[1]; - if (Math.abs(size - firstcolumlen) < 3) { - return; - } - - if ((x + 3) - Store.luckysheet_cols_change_size_start[0] < 30) { - size = 30; - } + has_PartMC = hasPartMC(Store.config, r1, r2, c1, c2); - if (x >= winW - 100 + scrollLeft) { - size = winW - 100 - Store.luckysheet_cols_change_size_start[0] + scrollLeft; + if(has_PartMC){ + break; + } } - let cfg = $.extend(true, {}, Store.config); - if (cfg["columlen"] == null) { - cfg["columlen"] = {}; + if(has_PartMC){ + if(isEditMode()){ + alert("无法对部分合并单元格执行此操作"); + } + else{ + tooltip.info("无法对部分合并单元格执行此操作", ""); + } + return; } + } - cfg["columlen"][Store.luckysheet_cols_change_size_start[1]] = Math.ceil(size); - - if (Store.clearjfundo) { - Store.jfundo = []; - - Store.jfredo.push({ - "type": "resize", - "ctrlType": "resizeC", - "config": $.extend(true, {}, Store.config), - "curconfig": $.extend(true, {}, cfg), - "sheetIndex": Store.currentSheetIndex - }); - } + //多重选区 有条件格式时 提示 + let cdformat = Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)].luckysheet_conditionformat_save; + if(Store.luckysheet_select_save.length > 1 && cdformat != null && cdformat.length > 0){ + let hasCF = false; - //config - Store.config = cfg; - Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)].config = Store.config; + let cf_compute = conditionformat.getComputeMap(); - server.saveParam("cg", Store.currentSheetIndex, cfg["columlen"], { "k": "columlen" }); + label: + for(let s = 0; s < Store.luckysheet_select_save.length; s++){ + if(hasCF){ + break; + } + + let r1 = Store.luckysheet_select_save[s].row[0], + r2 = Store.luckysheet_select_save[s].row[1]; + let c1 = Store.luckysheet_select_save[s].column[0], + c2 = Store.luckysheet_select_save[s].column[1]; - jfrefreshgrid_rhcw(null, Store.flowdata[0].length); + for(let r = r1; r <= r2; r++){ + for(let c = c1; c <= c2; c++){ + if(conditionformat.checksCF(r, c, cf_compute) != null){ + hasCF = true; + continue label; + } + } + } + } - setTimeout(function () { - luckysheetrefreshgrid(); - }, 1); + if(hasCF){ + if(isEditMode()){ + alert("无法对多重选择区域执行此操作"); + } + else{ + tooltip.info("无法对多重选择区域执行此操作", ""); + } + return; + } } - if (formula.rangeMove) { - formula.rangeMoveDragged(formula.rangeMoveObj); + //多重选区 行不一样且列不一样时 提示 + if(Store.luckysheet_select_save.length > 1){ + let isSameRow = true, + str_r = Store.luckysheet_select_save[0].row[0], + end_r = Store.luckysheet_select_save[0].row[1]; + let isSameCol = true, + str_c = Store.luckysheet_select_save[0].column[0], + end_c = Store.luckysheet_select_save[0].column[1]; + + for(let s = 1; s < Store.luckysheet_select_save.length; s++){ + if(Store.luckysheet_select_save[s].row[0] != str_r || Store.luckysheet_select_save[s].row[1] != end_r){ + isSameRow = false; + } + if(Store.luckysheet_select_save[s].column[0] != str_c || Store.luckysheet_select_save[s].column[1] != end_c){ + isSameCol = false; + } + } + + if((!isSameRow && !isSameCol) || selectIsOverlap()){ + if(isEditMode()){ + alert("无法对多重选择区域执行此操作"); + } + else{ + tooltip.info("无法对多重选择区域执行此操作", ""); + } + return; + } } + + selection.copy(event); + }); - //改变选择框的位置并替换目标单元格 - if (Store.luckysheet_cell_selected_move) { - $("#luckysheet-cell-selected-move").hide(); + //右键菜单 粘贴按钮 + $("#luckysheet-copy-paste, #luckysheet-cols-paste-btn, #luckysheet-paste-btn-title").click(function (event) { + selection.paste(event, "btn"); + $(this).parent().hide(); + }); - Store.luckysheet_cell_selected_move = false; - let mouse = mouseposition(event.pageX, event.pageY); + //菜单栏 图表按钮 + $("#luckysheet-chart-btn-title").click(function () { + $("#luckysheetdatavisual").click(); + }); - let scrollLeft = $("#luckysheet-cell-main").scrollLeft(); - let scrollTop = $("#luckysheet-cell-main").scrollTop(); + //菜单栏 数据透视表 + $("#luckysheet-pivot-btn-title").click(function (e) { + pivotTable.createPivotTable(e); + }); - let x = mouse[0] + scrollLeft; - let y = mouse[1] + scrollTop; + //菜单栏 截图按钮 + $("#luckysheet-chart-btn-screenshot").click(function () { + if(Store.luckysheet_select_save.length == 0){ + if(isEditMode()){ + alert("请框选需要截图的范围"); + } + else{ + tooltip.info("提示!", "请框选需要截图的范围"); + } + return; + } - let winH = $(window).height() + scrollTop - Store.sheetBarHeight - Store.statisticBarHeight, - winW = $(window).width() + scrollLeft; + if(Store.luckysheet_select_save.length > 1){ + if(isEditMode()){ + alert("无法对多重选择区域执行此操作"); + } + else{ + tooltip.info("提示!", "无法对多重选择区域执行此操作"); + } - let row_index = rowLocation(y)[2]; - let col_index = colLocation(x)[2]; + return; + } - let row_index_original = Store.luckysheet_cell_selected_move_index[0], - col_index_original = Store.luckysheet_cell_selected_move_index[1]; + //复制范围内包含部分合并单元格,提示 + if(Store.config["merge"] != null){ + let has_PartMC = false; - if(row_index == row_index_original && col_index == col_index_original){ - return; - } + for(let s = 0; s < Store.luckysheet_select_save.length; s++){ + let r1 = Store.luckysheet_select_save[s].row[0], + r2 = Store.luckysheet_select_save[s].row[1]; + let c1 = Store.luckysheet_select_save[s].column[0], + c2 = Store.luckysheet_select_save[s].column[1]; - let d = editor.deepCopyFlowData(Store.flowdata); - let last = Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]; - - let data = getdatabyselection(last); + has_PartMC = hasPartMC(Store.config, r1, r2, c1, c2); - let cfg = $.extend(true, {}, Store.config); - if(cfg["merge"] == null){ - cfg["merge"] = {}; - } - if(cfg["rowlen"] == null){ - cfg["rowlen"] = {}; + if(has_PartMC){ + break; + } } - //选区包含部分单元格 - if(hasPartMC(cfg, last["row"][0], last["row"][1], last["column"][0], last["column"][1])){ + if(has_PartMC){ if(isEditMode()){ alert("无法对合并单元格执行此操作"); } else{ - tooltip.info('提示',"无法对合并单元格执行此操作"); + tooltip.info("提示!", "无法对合并单元格执行此操作"); } - return; + return; } + } - let row_s = last["row"][0] - row_index_original + row_index, - row_e = last["row"][1] - row_index_original + row_index; - let col_s = last["column"][0] - col_index_original + col_index, - col_e = last["column"][1] - col_index_original + col_index; - - if (row_s < 0 || y < 0) { - row_s = 0; - row_e = last["row"][1] - last["row"][0]; - } + let st_r = Store.luckysheet_select_save[0].row[0], + ed_r = Store.luckysheet_select_save[0].row[1]; + let st_c = Store.luckysheet_select_save[0].column[0], + ed_c = Store.luckysheet_select_save[0].column[1]; - if (col_s < 0 || x < 0) { - col_s = 0; - col_e = last["column"][1] - last["column"][0]; - } + let shotData = datagridgrowth([], ed_r + 1, ed_c + 1); - if (row_e >= Store.visibledatarow[Store.visibledatarow.length - 1] || y > winH) { - row_s = Store.visibledatarow.length - 1 - last["row"][1] + last["row"][0]; - row_e = Store.visibledatarow.length - 1; + for(let r = st_r; r <= ed_r; r++){ + for(let c = st_c; c <= ed_c; c++){ + shotData[r][c] = Store.flowdata[r][c]; } + } - if (col_e >= Store.visibledatacolumn[Store.visibledatacolumn.length - 1] || x > winW) { - col_s = Store.visibledatacolumn.length - 1 - last["column"][1] + last["column"][0]; - col_e = Store.visibledatacolumn.length - 1; - } + let scrollHeight, rh_height; + if(st_r - 1 < 0){ + scrollHeight = 0; + rh_height = Store.visibledatarow[ed_r]; + } + else{ + scrollHeight = Store.visibledatarow[st_r - 1]; + rh_height = Store.visibledatarow[ed_r] - Store.visibledatarow[st_r - 1]; + } - //替换的位置包含部分单元格 - if(hasPartMC(cfg, row_s, row_e, col_s, col_e)){ - if(isEditMode()){ - alert("无法对合并单元格执行此操作"); - } - else{ - tooltip.info('提示',"无法对合并单元格执行此操作"); - } - return; - } + let scrollWidth, ch_width; + if(st_c - 1 < 0){ + scrollWidth = 0; + ch_width = Store.visibledatacolumn[ed_c]; + } + else{ + scrollWidth = Store.visibledatacolumn[st_c - 1]; + ch_width = Store.visibledatacolumn[ed_c] - Store.visibledatacolumn[st_c - 1]; + } - let borderInfoCompute = getBorderInfoCompute(Store.currentSheetIndex); + let newCanvas = $("").attr({ + width: Math.ceil(ch_width * devicePixelRatio), + height: Math.ceil(rh_height * devicePixelRatio) + }).css({ width: ch_width, height: rh_height }); - //删除原本位置的数据 - let RowlChange = null; - for (let r = last["row"][0]; r <= last["row"][1]; r++) { - if(r in cfg["rowlen"]){ - RowlChange = true; - } + let d = Store.flowdata; + Store.flowdata = shotData; - for (let c = last["column"][0]; c <= last["column"][1]; c++) { - let cell = d[r][c]; + luckysheetDrawMain(scrollWidth, scrollHeight, ch_width, rh_height, 1, 1, null, null, newCanvas); - if(getObjType(cell) == "object" && ("mc" in cell)){ - if((cell["mc"].r + "_" + cell["mc"].c) in cfg["merge"]){ - delete cfg["merge"][cell["mc"].r + "_" + cell["mc"].c]; - } - } + Store.flowdata = d; + editor.webWorkerFlowDataCache(Store.flowdata);//worker存数据 - d[r][c] = null; - } - } + let image = new Image(); + let url = newCanvas.get(0).toDataURL("image/png"); + image.src = url; - //边框 - if(cfg["borderInfo"] && cfg["borderInfo"].length > 0){ - let borderInfo = []; + if(ch_width > rh_height){ + image.style.width = "100%"; + } + else{ + image.style.height = "100%"; + } - for(let i = 0; i < cfg["borderInfo"].length; i++){ - let bd_rangeType = cfg["borderInfo"][i].rangeType; + let maxHeight = $(window).height() - 200; + tooltip.screenshot("截取成功!", '
', url); + $("#luckysheet-confirm-screenshot-save").append(image); + newCanvas.remove(); + }); - if(bd_rangeType == "range"){ - let bd_range = cfg["borderInfo"][i].range; - let bd_emptyRange = []; + //截图下载 + $(document).on("click", "a.download", function(){ + let dataURI = $("#luckysheet-confirm-screenshot-save img").attr("src"); - for(let j = 0; j < bd_range.length; j++){ - bd_emptyRange = bd_emptyRange.concat(conditionformat.CFSplitRange(bd_range[j], {"row": last["row"], "column": last["column"]}, {"row": [row_s, row_e], "column": [col_s, col_e]}, "restPart")); - } + let binStr = atob(dataURI.split(",")[1]), + len = binStr.length, + arr = new Uint8Array(len); - cfg["borderInfo"][i].range = bd_emptyRange; + for(let i = 0; i < len; i++){ + arr[i] = binStr.charCodeAt(i); + } - borderInfo.push(cfg["borderInfo"][i]); - } - else if(bd_rangeType == "cell"){ - let bd_r = cfg["borderInfo"][i].value.row_index; - let bd_c = cfg["borderInfo"][i].value.col_index; + let blob = new Blob([arr]); - if(!(bd_r >= last["row"][0] && bd_r <= last["row"][1] && bd_c >= last["column"][0] && bd_c <= last["column"][1])){ - borderInfo.push(cfg["borderInfo"][i]); - } - } - } + let element = document.createElement('a'); + element.setAttribute('href', URL.createObjectURL(blob)); + element.setAttribute('download', '截图.png'); - cfg["borderInfo"] = borderInfo; - } - - //替换位置数据更新 - let offsetMC = {}; - for (let r = 0; r < data.length; r++) { - for (let c = 0; c < data[0].length; c++) { - if(borderInfoCompute[(r + last["row"][0]) + "_" + (c + last["column"][0])]){ - let bd_obj = { - "rangeType": "cell", - "value": { - "row_index": r + row_s, - "col_index": c + col_s, - "l": borderInfoCompute[(r + last["row"][0]) + "_" + (c + last["column"][0])].l, - "r": borderInfoCompute[(r + last["row"][0]) + "_" + (c + last["column"][0])].r, - "t": borderInfoCompute[(r + last["row"][0]) + "_" + (c + last["column"][0])].t, - "b": borderInfoCompute[(r + last["row"][0]) + "_" + (c + last["column"][0])].b - } - } + element.style.display = 'none'; + document.body.appendChild(element); + + element.click(); - if(cfg["borderInfo"] == null){ - cfg["borderInfo"] = []; - } + let clickHandler; + element.addEventListener('click', clickHandler = function(){ + requestAnimationFrame(function(){ + URL.revokeObjectURL(element.href); + }); - cfg["borderInfo"].push(bd_obj); - } + element.removeAttribute('href'); + element.removeEventListener('click', clickHandler); + }) - let value = ""; - if (data[r] != null && data[r][c] != null) { - value = data[r][c]; - } + document.body.removeChild(element); + }) + + //菜单栏 分列按钮 + $("#luckysheet-splitColumn-btn-title").click(function(){ + if(Store.luckysheet_select_save == null || Store.luckysheet_select_save.length == 0){ + return; + } - if(getObjType(value) == "object" && ("mc" in value)){ - let mc = $.extend(true, {}, value["mc"]); - if("rs" in value["mc"]){ - offsetMC[mc.r + "_" + mc.c] = [r + row_s, c + col_s]; + if(Store.luckysheet_select_save.length > 1){ + tooltip.info("不能对多重选择区域执行此操作,请选择单个区域,然后再试", ""); + return; + } - value["mc"].r = r + row_s; - value["mc"].c = c + col_s; + if(Store.luckysheet_select_save[0].column[0] != Store.luckysheet_select_save[0].column[1]){ + tooltip.info("一次只能转换一列数据,选定区域可以有多行,但不能有多列,请在选定单列区域以后再试", ""); + return; + } - cfg["merge"][(r + row_s) + "_" + (c + col_s)] = value["mc"]; - } - else{ - value["mc"].r = offsetMC[mc.r + "_" + mc.c][0]; - value["mc"].c = offsetMC[mc.r + "_" + mc.c][1]; - } - } - d[r + row_s][c + col_s] = value; - } - } + splitColumn.createDialog(); + splitColumn.init(); + }); - if(RowlChange){ - cfg = rowlenByRange(d, last["row"][0], last["row"][1], cfg); - cfg = rowlenByRange(d, row_s, row_e, cfg); + //冻结行列 + $("#luckysheet-freezen-btn-horizontal").click(function () { + if($.trim($(this).text())=="取消冻结"){ + if (luckysheetFreezen.freezenverticaldata != null) { + luckysheetFreezen.cancelFreezenVertical(); + luckysheetFreezen.createAssistCanvas(); + luckysheetrefreshgrid(); } - //条件格式 - let cdformat = $.extend(true, [], Store.luckysheetfile[getSheetIndex(Store.currentSheetIndex)]["luckysheet_conditionformat_save"]); - if(cdformat != null && cdformat.length > 0){ - for(let i = 0; i < cdformat.length; i++){ - let cdformat_cellrange = cdformat[i].cellrange; - let emptyRange = []; - for(let j = 0; j < cdformat_cellrange.length; j++){ - let range = conditionformat.CFSplitRange(cdformat_cellrange[j], {"row": last["row"], "column": last["column"]}, {"row": [row_s, row_e], "column": [col_s, col_e]}, "allPart"); - emptyRange = emptyRange.concat(range); - } - cdformat[i].cellrange = emptyRange; - } + if (luckysheetFreezen.freezenhorizontaldata != null) { + luckysheetFreezen.cancelFreezenHorizontal(); + luckysheetFreezen.createAssistCanvas(); + luckysheetrefreshgrid(); } - let rf; - if(Store.luckysheet_select_save[0].row_focus == Store.luckysheet_select_save[0].row[0]){ - rf = row_s; + luckysheetFreezen.scrollAdapt(); + } + else{ + if (luckysheetFreezen.freezenverticaldata != null) { + luckysheetFreezen.cancelFreezenVertical(); + luckysheetFreezen.createAssistCanvas(); + luckysheetrefreshgrid(); } - else{ - rf = row_e; + + if (luckysheetFreezen.freezenhorizontaldata == null) { + luckysheetFreezen.createFreezenHorizontal(); + luckysheetFreezen.createAssistCanvas(); } + } + }); - let cf; - if(Store.luckysheet_select_save[0].column_focus == Store.luckysheet_select_save[0].column[0]){ - cf = col_s; + $("#luckysheet-freezen-btn-vertical").click(function () { + if (luckysheetFreezen.freezenverticaldata != null) { + luckysheetFreezen.cancelFreezenVertical(); + luckysheetrefreshgrid(); + } + else { + luckysheetFreezen.createFreezenVertical(); + } + luckysheetFreezen.createAssistCanvas(); + }); + + //右键菜单 菜单项hover + let submenuhide = null, rightclickmenu = null; + $(".luckysheet-cols-menu .luckysheet-cols-submenu").hover( + function () { + let $t = $(this), attrid = $t.attr("id"), $attr = $("#" + attrid + "_sub"), $con = $t.parent(); + let winW = $(window).width(), winH = $(window).height(); + let menuW = $con.width(), attrH = $attr.height() + 25, attrW = $attr.width() + 5; + let offset = $t.offset(); + let top = offset.top, left = offset.left + menuW; + + if (left + attrW > winW) { + left = offset.left - attrW; } - else{ - cf = col_e; + + if (top + attrH > winH) { + top = winH - attrH; } - let range = []; - range.push({ "row": last["row"], "column": last["column"] }); - range.push({ "row": [row_s, row_e], "column": [col_s, col_e] }); + $attr.css({ "top": top, "left": left }).show(); + rightclickmenu = $t; + }, + function () { + let $t = $(this), attrid = $t.attr("id"), $attr = $("#" + attrid + "_sub"); + submenuhide = setTimeout(function () { $attr.hide(); }, 200); + } + ); - last["row"] = [row_s, row_e]; - last["column"] = [col_s, col_e]; - last["row_focus"] = rf; - last["column_focus"] = cf; + $(".luckysheet-rightgclick-menu-sub").hover( + function () { + rightclickmenu.addClass("luckysheet-cols-menuitem-hover"); + clearTimeout(submenuhide); + }, + function () { + rightclickmenu.removeClass("luckysheet-cols-menuitem-hover"); + $(this).hide(); + } + ); - jfrefreshgrid(d, range, cfg, cdformat, RowlChange); + $("#luckysheet-rightclick-menu input").on("keydown", function (e) { + e.stopPropagation(); + }); - selectHightlightShow(); + $("#luckysheet-modal-dialog-mask").on("click dbclick mousedown mousemove mouseup", function (e) { + e.stopPropagation(); + e.preventDefault(); + }); - $("#luckysheet-sheettable").css("cursor", "default"); - clearTimeout(Store.countfuncTimeout); - Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); + let copychange = function () { + if (document.hidden || document.webkitHidden || document.msHidden) { + Store.iscopyself = false; } + } - //选区下拉 - if (Store.luckysheet_cell_selected_extend) { - Store.luckysheet_cell_selected_extend = false; - $("#luckysheet-cell-selected-extend").hide(); + $(document).on("visibilitychange webkitvisibilitychange msvisibilitychange", copychange).mouseleave(function () { + Store.iscopyself = false; + }).mousedown(function (event) { + //有批注在编辑时 + luckysheetPostil.removeActivePs(); - let mouse = mouseposition(event.pageX, event.pageY); - let scrollLeft = $("#luckysheet-cell-main").scrollLeft(); - let scrollTop = $("#luckysheet-cell-main").scrollTop(); + if (!$(event.target).hasClass("luckysheet-mousedown-cancel") && $(event.target).filter("[class*='sp-palette']").length == 0 && $(event.target).filter("[class*='sp-thumb']").length == 0 && $(event.target).filter("[class*='sp-']").length == 0) { + $("#luckysheet-rightclick-menu").hide(); + $("#luckysheet-cols-h-hover").hide(); + $("#luckysheet-cols-menu-btn").hide(); + $("#luckysheet-rightclick-menu").hide(); + $("#luckysheet-sheet-list, #luckysheet-rightclick-sheet-menu, #luckysheet-user-menu").hide(); + $("body > .luckysheet-filter-menu, body > .luckysheet-filter-submenu, body > .luckysheet-cols-menu").hide(); + //$("body > luckysheet-menuButton").hide(); + Store.luckysheet_cols_menu_status = false; + } - let x = mouse[0] + scrollLeft - 5; - let y = mouse[1] + scrollTop - 5; + //点击功能栏时 如果是单元格编辑模式 则退出编辑模式 + if($(event.target).closest("#luckysheet-wa-editor").length > 0 && parseInt($("#luckysheet-input-box").css("top")) > 0){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("down", 0, "rangeOfSelect"); + } + }); - let winH = $(window).height() + scrollTop - Store.sheetBarHeight - Store.statisticBarHeight, - winW = $(window).width() + scrollLeft; + //单元格编辑 keydown (公式 上下左右键移动) + $("#" + Store.container).add("#luckysheet-input-box").keydown(function (event) { + if ($("#luckysheet-modal-dialog-mask").is(":visible") || $(event.target).hasClass("luckysheet-mousedown-cancel") || $(event.target).hasClass("formulaInputFocus")) { + return; + } - let row_location = rowLocation(y), - row = row_location[1], - row_pre = row_location[0], - row_index = row_location[2]; - let col_location = colLocation(x), - col = col_location[1], - col_pre = col_location[0], - col_index = col_location[2]; + let ctrlKey = event.ctrlKey; + let altKey = event.altKey; + let shiftKey = event.shiftKey; + let kcode = event.keyCode; + + let $inputbox = $("#luckysheet-input-box"); + if (kcode == keycode.ESC && parseInt($("#luckysheet-input-box").css("top")) > 0) { + formula.dontupdate(); + luckysheetMoveHighlightCell("down", 0, "rangeOfSelect"); + event.preventDefault(); + } + else if (kcode == keycode.ENTER && parseInt($inputbox.css("top")) > 0) { + if ($("#luckysheet-formula-search-c").is(":visible") && formula.searchFunctionCell != null) { + formula.searchFunctionEnter($("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item-active")); + event.preventDefault(); + } + } + else if(kcode == keycode.TAB && parseInt($inputbox.css("top")) > 0){ + if ($("#luckysheet-formula-search-c").is(":visible") && formula.searchFunctionCell != null) { + formula.searchFunctionEnter($("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item-active")); + } + else{ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("right", 1, "rangeOfSelect"); + } + + event.preventDefault(); + } + else if (kcode == keycode.F4 && parseInt($inputbox.css("top")) > 0) { + formula.setfreezonFuc(event); + event.preventDefault(); + } + else if (kcode == keycode.UP && parseInt($inputbox.css("top")) > 0) { + formulaMoveEvent("up", ctrlKey, shiftKey); + } + else if (kcode == keycode.DOWN && parseInt($inputbox.css("top")) > 0) { + formulaMoveEvent("down", ctrlKey, shiftKey); + } + else if (kcode == keycode.LEFT && parseInt($inputbox.css("top")) > 0) { + formulaMoveEvent("left", ctrlKey, shiftKey); + } + else if (kcode == keycode.RIGHT && parseInt($inputbox.css("top")) > 0) { + formulaMoveEvent("right", ctrlKey, shiftKey); + } + else if (!((kcode >= 112 && kcode <= 123) || kcode <= 46 || kcode == 144 || kcode == 108 || event.ctrlKey || event.altKey || (event.shiftKey && (kcode == 37 || kcode == 38 || kcode == 39 || kcode == 40))) || kcode == 8 || kcode == 32 || kcode == 46 || (event.ctrlKey && kcode == 86)) { + formula.functionInputHanddler($("#luckysheet-functionbox-cell"), $("#luckysheet-rich-text-editor"), kcode); + } + }).keyup(function (e) { + let kcode = e.keyCode; + + if (!e.shiftKey && kcode == 16) { + Store.luckysheet_shiftkeydown = false; + Store.luckysheet_shiftpositon = null; + } - let row_index_original = Store.luckysheet_cell_selected_extend_index[0], - col_index_original = Store.luckysheet_cell_selected_extend_index[1]; + //输入框中文输入后 shift 和 空格 处理 + if(parseInt($("#luckysheet-input-box").css("top")) > 0 && (kcode == 13 || kcode == 16 || kcode == 32)){ + formula.functionInputHanddler($("#luckysheet-functionbox-cell"), $("#luckysheet-rich-text-editor"), kcode); + } - let last = Store.luckysheet_select_save[Store.luckysheet_select_save.length - 1]; - let row_s = last["row"][0], row_e = last["row"][1]; - let col_s = last["column"][0], col_e = last["column"][1]; + e.preventDefault(); + }); - if (row_s < 0 || y < 0) { - row_s = 0; - row_e = last["row"][1] - last["row"][0]; + function formulaMoveEvent(dir, ctrlKey, shiftKey){ + if ($("#luckysheet-formula-search-c").is(":visible")) { + let $up = $("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item-active").next(); + if ($up.length == 0) { + $up = $("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item").first(); } - if (col_s < 0 || x < 0) { - col_s = 0; - col_e = last["column"][1] - last["column"][0]; - } + $("#luckysheet-formula-search-c").find(".luckysheet-formula-search-item").removeClass("luckysheet-formula-search-item-active"); + $up.addClass("luckysheet-formula-search-item-active"); - if (row_e >= Store.visibledatarow[Store.visibledatarow.length - 1] || y > winH) { - row_s = Store.visibledatarow.length - 1 - last["row"][1] + last["row"][0]; - row_e = Store.visibledatarow.length - 1; - } + event.preventDefault(); + } + else{ + if($("#luckysheet-formula-functionrange-select").is(":visible")){ + if(ctrlKey && shiftKey){ + luckysheetMoveHighlightRange2(dir, "rangeOfFormula"); + } + else if(ctrlKey){ + luckysheetMoveHighlightCell2(dir, "rangeOfFormula"); + } + else if(shiftKey){ + let dir_n = dir, step = 1; + if(dir == 'up'){ + dir_n = 'down'; + step = -1; + } + if(dir == 'left'){ + dir_n = 'right'; + step = -1; + } - if (col_e >= Store.visibledatacolumn[Store.visibledatacolumn.length - 1] || x > winW) { - col_s = Store.visibledatacolumn.length - 1 - last["column"][1] + last["column"][0]; - col_e = Store.visibledatacolumn.length - 1; - } + luckysheetMoveHighlightRange(dir_n, step, "rangeOfFormula"); + } + else{ + let dir_n = dir, step = 1; + if(dir == 'up'){ + dir_n = 'down'; + step = -1; + } + if(dir == 'left'){ + dir_n = 'right'; + step = -1; + } - //复制范围 - luckysheetDropCell.copyRange = {"row": $.extend(true, [], last["row"]), "column": $.extend(true, [], last["column"])}; - //applyType - let typeItemHide = luckysheetDropCell.typeItemHide(); - - if(!typeItemHide[0] && !typeItemHide[1] && !typeItemHide[2] && !typeItemHide[3] && !typeItemHide[4] && !typeItemHide[5] && !typeItemHide[6]){ - luckysheetDropCell.applyType = "0"; - } - else{ - luckysheetDropCell.applyType = "1"; + luckysheetMoveHighlightCell(dir_n, step, "rangeOfFormula"); + } } + else if(formula.israngeseleciton()){ + let anchor = $(window.getSelection().anchorNode); + + if(anchor.parent().next().text() == null || anchor.parent().next().text() == ""){ + let vText = $("#luckysheet-input-box #luckysheet-input-box-index").text(); + let range = formula.getcellrange(vText); - if (Math.abs(row_index_original - row_index) > Math.abs(col_index_original - col_index)) { - if (!(row_index >= row_s && row_index <= row_e)) { - if (Store.luckysheet_select_save[0].top_move >= row_pre) {//当往上拖拽时 - luckysheetDropCell.applyRange = {"row": [row_index, last["row"][0] - 1], "column": last["column"]}; - luckysheetDropCell.direction = "up"; + if(range == null){ + range = formula.getcellrange($("#luckysheet-input-box-index").text()); + } - row_s -= last["row"][0] - row_index; + let r1 = range["row"][0], r2 = range["row"][1]; + let c1 = range["column"][0], c2 = range["column"][1]; - //是否有数据透视表范围 - if(pivotTable.isPivotRange(row_s, col_e)){ - tooltip.info("无法对所选单元格进行此更改,因为它会影响数据透视表!",""); - return; - } - } - else {//当往下拖拽时 - luckysheetDropCell.applyRange = {"row": [last["row"][1] + 1, row_index], "column": last["column"]}; - luckysheetDropCell.direction = "down"; + let row = Store.visibledatarow[r2], + row_pre = r1 - 1 == -1 ? 0 : Store.visibledatarow[r1 - 1]; + let col = Store.visibledatacolumn[c2], + col_pre = c1 - 1 == -1 ? 0 : Store.visibledatacolumn[c1 - 1]; - row_e += row_index - last["row"][1]; + formula.func_selectedrange = { + "left": col_pre, + "width": col - col_pre - 1, + "top": row_pre, + "height": row - row_pre - 1, + "left_move": col_pre, + "width_move": col - col_pre - 1, + "top_move": row_pre, + "height_move": row - row_pre - 1, + "row": [r1, r2], + "column": [c1, c2], + "row_focus": r1, + "column_focus": c1 + }; - //是否有数据透视表范围 - if(pivotTable.isPivotRange(row_e, col_e)){ - tooltip.info("无法对所选单元格进行此更改,因为它会影响数据透视表!",""); - return; + formula.rangeSetValue({ "row": [r1, r2], "column": [c1, c2] }); + + formula.rangestart = true; + formula.rangedrag_column_start = false; + formula.rangedrag_row_start = false; + + if(ctrlKey && shiftKey){ + luckysheetMoveHighlightRange2(dir, "rangeOfFormula"); + } + else if(ctrlKey){ + luckysheetMoveHighlightCell2(dir, "rangeOfFormula"); + } + else if(shiftKey){ + let dir_n = dir, step = 1; + if(dir == 'up'){ + dir_n = 'down'; + step = -1; + } + if(dir == 'left'){ + dir_n = 'right'; + step = -1; } + + luckysheetMoveHighlightRange(dir_n, step, "rangeOfFormula"); } - } - else{ - return; + else{ + let dir_n = dir, step = 1; + if(dir == 'up'){ + dir_n = 'down'; + step = -1; + } + if(dir == 'left'){ + dir_n = 'right'; + step = -1; + } + + luckysheetMoveHighlightCell(dir_n, step, "rangeOfFormula"); + } } } - else { - if (!(col_index >= col_s && col_index <= col_e)) { - if (Store.luckysheet_select_save[0].left_move >= col_pre) {//当往左拖拽时 - luckysheetDropCell.applyRange = {"row": last["row"], "column": [col_index, last["column"][0] - 1]}; - luckysheetDropCell.direction = "left"; + else if(!ctrlKey && !shiftKey){ + let anchor = $(window.getSelection().anchorNode); + let anchorOffset = window.getSelection().anchorOffset; - col_s -= last["column"][0] - col_index; + if(dir == 'up'){ + if(anchor.parent().is("span") && anchor.parent().next().length == 0 && anchorOffset > 0){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("down", -1, "rangeOfSelect"); - //是否有数据透视表范围 - if(pivotTable.isPivotRange(row_e, col_s)){ - tooltip.info("无法对所选单元格进行此更改,因为它会影响数据透视表!",""); - return; - } + event.preventDefault(); } - else {//当往右拖拽时 - luckysheetDropCell.applyRange = {"row": last["row"], "column": [last["column"][1] + 1, col_index]}; - luckysheetDropCell.direction = "right"; + else if(anchor.is("#luckysheet-rich-text-editor") && anchor.context.childElementCount == anchorOffset){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("down", -1, "rangeOfSelect"); - col_e += col_index - last["column"][1]; + event.preventDefault(); + } + else if(anchor.parent().is("#luckysheet-rich-text-editor") && anchor.context.length == anchorOffset){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("down", -1, "rangeOfSelect"); - //是否有数据透视表范围 - if(pivotTable.isPivotRange(row_e, col_e)){ - tooltip.info("无法对所选单元格进行此更改,因为它会影响数据透视表!",""); - return; - } + event.preventDefault(); } } - else{ - return; - } - } + else if(dir == 'down'){ + if(anchor.parent().is("span") && anchor.parent().next().length == 0 && anchorOffset > 0){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("down", 1, "rangeOfSelect"); - if(Store.config["merge"] != null){ - let hasMc = false; + event.preventDefault(); + } + else if(anchor.is("#luckysheet-rich-text-editor") && anchor.context.childElementCount == anchorOffset){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("down", 1, "rangeOfSelect"); - for(let r = last["row"][0]; r <= last["row"][1]; r++){ - for(let c = last["column"][0]; c <= last["column"][1]; c++){ - let cell = Store.flowdata[r][c]; + event.preventDefault(); + } + else if(anchor.parent().is("#luckysheet-rich-text-editor") && anchor.context.length == anchorOffset){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("down", 1, "rangeOfSelect"); - if(cell != null && cell.mc != null){ - hasMc = true; - break; - } + event.preventDefault(); } } + else if(dir == 'left'){ + if(anchor.parent().is("span") && anchor.parent().prev().length == 0 && anchorOffset == 0){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("right", -1, "rangeOfSelect"); - if(hasMc){ - if(isEditMode()){ - alert("无法对合并单元格执行此操作"); + event.preventDefault(); } - else{ - tooltip.info("无法对合并单元格执行此操作", ""); - } - - return; - } + else if(anchor.is("#luckysheet-rich-text-editor") && anchorOffset == 1){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("right", -1, "rangeOfSelect"); - for(let r = row_s; r <= row_e; r++){ - for(let c = col_s; c <= col_e; c++){ - let cell = Store.flowdata[r][c]; + event.preventDefault(); + } + else if(anchor.parent().is("#luckysheet-rich-text-editor") && anchorOffset == 0){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("right", -1, "rangeOfSelect"); - if(cell != null && cell.mc != null){ - hasMc = true; - break; - } + event.preventDefault(); } } + else if(dir == 'right'){ + if(anchor.parent().is("span") && anchor.parent().next().length == 0 && anchorOffset > 0){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("right", 1, "rangeOfSelect"); - if(hasMc){ - if(isEditMode()){ - alert("无法对合并单元格执行此操作"); + event.preventDefault(); } - else{ - tooltip.info("无法对合并单元格执行此操作", ""); + else if(anchor.is("#luckysheet-rich-text-editor") && anchor.context.childElementCount == anchorOffset){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("right", 1, "rangeOfSelect"); + + event.preventDefault(); } + else if(anchor.parent().is("#luckysheet-rich-text-editor") && anchor.context.length == anchorOffset){ + formula.updatecell(Store.luckysheetCellUpdate[0], Store.luckysheetCellUpdate[1]); + luckysheetMoveHighlightCell("right", 1, "rangeOfSelect"); - return; + event.preventDefault(); + } } } - - last["row"] = [row_s, row_e]; - last["column"] = [col_s, col_e]; - - luckysheetDropCell.update(); - luckysheetDropCell.createIcon(); - - $("#luckysheet-cell-selected-move").hide(); - - $("#luckysheet-sheettable").css("cursor", "default"); - clearTimeout(Store.countfuncTimeout); - Store.countfuncTimeout = setTimeout(function () { countfunc() }, 500); } - }); + } //表格左上角点击 全选表格 $("#luckysheet-left-top").mousedown(function (event) { @@ -6651,8 +6718,8 @@ export default function luckysheetHandler() { }); $("#luckysheetsheetconfigmoveleft").click(function () { - if (luckysheetcurrentSheetitem.prevAll(":visible").length > 0) { - luckysheetcurrentSheetitem.insertBefore(luckysheetcurrentSheetitem.prevAll(":visible").eq(0)); + if (luckysheetcurrentSheetitem.preval(":visible").length > 0) { + luckysheetcurrentSheetitem.insertBefore(luckysheetcurrentSheetitem.preval(":visible").eq(0)); sheetmanage.reOrderAllSheet(); } $("#luckysheet-input-box").removeAttr("style"); diff --git a/src/controllers/menuButton.js b/src/controllers/menuButton.js index 09c8217..c6dbd43 100644 --- a/src/controllers/menuButton.js +++ b/src/controllers/menuButton.js @@ -3522,7 +3522,7 @@ const menuButton = { } } - if(["0", "1", "2"].indexOf(foucsStatus) == -1){ + if(["0", "1", "2"].indexOf(foucsStatus.toString()) == -1){ foucsStatus = "1"; } } @@ -3537,7 +3537,7 @@ const menuButton = { } } - if(["0", "1", "2"].indexOf(foucsStatus) == -1){ + if(["0", "1", "2"].indexOf(foucsStatus.toString()) == -1){ foucsStatus = "2"; } } diff --git a/src/controllers/selection.js b/src/controllers/selection.js index c9b76b2..ecef695 100644 --- a/src/controllers/selection.js +++ b/src/controllers/selection.js @@ -590,7 +590,7 @@ const selection = { } } - if (getObjType(data) == "object") { + if (typeof data == "object") { if (data.length == 0) { return; }; let cfg = $.extend(true, {}, Store.config); @@ -1679,7 +1679,7 @@ const selection = { }, matchcopy: function (data1, data2) { let data1cache = [], data2cache = [], data1len, data2len; - if (getObjType(data1) == "object") { + if (typeof data1 == "object") { data1cache = data1; } else { @@ -1691,7 +1691,7 @@ const selection = { data1len = data1cache.length; - if (getObjType(data2) == "object") { + if (typeof data2 == "object") { data2cache = data2; } else { diff --git a/src/controllers/sheetmanage.js b/src/controllers/sheetmanage.js index be96af3..f928cc3 100644 --- a/src/controllers/sheetmanage.js +++ b/src/controllers/sheetmanage.js @@ -228,7 +228,7 @@ const sheetmanage = { indicator = indicator.eq(0).data("index"); } else { - indicator = luckysheetcurrentSheetitem.prevAll(":visible").eq(0).data("index"); + indicator = luckysheetcurrentSheetitem.preval(":visible").eq(0).data("index"); } $("#luckysheet-sheets-item" + indicator).addClass("luckysheet-sheets-item-active"); diff --git a/src/core.js b/src/core.js index db3bacd..2f4613a 100644 --- a/src/core.js +++ b/src/core.js @@ -8,9 +8,17 @@ import sheetmanage from './controllers/sheetmanage'; import luckysheetsizeauto from './controllers/resize'; import luckysheetHandler from './controllers/handler'; import {initPlugins} from './controllers/expendPlugins'; +import { + getluckysheetfile, + getluckysheet_select_save, + getconfig, + getvisibledatarow, + getvisibledatacolumn +} from './methods/get'; let luckysheet = {}; +//创建luckysheet表格 luckysheet.create = function (setting) { let extendsetting = common_extend(defaultSetting, setting); @@ -101,6 +109,21 @@ luckysheet.create = function (setting) { } } +//获取所有表格数据 +luckysheet.getluckysheetfile = getluckysheetfile; + +//获取当前表格 选区 +luckysheet.getluckysheet_select_save = getluckysheet_select_save; + +//获取当前表格 config配置 +luckysheet.getconfig = getconfig; + +//获取当前表格 行高数据 +luckysheet.getvisibledatarow = getvisibledatarow; + +//获取当前表格 列宽数据 +luckysheet.getvisibledatacolumn = getvisibledatacolumn; + export { luckysheet } \ No newline at end of file diff --git a/src/demoData/sheetComment.js b/src/demoData/sheetComment.js index f641700..f17c584 100644 --- a/src/demoData/sheetComment.js +++ b/src/demoData/sheetComment.js @@ -6,7 +6,7 @@ const sheetComment = { "2": 102 } }, - "index": "4", + "index": "5", "chart": [{ "sheetIndex": "0", "dataSheetIndex": "0", @@ -20,7 +20,7 @@ const sheetComment = { "myTop": "11" }], "status": "0", - "order": "4", + "order": "5", "column": 18, "row": 36, "celldata": [{ diff --git a/src/demoData/sheetFormula.js b/src/demoData/sheetFormula.js index b896b7e..804e48c 100644 --- a/src/demoData/sheetFormula.js +++ b/src/demoData/sheetFormula.js @@ -6928,6 +6928,288 @@ const sheetFormula = { "c": 10, "v": {} }], + "calcChain":[ + { + "r": 6, + "c": 3, + "index": 1, + "func": [ + true, + 23.75, + "=AVERAGE(D3:D6)" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 7, + "c": 3, + "index": 1, + "func": [ + true, + 30, + "=MAX(D3:D6)" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 8, + "c": 3, + "index": 1, + "func": [ + true, + 17, + "=MIN(D3:D6)" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 5, + "c": 9, + "index": 1, + "func": [ + true, + "J2", + "=INDIRECT(\"I2\")" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 6, + "c": 9, + "index": 1, + "func": [ + true, + 1, + "=INDIRECT(I2)" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 7, + "c": 9, + "index": 1, + "func": [ + true, + "I", + "=INDIRECT(\"I\"&(1+2))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 8, + "c": 9, + "index": 1, + "func": [ + true, + 1, + "=INDIRECT(I4&J3)" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 9, + "c": 9, + "index": 1, + "func": [ + true, + "#REF!", + "=INDIRECT(\"Formula!\"&I2)" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 10, + "c": 9, + "index": 1, + "func": [ + true, + "#REF!", + "=INDIRECT(\"Formula!I2\")" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 14, + "c": 7, + "index": 1, + "func": [ + true, + 207, + "=SUBTOTAL(9,OFFSET($D$15,ROW($D$15:$D$18)-ROW($D$15),1,3))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 15, + "c": 7, + "index": 1, + "func": [ + true, + 182, + "=SUBTOTAL(9,OFFSET(E15,ROW(E15:E18)-ROW(E15),1,3))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 16, + "c": 7, + "index": 1, + "func": [ + true, + 152, + "=SUBTOTAL(9,OFFSET(F15,ROW(F15:F18)-ROW(F15),1,3))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 17, + "c": 7, + "index": 1, + "func": [ + true, + 541, + "=SUBTOTAL(9,OFFSET(G15,ROW(G15:G18)-ROW(G15),1,3))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 22, + "c": 8, + "index": 1, + "func": [ + true, + "#NAME?", + "=INDEX(D21:D25,MATCH(TRUE,ISNA(MATCH(D21:D25,C21:C27,0)),0))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 23, + "c": 8, + "index": 1, + "func": [ + true, + "#NAME?", + "=INDEX(D21:D25,MATCH(TRUE,ISNA(MATCH(D21:D25,C21:C27,0)),0))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 38, + "c": 6, + "index": 1, + "func": [ + true, + 1, + "=SUM(IF((C31:C39=\"Fax\")+(D31:D39=\"Jones\")<>2,1,0))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 30, + "c": 6, + "index": 1, + "func": [ + true, + "#NAME?", + "=SUM((C31:C39=\"Fax\")*(D31:D39=\"Brown\")*(E31:E39))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 32, + "c": 6, + "index": 1, + "func": [ + true, + "#NAME?", + "=SUM((C31:C39=\"Fax\")*(D31:D39=\"Brown\"))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 34, + "c": 6, + "index": 1, + "func": [ + true, + 1, + "=SUM(IF((C31:C39=\"Fax\")+(D31:D39=\"Jones\"),1,0))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 36, + "c": 6, + "index": 1, + "func": [ + true, + 1, + "=SUM(IF(MOD((C31:C39=\"Fax\")+(D31:D39=\"Jones\"),2),1,0))" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + } + ], "visibledatarow": [], "visibledatacolumn": [], "rowsplit": [], diff --git a/src/demoData/sheetPivotTable.js b/src/demoData/sheetPivotTable.js index ca25551..ef0946d 100644 --- a/src/demoData/sheetPivotTable.js +++ b/src/demoData/sheetPivotTable.js @@ -2,7 +2,7 @@ const sheetPivotTable = { "name": "PivotTable", "color": "", "config": {}, - "index": "6", + "index": "7", "chart": [{ "sheetIndex": "0", "dataSheetIndex": "0", @@ -16,7 +16,7 @@ const sheetPivotTable = { "myTop": "11" }], "status": "0", - "order": "6", + "order": "7", "column": 18, "row": 36, "celldata": [{ diff --git a/src/demoData/sheetPivotTableData.js b/src/demoData/sheetPivotTableData.js index f6adef7..d3fb2ba 100644 --- a/src/demoData/sheetPivotTableData.js +++ b/src/demoData/sheetPivotTableData.js @@ -4,7 +4,7 @@ const sheetPivotTableData = { "config": { "merge": {} }, - "index": "5", + "index": "6", "chart": [{ "sheetIndex": "0", "dataSheetIndex": "0", @@ -18,7 +18,7 @@ const sheetPivotTableData = { "myTop": "11" }], "status": "0", - "order": "5", + "order": "6", "hide": 1, "column": 18, "row": 36, diff --git a/src/demoData/sheetSparkline.js b/src/demoData/sheetSparkline.js new file mode 100644 index 0000000..48afea6 --- /dev/null +++ b/src/demoData/sheetSparkline.js @@ -0,0 +1,790 @@ +const sheetSparkline = { + "name": "Sparkline", + "color": "", + "config": { + "merge": { + "1_2": { + "r": 1, + "c": 2, + "rs": 1, + "cs": 2 + }, + "1_4": { + "r": 1, + "c": 4, + "rs": 1, + "cs": 2 + }, + "0_0": { + "r": 0, + "c": 0, + "rs": 1, + "cs": 6 + }, + "2_2": { + "r": 2, + "c": 2, + "rs": 3, + "cs": 2 + }, + "2_4": { + "r": 2, + "c": 4, + "rs": 3, + "cs": 2 + } + }, + "rowlen": { + "0": 25 + }, + "columlen": { + "0": 101 + } + }, + "index": "4", + "chart": [ + { + "sheetIndex": "0", + "dataSheetIndex": "0", + "chartType": "column", + "row": "[1,3]", + "column": "[3,3]", + "chartStyle": "default", + "myWidth": "480", + "myHeight": "288", + "myLeft": "67", + "myTop": "11" + } + ], + "status": "0", + "order": "4", + "column": 18, + "row": 36, + "celldata": [ + { + "r": 0, + "c": 0, + "v": { + "v": "The company revenue in 2014", + "ct": { + "fa": "General", + "t": "g" + }, + "m": "The company revenue in 2014", + "mc": { + "r": 0, + "c": 0, + "rs": 1, + "cs": 6 + }, + "fs": "14", + "ht": "0", + "vt": "0" + } + }, + { + "r": 0, + "c": 1, + "v": { + "mc": { + "r": 0, + "c": 0 + }, + "fs": "14", + "ht": "0", + "vt": "0" + } + }, + { + "r": 0, + "c": 2, + "v": { + "mc": { + "r": 0, + "c": 0 + }, + "fs": "14", + "ht": "0", + "vt": "0" + } + }, + { + "r": 0, + "c": 3, + "v": { + "mc": { + "r": 0, + "c": 0 + }, + "fs": "14", + "ht": "0", + "vt": "0" + } + }, + { + "r": 0, + "c": 4, + "v": { + "mc": { + "r": 0, + "c": 0 + }, + "fs": "14", + "ht": "0", + "vt": "0" + } + }, + { + "r": 0, + "c": 5, + "v": { + "mc": { + "r": 0, + "c": 0 + }, + "fs": "14", + "ht": "0", + "vt": "0" + } + }, + { + "r": 1, + "c": 0, + "v": { + "m": "Month", + "ct": { + "fa": "General", + "t": "g" + }, + "v": "Month", + "bg": "#f1c232", + "fc": "#ffffff", + "ht": "0", + "vt": "0" + } + }, + { + "r": 1, + "c": 1, + "v": { + "m": "Revenue", + "ct": { + "fa": "General", + "t": "g" + }, + "v": "Revenue", + "bg": "#f1c232", + "fc": "#ffffff", + "ht": "0", + "vt": "0" + } + }, + { + "r": 1, + "c": 2, + "v": { + "m": "Diagram 1", + "ct": { + "fa": "General", + "t": "g" + }, + "v": "Diagram 1", + "mc": { + "r": 1, + "c": 2, + "rs": 1, + "cs": 2 + }, + "bg": "#f1c232", + "fc": "#ffffff", + "ht": "0", + "vt": "0" + } + }, + { + "r": 1, + "c": 3, + "v": { + "mc": { + "r": 1, + "c": 2 + }, + "bg": "#f1c232", + "fc": "#ffffff", + "ht": "0", + "vt": "0" + } + }, + { + "r": 1, + "c": 4, + "v": { + "m": "Diagram 2", + "ct": { + "fa": "General", + "t": "g" + }, + "v": "Diagram 2", + "mc": { + "r": 1, + "c": 4, + "rs": 1, + "cs": 2 + }, + "bg": "#f1c232", + "fc": "#ffffff", + "ht": "0", + "vt": "0" + } + }, + { + "r": 1, + "c": 5, + "v": { + "mc": { + "r": 1, + "c": 4 + }, + "bg": "#f1c232", + "fc": "#ffffff", + "ht": "0", + "vt": "0" + } + }, + { + "r": 2, + "c": 0, + "v": { + "m": "2014-02-01", + "ct": { + "fa": "yyyy-MM-dd", + "t": "d" + }, + "v": 41671 + } + }, + { + "r": 2, + "c": 1, + "v": { + "v": 30, + "ct": { + "fa": "General", + "t": "n" + }, + "m": "30", + "ht": "0", + "vt": "0" + } + }, + { + "r": 2, + "c": 2, + "v": { + "mc": { + "r": 2, + "c": 2, + "rs": 3, + "cs": 2 + }, + "f": "=LINESPLINES(B3:B5,'pink',4,'avg','yellow','red','green',3)", + "spl": { + "shapes": { + "0": { + "id": 0, + "type": "Shape", + "args": [ + 0, + [ + [ + 0, + 20 + ], + [ + 0, + 20 + ], + [ + 72, + 51 + ], + [ + 144, + 3 + ] + ], + "pink", + null, + 4 + ] + }, + "1": { + "id": 1, + "type": "Rect", + "args": [ + 1, + 0, + null, + 144, + null, + null, + "yellow" + ] + }, + "2": { + "id": 2, + "type": "Circle", + "args": [ + 2, + 72, + 51, + 3, + null, + "green", + null + ] + }, + "3": { + "id": 3, + "type": "Circle", + "args": [ + 3, + 144, + 3, + 3, + null, + "red", + null + ] + } + }, + "shapeseq": [ + 0, + 1, + 2, + 3 + ], + "offsetX": 0, + "offsetY": 5, + "pixelWidth": 147, + "pixelHeight": 55 + } + } + }, + { + "r": 2, + "c": 3, + "v": { + "mc": { + "r": 2, + "c": 2 + } + } + }, + { + "r": 2, + "c": 4, + "v": { + "mc": { + "r": 2, + "c": 4, + "rs": 3, + "cs": 2 + }, + "f": "=COLUMNSPLINES(B3:B5,35,'red','green','auto','brown')", + "spl": { + "shapes": { + "0": { + "id": 0, + "type": "Rect", + "args": [ + 0, + 98, + 1, + 13, + 28, + "red", + "red" + ] + }, + "1": { + "id": 1, + "type": "Rect", + "args": [ + 1, + 49, + 30, + 13, + 20, + "green", + "green" + ] + }, + "2": { + "id": 2, + "type": "Rect", + "args": [ + 2, + 0, + 20, + 13, + 9, + "brown", + "brown" + ] + } + }, + "shapeseq": [ + 0, + 1, + 2 + ], + "offsetX": 0, + "offsetY": 0, + "pixelWidth": 147, + "pixelHeight": 60 + } + } + }, + { + "r": 2, + "c": 5, + "v": { + "mc": { + "r": 2, + "c": 4 + } + } + }, + { + "r": 3, + "c": 0, + "v": { + "m": "2014-03-01", + "ct": { + "fa": "yyyy-MM-dd", + "t": "d" + }, + "v": 41699 + } + }, + { + "r": 3, + "c": 1, + "v": { + "v": -60, + "ct": { + "fa": "General", + "t": "n" + }, + "m": "-60", + "ht": "0", + "vt": "0" + } + }, + { + "r": 3, + "c": 2, + "v": { + "mc": { + "r": 2, + "c": 2 + } + } + }, + { + "r": 3, + "c": 3, + "v": { + "mc": { + "r": 2, + "c": 2 + } + } + }, + { + "r": 3, + "c": 4, + "v": { + "mc": { + "r": 2, + "c": 4 + } + } + }, + { + "r": 3, + "c": 5, + "v": { + "mc": { + "r": 2, + "c": 4 + } + } + }, + { + "r": 4, + "c": 0, + "v": { + "m": "2014-04-01", + "ct": { + "fa": "yyyy-MM-dd", + "t": "d" + }, + "v": 41730 + } + }, + { + "r": 4, + "c": 1, + "v": { + "v": 80, + "ct": { + "fa": "General", + "t": "n" + }, + "m": "80", + "ht": "0", + "vt": "0" + } + }, + { + "r": 4, + "c": 2, + "v": { + "mc": { + "r": 2, + "c": 2 + } + } + }, + { + "r": 4, + "c": 3, + "v": { + "mc": { + "r": 2, + "c": 2 + } + } + }, + { + "r": 4, + "c": 4, + "v": { + "mc": { + "r": 2, + "c": 4 + } + } + }, + { + "r": 4, + "c": 5, + "v": { + "mc": { + "r": 2, + "c": 4 + } + } + } + ], + "visibledatarow": [ + 26, + 46, + 66, + 86, + 106, + 126, + 146, + 166, + 186, + 206, + 226, + 246, + 266, + 286, + 306, + 326, + 346, + 366, + 386, + 406, + 426, + 446, + 466, + 486, + 506, + 526, + 546, + 566, + 586, + 606, + 626, + 646, + 666, + 686, + 706, + 726, + 746, + 766, + 786, + 806, + 826, + 846, + 866, + 886, + 906, + 926, + 946, + 966, + 986, + 1006, + 1026, + 1046, + 1066, + 1086, + 1106, + 1126, + 1146, + 1166, + 1186, + 1206, + 1226, + 1246, + 1266, + 1286, + 1306, + 1326, + 1346, + 1366, + 1386, + 1406, + 1426, + 1446, + 1466, + 1486, + 1506, + 1526, + 1546, + 1566, + 1586, + 1606, + 1626, + 1646, + 1666, + 1686 + ], + "visibledatacolumn": [ + 102, + 176, + 250, + 324, + 398, + 472, + 546, + 620, + 694, + 768, + 842, + 916, + 990, + 1064, + 1138, + 1212, + 1286, + 1360, + 1434, + 1508, + 1582, + 1656, + 1730, + 1804, + 1878, + 1952, + 2026, + 2100, + 2174, + 2248, + 2322, + 2396, + 2470, + 2544, + 2618, + 2692, + 2766, + 2840, + 2914, + 2988, + 3062, + 3136, + 3210, + 3284, + 3358, + 3432, + 3506, + 3580, + 3654, + 3728, + 3802, + 3876, + 3950, + 4024, + 4098, + 4172, + 4246, + 4320, + 4394, + 4468 + ], + "rowsplit": [], + "ch_width": 4748, + "rh_height": 1790, + "luckysheet_select_save": [ + { + "row": [ + 0, + 0 + ], + "column": [ + 0, + 0 + ] + } + ], + "luckysheet_selection_range": [], + "scrollLeft": 0, + "scrollTop": 0, + "calcChain": [ + { + "r": 2, + "c": 2, + "index": "4", + "func": [ + true, + "", + "=LINESPLINES(B3:B5,'pink',4,'avg','yellow','red','green',3)" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + }, + { + "r": 2, + "c": 4, + "index": "4", + "func": [ + true, + "", + "=COLUMNSPLINES(B3:B5,35,'red','green','auto','brown')" + ], + "color": "w", + "parent": null, + "chidren": {}, + "times": 0 + } + ] +} + +export default sheetSparkline; \ No newline at end of file diff --git a/src/function/functionImplementation.js b/src/function/functionImplementation.js index a5fb3a2..f9e540a 100644 --- a/src/function/functionImplementation.js +++ b/src/function/functionImplementation.js @@ -10301,11 +10301,9 @@ const functionImplementation = { //计算 if(A1){ - var reg = /^(([a-zA-Z]+)|([$][a-zA-Z]+))(([0-9]+)|([$][0-9]+))$/g; - - if(reg.test(ref_text)){ - var row = parseInt(ref_text.replace(/[^0-9]/g, "")) - 1; - var col = ABCatNum(ref_text.replace(/[^A-Za-z]/g, "")); + if(formula.iscelldata(ref_text)){ + let cellrange = formula.getcellrange(ref_text); + let row = cellrange.row[0], col = cellrange.column[0]; if(row < 0 || row >= Store.flowdata.length || col < 0 || col >= Store.flowdata[0].length){ return formula.error.r; @@ -10322,11 +10320,9 @@ const functionImplementation = { } } else{ - var reg = /^[R][0-9]+[C][0-9]+$/g; - - if(reg.test(ref_text)){ - var row = parseInt(ref_text.split("R")[1].split("C")[0]); - var col = parseInt(ref_text.split("R")[1].split("C")[1]); + if(formula.iscelldata(ref_text)){ + let cellrange = formula.getcellrange(ref_text); + let row = cellrange.row[0], col = cellrange.column[0]; if(row < 0 || row >= Store.flowdata.length || col < 0 || col >= Store.flowdata[0].length){ return formula.error.r; diff --git a/src/global/draw.js b/src/global/draw.js index 50e3bcd..feb0bdc 100644 --- a/src/global/draw.js +++ b/src/global/draw.js @@ -833,7 +833,7 @@ function luckysheetDrawMain(scrollWidth, scrollHeight, drawWidth, drawHeight, of //水平对齐方式是 居中或居右对齐 且单元格宽度小于文字宽度 (用离屏canvas渲染) let canvasName, cellsize; - if(browser.BrowserType() != "Safari" && (canvasType == "offline" || ((horizonAlign == "0" || horizonAlign == "2") && (end_c - start_c) < textW) || ((verticalAlign == "0" || verticalAlign == "2") && (end_r - start_r) < textH))){ + if(browser.BrowserType() != "Safari" && (canvasType == "offline" || ((horizonAlign == "0" || horizonAlign == "2") && (end_c - start_c) < textW) || ((end_r - start_r) < textH))){ canvasName = offlinecanvas; canvasName.font = fontset; diff --git a/src/index.html b/src/index.html index 788422c..6836581 100644 --- a/src/index.html +++ b/src/index.html @@ -27,13 +27,14 @@ import sheetComment from './demoData/sheetComment.js' import sheetPivotTableData from './demoData/sheetPivotTableData.js' import sheetPivotTable from './demoData/sheetPivotTable.js' + import sheetSparkline from './demoData/sheetSparkline.js' $(function () { luckysheet.create({ container: 'luckysheet', lang: 'en', plugins: ['chart'], - data: [sheetCell,sheetFormula,sheetConditionFormat,sheetTable,sheetComment,sheetPivotTableData,sheetPivotTable] + data: [sheetCell,sheetFormula,sheetConditionFormat,sheetTable,sheetSparkline,sheetComment,sheetPivotTableData,sheetPivotTable] }) }) diff --git a/src/index.js b/src/index.js index 252759c..4da8f11 100644 --- a/src/index.js +++ b/src/index.js @@ -1,7 +1,8 @@ import './utils/math' import { luckysheet } from './core' import __firefox from './utils/polyfill' - +// Prevent gulp warning: 'Use of eval is strongly discouraged, as it poses security risks and may cause issues with minification' +// window.evall = window.eval; // polyfill event in firefox if(window.addEventListener && (navigator.userAgent.indexOf("Firefox") > 0)){ __firefox(); diff --git a/src/plugins/js/jquery-ui.min.js b/src/plugins/js/jquery-ui.min.js index 8c459fd..2b81c5b 100644 --- a/src/plugins/js/jquery-ui.min.js +++ b/src/plugins/js/jquery-ui.min.js @@ -1 +1 @@ -!function(){var t;t=function(M){M.ui=M.ui||{};M.ui.version="1.12.1";var n,i=0,l=Array.prototype.slice;M.cleanData=(n=M.cleanData,function(t){var e,i,s;for(s=0;null!=(i=t[s]);s++)try{(e=M._data(i,"events"))&&e.remove&&M(i).triggerHandler("remove")}catch(t){}n(t)}),M.widget=function(t,i,e){var s,n,o,a={},l=t.split(".")[0],h=l+"-"+(t=t.split(".")[1]);return e||(e=i,i=M.Widget),M.isArray(e)&&(e=M.extend.apply(null,[{}].concat(e))),M.expr[":"][h.toLowerCase()]=function(t){return!!M.data(t,h)},M[l]=M[l]||{},s=M[l][t],n=M[l][t]=function(t,e){if(!this._createWidget)return new n(t,e);arguments.length&&this._createWidget(t,e)},M.extend(n,s,{version:e.version,_proto:M.extend({},e),_childConstructors:[]}),(o=new i).options=M.widget.extend({},o.options),M.each(e,function(e,o){M.isFunction(o)?a[e]=function(){function s(){return i.prototype[e].apply(this,arguments)}function n(t){return i.prototype[e].apply(this,t)}return function(){var t,e=this._super,i=this._superApply;return this._super=s,this._superApply=n,t=o.apply(this,arguments),this._super=e,this._superApply=i,t}}():a[e]=o}),n.prototype=M.widget.extend(o,{widgetEventPrefix:s&&o.widgetEventPrefix||t},a,{constructor:n,namespace:l,widgetName:t,widgetFullName:h}),s?(M.each(s._childConstructors,function(t,e){var i=e.prototype;M.widget(i.namespace+"."+i.widgetName,n,e._proto)}),delete s._childConstructors):i._childConstructors.push(n),M.widget.bridge(t,n),n},M.widget.extend=function(t){for(var e,i,s=l.call(arguments,1),n=0,o=s.length;n",options:{classes:{},disabled:!1,create:null},_createWidget:function(t,e){e=M(e||this.defaultElement||this)[0],this.element=M(e),this.uuid=i++,this.eventNamespace="."+this.widgetName+this.uuid,this.bindings=M(),this.hoverable=M(),this.focusable=M(),this.classesElementLookup={},e!==this&&(M.data(e,this.widgetFullName,this),this._on(!0,this.element,{remove:function(t){t.target===e&&this.destroy()}}),this.document=M(e.style?e.ownerDocument:e.document||e),this.window=M(this.document[0].defaultView||this.document[0].parentWindow)),this.options=M.widget.extend({},this.options,this._getCreateOptions(),t),this._create(),this.options.disabled&&this._setOptionDisabled(this.options.disabled),this._trigger("create",null,this._getCreateEventData()),this._init()},_getCreateOptions:function(){return{}},_getCreateEventData:M.noop,_create:M.noop,_init:M.noop,destroy:function(){var i=this;this._destroy(),M.each(this.classesElementLookup,function(t,e){i._removeClass(e,t)}),this.element.off(this.eventNamespace).removeData(this.widgetFullName),this.widget().off(this.eventNamespace).removeAttr("aria-disabled"),this.bindings.off(this.eventNamespace)},_destroy:M.noop,widget:function(){return this.element},option:function(t,e){var i,s,n,o=t;if(0===arguments.length)return M.widget.extend({},this.options);if("string"==typeof t)if(o={},t=(i=t.split(".")).shift(),i.length){for(s=o[t]=M.widget.extend({},this.options[t]),n=0;n
"),s=i.children()[0];return M("body").append(i),t=s.offsetWidth,i.css("overflow","scroll"),t===(e=s.offsetWidth)&&(e=i[0].clientWidth),i.remove(),n=t-e},getScrollInfo:function(t){var e=t.isWindow||t.isDocument?"":t.element.css("overflow-x"),i=t.isWindow||t.isDocument?"":t.element.css("overflow-y"),s="scroll"===e||"auto"===e&&t.widthC(x(s),x(n))?o.important="horizontal":o.important="vertical",c.using.call(this,t,o)}),a.offset(M.extend(u,{using:t}))})},M.ui.position={fit:{left:function(t,e){var i,s=e.within,n=s.isWindow?s.scrollLeft:s.offset.left,o=s.width,a=t.left-e.collisionPosition.marginLeft,l=n-a,h=a+e.collisionWidth-o-n;e.collisionWidth>o?0o?0?@[\]^`{|}~])/g,function(t){return t.replace(e,"\\$1")}),M.fn.labels=function(){var t,e,i,s,n;return this[0].labels&&this[0].labels.length?this.pushStack(this[0].labels):(s=this.eq(0).parents("label"),(i=this.attr("id"))&&(n=(t=this.eq(0).parents().last()).add(t.length?t.siblings():this.siblings()),e="label[for='"+M.ui.escapeSelector(i)+"']",s=s.add(n.find(e).addBack(e))),this.pushStack(s))},M.fn.extend({uniqueId:(t=0,function(){return this.each(function(){this.id||(this.id="ui-id-"+ ++t)})}),removeUniqueId:function(){return this.each(function(){/^ui-id-\d+$/.test(this.id)&&M(this).removeAttr("id")})}});var e,t,o=/ui-corner-([a-z]){2,6}/g;M.widget("ui.controlgroup",{version:"1.12.1",defaultElement:"
",options:{direction:"horizontal",disabled:null,onlyVisible:!0,items:{button:"input[type=button], input[type=submit], input[type=reset], button, a",controlgroupLabel:".ui-controlgroup-label",checkboxradio:"input[type='checkbox'], input[type='radio']",selectmenu:"select",spinner:".ui-spinner-input"}},_create:function(){this._enhance()},_enhance:function(){this.element.attr("role","toolbar"),this.refresh()},_destroy:function(){this._callChildMethod("destroy"),this.childWidgets.removeData("ui-controlgroup-data"),this.element.removeAttr("role"),this.options.items.controlgroupLabel&&this.element.find(this.options.items.controlgroupLabel).find(".ui-controlgroup-label-contents").contents().unwrap()},_initWidgets:function(){var a=this,l=[];M.each(this.options.items,function(n,t){var e,o={};if(t)return"controlgroupLabel"===n?((e=a.element.find(t)).each(function(){var t=M(this);t.children(".ui-controlgroup-label-contents").length||t.contents().wrapAll("")}),a._addClass(e,null,"ui-widget ui-widget-content ui-state-default"),void(l=l.concat(e.get()))):void(M.fn[n]&&(o=a["_"+n+"Options"]?a["_"+n+"Options"]("middle"):{classes:{}},a.element.find(t).each(function(){var t=M(this),e=t[n]("instance"),i=M.widget.extend({},o);if("button"!==n||!t.parent(".ui-spinner").length){e||(e=t[n]()[n]("instance")),e&&(i.classes=a._resolveClassesValues(i.classes,e)),t[n](i);var s=t[n]("widget");M.data(s[0],"ui-controlgroup-data",e||t[n]("instance")),l.push(s[0])}})))}),this.childWidgets=M(M.unique(l)),this._addClass(this.childWidgets,"ui-controlgroup-item")},_callChildMethod:function(e){this.childWidgets.each(function(){var t=M(this).data("ui-controlgroup-data");t&&t[e]&&t[e]()})},_updateCornerClass:function(t,e){var i=this._buildSimpleOptions(e,"label").classes.label;this._removeClass(t,null,"ui-corner-top ui-corner-bottom ui-corner-left ui-corner-right ui-corner-all"),this._addClass(t,null,i)},_buildSimpleOptions:function(t,e){var i="vertical"===this.options.direction,s={classes:{}};return s.classes[e]={middle:"",first:"ui-corner-"+(i?"top":"left"),last:"ui-corner-"+(i?"bottom":"right"),only:"ui-corner-all"}[t],s},_spinnerOptions:function(t){var e=this._buildSimpleOptions(t,"ui-spinner");return e.classes["ui-spinner-up"]="",e.classes["ui-spinner-down"]="",e},_buttonOptions:function(t){return this._buildSimpleOptions(t,"ui-button")},_checkboxradioOptions:function(t){return this._buildSimpleOptions(t,"ui-checkboxradio-label")},_selectmenuOptions:function(t){var e="vertical"===this.options.direction;return{width:!!e&&"auto",classes:{middle:{"ui-selectmenu-button-open":"","ui-selectmenu-button-closed":""},first:{"ui-selectmenu-button-open":"ui-corner-"+(e?"top":"tl"),"ui-selectmenu-button-closed":"ui-corner-"+(e?"top":"left")},last:{"ui-selectmenu-button-open":e?"":"ui-corner-tr","ui-selectmenu-button-closed":"ui-corner-"+(e?"bottom":"right")},only:{"ui-selectmenu-button-open":"ui-corner-top","ui-selectmenu-button-closed":"ui-corner-all"}}[t]}},_resolveClassesValues:function(i,s){var n={};return M.each(i,function(t){var e=s.options.classes[t]||"";e=M.trim(e.replace(o,"")),n[t]=(e+" "+i[t]).replace(/\s+/g," ")}),n},_setOption:function(t,e){"direction"===t&&this._removeClass("ui-controlgroup-"+this.options.direction),this._super(t,e),"disabled"!==t?this.refresh():this._callChildMethod(e?"disable":"enable")},refresh:function(){var n,o=this;this._addClass("ui-controlgroup ui-controlgroup-"+this.options.direction),"horizontal"===this.options.direction&&this._addClass(null,"ui-helper-clearfix"),this._initWidgets(),n=this.childWidgets,this.options.onlyVisible&&(n=n.filter(":visible")),n.length&&(M.each(["first","last"],function(t,e){var i=n[e]().data("ui-controlgroup-data");if(i&&o["_"+i.widgetName+"Options"]){var s=o["_"+i.widgetName+"Options"](1===n.length?"only":e);s.classes=o._resolveClassesValues(s.classes,i),i.element[i.widgetName](s)}else o._updateCornerClass(n[e](),e)}),this._callChildMethod("refresh"))}});M.widget("ui.checkboxradio",[M.ui.formResetMixin,{version:"1.12.1",options:{disabled:null,label:null,icon:!0,classes:{"ui-checkboxradio-label":"ui-corner-all","ui-checkboxradio-icon":"ui-corner-all"}},_getCreateOptions:function(){var t,e,i=this,s=this._super()||{};return this._readType(),e=this.element.labels(),this.label=M(e[e.length-1]),this.label.length||M.error("No label found for checkboxradio widget"),this.originalLabel="",this.label.contents().not(this.element[0]).each(function(){i.originalLabel+=3===this.nodeType?M(this).text():this.outerHTML}),this.originalLabel&&(s.label=this.originalLabel),null!=(t=this.element[0].disabled)&&(s.disabled=t),s},_create:function(){var t=this.element[0].checked;this._bindFormResetHandler(),null==this.options.disabled&&(this.options.disabled=this.element[0].disabled),this._setOption("disabled",this.options.disabled),this._addClass("ui-checkboxradio","ui-helper-hidden-accessible"),this._addClass(this.label,"ui-checkboxradio-label","ui-button ui-widget"),"radio"===this.type&&this._addClass(this.label,"ui-checkboxradio-radio-label"),this.options.label&&this.options.label!==this.originalLabel?this._updateLabel():this.originalLabel&&(this.options.label=this.originalLabel),this._enhance(),t&&(this._addClass(this.label,"ui-checkboxradio-checked","ui-state-active"),this.icon&&this._addClass(this.icon,null,"ui-state-hover")),this._on({change:"_toggleClasses",focus:function(){this._addClass(this.label,null,"ui-state-focus ui-visual-focus")},blur:function(){this._removeClass(this.label,null,"ui-state-focus ui-visual-focus")}})},_readType:function(){var t=this.element[0].nodeName.toLowerCase();this.type=this.element[0].type,"input"===t&&/radio|checkbox/.test(this.type)||M.error("Can't create checkboxradio on element.nodeName="+t+" and element.type="+this.type)},_enhance:function(){this._updateIcon(this.element[0].checked)},widget:function(){return this.label},_getRadioGroup:function(){var t=this.element[0].name,e="input[name='"+M.ui.escapeSelector(t)+"']";return t?(this.form.length?M(this.form[0].elements).filter(e):M(e).filter(function(){return 0===M(this).form().length})).not(this.element):M([])},_toggleClasses:function(){var t=this.element[0].checked;this._toggleClass(this.label,"ui-checkboxradio-checked","ui-state-active",t),this.options.icon&&"checkbox"===this.type&&this._toggleClass(this.icon,null,"ui-icon-check ui-state-checked",t)._toggleClass(this.icon,null,"ui-icon-blank",!t),"radio"===this.type&&this._getRadioGroup().each(function(){var t=M(this).checkboxradio("instance");t&&t._removeClass(t.label,"ui-checkboxradio-checked","ui-state-active")})},_destroy:function(){this._unbindFormResetHandler(),this.icon&&(this.icon.remove(),this.iconSpace.remove())},_setOption:function(t,e){if("label"!==t||e){if(this._super(t,e),"disabled"===t)return this._toggleClass(this.label,null,"ui-state-disabled",e),void(this.element[0].disabled=e);this.refresh()}},_updateIcon:function(t){var e="ui-icon ui-icon-background ";this.options.icon?(this.icon||(this.icon=M(""),this.iconSpace=M(" "),this._addClass(this.iconSpace,"ui-checkboxradio-icon-space")),"checkbox"===this.type?(e+=t?"ui-icon-check ui-state-checked":"ui-icon-blank",this._removeClass(this.icon,null,t?"ui-icon-blank":"ui-icon-check")):e+="ui-icon-blank",this._addClass(this.icon,"ui-checkboxradio-icon",e),t||this._removeClass(this.icon,null,"ui-icon-check ui-state-checked"),this.icon.prependTo(this.label).after(this.iconSpace)):void 0!==this.icon&&(this.icon.remove(),this.iconSpace.remove(),delete this.icon)},_updateLabel:function(){var t=this.label.contents().not(this.element[0]);this.icon&&(t=t.not(this.icon[0])),this.iconSpace&&(t=t.not(this.iconSpace[0])),t.remove(),this.label.append(this.options.label)},refresh:function(){var t=this.element[0].checked,e=this.element[0].disabled;this._updateIcon(t),this._toggleClass(this.label,"ui-checkboxradio-checked","ui-state-active",t),null!==this.options.label&&this._updateLabel(),e!==this.options.disabled&&this._setOptions({disabled:e})}}]);var s;M.ui.checkboxradio;M.widget("ui.button",{version:"1.12.1",defaultElement:"
"),s=i.children()[0];return M("body").append(i),t=s.offsetWidth,i.css("overflow","scroll"),t===(e=s.offsetWidth)&&(e=i[0].clientWidth),i.remove(),n=t-e},getScrollInfo:function(t){var e=t.isWindow||t.isDocument?"":t.element.css("overflow-x"),i=t.isWindow||t.isDocument?"":t.element.css("overflow-y"),s="scroll"===e||"auto"===e&&t.widthC(x(s),x(n))?o.important="horizontal":o.important="vertical",c.using.call(this,t,o)}),a.offset(M.extend(u,{using:t}))})},M.ui.position={fit:{left:function(t,e){var i,s=e.within,n=s.isWindow?s.scrollLeft:s.offset.left,o=s.width,a=t.left-e.collisionPosition.marginLeft,l=n-a,h=a+e.collisionWidth-o-n;e.collisionWidth>o?0o?0?@[\]^`{|}~])/g,function(t){return t.replace(e,"\\$1")}),M.fn.labels=function(){var t,e,i,s,n;return this[0].labels&&this[0].labels.length?this.pushStack(this[0].labels):(s=this.eq(0).parents("label"),(i=this.attr("id"))&&(n=(t=this.eq(0).parents().last()).add(t.length?t.siblings():this.siblings()),e="label[for='"+M.ui.escapeSelector(i)+"']",s=s.add(n.find(e).addBack(e))),this.pushStack(s))},M.fn.extend({uniqueId:(t=0,function(){return this.each(function(){this.id||(this.id="ui-id-"+ ++t)})}),removeUniqueId:function(){return this.each(function(){/^ui-id-\d+$/.test(this.id)&&M(this).removeAttr("id")})}});var e,t,o=/ui-corner-([a-z]){2,6}/g;M.widget("ui.controlgroup",{version:"1.12.1",defaultElement:"
",options:{direction:"horizontal",disabled:null,onlyVisible:!0,items:{button:"input[type=button], input[type=submit], input[type=reset], button, a",controlgroupLabel:".ui-controlgroup-label",checkboxradio:"input[type='checkbox'], input[type='radio']",selectmenu:"select",spinner:".ui-spinner-input"}},_create:function(){this._enhance()},_enhance:function(){this.element.attr("role","toolbar"),this.refresh()},_destroy:function(){this._callChildMethod("destroy"),this.childWidgets.removeData("ui-controlgroup-data"),this.element.removeAttr("role"),this.options.items.controlgroupLabel&&this.element.find(this.options.items.controlgroupLabel).find(".ui-controlgroup-label-contents").contents().unwrap()},_initWidgets:function(){var a=this,l=[];M.each(this.options.items,function(n,t){var e,o={};if(t)return"controlgroupLabel"===n?((e=a.element.find(t)).each(function(){var t=M(this);t.children(".ui-controlgroup-label-contents").length||t.contents().wrapAll("")}),a._addClass(e,null,"ui-widget ui-widget-content ui-state-default"),void(l=l.concat(e.get()))):void(M.fn[n]&&(o=a["_"+n+"Options"]?a["_"+n+"Options"]("middle"):{classes:{}},a.element.find(t).each(function(){var t=M(this),e=t[n]("instance"),i=M.widget.extend({},o);if("button"!==n||!t.parent(".ui-spinner").length){e||(e=t[n]()[n]("instance")),e&&(i.classes=a._resolveClassesValues(i.classes,e)),t[n](i);var s=t[n]("widget");M.data(s[0],"ui-controlgroup-data",e||t[n]("instance")),l.push(s[0])}})))}),this.childWidgets=M(M.unique(l)),this._addClass(this.childWidgets,"ui-controlgroup-item")},_callChildMethod:function(e){this.childWidgets.each(function(){var t=M(this).data("ui-controlgroup-data");t&&t[e]&&t[e]()})},_updateCornerClass:function(t,e){var i=this._buildSimpleOptions(e,"label").classes.label;this._removeClass(t,null,"ui-corner-top ui-corner-bottom ui-corner-left ui-corner-right ui-corner-all"),this._addClass(t,null,i)},_buildSimpleOptions:function(t,e){var i="vertical"===this.options.direction,s={classes:{}};return s.classes[e]={middle:"",first:"ui-corner-"+(i?"top":"left"),last:"ui-corner-"+(i?"bottom":"right"),only:"ui-corner-all"}[t],s},_spinnerOptions:function(t){var e=this._buildSimpleOptions(t,"ui-spinner");return e.classes["ui-spinner-up"]="",e.classes["ui-spinner-down"]="",e},_buttonOptions:function(t){return this._buildSimpleOptions(t,"ui-button")},_checkboxradioOptions:function(t){return this._buildSimpleOptions(t,"ui-checkboxradio-label")},_selectmenuOptions:function(t){var e="vertical"===this.options.direction;return{width:!!e&&"auto",classes:{middle:{"ui-selectmenu-button-open":"","ui-selectmenu-button-closed":""},first:{"ui-selectmenu-button-open":"ui-corner-"+(e?"top":"tl"),"ui-selectmenu-button-closed":"ui-corner-"+(e?"top":"left")},last:{"ui-selectmenu-button-open":e?"":"ui-corner-tr","ui-selectmenu-button-closed":"ui-corner-"+(e?"bottom":"right")},only:{"ui-selectmenu-button-open":"ui-corner-top","ui-selectmenu-button-closed":"ui-corner-all"}}[t]}},_resolveClassesValues:function(i,s){var n={};return M.each(i,function(t){var e=s.options.classes[t]||"";e=M.trim(e.replace(o,"")),n[t]=(e+" "+i[t]).replace(/\s+/g," ")}),n},_setOption:function(t,e){"direction"===t&&this._removeClass("ui-controlgroup-"+this.options.direction),this._super(t,e),"disabled"!==t?this.refresh():this._callChildMethod(e?"disable":"enable")},refresh:function(){var n,o=this;this._addClass("ui-controlgroup ui-controlgroup-"+this.options.direction),"horizontal"===this.options.direction&&this._addClass(null,"ui-helper-clearfix"),this._initWidgets(),n=this.childWidgets,this.options.onlyVisible&&(n=n.filter(":visible")),n.length&&(M.each(["first","last"],function(t,e){var i=n[e]().data("ui-controlgroup-data");if(i&&o["_"+i.widgetName+"Options"]){var s=o["_"+i.widgetName+"Options"](1===n.length?"only":e);s.classes=o._resolveClassesValues(s.classes,i),i.element[i.widgetName](s)}else o._updateCornerClass(n[e](),e)}),this._callChildMethod("refresh"))}});M.widget("ui.checkboxradio",[M.ui.formResetMixin,{version:"1.12.1",options:{disabled:null,label:null,icon:!0,classes:{"ui-checkboxradio-label":"ui-corner-all","ui-checkboxradio-icon":"ui-corner-all"}},_getCreateOptions:function(){var t,e,i=this,s=this._super()||{};return this._readType(),e=this.element.labels(),this.label=M(e[e.length-1]),this.label.length||M.error("No label found for checkboxradio widget"),this.originalLabel="",this.label.contents().not(this.element[0]).each(function(){i.originalLabel+=3===this.nodeType?M(this).text():this.outerHTML}),this.originalLabel&&(s.label=this.originalLabel),null!=(t=this.element[0].disabled)&&(s.disabled=t),s},_create:function(){var t=this.element[0].checked;this._bindFormResetHandler(),null==this.options.disabled&&(this.options.disabled=this.element[0].disabled),this._setOption("disabled",this.options.disabled),this._addClass("ui-checkboxradio","ui-helper-hidden-accessible"),this._addClass(this.label,"ui-checkboxradio-label","ui-button ui-widget"),"radio"===this.type&&this._addClass(this.label,"ui-checkboxradio-radio-label"),this.options.label&&this.options.label!==this.originalLabel?this._updateLabel():this.originalLabel&&(this.options.label=this.originalLabel),this._enhance(),t&&(this._addClass(this.label,"ui-checkboxradio-checked","ui-state-active"),this.icon&&this._addClass(this.icon,null,"ui-state-hover")),this._on({change:"_toggleClasses",focus:function(){this._addClass(this.label,null,"ui-state-focus ui-visual-focus")},blur:function(){this._removeClass(this.label,null,"ui-state-focus ui-visual-focus")}})},_readType:function(){var t=this.element[0].nodeName.toLowerCase();this.type=this.element[0].type,"input"===t&&/radio|checkbox/.test(this.type)||M.error("Can't create checkboxradio on element.nodeName="+t+" and element.type="+this.type)},_enhance:function(){this._updateIcon(this.element[0].checked)},widget:function(){return this.label},_getRadioGroup:function(){var t=this.element[0].name,e="input[name='"+M.ui.escapeSelector(t)+"']";return t?(this.form.length?M(this.form[0].elements).filter(e):M(e).filter(function(){return 0===M(this).form().length})).not(this.element):M([])},_toggleClasses:function(){var t=this.element[0].checked;this._toggleClass(this.label,"ui-checkboxradio-checked","ui-state-active",t),this.options.icon&&"checkbox"===this.type&&this._toggleClass(this.icon,null,"ui-icon-check ui-state-checked",t)._toggleClass(this.icon,null,"ui-icon-blank",!t),"radio"===this.type&&this._getRadioGroup().each(function(){var t=M(this).checkboxradio("instance");t&&t._removeClass(t.label,"ui-checkboxradio-checked","ui-state-active")})},_destroy:function(){this._unbindFormResetHandler(),this.icon&&(this.icon.remove(),this.iconSpace.remove())},_setOption:function(t,e){if("label"!==t||e){if(this._super(t,e),"disabled"===t)return this._toggleClass(this.label,null,"ui-state-disabled",e),void(this.element[0].disabled=e);this.refresh()}},_updateIcon:function(t){var e="ui-icon ui-icon-background ";this.options.icon?(this.icon||(this.icon=M(""),this.iconSpace=M(" "),this._addClass(this.iconSpace,"ui-checkboxradio-icon-space")),"checkbox"===this.type?(e+=t?"ui-icon-check ui-state-checked":"ui-icon-blank",this._removeClass(this.icon,null,t?"ui-icon-blank":"ui-icon-check")):e+="ui-icon-blank",this._addClass(this.icon,"ui-checkboxradio-icon",e),t||this._removeClass(this.icon,null,"ui-icon-check ui-state-checked"),this.icon.prependTo(this.label).after(this.iconSpace)):void 0!==this.icon&&(this.icon.remove(),this.iconSpace.remove(),delete this.icon)},_updateLabel:function(){var t=this.label.contents().not(this.element[0]);this.icon&&(t=t.not(this.icon[0])),this.iconSpace&&(t=t.not(this.iconSpace[0])),t.remove(),this.label.append(this.options.label)},refresh:function(){var t=this.element[0].checked,e=this.element[0].disabled;this._updateIcon(t),this._toggleClass(this.label,"ui-checkboxradio-checked","ui-state-active",t),null!==this.options.label&&this._updateLabel(),e!==this.options.disabled&&this._setOptions({disabled:e})}}]);var s;M.ui.checkboxradio;M.widget("ui.button",{version:"1.12.1",defaultElement:"