• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

mozilla / fx-private-relay / 0128c881-32be-4daa-83f2-8553af8a5e6f

14 Oct 2024 03:57PM CUT coverage: 84.402%. Remained the same
0128c881-32be-4daa-83f2-8553af8a5e6f

push

circleci

web-flow
Merge pull request #5106 from mozilla/dependabot/npm_and_yarn/stylelint-16.10.0

Bump stylelint from 16.9.0 to 16.10.0

2355 of 3497 branches covered (67.34%)

Branch coverage included in aggregate %.

16335 of 18647 relevant lines covered (87.6%)

10.22 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

0.0
/frontend/src/components/Localized.tsx
1
// Imports of `Localized` from @fluent/react are forbidden because the component
2
// in this file should be used instead, but of course this component can use it
3
// just fine:
4
// eslint-disable-next-line no-restricted-imports
5
import { LocalizedProps, Localized as OriginalLocalized } from "@fluent/react";
×
6
import { cloneElement, isValidElement, useEffect, useState } from "react";
×
7
import { useL10n } from "../hooks/l10n";
×
8

9
/**
10
 * Wraps @fluent/react's Localized to be consistent between prerender and first render
11
 *
12
 * React will throw a tantrum if the HTML rendered during the build differs from
13
 * the DOM rendered by React when running client-side. However, at build-time we
14
 * don't yet know the user's locale. Thus, if we render strings in the user's
15
 * locale on the first client-side render, we'll make React unhappy, and who
16
 * wants that?
17
 *
18
 * To work around this, the useL10n hook makes sure that the English strings are
19
 * rendered when both prerendering and doing the first client-side render, and
20
 * only after that use the language that aligns with the user's preferences.
21
 * Thus, while pre-rendering and during the first client-side render, we call
22
 * out to that hook.
23
 *
24
 * This means tags embedded in the localised strings won't get added initially,
25
 * but since that's only for SEO and the initial render, that's acceptable.
26
 */
27
export const Localized = (props: LocalizedProps) => {
×
28
  const [isPrerendering, setIsPrerendering] = useState(true);
×
29
  const l10n = useL10n();
×
30

31
  useEffect(() => {
×
32
    setIsPrerendering(false);
×
33
  }, []);
34

35
  if (isPrerendering) {
×
36
    // `useL10n` makes sure that this is a prerenderable string
37
    return isValidElement(props.children) ? (
38
      cloneElement(
×
39
        props.children,
40
        {},
41
        <>{l10n.getString(props.id, props.vars)}</>,
42
      )
43
    ) : (
44
      <>{l10n.getString(props.id, props.vars)}</>
45
    );
46
  }
47

48
  return <OriginalLocalized {...props} />;
49
};
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc