UNPKG

@wener/console

Version:
326 lines (325 loc) 12.8 kB
function _array_like_to_array(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } function _array_with_holes(arr) { if (Array.isArray(arr)) return arr; } function _define_property(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; } function _iterable_to_array_limit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } function _non_iterable_rest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _object_spread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === "function") { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _define_property(target, key, source[key]); }); } return target; } 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 _object_spread_props(target, source) { source = source != null ? source : {}; 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 _object_without_properties(source, excluded) { if (source == null) return {}; var target = {}, sourceKeys, key, i; if (typeof Reflect !== "undefined" && Reflect.ownKeys) { sourceKeys = Reflect.ownKeys(source); for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } return target; } target = _object_without_properties_loose(source, excluded); if (Object.getOwnPropertySymbols) { sourceKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } function _object_without_properties_loose(source, excluded) { if (source == null) return {}; var target = {}, sourceKeys = Object.getOwnPropertyNames(source), key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } return target; } function _sliced_to_array(arr, i) { return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest(); } function _unsupported_iterable_to_array(o, minLen) { if (!o) return; if (typeof o === "string") return _array_like_to_array(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen); } import React, { useState } from "react"; import { HiExclamationCircle } from "react-icons/hi2"; import { PiArrowsCounterClockwiseLight, PiArrowSquareOutLight, PiTrashSimpleLight, PiUserPlusLight } from "react-icons/pi"; import { useRender } from "@base-ui/react/use-render"; import { flexRender, useDebounce } from "@wener/reaction"; import { clsx } from "clsx"; import { Daisy } from "../daisy/index.js"; import { showErrorToast } from "../toast/index.js"; import { cn } from "../utils/cn.js"; (function (FunctionButton) { FunctionButton.Refresh = function (_0) { var className = _0.className, children = _0.children, onClick = _0.onClick, _0_onRefresh = _0.onRefresh, onRefresh = _0_onRefresh === void 0 ? onClick : _0_onRefresh, loading = _0.loading, error = _0.error, size = _0.size, props = _object_without_properties(_0, [ "className", "children", "onClick", "onRefresh", "loading", "error", "size" ]); var _loading = useDebounce(loading, 250); var sz = Daisy.getSize(size); var btn = /*#__PURE__*/ React.createElement("button", _object_spread({ type: "button", className: cn("btn", !children && "btn-square", error && "join-item", sz === null || sz === void 0 ? void 0 : sz.btn, className), onClick: function (e) { if (loading) { return; } onRefresh === null || onRefresh === void 0 ? void 0 : onRefresh(e); } }, props), !_loading && /*#__PURE__*/ React.createElement(PiArrowsCounterClockwiseLight, null), _loading && /*#__PURE__*/ React.createElement("div", { className: cn("loading loading-spinner", sz === null || sz === void 0 ? void 0 : sz.loading) }), children); if (error) { return /*#__PURE__*/ React.createElement("div", { className: cn("join") }, btn, /*#__PURE__*/ React.createElement("button", { type: "button", className: cn("btn btn-square btn-outline btn-warning", sz === null || sz === void 0 ? void 0 : sz.btn, className), onClick: function () { showErrorToast(error); } }, /*#__PURE__*/ React.createElement(HiExclamationCircle, null))); } return /*#__PURE__*/ React.createElement(React.Fragment, null, btn); }; FunctionButton.Submit = function (_0) { var _0_children = _0.children, children = _0_children === void 0 ? /*#__PURE__*/ React.createElement(React.Fragment, null, "\u63D0\u4EA4") : _0_children, loading = _0.loading, props = _object_without_properties(_0, [ "children", "loading" ]); var sz = Daisy.getSize(props.size); return /*#__PURE__*/ React.createElement(FunctionButton.Button, _object_spread({ type: "submit" }, props), loading && /*#__PURE__*/ React.createElement("div", { className: cn("loading loading-spinner", sz === null || sz === void 0 ? void 0 : sz.loading) }), children); }; FunctionButton.Popup = function (_0) { var onPopup = _0.onPopup, children = _0.children, className = _0.className, props = _object_without_properties(_0, [ "onPopup", "children", "className" ]); return /*#__PURE__*/ React.createElement(FunctionButton.Button, _object_spread_props(_object_spread({}, props), { className: cn(!children && "btn-square", className), onClick: onPopup }), children !== null && children !== void 0 ? children : /*#__PURE__*/ React.createElement(PiArrowSquareOutLight, null)); }; FunctionButton.Delete = function (_0) { var onDelete = _0.onDelete, children = _0.children, className = _0.className, props = _object_without_properties(_0, [ "onDelete", "children", "className" ]); return /*#__PURE__*/ React.createElement(FunctionButton.Button, _object_spread_props(_object_spread({}, props), { icon: PiTrashSimpleLight, className: cn("btn-error", className), onAction: onDelete }), children); }; FunctionButton.BindCustomer = function (_0) { var children = _0.children, className = _0.className, props = _object_without_properties(_0, [ "children", "className" ]); return /*#__PURE__*/ React.createElement(FunctionButton.Button, _object_spread({ icon: PiUserPlusLight }, props)); }; FunctionButton.BindUser = function (_0) { var children = _0.children, className = _0.className, props = _object_without_properties(_0, [ "children", "className" ]); return /*#__PURE__*/ React.createElement(FunctionButton.Button, _object_spread({ icon: PiUserPlusLight }, props)); }; FunctionButton.Button = function (_0) { var size = _0.size, children = _0.children, render = _0.render, className = _0.className, onAction = _0.onAction, onClick = _0.onClick, icon = _0.icon, text = _0.text, loading = _0.loading, ref = _0.ref, props = _object_without_properties(_0, [ "size", "children", "render", "className", "onAction", "onClick", "icon", "text", "loading", "ref" ]); var sz = Daisy.getSize(size); var _useState = _sliced_to_array(useState(false), 2), _loading = _useState[0], setLoading = _useState[1]; loading || (loading = _loading); if (!onClick && onAction) { onClick = function (e) { if (loading) { return; } var p = onAction(e); if (p && p.then) { setLoading(true); p.then(function () { setLoading(false); }).catch(function () { setLoading(false); // 不一定是直接处理error // showErrorToast(e); }); } }; } var square = false; if (!children) { var _icon; square = Boolean(icon && !text); if (loading) { _icon = /*#__PURE__*/ React.createElement("div", { className: clsx("loading loading-spinner", sz === null || sz === void 0 ? void 0 : sz.loading) }); } else { _icon = flexRender(icon, { className: sz === null || sz === void 0 ? void 0 : sz.icon }); } children = /*#__PURE__*/ React.createElement(React.Fragment, null, _icon, text); } return useRender({ defaultTagName: "button", render: render, ref: ref, props: _object_spread_props(_object_spread({ type: "button", className: cn("btn", sz === null || sz === void 0 ? void 0 : sz.btn, square && "btn-square", className), "data-loading": loading || null }, props), { onClick: onClick, children: children }) }); }; })(FunctionButton || (FunctionButton = {})); export var FunctionButton;