File size: 1,674 Bytes
3578090
 
506c5f2
 
 
 
 
3578090
 
 
 
 
 
 
506c5f2
 
 
 
 
 
 
3578090
 
 
 
506c5f2
 
 
 
3578090
506c5f2
 
 
 
 
 
 
 
 
 
3578090
 
 
 
 
 
 
506c5f2
3578090
506c5f2
3578090
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
import { Alert, AlertDescription, AlertTitle } from '@/components/ui/Alert'
import { useBackendState } from '@/stores/state'
import { useEffect, useState } from 'react'
import { cn } from '@/lib/utils'

// import Button from '@/components/ui/Button'
// import { controlButtonVariant } from '@/lib/constants'

import { AlertCircle } from 'lucide-react'

const MessageAlert = () => {
  const health = useBackendState.use.health()
  const message = useBackendState.use.message()
  const messageTitle = useBackendState.use.messageTitle()
  const [isMounted, setIsMounted] = useState(false)

  useEffect(() => {
    setTimeout(() => {
      setIsMounted(true)
    }, 50)
  }, [])

  return (
    <Alert
      variant={health ? 'default' : 'destructive'}
      className={cn(
        'bg-background/90 absolute top-2 left-1/2 flex w-auto -translate-x-1/2 transform items-center gap-4 shadow-md backdrop-blur-lg transition-all duration-500 ease-in-out',
        isMounted ? 'translate-y-0 opacity-100' : '-translate-y-20 opacity-0'
      )}
    >
      {!health && (
        <div>
          <AlertCircle className="size-4" />
        </div>
      )}
      <div>
        <AlertTitle className="font-bold">{messageTitle}</AlertTitle>
        <AlertDescription>{message}</AlertDescription>
      </div>
      {/* <div className="flex">
        <div className="flex-auto" />
        <Button
          size="sm"
          variant={controlButtonVariant}
          className="text-primary max-h-8 border !p-2 text-xs"
          onClick={() => useBackendState.getState().clear()}
        >
          Close
        </Button>
      </div> */}
    </Alert>
  )
}

export default MessageAlert