Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

i18n: placeholders #9114

Merged
merged 77 commits into from
Jul 24, 2019
Merged
Show file tree
Hide file tree
Changes from 53 commits
Commits
Show all changes
77 commits
Select commit Hold shift + click to select a range
656acce
basic format
exterkamp Jun 3, 2019
fc762a5
Basic placeholder syntax.
exterkamp Jun 4, 2019
d1cdeab
minor corrections
exterkamp Jun 4, 2019
74e11c1
iterating
exterkamp Jun 4, 2019
981e028
Added ICU plural and ICU select examples.
exterkamp Jun 4, 2019
6d2dd5d
Gender example has replacement AND ICU.
exterkamp Jun 4, 2019
f22ee1b
less stutter syntax
exterkamp Jun 4, 2019
c66c0c6
docs
exterkamp Jun 4, 2019
70a5a07
Updated README.
exterkamp Jun 12, 2019
a7fc83a
correct-strings
exterkamp Jul 3, 2019
0de5485
updated i18n.js
exterkamp Jul 3, 2019
f8650eb
Merge branch 'master' into placeholders
exterkamp Jul 3, 2019
37dc2ae
remove unused from correct-strings
exterkamp Jul 3, 2019
58c7ded
exported correct-strings to be reused to import. ts first pass on co…
exterkamp Jul 3, 2019
ad01bdd
first pass at new UIStrings format.
exterkamp Jul 3, 2019
4182889
new jsdoc format for comments + _very_ basic parsing.
exterkamp Jul 4, 2019
8b0f8ea
Better parsing, filled out lh-error descriptions.
exterkamp Jul 5, 2019
ddf8171
Fixed tests, made unminified-css and doc-title back to normal.
exterkamp Jul 7, 2019
705ffb6
Updating readme for i18n.
exterkamp Jul 7, 2019
902c2f7
More readme updates.
exterkamp Jul 8, 2019
4507138
Move collect code into seperate util file for testing, and the tests …
exterkamp Jul 8, 2019
29e29df
Add placeholder baking tests.
exterkamp Jul 8, 2019
393beb6
readme updates
exterkamp Jul 8, 2019
799084c
More readme details.
exterkamp Jul 8, 2019
86e1593
Added test for ICU with examples, fixed audits that violated this.
exterkamp Jul 8, 2019
6160402
Patrick foodback
exterkamp Jul 9, 2019
02e8977
ICU select & ordinal readme examples. made runtime example more accu…
exterkamp Jul 9, 2019
f5083b8
collection-util docstrings
exterkamp Jul 9, 2019
5aca05a
remove old console log
exterkamp Jul 9, 2019
ee3e235
update assert on strings to new en-US
exterkamp Jul 9, 2019
6b8297d
polish
exterkamp Jul 9, 2019
77fcd92
refactoring conversion method, testing conversion to follow.
exterkamp Jul 9, 2019
7252f3d
brendan readme foodback.
exterkamp Jul 10, 2019
d4dd3ac
check for empty descriptions
exterkamp Jul 10, 2019
996ee5c
Use UIString as primary fallback, since it is just en. Update fallba…
exterkamp Jul 11, 2019
4ff414a
Untrack pre-locales.
exterkamp Jul 11, 2019
588f574
reorganized collect and correct
exterkamp Jul 11, 2019
2b17130
fixup collect-string output
paulirish Jul 11, 2019
570a6cc
Paul foodback. Readme updates, updated yarn cmds, updated ctc naming …
exterkamp Jul 12, 2019
dcc7cc7
Wording of CTC and LHL in readme and docstrings. Removed mkdirp. Ad…
exterkamp Jul 12, 2019
7743cda
rip my hopes and dreams, thanks linter.
exterkamp Jul 12, 2019
ce01c75
polish to package and to collect-strings
exterkamp Jul 12, 2019
dea280a
better examples!
exterkamp Jul 12, 2019
7f89ccf
correct some complex ICU, add backticks.
exterkamp Jul 15, 2019
cf42496
Merge branch 'master' into placeholders
exterkamp Jul 15, 2019
d156737
Update 'yarn update:sample-json' and json itself
exterkamp Jul 15, 2019
89410f8
Handle the TODOs in readme.
exterkamp Jul 15, 2019
ea3616b
Added @meanings for all duplicated strings.
exterkamp Jul 15, 2019
3d40437
update sample json
exterkamp Jul 15, 2019
bc2b8f3
remove from UIStrings, add autofilled meanings + warning log.
exterkamp Jul 16, 2019
92cafeb
Some comments
exterkamp Jul 16, 2019
3d746d6
added TODO to collect-strings
exterkamp Jul 16, 2019
5ad0dff
Merge branch 'master' into placeholders
exterkamp Jul 17, 2019
c2e4ce5
Paul foodback.
exterkamp Jul 17, 2019
5dd3e07
Brendan baking foodback part 1.
exterkamp Jul 18, 2019
6eef366
update bakery, and tests. Remove space from yarn clean.
exterkamp Jul 18, 2019
a35a45e
lint
exterkamp Jul 18, 2019
13d0f02
foodback round 2, renaming party.
exterkamp Jul 18, 2019
b34ef95
Last part of feedback
exterkamp Jul 18, 2019
48283f4
windows compat collect-strings handled in appropriate PR.
exterkamp Jul 18, 2019
95527d5
Brendan foodback part 2.
exterkamp Jul 19, 2019
327c7db
How'd that var get there.
exterkamp Jul 19, 2019
b006cf7
Brendan feedback v3
exterkamp Jul 21, 2019
51cbb78
added comment to example fallback.
exterkamp Jul 22, 2019
37be64c
Merge branch 'master' into placeholders
exterkamp Jul 22, 2019
d2a8326
complex ICU -> custom-formatted ICU
exterkamp Jul 22, 2019
be426b8
reorg example logic to directIcu replacement.
exterkamp Jul 22, 2019
125cb1d
stop empty plcaeholders from being added to every message. Stricter c…
exterkamp Jul 22, 2019
b95b96b
updated columnName description
exterkamp Jul 22, 2019
90efcff
actually can't assert that in the tests. The undefined part is done …
exterkamp Jul 22, 2019
6e6ef24
@example {example} varName
exterkamp Jul 23, 2019
6a9ef28
whoops. console log left in
exterkamp Jul 23, 2019
7762381
brendan feedback
exterkamp Jul 23, 2019
6c19a17
Merge branch 'master' into placeholders
exterkamp Jul 24, 2019
be34f7e
Add sanity check for ctc files
exterkamp Jul 24, 2019
23a68d5
I feel like my linter is turned off
exterkamp Jul 24, 2019
3685dd6
Merge branch 'master' into placeholders
exterkamp Jul 24, 2019
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ last-run-results.html
*.report.csv
*.report.pretty
*.artifacts.log
*.ctc.json

