565 lines
22 KiB
JavaScript
565 lines
22 KiB
JavaScript
function getPanelHeight(v) {
|
|
var list = $('.list-jqgrid').position();
|
|
var position = list.top + v +'px';
|
|
return 'calc(100vh - ' + position + ')';
|
|
}
|
|
|
|
(function (window, $) {
|
|
|
|
const localeText = {
|
|
page: "页",
|
|
more: "更多",
|
|
to: "到",
|
|
of: "至",
|
|
next: "下一页",
|
|
last: "上一页",
|
|
first: "首页",
|
|
previous: "上一页",
|
|
loadingOoo: "加载中...",
|
|
selectAll: "查询全部",
|
|
searchOoo: "查询...",
|
|
blanks: "空白",
|
|
filterOoo: "过滤...",
|
|
applyFilter: "daApplyFilter...",
|
|
equals: "相等",
|
|
notEqual: "不相等",
|
|
lessThan: "小于",
|
|
greaterThan: "大于",
|
|
lessThanOrEqual: "小于等于",
|
|
greaterThanOrEqual: "大于等于",
|
|
inRange: "范围",
|
|
contains: "包含",
|
|
notContains: "不包含",
|
|
startsWith: "开始于",
|
|
endsWith: "结束于",
|
|
group: "组",
|
|
columns: "列",
|
|
filters: "筛选",
|
|
rowGroupColumns: "laPivot Cols",
|
|
rowGroupColumnsEmptyMessage: "la drag cols to group",
|
|
valueColumns: "laValue Cols",
|
|
pivotMode: "laPivot-Mode",
|
|
groups: "laGroups",
|
|
values: "值",
|
|
pivots: "laPivots",
|
|
valueColumnsEmptyMessage: "la drag cols to aggregate",
|
|
pivotColumnsEmptyMessage: "la drag here to pivot",
|
|
toolPanelButton: "la tool panel",
|
|
noRowsToShow: "数据为空",
|
|
pinColumn: "laPin Column",
|
|
//valueAggregation: "laValue Agg",
|
|
//autosizeThiscolumn: "laAutosize Diz",
|
|
//autosizeAllColumns: "laAutsoie em All",
|
|
groupBy: "排序",
|
|
ungroupBy: "不排序",
|
|
resetColumns: "重置列",
|
|
expandAll: "展开全部",
|
|
collapseAll: "关闭",
|
|
toolPanel: "工具面板",
|
|
export: "导出",
|
|
csvExport: "导出为CSV格式文件",
|
|
excelExport: "导出到Excel",
|
|
//pinLeft: "laPin <<",
|
|
//pinRight: "laPin >>",
|
|
//noPin: "laDontPin <>",
|
|
sum: "总数",
|
|
min: "最小值",
|
|
max: "最大值",
|
|
none: "无",
|
|
count: "总",
|
|
average: "平均值",
|
|
copy: "复制",
|
|
copyWithHeaders: "携带表头复制",
|
|
ctrlC: "ctrl + C",
|
|
paste: "粘贴",
|
|
ctrlV: "ctrl + V"
|
|
};
|
|
|
|
function OptionCellRenderer() {}
|
|
OptionCellRenderer.prototype.init = function (params) {
|
|
if (params.node.rowPinned) {
|
|
return;
|
|
}
|
|
this.eGui = document.createElement('div');
|
|
this.eGui.className = 'options';
|
|
this.eGui.innerHTML = '<a data-toggle="event" data-action="option" data-type="add" data-index="'+ params.rowIndex +'" data-id="'+ params.data.id +'" class="fa fa-plus" title="新增行"></a> <a data-toggle="event" data-action="option" data-type="delete" data-id="'+ params.data.id +'" data-index="'+ params.rowIndex +'" class="fa fa-times" title="删除行"></a></div>';
|
|
};
|
|
OptionCellRenderer.prototype.getGui = function () {
|
|
return this.eGui;
|
|
};
|
|
|
|
function HtmlCellRenderer() {}
|
|
HtmlCellRenderer.prototype.init = function (params) {
|
|
this.eGui = document.createElement('span');
|
|
this.eGui.innerHTML = (params.value || '');
|
|
};
|
|
HtmlCellRenderer.prototype.getGui = function () {
|
|
return this.eGui;
|
|
};
|
|
|
|
function ActionCellRenderer() {}
|
|
ActionCellRenderer.prototype.init = function (params) {
|
|
var gridOptions = params.api.gridCore.gridOptions;
|
|
if (params.node.rowPinned) {
|
|
return;
|
|
}
|
|
if (params.data == undefined) {
|
|
return;
|
|
}
|
|
var data = params.data;
|
|
|
|
var links = '';
|
|
if (data.master_id > 0) {
|
|
params.colDef.options.forEach(function (action) {
|
|
if (action.display) {
|
|
var html = '<a data-toggle="event" class="option" data-action="' + action.action + '" data-master_name="' + data.name + '" data-master_id="' + data.master_id + '" href="javascript:;">' + action.name + '</a>';
|
|
links += gridOptions.actionCellBeforeRender(html, action, data) || '';
|
|
}
|
|
});
|
|
}
|
|
this.eGui = document.createElement('span');
|
|
this.eGui.innerHTML = links;
|
|
};
|
|
ActionCellRenderer.prototype.getGui = function () {
|
|
return this.eGui;
|
|
};
|
|
|
|
function SelectCellEditor() {}
|
|
SelectCellEditor.prototype.init = function(params) {
|
|
this.grid = params;
|
|
this.selectedKey = null;
|
|
this.items = params.colDef.cellEditorParams.values;
|
|
this.eInput = document.createElement('input');
|
|
this.eInput.value = params.value || '';
|
|
this.eInput.className = 'ag-cell-edit-input form-control';
|
|
};
|
|
SelectCellEditor.prototype.getGui = function(params) {
|
|
return this.eInput;
|
|
};
|
|
|
|
SelectCellEditor.prototype.afterGuiAttached = function() {
|
|
var me = this;
|
|
var grid = me.grid;
|
|
var oValue = me.eInput.value;
|
|
// 初始化编辑器
|
|
$(me.eInput).agDropdownCellEditor({
|
|
grid: me,
|
|
arrow: 'fa-caret-down',
|
|
data: {
|
|
items: me.items,
|
|
selected: grid.data[grid.select_key],
|
|
},
|
|
select: function(item) {
|
|
if (item) {
|
|
grid.data[grid.select_key] = item.id;
|
|
me.eInput.value = item.name;
|
|
me.selectedKey = item.id;
|
|
} else {
|
|
me.eInput.value = oValue;
|
|
}
|
|
grid.stopEditing();
|
|
}
|
|
});
|
|
me.eInput.focus();
|
|
me.eInput.select();
|
|
};
|
|
SelectCellEditor.prototype.getValue = function() {
|
|
return this.eInput.value;
|
|
};
|
|
SelectCellEditor.prototype.destroy = function() {
|
|
$('body').find('.combo-select').remove();
|
|
};
|
|
|
|
function CheckboxCellRenderer() {}
|
|
CheckboxCellRenderer.prototype.init = function (params) {
|
|
var value = params.value;
|
|
var values = params.colDef.cellEditorParams.values;
|
|
this.eGui = document.createElement('div');
|
|
this.eGui.innerHTML = values[value] || values[0];
|
|
};
|
|
CheckboxCellRenderer.prototype.getGui = function () {
|
|
return this.eGui;
|
|
};
|
|
function CheckboxCellEditor() {}
|
|
CheckboxCellEditor.prototype.init = function(params) {
|
|
var value = params.value;
|
|
this.eInput = document.createElement('input');
|
|
this.eInput.type = 'checkbox';
|
|
this.eInput.checked = value;
|
|
this.eInput.value = value;
|
|
};
|
|
CheckboxCellEditor.prototype.getGui = function(params) {
|
|
return this.eInput;
|
|
};
|
|
|
|
CheckboxCellEditor.prototype.afterGuiAttached = function() {
|
|
var me = this;
|
|
me.eInput.focus();
|
|
me.eInput.select();
|
|
};
|
|
CheckboxCellEditor.prototype.getValue = function() {
|
|
return this.eInput.checked ? 1 : 0;
|
|
};
|
|
CheckboxCellEditor.prototype.destroy = function() {
|
|
};
|
|
|
|
function DialogCellEditor() {}
|
|
DialogCellEditor.prototype.init = function(params) {
|
|
this.params = params;
|
|
this.eInput = document.createElement('div');
|
|
this.eInput.tabIndex = '-1';
|
|
var key = params.colDef.field + '_' + params.data.id;
|
|
var query = params.query;
|
|
query.multi = 1;
|
|
query.is_grid = 1;
|
|
query.url = params.url;
|
|
query.grid_id = params.data.id;
|
|
query.title = params.title;
|
|
var url = '';
|
|
$.each(query, function(k, v) {
|
|
url += ' data-' + k + '="' + v + '"';
|
|
});
|
|
this.query = query;
|
|
this.eInput.innerHTML = '<input class="ag-cell-edit-input" value="' + (params.value || '') + '" id="' + key + '"><a class="combo-arrow" data-toggle="dialog-view" '+ url +'><i class="fa fa-search"></i></a>';
|
|
this.eInput.className = 'ag-input-wrapper ag-input-dialog-wrapper';
|
|
};
|
|
DialogCellEditor.prototype.getGui = function(params) {
|
|
return this.eInput;
|
|
};
|
|
|
|
DialogCellEditor.prototype.afterGuiAttached = function() {
|
|
var me = this;
|
|
$(me.eInput).find('input').gdooSuggest({item:me.params.data, query:me.query})
|
|
.on('onSelect', function(e, item) {
|
|
me.params.data[me.query.name] = item[me.query.name];
|
|
me.eInput.querySelector('input').value = item[me.query.name];
|
|
});
|
|
me.eInput.querySelector('input').select();
|
|
};
|
|
DialogCellEditor.prototype.getValue = function() {
|
|
return this.params.data[this.params.query.name];
|
|
};
|
|
DialogCellEditor.prototype.destroy = function() {
|
|
var me = this;
|
|
$(me.eInput).find('input').off();
|
|
};
|
|
|
|
DialogCellEditor.prototype.isPopup = function () {
|
|
return false;
|
|
};
|
|
|
|
function DateCellEditor() {}
|
|
DateCellEditor.prototype.init = function(params) {
|
|
this.params = params.colDef.cellEditorParams;
|
|
this.eInput = document.createElement('div');
|
|
this.eInput.innerHTML = '<input type="text" class="ag-cell-edit-input" data-toggle="date" value="' + (params.value || '') + '">';
|
|
this.eInput.className = 'ag-input-wrapper ag-input-date-wrapper';
|
|
};
|
|
DateCellEditor.prototype.getGui = function(params) {
|
|
return this.eInput;
|
|
};
|
|
DateCellEditor.prototype.afterGuiAttached = function() {
|
|
this.eInput.querySelector('input').click();
|
|
};
|
|
DateCellEditor.prototype.getValue = function() {
|
|
return this.eInput.querySelector('input').value;
|
|
};
|
|
DateCellEditor.prototype.destroy = function() {
|
|
};
|
|
|
|
function agGridOptions() {
|
|
|
|
// 定义ag-grid默认参数
|
|
var gridOptions = {
|
|
defaultColDef: {
|
|
minWidth: 100,
|
|
enableRowGroup: true,
|
|
enablePivot: true,
|
|
enableValue: true,
|
|
sortable: true,
|
|
resizable: true,
|
|
filter: true,
|
|
comparator: function(a, b) {
|
|
if (this.cellRenderer == 'htmlCellRenderer') {
|
|
a = delHtmlTag(a);
|
|
b = delHtmlTag(b);
|
|
return a.localeCompare(b);
|
|
}
|
|
return typeof a === 'string' ? a.localeCompare(b) : (a > b ? 1 : (a < b ? -1 : 0));
|
|
}
|
|
},
|
|
pinnedBottomRowData: [],
|
|
rowDragManaged: true,
|
|
suppressRowClickSelection: true,
|
|
rowMultiSelectWithClick: false,
|
|
rowSelection: 'multiple',
|
|
localeText: localeText,
|
|
suppressAnimationFrame: true,
|
|
// suppressAutoSize: true,
|
|
suppressContextMenu: true,
|
|
// 关闭参数检查
|
|
suppressPropertyNamesCheck: true,
|
|
// pagination: true,
|
|
// rowModelType: 'infinite',
|
|
// paginationPageSize: 25,
|
|
// cacheBlockSize: 25,
|
|
// suppressPaginationPanel: true,
|
|
suppressCellSelection: true,
|
|
enableCellTextSelection: true,
|
|
// 自定义后端数据地址
|
|
remoteDataUrl: '',
|
|
remoteParams: {},
|
|
dialogList: {},
|
|
editableList: {},
|
|
autoColumnsToFit: true,
|
|
lastEditCell: {},
|
|
selectedRows: [],
|
|
pager: false,
|
|
pagerDom: null,
|
|
pagePer: 50,
|
|
// 格式化数字时候默认值是否强行为空
|
|
numberEmptyDefaultValue: false,
|
|
pageList: [50, 100, 500, 1000, 2000, 5000, 10000, 20000, 50000],
|
|
|
|
onCellEditingStarted(params) {
|
|
this.lastEditCell = params;
|
|
},
|
|
remoteSuccessed() {},
|
|
onGridSizeChanged(params) {
|
|
},
|
|
onGridReady(params) {
|
|
},
|
|
onFirstDataRendered(params) {
|
|
var me = this;
|
|
var api = me.api;
|
|
if (me.autoColumnsToFit) {
|
|
api.sizeColumnsToFit();
|
|
}
|
|
|
|
if (typeof me.onCustomFirstDataRendered == "function") {
|
|
me.onCustomFirstDataRendered.call(me, params);
|
|
}
|
|
|
|
// 计算合计行
|
|
me.generatePinnedBottomData();
|
|
},
|
|
onCellValueChanged(params) {
|
|
this.generatePinnedBottomData();
|
|
},
|
|
getRowStyle(params) {
|
|
},
|
|
onRowClicked(params) {
|
|
var selected = params.node.isSelected();
|
|
if (selected === false) {
|
|
params.node.setSelected(true, true);
|
|
}
|
|
},
|
|
getSelectedRows() {
|
|
return this.selectedRows;
|
|
},
|
|
onRowSelected(params) {
|
|
var me = this;
|
|
var node = params.node;
|
|
if (node.selected) {
|
|
me.selectedRows.push(node.data);
|
|
} else {
|
|
for (let i = 0; i < me.selectedRows.length; i++) {
|
|
var select = me.selectedRows[i];
|
|
if (node.data.id == select.id) {
|
|
me.selectedRows.splice(i, 1);
|
|
}
|
|
}
|
|
}
|
|
if (typeof me.onCustomRowSelected == "function") {
|
|
me.onCustomRowSelected.call(me, params);
|
|
}
|
|
},
|
|
onRowDoubleClicked(params) {
|
|
console.log('onRowDoubleClicked');
|
|
},
|
|
/*
|
|
getRowNodeId_bak(data) {
|
|
if (data.id) {
|
|
return data.id;
|
|
}
|
|
},
|
|
*/
|
|
columnTypes: {
|
|
number: {
|
|
cellClass: 'ag-cell-number',
|
|
valueFormatter: function (params) {
|
|
var me = this;
|
|
if (params.node.rowPinned) {
|
|
if(params.colDef.calcFooter) {
|
|
} else {
|
|
return '';
|
|
}
|
|
}
|
|
var options = params.colDef.numberOptions || {};
|
|
var places = options.places == undefined ? 2 : options.places;
|
|
var separator = options.separator == undefined ? '.' : options.separator;
|
|
var thousands = options.thousands == undefined ? ',' : options.thousands;
|
|
var defaultValue = options.default == undefined ? 0 : options.default;
|
|
var value = parseFloat(params.value);
|
|
|
|
if (isNaN(value) || value == 0) {
|
|
return gridOptions.numberEmptyDefaultValue == false ? defaultValue : '';
|
|
}
|
|
value = number_format(value, places, separator, thousands);
|
|
return value;
|
|
},
|
|
valueParser: function (params) {
|
|
var value = parseFloat(params.newValue);
|
|
if (isNaN(value)) {
|
|
return 0;
|
|
}
|
|
return value;
|
|
}
|
|
},
|
|
sn: {
|
|
cellClass: 'ag-cell-sn',
|
|
valueFormatter: function (params) {
|
|
if (params.node.rowPinned) {
|
|
return '';
|
|
}
|
|
return parseInt(params.node.childIndex) + 1
|
|
},
|
|
valueParser: function (params) {
|
|
return parseFloat(params.newValue);
|
|
}
|
|
},
|
|
datetime: {
|
|
cellClass: 'ag-cell-datetime',
|
|
valueFormatter: function (params) {
|
|
if (params.node.rowPinned) {
|
|
return '';
|
|
}
|
|
return format_datetime(params.value);
|
|
},
|
|
valueParser: function (params) {
|
|
return parseFloat(params.newValue);
|
|
}
|
|
},
|
|
date: {
|
|
cellClass: 'ag-cell-date',
|
|
valueFormatter: function (params) {
|
|
if (params.node.rowPinned) {
|
|
return '';
|
|
}
|
|
return format_date(params.value);
|
|
},
|
|
valueParser: function (params) {
|
|
return parseFloat(params.newValue);
|
|
}
|
|
}
|
|
},
|
|
components: {
|
|
'optionCellRenderer': OptionCellRenderer,
|
|
'actionCellRenderer': ActionCellRenderer,
|
|
'htmlCellRenderer': HtmlCellRenderer,
|
|
'selectCellEditor': SelectCellEditor,
|
|
'dialogCellEditor': DialogCellEditor,
|
|
'dateCellEditor': DateCellEditor,
|
|
'checkboxCellEditor': CheckboxCellEditor,
|
|
'checkboxCellRenderer': CheckboxCellRenderer,
|
|
},
|
|
overlayLoadingTemplate: '<span class="ag-overlay-loading-center">数据加载中...</span>',
|
|
overlayNoRowsTemplate: '<div style="padding-top:20px;"><img alt="暂无数据" src=""><div style="padding-top:5px;color:#999;">暂无数据</div></div>',
|
|
};
|
|
|
|
gridOptions.generatePinnedBottomData = function() {
|
|
var me = this;
|
|
var result = {};
|
|
var renderer = false;
|
|
var columns = gridOptions.columnApi.getAllGridColumns();
|
|
columns.forEach(function (item) {
|
|
if (item.colDef.calcFooter) {
|
|
renderer = true;
|
|
result[item.colId] = me.calculatePinnedBottomData(item);
|
|
}
|
|
});
|
|
if (renderer) {
|
|
me.api.setPinnedBottomRowData([result]);
|
|
}
|
|
}
|
|
gridOptions.calculatePinnedBottomData = function(item) {
|
|
var value = 0;
|
|
gridOptions.api.forEachNode(function (row) {
|
|
value += toNumber(row.data[item.colId]);
|
|
});
|
|
return value == 0 ? '' : value;
|
|
}
|
|
|
|
// 格式化行按钮
|
|
gridOptions.actionCellBeforeRender = function(html, action, data) {
|
|
return html;
|
|
}
|
|
|
|
gridOptions.remoteData = function (params, success) {
|
|
var me = this;
|
|
let remoteParams = gridOptions.remoteParams;
|
|
for (let key in params) {
|
|
remoteParams[key] = params[key];
|
|
}
|
|
gridOptions.api.showLoadingOverlay();
|
|
$.post(gridOptions.remoteDataUrl, remoteParams, function (res) {
|
|
|
|
if (res.per_page) {
|
|
if (me.pagerDom === null) {
|
|
var div = me.api.gridCore.eGridDiv;
|
|
var pageId = div.id + '-pager';
|
|
$(div).after('<div id="' + pageId + '" class="ag-pager"></div>');
|
|
me.pagerDom = $('#' + pageId).Paging({
|
|
pagesize: res.per_page,
|
|
count: res.total,
|
|
current: res.current_page,
|
|
pageSizeList: [50, 100, 500, 1000, 2000, 5000, 10000, 20000, 50000],
|
|
callback: function(page, size, count) {
|
|
me.remoteData2({page: page, limit: size});
|
|
}
|
|
});
|
|
} else {
|
|
me.pagerDom[0].render({
|
|
pagesize: res.per_page,
|
|
count: res.total,
|
|
current: res.current_page
|
|
});
|
|
}
|
|
}
|
|
|
|
gridOptions.api.hideOverlay();
|
|
gridOptions.api.setRowData(res.data);
|
|
gridOptions.generatePinnedBottomData();
|
|
|
|
if (typeof success === 'function') {
|
|
success(res);
|
|
}
|
|
gridOptions.remoteSuccessed.call(gridOptions, res.data);
|
|
|
|
}, 'json');
|
|
}
|
|
|
|
gridOptions.remoteData2 = function (params, success) {
|
|
var me = this;
|
|
let remoteParams = gridOptions.remoteParams;
|
|
for (let key in params) {
|
|
remoteParams[key] = params[key];
|
|
}
|
|
gridOptions.api.showLoadingOverlay();
|
|
$.post(gridOptions.remoteDataUrl, remoteParams, function (res) {
|
|
|
|
gridOptions.api.hideOverlay();
|
|
gridOptions.api.setRowData(res.data);
|
|
gridOptions.generatePinnedBottomData();
|
|
if (typeof success === 'function') {
|
|
success(res);
|
|
}
|
|
gridOptions.remoteSuccessed.call(gridOptions, res.data);
|
|
|
|
}, 'json');
|
|
}
|
|
|
|
return gridOptions;
|
|
}
|
|
window.agGridOptions = agGridOptions;
|
|
})(window, jQuery); |