123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696 |
- /**
- * Created by zhang on 2018/7/13.
- */
- const locked = lockUtil.getLocked();
- let TEMPLATE_BILLS_SETTING = {
- "emptyRows": 1,
- "headRows": 1,
- "headRowHeight": [35],
- "treeCol": 1,
- "cols": [{
- "width": 80,
- "readOnly": locked,
- "head": {
- "titleNames": ["类别"],
- "spanCols": [1],
- "spanRows": [1],
- "vAlign": [1],
- "hAlign": [1],
- "font": ["Arial"]
- },
- "data": {
- "field": "type",
- "vAlign": 0,
- "hAlign": 1,
- "font": "Arail",
- }
- }, {
- "width": 200,
- "readOnly": locked,
- "head": {
- "titleNames": ["编号"],
- "spanCols": [1],
- "spanRows": [1],
- "vAlign": [1],
- "hAlign": [1],
- "font": ["Arial"],
- },
- "data": {
- "field": "code",
- "vAlign": 0,
- "hAlign": 3,
- "font": "Arail",
- "formatter": '@'
- }
- }, {
- "width": 300,
- "readOnly": locked,
- "head": {
- "titleNames": ["名称"],
- "spanCols": [1],
- "spanRows": [1],
- "vAlign": [1],
- "hAlign": [1],
- "font": ["Arial"]
- },
- "data": {
- "field": "name",
- "vAlign": 0,
- "hAlign": 3,
- "font": "Arail"
- }
- }, {
- "width": 50,
- "readOnly": locked,
- "head": {
- "titleNames": ["单位"],
- "spanCols": [1],
- "spanRows": [1],
- "vAlign": [1],
- "hAlign": [1],
- "font": ["Arial"]
- },
- "data": {
- "field": "unit",
- "vAlign": 0,
- "hAlign": 1,
- "font": "Arail"
- }
- }, {
- "width": 80,
- "readOnly": locked,
- "head": {
- "titleNames": ["工程量"],
- "spanCols": [1],
- "spanRows": [1],
- "vAlign": [1],
- "hAlign": [1],
- "font": ["Arial"]
- },
- "data": {
- "field": "quantity",
- "type": 'Number',
- "vAlign": 0,
- "hAlign": 2,
- "font": "Arail"
- }
- }, {
- "width": 200,
- "readOnly": locked,
- "head": {
- "titleNames": ["清单固定类别"],
- "spanCols": [1],
- "spanRows": [1],
- "vAlign": [1],
- "hAlign": [1],
- "font": ["Arial"]
- },
- "data": {
- "field": "flagsIndex.fixed.flag",
- "vAlign": 0,
- "hAlign": 3,
- "font": "Arail",
- }
- },
- {
- width: 40,
- readOnly: locked,
- head: {
- titleNames: ["不可\n删除"],
- spanCols: [1],
- spanRows: [1],
- vAlign: [1],
- hAlign: [1],
- font: ["Arial"],
- },
- data: {
- field: "cantDelete",
- vAlign: 0,
- hAlign: 1,
- font: "Arail",
- },
- },
- {
- width: 200,
- readOnly: locked,
- head: {
- titleNames: ["计价规则"],
- spanCols: [1],
- spanRows: [1],
- vAlign: [1],
- hAlign: [1],
- font: ["Arial"],
- },
- data: {
- field: "itemCharacterText",
- vAlign: 0,
- hAlign: 3,
- font: "Arail",
- },
- },
- {
- width: 200,
- readOnly: locked,
- head: {
- titleNames: ["计价内容"],
- spanCols: [1],
- spanRows: [1],
- vAlign: [1],
- hAlign: [1],
- font: ["Arial"],
- },
- data: {
- field: "jobContentText",
- vAlign: 0,
- hAlign: 3,
- font: "Arail",
- },
- },
- {
- "width": 250,
- "readOnly": locked,
- "head": {
- "titleNames": ["计算基数"],
- "spanCols": [1],
- "spanRows": [1],
- "vAlign": [1],
- "hAlign": [1],
- "font": ["Arial"]
- },
- "data": {
- "field": "calcBase",
- "vAlign": 0,
- "hAlign": 3,
- "font": "Arail",
- }
- }, {
- "width": 50,
- "readOnly": locked,
- "head": {
- "titleNames": ["费率ID"],
- "spanCols": [1],
- "spanRows": [1],
- "vAlign": [1],
- "hAlign": [1],
- "font": ["Arial"]
- },
- "data": {
- "field": "feeRateID",
- "type": 'Number',
- "vAlign": 0,
- "hAlign": 1,
- "font": "Arail"
- }
- }, {
- "width": 50,
- "readOnly": true,
- "head": {
- "titleNames": ["ID"],
- "spanCols": [1],
- "spanRows": [1],
- "vAlign": [1],
- "hAlign": [1],
- "font": ["Arial"]
- },
- "data": {
- "field": "ID",
- "vAlign": 0,
- "hAlign": 1,
- "font": "Arail"
- }
- }, {
- "width": 50,
- "readOnly": true,
- "head": {
- "titleNames": ["ParentID"],
- "spanCols": [1],
- "spanRows": [1],
- "vAlign": [1],
- "hAlign": [1],
- "font": ["Arial"]
- },
- "data": {
- "field": "ParentID",
- "vAlign": 0,
- "hAlign": 1,
- "font": "Arail"
- }
- }, {
- "width": 50,
- "readOnly": true,
- "head": {
- "titleNames": ["NextSiblingID"],
- "spanCols": [1],
- "spanRows": [1],
- "vAlign": [1],
- "hAlign": [1],
- "font": ["Arial"]
- },
- "data": {
- "field": "NextSiblingID",
- "vAlign": 0,
- "hAlign": 1,
- "font": "Arail"
- }
- }]
- };
- $(document).ready(function () {
- autoFlashHeight();
- let RefreshBaseActn = function (tree) {
- if (locked) {
- return;
- }
- let setButtonValid = function (valid, btn) {
- if (valid) {
- btn.removeClass('disabled');
- } else {
- btn.addClass('disabled');
- }
- };
- setButtonValid(tree.selected && tree.selected.canUpLevel(), $('#upLevel'));
- setButtonValid(tree.selected && tree.selected.canDownLevel(), $('#downLevel'));
- setButtonValid(tree.selected && tree.selected.canUpMove(), $('#upMove'));
- setButtonValid(tree.selected && tree.selected.canDownMove(), $('#downMove'));
- setButtonValid(tree.selected ? true : false, $('#delete'));
- };
- let RefreshBillsData = function (datas) {
- datas.forEach(function (data) {
- let node = tree.findNode(data.data.ID);
- if (node) {
- setFlagsIndex(data.data, node.data.flagsIndex);
- $.extend(true, node.data, data.data);
- }
- });
- };
- let getNameValueComboCellType = function (datas) {
- let comboItems = [];
- for (let data of datas) {
- comboItems.push({ text: data.name, value: data.value });
- }
- let combo = new GC.Spread.Sheets.CellTypes.ComboBox();
- combo.editorValueType(GC.Spread.Sheets.CellTypes.EditorValueType.value)
- .items(comboItems);
- return combo;
- };
- let getFixedFlagCellType = function () {
- let billsFixedFlagData = JSON.parse(billsFixedFlagList);
- return getNameValueComboCellType(billsFixedFlagData);
- };
- let getNameToValueMap = function (listString) {
- let map = {};
- let datas = JSON.parse(listString);
- for (let data of datas) {
- map[data.name] = data.value;
- }
- return map;
- };
- let getTypeFlagCellType = function () {
- let billsTypeFlagData = JSON.parse(billsTypeFlagList);
- return getNameValueComboCellType(billsTypeFlagData);
- };
- let setFee = function (data, fullField, value) {
- let fields = fullField.split('.'), valueField = data;
- for (let i in fields) {
- if (valueField[fields[i]]) {
- if (i == fields.length - 1) {
- valueField[fields[i]] = value;
- } else {
- valueField = valueField[fields[i]];
- }
- } else {
- if (i == fields.length - 1) {
- valueField[fields[i]] = value;
- } else {
- valueField[fields[i]] = {};
- };
- valueField = valueField[fields[i]];
- }
- }
- };
- let getRealValue = function (value, map) {//中文到实际值的转换
- if (value) value = value.replace(/[\s\r\n]/g, "");//去掉空格,回车等无用字符
- if (map[value] !== undefined && map[value] !== null) value = map[value];
- return value;
- };
- let setUpdateData = function (node, data, col, value, setting) {
- let fieldName = setting.cols[col].data.field;
- let valueType = setting.cols[col].data.type;
- if (fieldName == 'type') {
- value = getRealValue(value, typeMap);
- }
- if (fieldName == 'flagsIndex.fixed.flag') {
- value = getRealValue(value, fixedFlagMap);
- }
- if (/flagsIndex/.test(fieldName)) {
- data.data.flags = [];
- let flagField = fieldName.split('.');
- data.data.flags.push({ fieldName: flagField[1], flag: value });
- } else {
- if (value && valueType == 'Number') value = parseInt(value);
- setFee(data.data, fieldName, value);
- }
- };
- let setFlagsIndex = function (data, flagsIndex) {
- if (data.flags) {
- flagsIndex ? data.flagsIndex = flagsIndex : data.flagsIndex = {};
- for (let flag of data.flags) {
- data.flagsIndex[flag.fieldName] = flag;
- }
- }
- };
- billsTemplateData = billsTemplateData.replace(/\n/g, '\\n');
- let templateData = JSON.parse(billsTemplateData);
- for (let data of templateData) {
- setFlagsIndex(data);
- /* if (data.flags) {
- data.flagsIndex = {};
- for (let flag of data.flags) {
- data.flagsIndex[flag.fieldName] = flag;
- }
- }*/
- }
- for (col of TEMPLATE_BILLS_SETTING.cols) {
- if (col.data.field === 'type' && TEMPLATE_BILLS_SETTING.cols.indexOf(col) !== TEMPLATE_BILLS_SETTING.treeCol) {
- col.data.cellType = getTypeFlagCellType();
- } else if (col.data.field === 'flagsIndex.fixed.flag' && TEMPLATE_BILLS_SETTING.cols.indexOf(col) !== TEMPLATE_BILLS_SETTING.treeCol) {
- col.data.cellType = getFixedFlagCellType();
- } else if (col.data.field === 'cantDelete' && TEMPLATE_BILLS_SETTING.cols.indexOf(col) !== TEMPLATE_BILLS_SETTING.treeCol) {
- col.data.cellType = new GC.Spread.Sheets.CellTypes.CheckBox();
- }
- }
- let tree = idTree.createNew({ id: 'ID', pid: 'ParentID', nid: 'NextSiblingID', rootId: -1, autoUpdate: true });
- let billsSpread = TREE_SHEET_HELPER.createNewSpread($('#billsSpread')[0]);
- sheetCommonObj.bindEscKey(billsSpread, [{ sheet: billsSpread.getSheet(0), editStarting: null, editEnded: billsOnEditEnded }]);
- let controller = TREE_SHEET_CONTROLLER.createNew(tree, billsSpread.getActiveSheet(), TEMPLATE_BILLS_SETTING);
- let fixedFlagMap = getNameToValueMap(billsFixedFlagList);
- let typeMap = getNameToValueMap(billsTypeFlagList);
- //format code
- //billsSpread.getSheet(0).setFormatter(-1, 1, '@');
- controller.bind('refreshBaseActn', RefreshBaseActn);
- function onButtonClicked(sender, info) {
- if (info.sheet.isEditing()) {
- info.sheet.endEdit(true);
- }
- const fieldName = controller.setting.cols[info.col].data.field;
- var node = controller.tree.items[info.row];
- if (node && fieldName === 'cantDelete') {
- const isChecked = Boolean(info.sheet.getValue(info.row, info.col));
- const data = { type: "update", data: { ID: node.getID() } };
- setFee(data.data, fieldName, isChecked);
- console.log(isChecked);
- const updateData = [data];
- CommonAjax.post(
- updateUrl,
- updateData,
- function (data) {
- setFee(node.data, fieldName, isChecked);
- controller.refreshTreeNode([node], false);
- },
- function () {
- controller.refreshTreeNode([node], false);
- }
- );
- }
- }
- function billsOnEditEnded(sender, info) {
- var node = controller.tree.items[info.row];
- var fieldName = controller.setting.cols[info.col].data.field;
- var valueType = controller.setting.cols[info.col].data.type;
- let value = info.editingText;
- if (node) {
- var data = { type: 'update', data: { ID: node.getID() } };
- if (/flagsIndex/.test(fieldName)) {
- data.data.flags = [];
- let flagField = fieldName.split('.');
- data.data.flags.push({ fieldName: flagField[1], flag: info.editingText });
- } else {
- if (value && valueType == 'Number') value = parseInt(info.editingText);
- setFee(data.data, fieldName, value);
- }
- var updateData = [data];
- CommonAjax.post(updateUrl, updateData, function (data) {
- setFee(node.data, fieldName, value);
- controller.refreshTreeNode([node], false);
- }, function () {
- controller.refreshTreeNode([node], false);
- });
- } else {
- info.sheet.getCell(info.row, info.col).value("");
- }
- }
- billsSpread.bind(GC.Spread.Sheets.Events.EditEnded, billsOnEditEnded);
- billsSpread.bind(GC.Spread.Sheets.Events.ButtonClicked, onButtonClicked);
- billsSpread.bind(GC.Spread.Sheets.Events.ClipboardPasted, function (e, info) {
- console.log("ClipboardPasted");
- var node, iRow, iCol, curRow, curCol, datas = [], data, fieldName, valueType, value, updateData;
- for (iRow = 0; iRow < info.cellRange.rowCount; iRow++) {
- curRow = info.cellRange.row + iRow;
- node = controller.tree.items[curRow];
- if (node) {
- data = { type: 'update', data: { ID: node.getID() } };
- for (iCol = 0; iCol < info.cellRange.colCount; iCol++) {
- curCol = info.cellRange.col + iCol;
- value = info.sheet.getText(curRow, curCol);
- setUpdateData(node, data, curCol, value, controller.setting);
- }
- datas.push(data);
- }
- };
- CommonAjax.post(updateUrl, datas, function (data) {
- RefreshBillsData(data);
- controller.showTreeData();
- }, function () {
- controller.showTreeData();
- });
- });
- billsSpread.bind(GC.Spread.Sheets.Events.RangeChanged, function (e, info) {
- let datas = [];
- let changGroup = _.groupBy(info.changedCells, 'row');
- for (let row in changGroup) {
- let node = controller.tree.items[row];
- if (node) {
- let data = { type: 'update', data: { ID: node.getID() } };
- for (let cell of changGroup[row]) {
- let value = info.sheet.getText(cell.row, cell.col);
- if (value == "") value = null;
- setUpdateData(node, data, cell.col, value, controller.setting);
- }
- datas.push(data);
- }
- }
- CommonAjax.post(updateUrl, datas, function (data) {
- RefreshBillsData(data);
- controller.showTreeData();
- }, function () {
- controller.showTreeData();
- });
- });
- tree.loadDatas(templateData);
- controller.showTreeData();
- let sel = billsSpread.getActiveSheet().getSelections()[0];
- controller.setTreeSelected(tree.items[sel.row == -1 ? 0 : sel.row]);//初始化选中项
- RefreshBaseActn(tree);
- lockUtil.lockSpreadsAndTools([billsSpread], $(document.body), locked);
- $('#insert').click(function () {
- let me = this;
- $(me).addClass('disabled');
- var selected = controller.tree.selected, updateData;
- if (selected) {
- updateData = controller.tree.getInsertData(selected.getParentID(), selected.getNextSiblingID());
- } else {
- updateData = controller.tree.getInsertData();
- }
- if (updateData.length > 0) {
- CommonAjax.post(updateUrl, updateData, function (data) {
- controller.insert();
- controller.showTreeData();
- $(me).removeClass('disabled');
- });
- } else {
- alert('新增节点失败, 请重试.');
- $(me).removeClass('disabled');
- }
- });
- $('#m_insert_confirm').click(function () {
- let me = this;
- let insertCount = $("#insertCount").val();
- if (isNaN(insertCount) || insertCount < 1) {
- $("#insertError").show();
- return;
- }
- $(me).addClass('disabled');
- let selected = controller.tree.selected, updateData;
- if (selected) {
- updateData = controller.tree.getInsertDatas(insertCount, selected.getParentID(), selected.getNextSiblingID());
- } else {
- updateData = controller.tree.getInsertDatas(insertCount);
- }
- if (updateData.length > 0) {
- CommonAjax.post(updateUrl, updateData, function (data) {
- data = _.filter(data, { 'type': 'new' });
- console.log(data);
- controller.m_insert(data);
- controller.showTreeData();
- $("#insertInputDiv").modal('hide');
- $("#insertError").hide();
- $(me).removeClass('disabled');
- });
- } else {
- alert('新增节点失败, 请重试.');
- $(me).removeClass('disabled');
- }
- /* var selected = controller.tree.selected, updateData;
- if (selected) {
- updateData = controller.tree.getInsertData(selected.getParentID(), selected.getNextSiblingID());
- } else {
- updateData = controller.tree.getInsertData();
- }
- if (updateData.length > 0) {
- CommonAjax.post(updateUrl, updateData, function (data) {
- controller.insert();
- controller.showTreeData();
- $(me).removeClass('disabled');
- });
- } else {
- alert('新增节点失败, 请重试.');
- $(me).removeClass('disabled');
- }*/
- });
- $('#delete').click(function () {
- let me = this;
- $(me).addClass('disabled');
- let [deleteMap, deleteNodes] = getNodesAndMapFromSheet(controller);
- if (deleteNodes.length > 0) {
- let updateData = controller.tree.getDeleteDatas(deleteMap, deleteNodes);
- CommonAjax.post(updateUrl, updateData, function (data) {
- controller.m_delete(deleteNodes);
- controller.showTreeData();
- $(me).removeClass('disabled');
- });
- }
- });
- $('#upLevel').click(function () {
- let me = this;
- $(me).addClass('disabled');
- let [dMap, dNodes] = getNodesAndMapFromSheet(controller);
- let newNodes = [dNodes[0]];
- if (dNodes.length > 1) {//如果是多选,则去掉与第一个节点不同级的节点
- for (let i = 1; i < dNodes.length; i++) {
- if (dNodes[i].parent == dNodes[0].parent) newNodes.push(dNodes[i])
- }
- }
- let updateDatas = controller.tree.getUpLevelDatas(newNodes);
- if (updateDatas.length > 0) {
- CommonAjax.post(updateUrl, updateDatas, function (data) {
- controller.m_upLevel(newNodes);
- for (let u of updateDatas) {
- let node = controller.tree.findNode(u.data.ID);
- refreshNodeData(node, u.data);
- }
- controller.showTreeData();
- $(me).removeClass('disabled');
- });
- }
- });
- $('#downLevel').click(function () {
- let me = this;
- $(me).addClass('disabled');
- let [dMap, dNodes] = getNodesAndMapFromSheet(controller);
- let newNodes = [dNodes[0]];
- if (dNodes.length > 1) {//如果是多选,则去掉与第一个节点不同级的节点
- for (let i = 1; i < dNodes.length; i++) {
- if (dNodes[i].parent == dNodes[0].parent) newNodes.push(dNodes[i])
- }
- }
- let updateDatas = controller.tree.getDownLevelDatas(newNodes);
- if (updateDatas.length > 0) {
- CommonAjax.post(updateUrl, updateDatas, function (data) {
- controller.m_downLevel(newNodes);
- for (let u of updateDatas) {
- let node = controller.tree.findNode(u.data.ID);
- refreshNodeData(node, u.data);
- }
- controller.showTreeData();
- $(me).removeClass('disabled');
- });
- }
- });
- $('#upMove').click(function () {
- let me = this;
- $(me).addClass('disabled');
- var selected = controller.tree.selected, updateData;
- if (selected) {
- updateData = selected.getUpMoveData();
- CommonAjax.post(updateUrl, updateData, function (data) {
- controller.upMove();
- controller.showTreeData();
- $(me).removeClass('disabled');
- });
- }
- });
- $('#downMove').click(function () {
- let me = this;
- $(me).addClass('disabled');
- var selected = controller.tree.selected, updateData;
- if (selected) {
- updateData = selected.getDownMoveData();
- CommonAjax.post(updateUrl, updateData, function (data) {
- controller.downMove();
- controller.showTreeData();
- $(me).removeClass('disabled');
- });
- }
- });
- function getNodesAndMapFromSheet(controller) {//表格中选中的节点整理,只留下父节点
- let selection = controller.sheet.getSelections()[0], map = {}, nodes = [];
- for (let i = 0; i < selection.rowCount; i++) {
- let tem_node = controller.tree.items[selection.row + i];
- if (i == 0) {//第一个直接添加;
- map[tem_node.getID()] = tem_node;
- nodes.push(tem_node);
- } else {
- setNodeToMapAndArray(tem_node, map, nodes);
- }
- }
- return [map, nodes];
- }
- function setNodeToMapAndArray(node, map, array) {
- let nodeID = node.getID();
- if (map[nodeID] == undefined || map[nodeID] == null) {
- newMap(node, node.parent, map, array)
- }
- function newMap(node, parent, map, array) {
- let nodeID = node.getID();
- if (parent == null) {//说明已经是最顶层了
- map[nodeID] = node;
- array.push(node);
- } else {
- let parentID = parent.getID();
- if (map[parentID] == undefined || map[parentID] == null) {
- newMap(node, parent.parent, map, array);
- }
- }
- }
- }
- function refreshNodeData(node, data) {
- for (let key in data) {
- if (key == 'ID') continue;
- node.data[key] = data[key];
- }
- }
- });
|