2020-01-30 20:59:37 +08:00
|
|
|
import {
|
|
|
|
|
appendChild,
|
2020-01-31 16:30:30 +08:00
|
|
|
removeChild,
|
|
|
|
|
createElement,
|
|
|
|
|
querySelector,
|
|
|
|
|
appendChildren,
|
2020-01-30 20:59:37 +08:00
|
|
|
} from './node-ops';
|
|
|
|
|
|
|
|
|
|
export function refactorCell(cell) {
|
|
|
|
|
let nodes = cell.childNodes;
|
2020-01-31 13:23:47 +08:00
|
|
|
let wrapper = createElement("div", "smart-table_cell");
|
2020-01-30 20:59:37 +08:00
|
|
|
while (nodes.length) {
|
|
|
|
|
appendChild(wrapper, nodes[0])
|
|
|
|
|
}
|
|
|
|
|
appendChild(cell, wrapper)
|
|
|
|
|
}
|
|
|
|
|
|
2020-02-03 14:06:31 +08:00
|
|
|
export function createTabelWrapper(className, vm, type, content, hasGutter) {
|
2020-01-31 13:23:47 +08:00
|
|
|
let wrapper = createElement("div", className);
|
|
|
|
|
let table = createElement("table", "smart-table_" + type);
|
2020-01-20 11:28:19 +08:00
|
|
|
table.style.width = (vm.size.tabelWidth - 1) + "px";
|
2020-02-03 14:06:31 +08:00
|
|
|
appendChildren(table, [createColgroup(vm.colgroup, vm.gutterWidth, hasGutter), content])
|
2020-01-30 20:59:37 +08:00
|
|
|
appendChild(wrapper, table)
|
2020-01-13 16:25:20 +08:00
|
|
|
return wrapper;
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-20 11:28:19 +08:00
|
|
|
export function replaceColGroup(vm, wrapper) {
|
2020-01-16 14:25:41 +08:00
|
|
|
let colgroup = createColgroup(vm.colgroup);
|
2020-01-30 20:59:37 +08:00
|
|
|
wrapper.replaceChild(colgroup, querySelector(wrapper, 'colgroup'));
|
2020-01-16 14:25:41 +08:00
|
|
|
}
|
|
|
|
|
|
2020-01-20 11:28:19 +08:00
|
|
|
export function getIntByAttr(el, key, def) {
|
2020-01-13 16:25:20 +08:00
|
|
|
return Number.parseInt(el.getAttribute(key) || def)
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-20 11:28:19 +08:00
|
|
|
export function getEmptyIndexInArray(array) {
|
2020-01-13 16:25:20 +08:00
|
|
|
for (let i = 0, len = array.length; i < len; i++) {
|
|
|
|
|
if (array[i] === undefined) {
|
|
|
|
|
return i
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-20 11:28:19 +08:00
|
|
|
export function throttle(delay, callback) {
|
2020-01-13 16:25:20 +08:00
|
|
|
let timeoutID;
|
|
|
|
|
let lastExec = 0;
|
|
|
|
|
|
2020-01-20 11:28:19 +08:00
|
|
|
function wrapper() {
|
2020-01-13 16:25:20 +08:00
|
|
|
|
|
|
|
|
let self = this;
|
|
|
|
|
let elapsed = new Date().getTime() - lastExec;
|
|
|
|
|
let args = arguments;
|
|
|
|
|
|
2020-01-20 11:28:19 +08:00
|
|
|
function exec() {
|
2020-01-13 16:25:20 +08:00
|
|
|
lastExec = new Date().getTime();
|
|
|
|
|
callback.apply(self, args)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (timeoutID) {
|
|
|
|
|
clearTimeout(timeoutID)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (elapsed > delay) {
|
|
|
|
|
exec()
|
|
|
|
|
} else {
|
|
|
|
|
timeoutID = setTimeout(exec, delay - elapsed)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return wrapper;
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-20 11:28:19 +08:00
|
|
|
export function debounce(delay, callback) {
|
2020-01-16 14:25:41 +08:00
|
|
|
let timeout = null;
|
2020-01-30 20:59:37 +08:00
|
|
|
return function() {
|
2020-01-16 14:25:41 +08:00
|
|
|
if (timeout !== null) clearTimeout(timeout);
|
|
|
|
|
timeout = setTimeout(callback, delay);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-02-03 14:06:31 +08:00
|
|
|
function createColgroup(arr, gutterWidth, hasGutter) {
|
2020-01-13 16:25:20 +08:00
|
|
|
if (!arr) return;
|
2020-01-30 20:59:37 +08:00
|
|
|
let colgroup = createElement("colgroup");
|
2020-01-13 16:25:20 +08:00
|
|
|
arr.forEach(item => {
|
2020-01-30 20:59:37 +08:00
|
|
|
let col = createElement("col");
|
2020-01-13 16:25:20 +08:00
|
|
|
col.setAttribute("width", item);
|
2020-01-30 20:59:37 +08:00
|
|
|
appendChild(colgroup, col)
|
2020-01-13 16:25:20 +08:00
|
|
|
})
|
2020-02-03 14:06:31 +08:00
|
|
|
if (hasGutter) {
|
|
|
|
|
let col = createElement("col");
|
|
|
|
|
col.setAttribute("width", gutterWidth)
|
|
|
|
|
appendChild(colgroup, col)
|
|
|
|
|
}
|
2020-01-13 16:25:20 +08:00
|
|
|
return colgroup;
|
2020-01-30 20:59:37 +08:00
|
|
|
}
|