@yuntijs/ui
Version:
☁️ Yunti UI - an open-source UI component library for building Cloud Native web apps
65 lines • 3.33 kB
JavaScript
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;