saleor-dashboard/src/translations/components/TranslationsLanguageList/TranslationsLanguageList.tsx
Michał Droń d5c9a3dae8
Add trailing commas (#2062)
* Require trailing commas

* Add trailing commas

* Add trailing commas in testUtils dir

* Add trailing commas
2022-06-21 11:36:55 +02:00

86 lines
2.4 KiB
TypeScript

import {
Card,
TableBody,
TableCell,
TableHead,
TableRow,
} from "@material-ui/core";
import ResponsiveTable from "@saleor/components/ResponsiveTable";
import Skeleton from "@saleor/components/Skeleton";
import TableRowLink from "@saleor/components/TableRowLink";
import { LanguageFragment } from "@saleor/graphql";
import { makeStyles } from "@saleor/macaw-ui";
import { languageEntitiesUrl } from "@saleor/translations/urls";
import React from "react";
import { FormattedMessage } from "react-intl";
import { maybe, renderCollection } from "../../../misc";
export interface TranslationsLanguageListProps {
languages: LanguageFragment[];
}
const useStyles = makeStyles(
{
capitalize: {
textTransform: "capitalize",
},
link: {
cursor: "pointer",
},
},
{ name: "TranslationsLanguageList" },
);
const TranslationsLanguageList: React.FC<TranslationsLanguageListProps> = props => {
const { languages } = props;
const classes = useStyles(props);
return (
<Card>
<ResponsiveTable>
<TableHead>
<TableRow>
<TableCell>
<FormattedMessage id="y1Z3or" defaultMessage="Language" />
</TableCell>
</TableRow>
</TableHead>
<TableBody>
{renderCollection(
languages,
language => (
<TableRowLink
data-test-id={language ? language.code : "skeleton"}
className={!!language ? classes.link : undefined}
hover={!!language}
key={language ? language.code : "skeleton"}
href={language && languageEntitiesUrl(language.code, {})}
>
<TableCell className={classes.capitalize}>
{maybe<React.ReactNode>(
() => language.language,
<Skeleton />,
)}
</TableCell>
</TableRowLink>
),
() => (
<TableRow>
<TableCell colSpan={1}>
<FormattedMessage
id="ptPPVk"
defaultMessage="No languages found"
/>
</TableCell>
</TableRow>
),
)}
</TableBody>
</ResponsiveTable>
</Card>
);
};
TranslationsLanguageList.displayName = "TranslationsLanguageList";
export default TranslationsLanguageList;