test-nut-ui
Version:
<p align="center"> <img alt="logo" src="https://img11.360buyimg.com/imagetools/jfs/t1/211965/25/7152/22022/61b16785E433119bb/aa41d7a9f7e823f3.png" width="150" style="margin-bottom: 10px;"> </p>
114 lines (113 loc) • 4.61 kB
JavaScript
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
import _defineProperty from "@babel/runtime/helpers/defineProperty";
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
var _excluded = ["children", "columns", "scrollX", "gap", "center", "square", "reverse", "direction", "style", "className", "onClick"];
function ownKeys(object, enumerableOnly) {
var keys = Object.keys(object);
if (Object.getOwnPropertySymbols) {
var symbols = Object.getOwnPropertySymbols(object);
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 = null != arguments[i] ? arguments[i] : {};
i % 2 ? ownKeys(Object(source), true).forEach(function(key) {
_defineProperty(target, key, source[key]);
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function(key) {
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
});
}
return target;
}
import React__default, { useState } from "react";
import classNames from "classnames";
import { a as GridContext, G as GridItem } from "./griditem2.js";
import { p as pxCheck } from "./px-check.js";
var defaultProps = {
columns: 4,
scrollX: false,
gap: 0,
center: true,
square: false,
reverse: false,
direction: "vertical"
};
var Grid = function Grid2(props) {
var _defaultProps$props = _objectSpread(_objectSpread({}, defaultProps), props), children = _defaultProps$props.children, columns = _defaultProps$props.columns, scrollX = _defaultProps$props.scrollX, gap = _defaultProps$props.gap, center = _defaultProps$props.center, square = _defaultProps$props.square, reverse = _defaultProps$props.reverse, direction = _defaultProps$props.direction, style = _defaultProps$props.style, className = _defaultProps$props.className, onClick = _defaultProps$props.onClick, rest = _objectWithoutProperties(_defaultProps$props, _excluded);
var childrenDom = React__default.Children.toArray(children);
var classPrefix = "nut-grid";
var rootClass = function rootClass2() {
return classNames(className, classPrefix, _defineProperty({}, "".concat(classPrefix, "__scroll"), scrollX));
};
var containerClass = function containerClass2() {
return classNames("".concat(classPrefix, "__container"));
};
var rootStyle = function rootStyle2() {
var styleSelf = {};
if (style) {
styleSelf = style;
}
if (gap) {
styleSelf.paddingLeft = pxCheck(gap);
}
return styleSelf;
};
var generateRandomId = function generateRandomId2() {
var characters = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
var uniqueId = "";
var idLength = 10;
for (var i = 0; i < idLength; i++) {
var randomIndex = Math.floor(Math.random() * characters.length);
uniqueId += characters.charAt(randomIndex);
}
return uniqueId;
};
var domId = "".concat(classPrefix, "__container--") + generateRandomId();
var _useState = useState(true), _useState2 = _slicedToArray(_useState, 2), showScreen = _useState2[0], setShowScreen = _useState2[1];
var onScroll = function onScroll2() {
var container = document.getElementById(domId);
if (container) {
if (container.clientWidth + container.scrollLeft >= container.scrollWidth) {
setShowScreen(false);
} else {
setShowScreen(true);
}
}
};
return React__default.createElement("div", _objectSpread({
className: rootClass(),
style: rootStyle()
}, rest), scrollX && showScreen ? React__default.createElement(React__default.Fragment, null, React__default.createElement("div", {
className: "".concat(classPrefix, "__scroll--screen")
}), React__default.createElement("div", {
className: "".concat(classPrefix, "__scroll--block")
})) : null, React__default.createElement("div", {
id: domId,
className: containerClass(),
onScroll
}, React__default.createElement(GridContext.Provider, {
value: {
onClick
}
}, childrenDom.map(function(item, idex) {
return React__default.cloneElement(item, {
index: idex,
columns,
center,
gap,
square,
reverse,
direction
});
}))));
};
Grid.defaultProps = defaultProps;
Grid.displayName = "NutGrid";
Grid.Item = GridItem;
export {
Grid as G
};