UNPKG

@yuntijs/ui

Version:

☁️ Yunti UI - an open-source UI component library for building Cloud Native web apps

65 lines 3.33 kB
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty"; import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray"; import _taggedTemplateLiteral from "@babel/runtime/helpers/esm/taggedTemplateLiteral"; var _templateObject, _templateObject2; 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; } import { Icon, Markdown } from '@lobehub/ui'; import { createStyles } from 'antd-style'; import { ChevronDown, ChevronRight, Sparkles } from 'lucide-react'; import { memo, useState } from 'react'; import { Flexbox } from 'react-layout-kit'; import { jsx as _jsx } from "react/jsx-runtime"; import { jsxs as _jsxs } from "react/jsx-runtime"; var useStyles = createStyles(function (_ref) { var css = _ref.css, token = _ref.token, isDarkMode = _ref.isDarkMode; return { container: css(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n padding-block: 12px;\n color: ", ";\n "])), token.colorTextSecondary), titlebox: css(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n cursor: pointer;\n\n min-width: 140px;\n max-width: 230px;\n padding: 8px 12px;\n\n font-size: 12px;\n color: ", ";\n\n background: ", ";\n border-radius: 8px;\n "])), token.colorText, isDarkMode ? token.colorFillTertiary : '#f3f5fc') }; }); var mProps = { fontSize: 13, lineHeight: 1.625, headerMultiple: 0.2, marginMultiple: 0.6 }; var Render = /*#__PURE__*/memo(function (_ref2) { var children = _ref2.children, second = _ref2.second, done = _ref2.done; var _useStyles = useStyles(), styles = _useStyles.styles, theme = _useStyles.theme; var _useState = useState(true), _useState2 = _slicedToArray(_useState, 2), showDetail = _useState2[0], setShowDetail = _useState2[1]; return /*#__PURE__*/_jsxs(Flexbox, { className: styles.container, children: [/*#__PURE__*/_jsxs(Flexbox, { className: styles.titlebox, distribution: 'space-between', flex: 1, horizontal: true, onClick: function onClick() { setShowDetail(!showDetail); }, children: [/*#__PURE__*/_jsxs(Flexbox, { gap: 8, horizontal: true, children: [/*#__PURE__*/_jsx(Icon, { color: theme.purple, icon: Sparkles }), done ? "\u5DF2\u6DF1\u5EA6\u601D\u8003".concat(second ? '(用时 ' + second + ' s)' : '', " ") : '思考中...'] }), /*#__PURE__*/_jsx(Icon, { icon: showDetail ? ChevronDown : ChevronRight })] }), showDetail && /*#__PURE__*/_jsx(Markdown, _objectSpread(_objectSpread({}, mProps), {}, { children: children }))] }); }); export default Render;