Skip to content

Commit

Permalink
refactor: new search components
Browse files Browse the repository at this point in the history
  • Loading branch information
Jonas-C committed Oct 9, 2024
1 parent 66e5bcc commit fcf50a9
Show file tree
Hide file tree
Showing 14 changed files with 442 additions and 421 deletions.

This file was deleted.

58 changes: 27 additions & 31 deletions src/containers/SearchPage/components/results/SearchAudio.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,21 +7,16 @@
*/

import { useTranslation } from "react-i18next";
import { Link } from "react-router-dom";
import { Audio, Podcast } from "@ndla/icons/common";
import { getLicenseByAbbreviation } from "@ndla/licenses";
import { ListItemContent, ListItemHeading, ListItemImage, ListItemRoot } from "@ndla/primitives";
import { SafeLink } from "@ndla/safelink";
import { IAudioSummary } from "@ndla/types-backend/audio-api";
import { LicenseLink } from "@ndla/ui";
import { SearchContentWrapper } from "./SearchContentWrapper";
import { SearchLanguages } from "./SearchLanguages";
import { useLicenses } from "../../../../modules/draft/draftQueries";
import { toEditAudio, toEditPodcast } from "../../../../util/routeHelpers";
import {
StyledSearchContent,
StyledSearchDescription,
StyledSearchImageContainer,
StyledSearchOtherLink,
StyledSearchResult,
StyledSearchTitle,
} from "../form/StyledSearchComponents";
import { routes } from "../../../../util/routeHelpers";

interface Props {
audio: IAudioSummary;
Expand All @@ -32,28 +27,29 @@ const SearchAudio = ({ audio, locale }: Props) => {
const { t } = useTranslation();
const { data: licenses } = useLicenses();
const license = licenses && licenses.find((l) => audio.license === l.license);

return (
<StyledSearchResult data-testid="audio-search-result">
<StyledSearchImageContainer>{audio.audioType === "podcast" ? <Podcast /> : <Audio />}</StyledSearchImageContainer>
<StyledSearchContent>
<Link
to={
audio.audioType === "podcast"
? toEditPodcast(audio.id, audio.title.language)
: toEditAudio(audio.id, audio.title.language)
}
>
<StyledSearchTitle>{audio.title.title || t("audioSearch.noTitle")}</StyledSearchTitle>
</Link>
<StyledSearchDescription>
{`${t("searchPage.language")}: `}
{audio.supportedLanguages?.map((lang) => (
<StyledSearchOtherLink key={lang}>{t(`languages.${lang}`)}</StyledSearchOtherLink>
))}
</StyledSearchDescription>
{license && <LicenseLink license={getLicenseByAbbreviation(license.license, locale)} />}
</StyledSearchContent>
</StyledSearchResult>
<ListItemRoot variant="list" data-testid="audio-search-result">
<ListItemImage fallbackElement={audio.audioType === "podcast" ? <Podcast /> : <Audio />} src="" alt="" />
<ListItemContent>
<SearchContentWrapper>
<ListItemHeading asChild consumeCss>
<SafeLink
to={
audio.audioType === "podcast"
? routes.podcast.edit(audio.id, audio.title.language)
: routes.audio.edit(audio.id, audio.title.language)
}
unstyled
>
{audio.title.title || t("audioSearch.noTitle")}
</SafeLink>
</ListItemHeading>
<SearchLanguages content={audio} language={audio.title.language} contentType="audio" />
</SearchContentWrapper>
{!!license && <LicenseLink license={getLicenseByAbbreviation(license?.license, locale)} />}
</ListItemContent>
</ListItemRoot>
);
};

Expand Down
Loading

0 comments on commit fcf50a9

Please sign in to comment.