import type { HTMLAttributes, ReactNode } from 'react'; type PlatformStatusTone = 'error' | 'success' | 'info' | 'warning' | 'neutral'; type PlatformStatusSurface = | 'light' | 'tinted' | 'platform' | 'profile' | 'editorDark'; type PlatformStatusSize = 'xs' | 'sm' | 'md'; type PlatformStatusMessageProps = Omit< HTMLAttributes, 'children' > & { tone: PlatformStatusTone; surface?: PlatformStatusSurface; size?: PlatformStatusSize; remapSurface?: boolean; children: ReactNode; }; const PLATFORM_STATUS_MESSAGE_CLASS_BY_SURFACE_AND_TONE: Record< PlatformStatusSurface, Record > = { light: { error: 'border-rose-200 bg-rose-50 text-rose-700', success: 'border-emerald-200 bg-emerald-50 text-emerald-700', info: 'border-[var(--platform-cool-border)] bg-[var(--platform-cool-bg)] text-[var(--platform-cool-text)]', warning: 'border-amber-200 bg-amber-50 text-amber-900', neutral: 'border-[var(--platform-subpanel-border)] bg-white/68 text-[var(--platform-text-base)]', }, tinted: { error: 'border-rose-400/20 bg-rose-500/10 text-rose-700', success: 'border-emerald-300/25 bg-emerald-500/12 text-emerald-700', info: 'border-[var(--platform-cool-border)] bg-[var(--platform-cool-bg)] text-[var(--platform-cool-text)]', warning: 'border-amber-300/30 bg-amber-500/12 text-amber-900', neutral: 'border-[var(--platform-subpanel-border)] bg-white/20 text-[var(--platform-text-base)]', }, platform: { error: 'border-[var(--platform-button-danger-border)] bg-[var(--platform-button-danger-fill)] text-[var(--platform-button-danger-text)]', success: 'border-[var(--platform-success-border)] bg-[var(--platform-success-bg)] text-[var(--platform-success-text)]', info: 'border-[var(--platform-cool-border)] bg-[var(--platform-cool-bg)] text-[var(--platform-cool-text)]', warning: 'border-[var(--platform-warm-border)] bg-[var(--platform-warm-bg)] text-[var(--platform-warm-text)]', neutral: 'border-[var(--platform-subpanel-border)] bg-white/68 text-[var(--platform-text-base)]', }, profile: { error: 'border-[var(--platform-button-danger-border)] bg-[var(--platform-button-danger-fill)] text-[var(--platform-button-danger-text)]', success: 'border-[var(--platform-success-border)] bg-[var(--platform-success-bg)] text-[var(--platform-success-text)]', info: 'border-[var(--platform-cool-border)] bg-[var(--platform-cool-bg)] text-[var(--platform-cool-text)]', warning: 'border-amber-300 bg-amber-500/12 text-amber-900', neutral: 'border-[var(--platform-subpanel-border)] bg-white/68 text-[var(--platform-text-base)]', }, editorDark: { error: 'border-rose-300/15 bg-rose-500/10 text-rose-50/90', success: 'border-emerald-300/15 bg-emerald-500/10 text-emerald-50/90', info: 'border-sky-300/15 bg-sky-500/10 text-sky-50/90', warning: 'border-amber-300/15 bg-amber-500/10 text-amber-50/90', neutral: 'border-white/10 bg-black/20 text-zinc-300', }, }; const PLATFORM_STATUS_MESSAGE_SIZE_CLASS: Record = { xs: 'px-3 py-2 text-xs', sm: 'px-3 py-2 text-sm', md: 'px-4 py-3 text-sm leading-6', }; /** * 平台通用状态提示条。 * 收口错误、成功和提示类状态的基础边框、底色和文字颜色。 */ export function PlatformStatusMessage({ tone, surface = 'light', size = 'sm', remapSurface = false, children, className, ...divProps }: PlatformStatusMessageProps) { return (
{children}
); }