UNPKG

virtualizedtableforantd-temp

Version:

The virtualized table component for ant design, using typescript.

87 lines (72 loc) 2.76 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.useVT = useVT; var _react = require("react"); var _vt = require("./vt"); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } /** * @private functions */ function _generate_id() { do { var id = 0 | Math.random() * (Math.pow(2, 31) - 1); if (!_vt.vt_context.has(id)) return id; } while (1); } /** * @private functions */ function init_once(factory) { for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { args[_key - 1] = arguments[_key]; } var ref = (0, _react.useRef)(null); return (0, _react.useMemo)(function () { return factory.apply(void 0, args); }, [ref.current]); } /** * @hooks No longer needs the parameter id. * @example * * function MyTableComponent() { * * // ... your code * * * // `set_components` is the same as the setComponents, excepet for the param id. * // `vt_scroll` is the same as the VTScroll, excepet for the param id. * const [ vt, set_components, vt_scroll ] = useVT(); * * * return ( * <Table * columns={columns} * dataSource={dataSource} * scroll={{ x: 1000, y: 600 }} * components={vt} * /> * ); * } */ function useVT(opts) { var _id = init_once(_generate_id); var _lambda_scroll = init_once(function () { return function (param) { return (0, _vt.VTScroll)(_id, param); }; }); var _lambda_set = init_once(function () { return function (components) { return (0, _vt.setComponents)(_id, components); }; }); return [(0, _vt.VTComponents)(_objectSpread({}, opts, { id: _id, destroy: true })), _lambda_set, _lambda_scroll]; }