UNPKG

bee-table

Version:
520 lines (477 loc) 15.9 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.Event = exports.EventUtil = exports.tryParseInt = undefined; var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; exports.measureScrollbar = measureScrollbar; exports.myBrowser = myBrowser; exports.debounce = debounce; exports.warningOnce = warningOnce; exports.getOffset = getOffset; exports.addClass = addClass; exports.removeClass = removeClass; exports.ObjectAssign = ObjectAssign; exports.closest = closest; exports.getMaxColChildrenLength = getMaxColChildrenLength; exports.getColChildrenLength = getColChildrenLength; exports.DicimalFormater = DicimalFormater; exports.checkDicimalInvalid = checkDicimalInvalid; exports.formatMoney = formatMoney; exports.convertListToTree = convertListToTree; var _warning = require('warning'); var _warning2 = _interopRequireDefault(_warning); var _parseInt = require('lodash/parseInt'); var _parseInt2 = _interopRequireDefault(_parseInt); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } var scrollbarSize = void 0; // Measure scrollbar width for padding body during modal show/hide var scrollbarMeasure = { position: 'absolute', top: '-9999px', width: '50px', height: '50px', overflow: 'scroll' }; //注意需要处理各系统及各浏览器的兼容性 function measureScrollbar(selectors) { var direction = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'vertical'; if (typeof document === 'undefined' || typeof window === 'undefined') { return 0; } if (scrollbarSize) { //计算一次即可 return scrollbarSize; } var brow = myBrowser(); var containerDom = selectors && document.querySelector(selectors) || document.body; var doubleDiv = function doubleDiv() { var scrollDivParent = document.createElement('div'); scrollDivParent.setAttribute("id", 'measureScrollbar_temp'); scrollDivParent.style.position = 'absolute'; scrollDivParent.style.top = '-9999px'; scrollDivParent.style.overflow = 'scroll'; // scrollDivParent.style.background = 'red'; scrollDivParent.style.width = '50px'; scrollDivParent.style.height = '100px'; var scrollDivChild = document.createElement('div'); // scrollDivChild.style.background = 'green'; scrollDivChild.style.height = '200px'; scrollDivChild.style.flex = "1"; scrollDivParent.appendChild(scrollDivChild); var a = document.getElementById('measureScrollbar_temp'); if (a) { containerDom.replaceChild(scrollDivParent, a); } else { containerDom.appendChild(scrollDivParent); } var barSize = scrollDivParent.getBoundingClientRect().width - scrollDivChild.getBoundingClientRect().width; containerDom.removeChild(scrollDivParent); scrollDivParent = null; scrollDivChild = null; return barSize; }; var singleDiv = function singleDiv() { var scrollDiv = document.createElement('div'); Object.keys(scrollbarMeasure).forEach(function (scrollProp) { scrollDiv.style[scrollProp] = scrollbarMeasure[scrollProp]; }); containerDom.appendChild(scrollDiv); var barSize = scrollDiv.offsetWidth - scrollDiv.clientWidth; containerDom.removeChild(scrollDiv); return barSize; }; if (brow.osType == 'Win') { switch (brow.browserType) { case "IE": case "FF": scrollbarSize = doubleDiv(); //window系统下firefox的offsetWidth同clientWidth一致,所以通过父子容器间带滚动条的墨盒尺寸计算出滚动条宽度 break; default: scrollbarSize = singleDiv(); //注意:chrome浏览器可以自定义宽度::-webkit-scrollbar{width:8px} } } else if (brow.osType == 'Mac') { switch (brow.browserType) { case "FF": scrollbarSize = 8; break; default: scrollbarSize = singleDiv(); } } else { scrollbarSize = singleDiv(); } return scrollbarSize; } function myBrowser() { var userAgent = navigator.userAgent; //取得浏览器的userAgent字符串 var browserType = '', osType = ''; if (userAgent.indexOf("Opera") > -1) { //判断是否Opera浏览器 browserType = "Opera"; } else if (userAgent.indexOf("Firefox") > -1) { //判断是否Firefox浏览器 browserType = "FF"; } else if (userAgent.indexOf("Chrome") > -1) { browserType = "Chrome"; } else if (userAgent.indexOf("Safari") > -1) { //判断是否Safari浏览器 browserType = "Safari"; } else if (userAgent.indexOf("compatible") > -1 && userAgent.indexOf("MSIE") > -1 || userAgent.indexOf('Trident') > -1 && userAgent.indexOf("rv:11.0") > -1 //ie版本11 ) { //判断是否IE浏览器 browserType = "IE"; } if (userAgent.indexOf("Win") > -1) { osType = 'Win'; } else if (userAgent.indexOf("Mac") > -1) { osType = 'Mac'; } return { browserType: browserType, osType: osType }; } function debounce(func, wait, immediate) { var timeout = void 0; return function debounceFunc() { var context = this; var args = arguments; // https://fb.me/react-event-pooling if (args[0] && args[0].persist) { args[0].persist(); } var later = function later() { timeout = null; if (!immediate) { func.apply(context, args); } }; var callNow = immediate && !timeout; clearTimeout(timeout); timeout = setTimeout(function () { later(); }, wait); // 兼容火狐浏览器的写法 if (callNow) { func.apply(context, args); } }; } var warned = {}; function warningOnce(condition, format, args) { if (!warned[format]) { (0, _warning2["default"])(condition, format, args); warned[format] = true; } } function getOffset(Node, offset) { if (!offset) { offset = {}; offset.top = 0; offset.left = 0; } if (Node == document.body) { return offset; } offset.top += Node.offsetTop; offset.left += Node.offsetLeft; if (Node.offsetParent) return getOffset(Node.offsetParent, offset);else return offset; }; var tryParseInt = exports.tryParseInt = function tryParseInt(value) { var defaultValue = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; var resultValue = (0, _parseInt2["default"])(value); if (isNaN(resultValue)) { return defaultValue; } return resultValue; }; function addClass(elm, className) { if (!className) return; var els = Array.isArray(elm) ? elm : [elm]; els.forEach(function (el) { if (el.classList) { el.classList.add(className.split(' ')); } else { el.className += ' ' + className; } }); } function removeClass(elm, className) { if (!className) return; var els = Array.isArray(elm) ? elm : [elm]; els.forEach(function (el) { if (el.classList) { el.classList.remove(className.split(' ')); } else { el.className = el.className.replace(new RegExp('(^|\\b)' + className.split(' ').join('|') + '(\\b|$)', 'gi'), ' '); } }); } /** * 简单数组数据对象拷贝 * @param {*} obj 要拷贝的对象 */ function ObjectAssign(obj) { var b = obj instanceof Array; var tagObj = b ? [] : {}; if (b) { //数组 obj.forEach(function (da) { var _da = {}; _extends(_da, da); tagObj.push(_da); }); } else { _extends(tagObj, obj); } return tagObj; } /** * 获取某个父元素 * */ function closest(ele, selector) { var matches = ele.matches || ele.webkitMatchesSelector || ele.mozMatchesSelector || ele.msMatchesSelector; if (matches) { while (ele) { if (matches.call(ele, selector)) { return ele; } else { ele = ele.parentElement; } } } return null; } function getMaxColChildrenLength(columns) { var arr = []; arr = columns.map(function (item, index) { var chilrenLen = 0; if (item.children) { chilrenLen = getColChildrenLength(item.children, chilrenLen + 1); } return chilrenLen; }); var max = Math.max.apply(null, arr); return max; } function getColChildrenLength(columns, chilrenLen) { columns.forEach(function (item, index) { if (item.children) { chilrenLen = getColChildrenLength(item.children, chilrenLen + 1); } }); return chilrenLen; } function addHandler(element, type, handler) { if (!element) return; var event = null; if (element.addEventListener) { //检测是否为DOM2级方法 event = element.addEventListener(type, handler, false); } else if (element.attachEvent) { //检测是否为IE级方法 event = element.attachEvent("on" + type, handler); } else { //检测是否为DOM0级方法 event = element["on" + type] = handler; } return event; } function removeHandler(element, type, handler) { if (element && element.removeEventListener) { //element&& ie11报错兼容 element.removeEventListener(type, handler, false); } else if (element && element.detachEvent) { element.detachEvent("on" + type, handler); } else if (element) { element["on" + type] = null; } } function addHandlerArray(elemArray, type, handler) { if (!elemArray || !elemArray.length) return; for (var i = 0; i < elemArray.length; i++) { var elem = elemArray[i]; addHandler(elem, type, handler); } } function removeHandlerArray(elemArray, type, handler) { if (!elemArray || !elemArray.length) return; for (var i = 0; i < elemArray.length; i++) { var elem = elemArray[i]; removeHandler(elem, type, handler); } } //获取事件对象的兼容性写法 function getEvent(event) { return event ? event : window.event; } //获取事件对象目标的兼容性写法 function getTarget(event) { return event.target || event.srcElement; } function preventDefault(event) { if (event.preventDefault) { event.preventDefault(); } else { event.returnValue = false; } } function stopPropagation(event) { if (event.stopPropagation) { event.stopPropagation(); } else { event.cancelBubble = true; } } //是否支持触摸事件 function isSupportTouch() { var support = { touch: !!('ontouchstart' in window || window.DocumentTouch && document instanceof window.DocumentTouch) }; return support; } //用事件冒泡方式,如果想兼容事件捕获只需要添加个bool参数 var EventUtil = exports.EventUtil = { addHandler: addHandler, removeHandler: removeHandler /* * 处理精度 */ };function DicimalFormater(value, precision) { var value = value + '', precision = precision ? precision : 0; for (var i = 0; i < value.length; i++) { if ("-0123456789.".indexOf(value.charAt(i)) == -1) return ""; } return checkDicimalInvalid(value, precision); }; function checkDicimalInvalid(value, precision) { if (value == null || isNaN(value)) return ""; // 浮点数总位数不能超过10位 var digit = parseFloat(value); var result = (digit * Math.pow(10, precision) / Math.pow(10, precision)).toFixed(precision); if (result == "NaN") return ""; return result; }; /** * 将数值转化为货币类型 * @param {*} number 数值 * @param {*} places 精度 * @param {*} thousand 是否展示千分位 */ function formatMoney(number, places, thousand) { number = number || 0; places = !isNaN(places = Math.abs(places)) ? places : 2; var thousandSymbol = thousand ? "," : ''; var negative = number < 0 ? "-" : ""; var i = (0, _parseInt2["default"])(number = Math.abs(+number || 0).toFixed(places), 10) + ""; var j = (j = i.length) > 3 ? j % 3 : 0; return negative + (j ? i.substr(0, j) + thousandSymbol : "") + i.substr(j).replace(/(\d{3})(?=\d)/g, "$1" + thousandSymbol) + (places ? '.' + Math.abs(number - i).toFixed(places).slice(2) : ""); } var Event = exports.Event = { addHandler: addHandler, removeHandler: removeHandler, addHandlerArray: addHandlerArray, removeHandlerArray: removeHandlerArray, isSupportTouch: isSupportTouch, getEvent: getEvent, getTarget: getTarget, preventDefault: preventDefault, stopPropagation: stopPropagation /** * 将一维数组转换为树结构 * @param {*} treeData 扁平结构的 List 数组 * @param {*} attr 属性配置设置 * @param {*} flatTreeKeysMap 存储所有 key-value 的映射,方便获取各节点信息 */ };function convertListToTree(treeData, attr, flatTreeKeysMap) { var tree = []; //存储所有一级节点 var resData = treeData, //resData 存储截取的节点 + 父节点(除一级节点外) resKeysMap = {}, //resData 的Map映射 treeKeysMap = {}; //tree 的Map映射 resData.map(function (element) { var key = attr.id; resKeysMap[element[key]] = element; }); // 查找父节点,为了补充不完整的数据结构 var findParentNode = function findParentNode(node) { var parentKey = node[attr.parendId]; if (parentKey !== attr.rootId) { //如果不是根节点,则继续递归 var item = flatTreeKeysMap[parentKey]; // 用 resKeysMap 判断,避免重复计算某节点的父节点 if (resKeysMap.hasOwnProperty(item[attr.id])) return; resData.unshift(item); resKeysMap[item[attr.id]] = item; findParentNode(item); } else { // 用 treeKeysMap 判断,避免重复累加 if (!treeKeysMap.hasOwnProperty(node[attr.id])) { var key = node.key, title = node.title, children = node.children, _isLeaf = node._isLeaf, otherProps = _objectWithoutProperties(node, ['key', 'title', 'children', '_isLeaf']); var obj = { key: key, title: title, _isLeaf: _isLeaf, children: [] }; tree.push(_extends(obj, _extends({}, otherProps))); treeKeysMap[key] = node; } } }; // 遍历 resData ,找到所有的一级节点 for (var i = 0; i < resData.length; i++) { var item = resData[i]; if (item[attr.parendId] === attr.rootId && !treeKeysMap.hasOwnProperty(item[attr.id])) { //如果是根节点,就存放进 tree 对象中 var key = item.key, title = item.title, children = item.children, otherProps = _objectWithoutProperties(item, ['key', 'title', 'children']); var obj = { key: item[attr.id], _isLeaf: item[attr._isLeaf], children: [] }; tree.push(_extends(obj, _extends({}, otherProps))); treeKeysMap[key] = item; resData.splice(i, 1); i--; } else { //递归查找根节点信息 findParentNode(item); } } // console.log('resData',resKeysMap); var run = function run(treeArrs) { if (resData.length > 0) { for (var _i = 0; _i < treeArrs.length; _i++) { for (var j = 0; j < resData.length; j++) { var _item = resData[j]; if (treeArrs[_i].key === _item[attr.parendId]) { var _key = _item.key, _title = _item.title, _children = _item.children, _otherProps = _objectWithoutProperties(_item, ['key', 'title', 'children']); var _obj = { key: _item[attr.id], _isLeaf: _item[attr._isLeaf], children: [] }; treeArrs[_i].children.push(_extends(_obj, _extends({}, _otherProps))); resData.splice(j, 1); j--; } } run(treeArrs[_i].children); } } }; run(tree); return tree; }