adui
Version:
<div> <img src="https://wxa.wxs.qq.com/mpweb/delivery/legacy/wxadtouch/upload/t1/od834zef_52939fc6.png" style="margin:40px 0 0 -8px; background-color: #fcfcfc; box-shadow: none;" /> </div>
148 lines • 19.4 kB
JavaScript
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }
function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
import React from "react";
var ColumnManager = _createClass(function ColumnManager(_elements) {
var _this = this;
_classCallCheck(this, ColumnManager);
this.cached = {};
this.columns = void 0;
this.isAnyColumnsFixed = function () {
return _this.cache("isAnyColumnsFixed", function () {
return _this.columns.some(function (column) {
return !!column.fixed;
});
});
};
this.isAnyColumnsLeftFixed = function () {
return _this.cache("isAnyColumnsLeftFixed", function () {
return _this.columns.some(function (column) {
return column.fixed === "left" || column.fixed === true;
});
});
};
this.isAnyColumnsRightFixed = function () {
return _this.cache("isAnyColumnsRightFixed", function () {
return _this.columns.some(function (column) {
return column.fixed === "right";
});
});
};
this.getLeftColumns = function () {
return _this.cache("getLeftColumns", function () {
return _this.columns.filter(function (column) {
return column.fixed === "left" || column.fixed === true;
});
});
};
this.getMainColumns = function () {
return _this.cache("getMainColumns", function () {
return _this.columns.filter(function (column) {
return !column.fixed;
});
});
};
this.getRightColumns = function () {
return _this.cache("getRightColumns", function () {
return _this.columns.filter(function (column) {
return column.fixed === "right";
});
});
};
this.getColumns = function () {
return [].concat(_toConsumableArray(_this.getLeftColumns()), _toConsumableArray(_this.getMainColumns()), _toConsumableArray(_this.getRightColumns()));
};
this.getLeftColumnsWidth = function () {
return _this.cache("getLeftColumnsWidth", function () {
return _this.getColumnsWidthBase(_this.getLeftColumns());
});
};
this.getRightColumnsWidth = function () {
return _this.cache("getRightColumnsWidth", function () {
return _this.getColumnsWidthBase(_this.getRightColumns());
});
};
this.getGroupColumnsDepth = function () {
return _this.cache("getGroupColumnsDepth", function () {
var depth = 1;
var children = _this.columns.filter(function (column) {
return !!column.children;
});
if (children.length) {
depth = 2;
children.forEach(function (child) {
var grands = child.children.some(function (grand) {
return !!grand.children;
});
if (grands) {
depth = 3;
}
});
}
return depth;
});
};
this.getColumnsWidthBase = function (columns) {
var sum = "calc(";
columns.forEach(function (column) {
var width = column.width;
if (typeof width === "number") {
sum += "".concat(width, "px + ");
} else {
sum += "".concat(width, " + ");
}
});
return "".concat(sum.slice(0, -2), ")");
};
this.normalize = function (elementsParam) {
var columns = [];
var elements = Array.isArray(elementsParam) ? elementsParam : [elementsParam];
if (elements.find(function (o) {
return React.isValidElement(o);
})) {
React.Children.forEach(elements, function (element) {
if (!React.isValidElement(element)) {
return;
}
var column = _objectSpread({}, element.props);
var children = column.children;
if (children) {
children = Array.isArray(children) ? children : [children];
column.children = _this.normalize(children);
}
columns.push(column);
});
} else {
elements.forEach(function (o) {
columns.push(o);
});
}
return columns;
};
this.reset = function (elements) {
_this.columns = _this.normalize(elements);
_this.cached = {};
};
this.cache = function (name, fn) {
if (name in _this.cached) {
return _this.cached[name];
}
_this.cached[name] = fn();
return _this.cached[name];
};
this.columns = this.normalize(_elements);
});
export { ColumnManager as default };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","ColumnManager","_createClass","elements","_this","_classCallCheck","cached","columns","isAnyColumnsFixed","cache","some","column","fixed","isAnyColumnsLeftFixed","isAnyColumnsRightFixed","getLeftColumns","filter","getMainColumns","getRightColumns","getColumns","concat","_toConsumableArray","getLeftColumnsWidth","getColumnsWidthBase","getRightColumnsWidth","getGroupColumnsDepth","depth","children","length","forEach","child","grands","grand","sum","width","slice","normalize","elementsParam","Array","isArray","find","o","isValidElement","Children","element","_objectSpread","props","push","reset","name","fn","default"],"sources":["../../components/table/ColumnManager.ts"],"sourcesContent":["import React from \"react\"\n\ninterface IBaseObject {\n  [key: string]: any\n}\n\nexport default class ColumnManager {\n  public cached: any = {}\n\n  public columns: IBaseObject[]\n\n  constructor(elements: IBaseObject[]) {\n    this.columns = this.normalize(elements)\n  }\n\n  public isAnyColumnsFixed = () =>\n    this.cache(\"isAnyColumnsFixed\", () =>\n      this.columns.some((column: IBaseObject) => !!column.fixed)\n    )\n\n  public isAnyColumnsLeftFixed = () =>\n    this.cache(\"isAnyColumnsLeftFixed\", () =>\n      this.columns.some(\n        (column: IBaseObject) =>\n          column.fixed === \"left\" || column.fixed === true\n      )\n    )\n\n  public isAnyColumnsRightFixed = () =>\n    this.cache(\"isAnyColumnsRightFixed\", () =>\n      this.columns.some((column: IBaseObject) => column.fixed === \"right\")\n    )\n\n  public getLeftColumns = () =>\n    this.cache(\"getLeftColumns\", () =>\n      this.columns.filter(\n        (column: IBaseObject) =>\n          column.fixed === \"left\" || column.fixed === true\n      )\n    )\n\n  public getMainColumns = () =>\n    this.cache(\"getMainColumns\", () =>\n      this.columns.filter((column: IBaseObject) => !column.fixed)\n    )\n\n  public getRightColumns = () =>\n    this.cache(\"getRightColumns\", () =>\n      this.columns.filter((column: IBaseObject) => column.fixed === \"right\")\n    )\n\n  public getColumns = () => [\n    ...this.getLeftColumns(),\n    ...this.getMainColumns(),\n    ...this.getRightColumns(),\n  ]\n\n  public getLeftColumnsWidth = () =>\n    this.cache(\"getLeftColumnsWidth\", () =>\n      this.getColumnsWidthBase(this.getLeftColumns())\n    )\n\n  public getRightColumnsWidth = () =>\n    this.cache(\"getRightColumnsWidth\", () =>\n      this.getColumnsWidthBase(this.getRightColumns())\n    )\n\n  public getGroupColumnsDepth = () =>\n    this.cache(\"getGroupColumnsDepth\", () => {\n      let depth = 1\n      const children = this.columns.filter(\n        (column: IBaseObject) => !!column.children\n      )\n      if (children.length) {\n        depth = 2\n        children.forEach((child) => {\n          const grands = child.children.some(\n            (grand: IBaseObject) => !!grand.children\n          )\n          if (grands) {\n            depth = 3\n          }\n        })\n      }\n      return depth\n    })\n\n  public getColumnsWidthBase = (columns: IBaseObject[]) => {\n    let sum = \"calc(\"\n    columns.forEach((column: IBaseObject) => {\n      const { width } = column\n      if (typeof width === \"number\") {\n        sum += `${width}px + `\n      } else {\n        sum += `${width} + `\n      }\n    })\n    return `${sum.slice(0, -2)})`\n  }\n\n  public normalize = (elementsParam: IBaseObject[]) => {\n    const columns: IBaseObject[] = []\n    const elements = Array.isArray(elementsParam)\n      ? elementsParam\n      : [elementsParam]\n    if (elements.find((o) => React.isValidElement(o))) {\n      React.Children.forEach(elements, (element) => {\n        /**\n         * Column 名存实亡，实际上是从 children 获取每一列的 props\n         * 因此需要判断 children isValidElement，再从 children 遍历 prop\n         */\n        if (!React.isValidElement(element)) {\n          return\n        }\n        const column: any = { ...(element.props as {}) }\n        let { children } = column\n        if (children) {\n          children = Array.isArray(children) ? children : [children]\n          column.children = this.normalize(children)\n        }\n        columns.push(column)\n      })\n    } else {\n      elements.forEach((o) => {\n        columns.push(o)\n      })\n    }\n    return columns\n  }\n\n  public reset = (elements: IBaseObject[]) => {\n    this.columns = this.normalize(elements)\n    this.cached = {}\n  }\n\n  public cache = (name: string, fn: () => void) => {\n    if (name in this.cached) {\n      return this.cached[name]\n    }\n    this.cached[name] = fn()\n    return this.cached[name]\n  }\n}\n"],"mappings":"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","ignoreList":[]}