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

mozilla / fx-private-relay / b206ad72-e127-4ddf-98e5-979270588f0c

30 Dec 2024 01:30AM CUT coverage: 85.075% (-0.01%) from 85.088%
b206ad72-e127-4ddf-98e5-979270588f0c

Pull #5287

circleci

web-flow
Bump swr from 2.2.5 to 2.3.0

Bumps [swr](https://github.com/vercel/swr) from 2.2.5 to 2.3.0.
- [Release notes](https://github.com/vercel/swr/releases)
- [Commits](https://github.com/vercel/swr/compare/v2.2.5...v2.3.0)

---
updated-dependencies:
- dependency-name: swr
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>
Pull Request #5287: Bump swr from 2.2.5 to 2.3.0

2432 of 3561 branches covered (68.3%)

Branch coverage included in aggregate %.

16994 of 19273 relevant lines covered (88.18%)

9.92 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