!lighthouse-core/test/results/artifacts/*.trace.json
!lighthouse-core/test/results/artifacts/*.devtoolslog.json
Expand Down
2 changes: 1 addition & 1 deletion lighthouse-core/audits/byte-efficiency/unminified-css.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ const UIStrings = {
title: 'Minify CSS',
/** Description of a Lighthouse audit that tells the user *why* they should minify (remove whitespace) the page's CSS code. This is displayed after a user expands the section to see more. No character length limits. 'Learn More' becomes link text to additional documentation. */
description: 'Minifying CSS files can reduce network payload sizes. ' +
'[Learn more](https://developers.google.com/web/tools/lighthouse/audits/minify-css).',
'[Learn more](https://developers.google.com/web/tools/lighthouse/audits/minify-css).',
};

const str_ = i18n.createMessageInstanceIdFn(__filename, UIStrings);
Expand Down
5 changes: 4 additions & 1 deletion lighthouse-core/audits/dobetterweb/appcache-manifest.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,10 @@ const UIStrings = {
/** Description of a Lighthouse audit that tells the user why they should not use the Application Cache API. This is displayed after a user expands the section to see more. No character length limits. 'Learn More' becomes link text to additional documentation. */
description: 'Application Cache is deprecated. ' +
'[Learn more](https://developers.google.com/web/tools/lighthouse/audits/appcache).',
/** Label for the audit identifying uses of the Application Cache. */
/**
* @description Label for the audit identifying uses of the Application Cache.
* @example {AppCacheManifest} clock.appcache
*/
displayValue: 'Found "{AppCacheManifest}"',
};

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,10 @@ const UIStrings = {
description: 'Add `rel="noopener"` or `rel="noreferrer"` to any external links to improve ' +
'performance and prevent security vulnerabilities. ' +
'[Learn more](https://developers.google.com/web/tools/lighthouse/audits/noopener).',
/** Warning that some links' destinations cannot be determined and therefore the audit cannot evaluate the link's safety. */
/**
* @description Warning that some links' destinations cannot be determined and therefore the audit cannot evaluate the link's safety.
* @example {anchorHTML} <a target="_blank">
* */
exterkamp marked this conversation as resolved.
Show resolved Hide resolved
warning: 'Unable to determine the destination for anchor ({anchorHTML}). ' +
'If not used as a hyperlink, consider removing target=_blank.',
/** Label for a column in a data table; entries will be the target attribute of a link. Each entry is either an empty string or a string like `_blank`. */
Expand Down
4 changes: 1 addition & 3 deletions lighthouse-core/audits/dobetterweb/js-libraries.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,6 @@ const UIStrings = {
title: 'Detected JavaScript libraries',
/** Description of a Lighthouse audit that tells the user what this audit is detecting. This is displayed after a user expands the section to see more. No character length limits. */
description: 'All front-end JavaScript libraries detected on the page.',
/** Label for a column in a data table; entries will be the names of the detected Javascript libraries. */
columnName: 'Name',
/** Label for a column in a data table; entries will be the version numbers of the detected Javascript libraries. */
columnVersion: 'Version',
};
Expand Down Expand Up @@ -54,7 +52,7 @@ class JsLibrariesAudit extends Audit {

/** @type {LH.Audit.Details.Table['headings']} */
const headings = [
{key: 'name', itemType: 'text', text: str_(UIStrings.columnName)},
{key: 'name', itemType: 'text', text: str_(i18n.UIStrings.columnName)},
{key: 'version', itemType: 'text', text: str_(UIStrings.columnVersion)},
];
const details = Audit.makeTableDetails(headings, libDetails, {});
Expand Down
5 changes: 4 additions & 1 deletion lighthouse-core/audits/font-display.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,10 @@ const UIStrings = {
'Leverage the font-display CSS feature to ensure text is user-visible while ' +
'webfonts are loading. ' +
'[Learn more](https://developers.google.com/web/updates/2016/02/font-display).',
/** A warning message that is shown when Lighthouse couldn't automatically check some of the page's fonts and that the user will need to manually check it. */
/**
* @description A warning message that is shown when Lighthouse couldn't automatically check some of the page's fonts and that the user will need to manually check it.
* @example {fontURL} https://font.cdn.com/
*/
undeclaredFontURLWarning: 'Lighthouse was unable to automatically check the font-display value ' +
'for the following URL: {fontURL}.',
};
Expand Down
5 changes: 4 additions & 1 deletion lighthouse-core/audits/image-aspect-ratio.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,10 @@ const UIStrings = {
/** Description of a Lighthouse audit that tells the user why they should maintain the correct aspect ratios for all images. This is displayed after a user expands the section to see more. No character length limits. 'Learn More' becomes link text to additional documentation. */
description: 'Image display dimensions should match natural aspect ratio. ' +
'[Learn more](https://developers.google.com/web/tools/lighthouse/audits/aspect-ratio).',
/** Warning that the size information for an image was nonsensical. `url` will be replaced with the url of that image. */
/**
* @description Warning that the size information for an image was nonsensical.
* @example {url} https://image.cdn.com/
*/
warningCompute: 'Invalid image sizing information {url}',
/** Label for a column in a data table; entries in the column will be the numeric aspect ratio of an image as displayed in a web page. */
columnDisplayed: 'Aspect Ratio (Displayed)',
Expand Down
2 changes: 1 addition & 1 deletion lighthouse-core/audits/resource-summary.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ const UIStrings = {
' add a budget.json file. [Learn more](https://developers.google.com/web/tools/lighthouse/audits/budgets).',
/** [ICU Syntax] Label for an audit identifying the number of requests and kilobytes used to load the page. */
displayValue: `{requestCount, plural, =1 {1 request} other {# requests}}` +
` • { byteCount, number, bytes } KB`,
` • {byteCount, number, bytes} KB`,
};

const str_ = i18n.createMessageInstanceIdFn(__filename, UIStrings);
Expand Down
25 changes: 20 additions & 5 deletions lighthouse-core/audits/seo/canonical.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,15 +18,30 @@ const UIStrings = {
/** Description of a Lighthouse audit that tells the user *why* they need to have a valid rel=canonical link. This is displayed after a user expands the section to see more. No character length limits. 'Learn More' becomes link text to additional documentation. */
description: 'Canonical links suggest which URL to show in search results. ' +
'[Learn more](https://developers.google.com/web/tools/lighthouse/audits/canonical).',
/** Explanatory message stating that there was a failure in an audit caused by multiple URLs conflicting with each other. "urlList" will be replaced by a list of URLs (e.g. https://example.com, https://example2.com, etc ). */
/**
* @description Explanatory message stating that there was a failure in an audit caused by multiple URLs conflicting with each other.
* @example {urlList} https://example.com, https://example2.com
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

do we have any guidance for @example content? And is this (comma separated) the way we should be handling multiple examples?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No real guidance. Basically its just literally what can be used as the final replacement afaik.

This isn't actually 2 examples, its literally what the url list looks like when there are multiple urls. That is a bit unclear though.

* */
explanationConflict: 'Multiple conflicting URLs ({urlList})',
/** Explanatory message stating that there was a failure in an audit caused by a URL being invalid. "url" will be replaced by the invalid URL (e.g. https://example.com). */
/**
* @description Explanatory message stating that there was a failure in an audit caused by a URL being invalid.
* @example {url} https://example.com/
* */
explanationInvalid: 'Invalid URL ({url})',
/** Explanatory message stating that there was a failure in an audit caused by a URL being relative instead of absolute. "url" will be replaced by the invalid URL (e.g. https://example.com). */
/**
* @description Explanatory message stating that there was a failure in an audit caused by a URL being relative instead of absolute.
* @example {url} https://example.com/
* */
explanationRelative: 'Relative URL ({url})',
/** Explanatory message stating that there was a failure in an audit caused by a URL pointing to a different hreflang than the current context. "url" will be replaced by the invalid URL (e.g. https://example.com). 'hreflang' is an HTML attribute and should not be translated. */
/**
* @description Explanatory message stating that there was a failure in an audit caused by a URL pointing to a different hreflang than the current context.'hreflang' is an HTML attribute and should not be translated.
* @example {url} https://example.com/
*/
explanationPointsElsewhere: 'Points to another `hreflang` location ({url})',
/** Explanatory message stating that there was a failure in an audit caused by a URL pointing to a different domain. "url" will be replaced by the invalid URL (e.g. https://example.com). */
/**
* @description Explanatory message stating that there was a failure in an audit caused by a URL pointing to a different domain.
* @example {url} https://example.com/
* */
explanationDifferentDomain: 'Points to a different domain ({url})',
/** Explanatory message stating that the page's canonical URL was pointing to the domain's root URL, which is a common mistake. "points" refers to the action of the 'rel=canonical' referencing another link. "root" refers to the starting/home page of the website. "domain" refers to the registered domain name of the website. */
explanationRoot: 'Points to the domain\'s root URL (the homepage), ' +
Expand Down
5 changes: 4 additions & 1 deletion lighthouse-core/audits/seo/robots-txt.js
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,10 @@ const UIStrings = {
/** Description of a Lighthouse audit that tells the user *why* they need to have a valid robots.txt file. Note: "robots.txt" is a canonical filename and should not be translated. This is displayed after a user expands the section to see more. No character length limits. */
description: 'If your robots.txt file is malformed, crawlers may not be able to understand ' +
'how you want your website to be crawled or indexed.',
/** Label for the audit identifying that the robots.txt request has returned a specific HTTP status code. Note: "robots.txt" is a canonical filename and should not be translated. "statusCode" will be replaced with a 3 digit integer which represents the status of the HTTP connectiong for this page. */
/**
* @description Label for the audit identifying that the robots.txt request has returned a specific HTTP status code. Note: "robots.txt" is a canonical filename and should not be translated.
* @example {statusCode} 500
* */
displayValueHttpBadCode: 'request for robots.txt returned HTTP status: {statusCode}',
/** [ICU Syntax] Label for the audit identifying the number of errors that occured while validating the robots.txt file. "itemCount" will be replaced by the integer count of errors encountered. */
displayValueValidationError: `{itemCount, plural,
Expand Down
4 changes: 1 addition & 3 deletions lighthouse-core/audits/seo/tap-targets.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,6 @@ const UIStrings = {
description: 'Interactive elements like buttons and links should be large enough (48x48px), and have enough space around them, to be easy enough to tap without overlapping onto other elements. [Learn more](https://developers.google.com/web/fundamentals/accessibility/accessible-styles#multi-device_responsive_design).',
/** Label of a table column that identifies tap targets (like buttons and links) that have failed the audit and aren't easy to tap on. */
tapTargetHeader: 'Tap Target',
/** Label of a table column that specifies the size of tap targets like buttons and links. */
sizeHeader: 'Size',
/** Label of a table column that identifies a tap target (like a link or button) that overlaps with another tap target. */
overlappingTargetHeader: 'Overlapping Target',
/** Explanatory message stating that there was a failure in an audit caused by the viewport meta tag not being optimized for mobile screens, which caused tap targets like buttons and links to be too small to tap on. */
Expand Down Expand Up @@ -303,7 +301,7 @@ class TapTargets extends Audit {
/** @type {LH.Audit.Details.Table['headings']} */
const headings = [
{key: 'tapTarget', itemType: 'node', text: str_(UIStrings.tapTargetHeader)},
{key: 'size', itemType: 'text', text: str_(UIStrings.sizeHeader)},
{key: 'size', itemType: 'text', text: str_(i18n.UIStrings.columnSize)},
{key: 'overlappingTarget', itemType: 'node', text: str_(UIStrings.overlappingTargetHeader)},
];

Expand Down
4 changes: 1 addition & 3 deletions lighthouse-core/audits/user-timings.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,6 @@ const UIStrings = {
=1 {1 user timing}
other {# user timings}
}`,
/** Label for the Name column in the User Timing event data table. User Timing API entries are added by the developer of the web page. An example user timing event name: 'pageload_logoimage_done' */
columnName: 'Name',
/** Label for the Type column in the User Timing event data table. User Timing API entries are added by the developer of the web page. The only possible types are 'Mark' and Measure'. */
columnType: 'Type',
/** Label for the Start Time column in the User Timing event data table. User Timing API entries are added by the developer of the web page. Start Times are the number of milliseconds since the page started loading, e.g. '380.26 ms' */
Expand Down Expand Up @@ -96,7 +94,7 @@ class UserTimings extends Audit {

/** @type {LH.Audit.Details.Table['headings']} */
const headings = [
{key: 'name', itemType: 'text', text: str_(UIStrings.columnName)},
{key: 'name', itemType: 'text', text: str_(i18n.UIStrings.columnName)},
{key: 'timingType', itemType: 'text', text: str_(UIStrings.columnType)},
{key: 'startTime', itemType: 'ms', granularity: 0.01,
text: str_(UIStrings.columnStartTime)},
Expand Down
5 changes: 4 additions & 1 deletion lighthouse-core/audits/uses-rel-preconnect.js
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,10 @@ const UIStrings = {
description:
'Consider adding preconnect or dns-prefetch resource hints to establish early ' +
`connections to important third-party origins. [Learn more](https://developers.google.com/web/fundamentals/performance/resource-prioritization#preconnect).`,
/** A warning message that is shown when the user tried to follow the advice of the audit, but it's not working as expected. Forgetting to set the `crossorigin` HTML attribute, or setting it to an incorrect value, on the link is a common mistake when adding preconnect links. */
/**
* @description A warning message that is shown when the user tried to follow the advice of the audit, but it's not working as expected. Forgetting to set the `crossorigin` HTML attribute, or setting it to an incorrect value, on the link is a common mistake when adding preconnect links.
* @example {securityOrigin} https://example.com
* */
crossoriginWarning: 'A preconnect <link> was found for "{securityOrigin}" but was not used ' +
'by the browser. Check that you are using the `crossorigin` attribute properly.',
};
Expand Down
7 changes: 5 additions & 2 deletions lighthouse-core/audits/uses-rel-preload.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,12 @@ const UIStrings = {
/** Imperative title of a Lighthouse audit that tells the user to use <link rel=preload> to initiate important network requests earlier during page load. This is displayed in a list of audit titles that Lighthouse generates. */
title: 'Preload key requests',
/** Description of a Lighthouse audit that tells the user *why* they should preload important network requests. The associated network requests are started halfway through pageload (or later) but should be started at the beginning. This is displayed after a user expands the section to see more. No character length limits. '<link rel=preload>' is the html code the user would include in their page and shouldn't be translated. 'Learn More' becomes link text to additional documentation. */
description: 'Consider using <link rel=preload> to prioritize fetching resources that are ' +
description: 'Consider using `<link rel=preload>` to prioritize fetching resources that are ' +
'currently requested later in page load. [Learn more](https://developers.google.com/web/tools/lighthouse/audits/preload).',
/** A warning message that is shown when the user tried to follow the advice of the audit, but it's not working as expected. Forgetting to set the `crossorigin` HTML attribute, or setting it to an incorrect value, on the link is a common mistake when adding preload links. */
/**
* @description A warning message that is shown when the user tried to follow the advice of the audit, but it's not working as expected. Forgetting to set the `crossorigin` HTML attribute, or setting it to an incorrect value, on the link is a common mistake when adding preload links.
* @example {preloadURL} https://example.com
* */
crossoriginWarning: 'A preload <link> was found for "{preloadURL}" but was not used ' +
'by the browser. Check that you are using the `crossorigin` attribute properly.',
};
Expand Down
7 changes: 2 additions & 5 deletions lighthouse-core/lib/i18n/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -69,10 +69,6 @@ See [Appendix A: How runtime string replacement works](#appendix)

# Writing UIStrings with LHL

❗TODO(exterkamp): explain all the comments and where they go/what they become.

❗TODO(exterkamp): explain why we can't use some ICU like number formatting.

We want to keep strings close to the code in which they are used so that developers can easily understand their context. We use `i18n.js` to extract the `UIStrings` strings from individual js files.

LHL strings in each module are defined in a `UIStrings` object with the strings as its properties. JSDoc is sometimes used to provide additional information about each string.
Expand Down Expand Up @@ -143,6 +139,8 @@ displayValue: `{itemCount, plural,
}`,
```

Note: Why are direct ICU and complex ICU placeholdered out, but Ordinals are not? Direct and complex ICU should not contain elements that need to be translated (Direct ICU replaces universal proper nouns, and Complex ICU replaces number formatting), while ordinals do need to be translated. Ordinals and selects are therefore handled specially, and do not need to be placeholdered out.
exterkamp marked this conversation as resolved.
Show resolved Hide resolved

### Selects

A select ICU message is used when the message should select a sub-message based on the value of a variable `pronoun` in this case. This is often used for gender based selections, but can be used for any enum. Lighthouse does not use selects very often.
Expand Down Expand Up @@ -280,4 +278,3 @@ CTC is a name that is distinct and identifies this as the Chrome translation for
```javascript
message = "Total size was 10 KB"
```

Loading