import {
  Column,
  Icon,
  Menu,
  MenuItem,
  MenuSection,
  MenuSeparator,
  MenuTrigger,
  Popover,
  Pressable,
  Row,
  SubmenuTrigger,
  Text,
} from '@umami/react-zen';
import { ArrowRight } from 'lucide-react';
import type { Key } from 'react';
import { IconLabel } from '@/components/common/IconLabel';
import { useLoginQuery, useMessages, useMobile, useNavigation } from '@/components/hooks';
import { ChevronRight, User, Users } from '@/components/icons';
import { Switch } from '@/components/svg';
import { LAST_TEAM_CONFIG } from '@/lib/constants';
import { removeItem } from '@/lib/storage';

export interface TeamsButtonProps {
  showText?: boolean;
  onAction?: (id: any) => void;
}

export function NavButton({ showText = true }: TeamsButtonProps) {
  const { user } = useLoginQuery();
  const { t, labels } = useMessages();
  const { teamId, router } = useNavigation();
  const { isMobile } = useMobile();
  const team = user?.teams?.find(({ id }) => id === teamId);
  const selectedKeys = new Set([teamId || 'user']);
  const label = teamId ? team?.name : user.username;
  const cloudMode = !!process.env.cloudMode;

  const getUrl = (url: string) => {
    return cloudMode ? `${process.env.cloudUrl}${url}` : url;
  };

  const handleAction = async (key: Key) => {
    if (key === 'user') {
      removeItem(LAST_TEAM_CONFIG);
      if (cloudMode) {
        window.location.href = '/';
      } else {
        router.push('/');
      }
    }
  };

  return (
    <MenuTrigger>
      <Pressable>
        <Row
          alignItems="center"
          justifyContent="space-between"
          flexGrow={1}
          padding
          border
          borderRadius
          shadow="sm"
          minHeight="40px"
          role="button"
          style={{ cursor: 'pointer', textWrap: 'nowrap', overflow: 'hidden', outline: 'none' }}
        >
          <Row alignItems="center" position="relative" gap maxHeight="40px">
            <Icon>{teamId ? <Users /> : <User />}</Icon>
            {showText && <Text>{label}</Text>}
          </Row>
          {showText && (
            <Icon rotate={90} size="sm">
              <ChevronRight />
            </Icon>
          )}
        </Row>
      </Pressable>
      <Popover placement="bottom start">
        <Column minWidth="300px">
          <Menu autoFocus="last">
            <SubmenuTrigger>
              <MenuItem id="teams" showChecked={false} showSubMenuIcon>
                <IconLabel icon={<Switch />} label={t(labels.switchAccount)} />
              </MenuItem>
              <Popover placement={isMobile ? 'bottom start' : 'right top'}>
                <Column minWidth="300px">
                  <Menu selectionMode="single" selectedKeys={selectedKeys} onAction={handleAction}>
                    <MenuSection title={t(labels.myAccount)}>
                      <MenuItem id="user">
                        <IconLabel icon={<User />} label={user.username} />
                      </MenuItem>
                    </MenuSection>
                    <MenuSeparator />
                    <MenuSection title={t(labels.teams)}>
                      {user?.teams?.map(({ id, name }) => (
                        <MenuItem key={id} id={id} href={getUrl(`/teams/${id}`)}>
                          <IconLabel icon={<Users />}>
                            <Text wrap="nowrap">{name}</Text>
                          </IconLabel>
                        </MenuItem>
                      ))}
                      {user?.teams?.length === 0 && (
                        <MenuItem id="manage-teams">
                          <a href="/settings/teams" style={{ width: '100%' }}>
                            <Row alignItems="center" justifyContent="space-between" gap>
                              <Text align="center">Manage teams</Text>
                              <Icon>
                                <ArrowRight />
                              </Icon>
                            </Row>
                          </a>
                        </MenuItem>
                      )}
                    </MenuSection>
                  </Menu>
                </Column>
              </Popover>
            </SubmenuTrigger>
          </Menu>
        </Column>
      </Popover>
    </MenuTrigger>
  );
}
