mirror of
https://github.com/infiniflow/ragflow.git
synced 2025-12-24 07:26:47 +08:00
### What problem does this PR solve? Feature: Added data source functionality ### Type of change - [x] New Feature (non-breaking change which adds functionality)
64 lines
2.2 KiB
TypeScript
64 lines
2.2 KiB
TypeScript
// src/pages/dataset/file-logs/file-status-badge.tsx
|
|
import { RunningStatus } from '@/pages/dataset/dataset/constant';
|
|
import { FC } from 'react';
|
|
/**
|
|
* params: status: 0 not run yet 1 running, 2 cancel, 3 success, 4 fail
|
|
*/
|
|
interface StatusBadgeProps {
|
|
// status: 'Success' | 'Failed' | 'Running' | 'Pending';
|
|
status: RunningStatus;
|
|
name?: string;
|
|
className?: string;
|
|
}
|
|
|
|
const FileStatusBadge: FC<StatusBadgeProps> = ({ status, name, className }) => {
|
|
const getStatusColor = () => {
|
|
// #3ba05c → rgb(59, 160, 92) // state-success
|
|
// #d8494b → rgb(216, 73, 75) // state-error
|
|
// #00beb4 → rgb(0, 190, 180) // accent-primary
|
|
// #faad14 → rgb(250, 173, 20) // state-warning
|
|
switch (status) {
|
|
case RunningStatus.DONE:
|
|
return `bg-[rgba(59,160,92,0.1)] text-state-success`;
|
|
case RunningStatus.FAIL:
|
|
return `bg-[rgba(216,73,75,0.1)] text-state-error`;
|
|
case RunningStatus.RUNNING:
|
|
return `bg-[rgba(0,190,180,0.1)] text-accent-primary`;
|
|
case RunningStatus.UNSTART:
|
|
return `bg-[rgba(250,173,20,0.1)] text-state-warning`;
|
|
default:
|
|
return 'bg-gray-500/10 text-text-secondary';
|
|
}
|
|
};
|
|
|
|
const getBgStatusColor = () => {
|
|
// #3ba05c → rgb(59, 160, 92) // state-success
|
|
// #d8494b → rgb(216, 73, 75) // state-error
|
|
// #00beb4 → rgb(0, 190, 180) // accent-primary
|
|
// #faad14 → rgb(250, 173, 20) // state-warning
|
|
switch (status) {
|
|
case RunningStatus.DONE:
|
|
return `bg-[rgba(59,160,92,1)] text-state-success`;
|
|
case RunningStatus.FAIL:
|
|
return `bg-[rgba(216,73,75,1)] text-state-error`;
|
|
case RunningStatus.RUNNING:
|
|
return `bg-[rgba(0,190,180,1)] text-accent-primary`;
|
|
case RunningStatus.UNSTART:
|
|
return `bg-[rgba(250,173,20,1)] text-state-warning`;
|
|
default:
|
|
return `bg-[rgba(117,120,122,1)] text-text-secondary`;
|
|
}
|
|
};
|
|
|
|
return (
|
|
<span
|
|
className={`inline-flex items-center w-[75px] px-2 py-1 rounded-full text-xs font-medium ${getStatusColor()} ${className}`}
|
|
>
|
|
<div className={`w-1 h-1 mr-1 rounded-full ${getBgStatusColor()}`}></div>
|
|
{name || ''}
|
|
</span>
|
|
);
|
|
};
|
|
|
|
export default FileStatusBadge;
|