mirror of
https://github.com/YFGaia/dify-plus.git
synced 2026-06-26 16:02:18 +08:00
17832f2424
本次提交整合了多个功能改进和问题修复: 主要功能: - 批量工作流处理功能完善,支持 Excel 上传和进度跟踪 - 管理中心反向代理和转发配置优化 - 用户同步添加互斥锁,防止并发问题 - 计费系统和额度显示优化 - AI 绘图功能扩展 前端改进: - 文本生成应用显示修复 - 批量任务进度展示优化 - 按钮样式和 CSS 优化,禁止换行 - 多语言支持完善(新增印尼语等) - 构建镜像逻辑优化 - 批量处理进度管理器实现 后端改进: - Docker Compose 配置升级 - 队列任务和 Worker Pool 优化 - Admin API 初始化和验证逻辑改进 - 数据库迁移和初始化完善 - 静态变量处理优化 - URL 签名助手实现 - Celery 扩展优化 - 代码和导入包问题修复(idea 自动调整代码位置) 技术改进: - 兼容性修复 (flask-restx, jschardet) - 钉钉 Web API 版本更新 - 代码格式化和导入包问题修复 - 日志处理优化 - 工作流循环管理优化 Docker 相关: - Nginx 配置更新 - 容器启动脚本优化 - 镜像构建流程改进 - docker-compose.dify-plus.yaml 大幅更新 管理后台: - 工作流批量处理 API 实现 - 工作池初始化 - 批量工作流服务实现 - 转发扩展配置 - 用户服务扩展
75 lines
1.8 KiB
TypeScript
75 lines
1.8 KiB
TypeScript
import type { CSSProperties } from 'react'
|
|
import React from 'react'
|
|
import { type VariantProps, cva } from 'class-variance-authority'
|
|
import classNames from '@/utils/classnames'
|
|
|
|
enum ActionButtonState {
|
|
Destructive = 'destructive',
|
|
Active = 'active',
|
|
Disabled = 'disabled',
|
|
Default = '',
|
|
Hover = 'hover',
|
|
}
|
|
|
|
const actionButtonVariants = cva(
|
|
'action-btn',
|
|
{
|
|
variants: {
|
|
size: {
|
|
xs: 'action-btn-xs',
|
|
sm: 'action-btn-sm',
|
|
m: 'action-btn-m',
|
|
l: 'action-btn-l',
|
|
xl: 'action-btn-xl',
|
|
},
|
|
},
|
|
defaultVariants: {
|
|
size: 'm',
|
|
},
|
|
},
|
|
)
|
|
|
|
export type ActionButtonProps = {
|
|
size?: 'xs' | 'sm' | 'm' | 'l' | 'xl'
|
|
state?: ActionButtonState
|
|
styleCss?: CSSProperties
|
|
} & React.ButtonHTMLAttributes<HTMLButtonElement> & VariantProps<typeof actionButtonVariants>
|
|
|
|
function getActionButtonState(state: ActionButtonState) {
|
|
switch (state) {
|
|
case ActionButtonState.Destructive:
|
|
return 'action-btn-destructive'
|
|
case ActionButtonState.Active:
|
|
return 'action-btn-active'
|
|
case ActionButtonState.Disabled:
|
|
return 'action-btn-disabled'
|
|
case ActionButtonState.Hover:
|
|
return 'action-btn-hover'
|
|
default:
|
|
return ''
|
|
}
|
|
}
|
|
|
|
const ActionButton = React.forwardRef<HTMLButtonElement, ActionButtonProps>(
|
|
({ className, size, state = ActionButtonState.Default, styleCss, children, ...props }, ref) => {
|
|
return (
|
|
<button
|
|
type='button'
|
|
className={classNames(
|
|
actionButtonVariants({ className, size }),
|
|
getActionButtonState(state),
|
|
)}
|
|
ref={ref}
|
|
style={styleCss}
|
|
{...props}
|
|
>
|
|
{children}
|
|
</button>
|
|
)
|
|
},
|
|
)
|
|
ActionButton.displayName = 'ActionButton'
|
|
|
|
export default ActionButton
|
|
export { ActionButton, ActionButtonState, actionButtonVariants }
|