import { Button, Loadable, PageLoader, Text } from "@allurereport/web-components";
import { useEffect } from "preact/hooks";
import type { ClassicStatus } from "types";

import Tree from "@/components/Tree/Tree";
import { useI18n } from "@/stores/locale";
import {
  clearPackagesFilters,
  filteredPackages,
  noTests,
  noTestsFound,
  packagesStore,
  setPackagesStatus,
} from "@/stores/packages";
import { currentTab } from "@/stores/tabs";

import * as styles from "./styles.scss";

export const PackagesList = () => {
  const { t } = useI18n("empty");

  useEffect(() => {
    setPackagesStatus(currentTab.value as ClassicStatus);
  }, [currentTab.value]);

  return (
    <Loadable
      source={packagesStore}
      renderLoader={() => <PageLoader />}
      renderData={() => {
        if (noTests.value) {
          return (
            <div className={styles["tree-list"]}>
              <div className={styles["tree-empty-results"]}>
                <Text className={styles["tree-empty-results-title"]}>{t("no-results")}</Text>
              </div>
            </div>
          );
        }

        if (noTestsFound.value) {
          return (
            <div className={styles["tree-list"]}>
              <div className={styles["tree-empty-results"]}>
                <Text tag="p" className={styles["tree-empty-results-title"]}>
                  {t("no-tests-found")}
                </Text>
                <Button
                  className={styles["tree-empty-results-clear-button"]}
                  type="button"
                  text={t("clear-filters")}
                  size={"s"}
                  style={"outline"}
                  onClick={() => clearPackagesFilters()}
                />
              </div>
            </div>
          );
        }

        return (
          <div className={styles["tree-list"]}>
            <Tree tree={filteredPackages.value} statusFilter={currentTab.value as ClassicStatus} root />
          </div>
        );
      }}
    />
  );
};
