UNPKG

@nutui/nutui-react

Version:

京东风格的轻量级移动端 React 组件库,支持一套代码生成 H5 和小程序

88 lines (87 loc) 3.76 kB
import { _ as _object_spread } from "@swc/helpers/_/_object_spread"; import { _ as _object_spread_props } from "@swc/helpers/_/_object_spread_props"; import { _ as _object_without_properties } from "@swc/helpers/_/_object_without_properties"; import { _ as _sliced_to_array } from "@swc/helpers/_/_sliced_to_array"; import React, { useEffect, useState } from "react"; import classNames from "classnames"; import { ComponentDefaults } from "../../utils/typings"; import Button from "../button"; var defaultStatus = { empty: 'https://storage.360buyimg.com/imgtools/30186cfda0-0d3eee40-c0ac-11ee-9382-9125782aa3b8.png', error: 'https://storage.360buyimg.com/imgtools/f3278d0ebb-0ce360c0-c0ac-11ee-8375-193101bb1a46.png', network: 'https://storage.360buyimg.com/imgtools/43c30f7e29-0d483d10-c0ac-11ee-bec4-eb4d2a09a51d.png' }; var defaultProps = _object_spread_props(_object_spread({}, ComponentDefaults), { title: '', description: '', imageSize: '', size: 'base', status: 'empty', actions: [] }); var classPrefix = "nut-empty"; export var Empty = function(props) { var _ref = _object_spread({}, defaultProps, props), image = _ref.image, imageSize = _ref.imageSize, title = _ref.title, description = _ref.description, children = _ref.children, className = _ref.className, size = _ref.size, status = _ref.status, actions = _ref.actions, style = _ref.style, rest = _object_without_properties(_ref, [ "image", "imageSize", "title", "description", "children", "className", "size", "status", "actions", "style" ]); var _useState = _sliced_to_array(useState({}), 2), imgStyle = _useState[0], setImgStyle = _useState[1]; var imageUrl = image || defaultStatus[status]; var imageNode = typeof imageUrl === 'string' ? /*#__PURE__*/ React.createElement("img", { style: { width: '100%', height: '100%' }, src: imageUrl, alt: "empty" }) : imageUrl; useEffect(function() { setImgStyle(function() { if (!imageSize) { return {}; } if (typeof imageSize === 'number') { return { width: "".concat(imageSize, "px"), height: "".concat(imageSize, "px") }; } return { width: imageSize, height: imageSize }; }); }, [ imageSize ]); var cls = classNames(classPrefix, className); return /*#__PURE__*/ React.createElement("div", _object_spread({ className: cls }, rest), /*#__PURE__*/ React.createElement("div", { className: "".concat(classPrefix, "-").concat(size), style: imgStyle }, imageNode), typeof title === 'string' && title ? /*#__PURE__*/ React.createElement("div", { className: "".concat(classPrefix, "-title") }, title) : title, typeof description === 'string' ? /*#__PURE__*/ React.createElement("div", { className: "".concat(classPrefix, "-description") }, description) : description, actions.length ? /*#__PURE__*/ React.createElement("div", { className: "".concat(classPrefix, "-actions-").concat(size) }, actions.map(function(action, index) { var text = action.text, rest = _object_without_properties(action, [ "text" ]); return /*#__PURE__*/ React.createElement("div", { className: "".concat(classPrefix, "-action"), key: index }, /*#__PURE__*/ React.createElement(Button, rest, action === null || action === void 0 ? void 0 : action.text)); })) : null, children); }; Empty.displayName = 'NutEmpty';