CINXE.COM

[Float][Fizz][Fiber] support imagesrcset and imagesizes for `ReactDOM.preload()` by gnoff · Pull Request #26940 · facebook/react · GitHub

<!DOCTYPE html> <html lang="en" data-color-mode="auto" data-light-theme="light" data-dark-theme="dark" data-a11y-animated-images="system" data-a11y-link-underlines="true" > <head> <meta charset="utf-8"> <link rel="dns-prefetch" href="https://github.githubassets.com"> <link rel="dns-prefetch" href="https://avatars.githubusercontent.com"> <link rel="dns-prefetch" href="https://github-cloud.s3.amazonaws.com"> <link rel="dns-prefetch" href="https://user-images.githubusercontent.com/"> <link rel="preconnect" href="https://github.githubassets.com" crossorigin> <link rel="preconnect" href="https://avatars.githubusercontent.com"> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/light-0cfd1fd8509e.css" /><link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/dark-d782f59290e2.css" /><link data-color-theme="dark_dimmed" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/dark_dimmed-f9fbc4b99a77.css" /><link data-color-theme="dark_high_contrast" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/dark_high_contrast-cff1c9b27b1a.css" /><link data-color-theme="dark_colorblind" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/dark_colorblind-70097f75aec1.css" /><link data-color-theme="light_colorblind" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/light_colorblind-c2f0d49bdcd9.css" /><link data-color-theme="light_high_contrast" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/light_high_contrast-4747d7bc0bc4.css" /><link data-color-theme="light_tritanopia" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/light_tritanopia-d3f6a61c91c8.css" /><link data-color-theme="dark_tritanopia" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/dark_tritanopia-a188d53f44bb.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-primitives-953961b66e63.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-c2a395868004.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/global-2f00718c6733.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/github-2bd3a44faeb2.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/repository-d031bcc14e1b.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/pull-requests-531a3fdee92a.css" /> <script type="application/json" id="client-env">{"locale":"en","featureFlags":["copilot_new_references_ui","copilot_beta_features_opt_in","copilot_conversational_ux_history_refs","copilot_implicit_context","copilot_smell_icebreaker_ux","experimentation_azure_variant_endpoint","failbot_handle_non_errors","geojson_azure_maps","ghost_pilot_confidence_truncation_25","ghost_pilot_confidence_truncation_40","hovercard_accessibility","issues_react_new_timeline","issues_react_avatar_refactor","issues_react_remove_placeholders","issues_react_blur_item_picker_on_close","marketing_pages_search_explore_provider","react_keyboard_shortcuts_dialog","remove_child_patch","sample_network_conn_type","site_metered_billing_update","lifecycle_label_name_updates"]}</script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/wp-runtime-513789f05308.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_oddbird_popover-polyfill_dist_popover_js-9da652f58479.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_arianotify-polyfill_ariaNotify-polyfill_js-node_modules_github_mi-3abb8f-d7e6bc799724.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_failbot_failbot_ts-09435cd1cf6d.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/environment-7b93e0f0c8ff.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_primer_behaviors_dist_esm_index_mjs-ea2a5d75d580.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_selector-observer_dist_index_esm_js-f690fd9ae3d5.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_relative-time-element_dist_index_js-f6da4b3fa34c.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_combobox-nav_dist_index_js-node_modules_github_g-emoji-element_di-6ce195-8dc38c1f27cc.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_auto-complete-element_dist_index_js-node_modules_github_catalyst_-8e9f78-a74b4e0a8a6b.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_text-expander-element_dist_index_js-78748950cb0c.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_filter-input-element_dist_index_js-node_modules_github_remote-inp-b5f1d7-a1760ffda83d.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_file-attachment-element_dist_index_js-node_modules_primer_view-co-381a4f-e1937e23751a.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/github-elements-902713b269e2.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/element-registry-3cb970f9c462.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_braintree_browser-detection_dist_browser-detection_js-node_modules_githu-bb80ec-1b4f4deecd3a.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_lit-html_lit-html_js-be8cb88f481b.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_mini-throttle_dist_index_js-node_modules_morphdom_dist_morphdom-e-7c534c-a4a1922eb55f.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_turbo_dist_turbo_es2017-esm_js-e3cbe28f1638.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_remote-form_dist_index_js-node_modules_delegated-events_dist_inde-893f9f-6cf3320416b8.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_color-convert_index_js-e3180fe3bcb3.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_quote-selection_dist_index_js-node_modules_github_session-resume_-69cfcc-833249ee3034.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_updatable-content_updatable-content_ts-863ef5872a03.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_behaviors_task-list_ts-app_assets_modules_github_sso_ts-ui_packages-900dde-917d4bda1f1a.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_sticky-scroll-into-view_ts-7cbef09a422c.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_behaviors_ajax-error_ts-app_assets_modules_github_behaviors_include-d0d0a6-b41aeef03499.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_behaviors_commenting_edit_ts-app_assets_modules_github_behaviors_ht-83c235-fb43816ab83c.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/behaviors-bd73f5127970.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_delegated-events_dist_index_js-node_modules_github_catalyst_lib_index_js-f6223d90c7ba.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/notifications-global-cfcd9f4f0f23.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_virtualized-list_es_index_js-node_modules_github_template-parts_lib_index_js-96453a51f920.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_remote-form_dist_index_js-node_modules_delegated-events_dist_inde-70450e-eecf0d50276f.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_ref-selector_ts-74c351a8d897.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/codespaces-a493a4b9528f.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/react-core-10ab7568dc1d.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/react-lib-2131e17288a8.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_tanstack_query-core_build_modern_queryClient_js-e6f07a7e80b7.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_tanstack_query-core_build_modern_queryObserver_js-node_modules_tanstack_-defd52-843b41414e0e.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_remote-form_dist_index_js-node_modules_github_details-dialog-elem-308dee-23f281d9acce.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_mini-throttle_dist_decorators_js-node_modules_delegated-events_di-e161aa-9d41fb1b6c9e.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_scroll-anchoring_dist_scroll-anchoring_esm_js-node_modules_github_cataly-db906b-3eeea7fa8b27.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_diffs_blob-lines_ts-app_assets_modules_github_diffs_linkable-line-n-b8c0ea-be4e711b7e28.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/diffs-d41e3f1a4f7b.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/scanning-3ceed65aa3f9.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_mini-throttle_dist_index_js-node_modules_github_catalyst_lib_inde-dbbea9-26cce2010167.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/code-menu-a6586c32bc2f.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/primer-react-dcbe4742cab1.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/react-core-10ab7568dc1d.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/react-lib-2131e17288a8.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/octicons-react-45c3a19dd792.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_tanstack_query-core_build_modern_queryClient_js-e6f07a7e80b7.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_emotion_is-prop-valid_dist_emotion-is-prop-valid_esm_js-node_modules_emo-37e3d5-92730c05e718.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_mini-throttle_dist_index_js-node_modules_stacktrace-parser_dist_s-e7dcdd-f7cc96ebae76.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_oddbird_popover-polyfill_dist_popover-fn_js-55fea94174bf.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/notifications-subscriptions-menu-51601778bd8d.js"></script> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-react.978a0e823d7b04f19850.module.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/notifications-subscriptions-menu.1bcff9205c241e99cff2.module.css" /> <title>[Float][Fizz][Fiber] support imagesrcset and imagesizes for `ReactDOM.preload()` by gnoff · Pull Request #26940 · facebook/react · GitHub</title> <meta name="route-pattern" content="/_view_fragments/voltron/pull_requests/show/:user_id/:repository/:id/pull_request_layout(.:format)" data-turbo-transient> <meta name="route-controller" content="voltron_pull_requests_fragments" data-turbo-transient> <meta name="route-action" content="pull_request_layout" data-turbo-transient> <meta name="current-catalog-service-hash" content="ae870bc5e265a340912cde392f23dad3671a0a881730ffdadd82f2f57d81641b"> <meta name="request-id" content="C886:201112:20C21E2:25ABDCF:675CC185" data-pjax-transient="true"/><meta name="html-safe-nonce" content="76f56c545ce3f8538851b3b1640460e50dcd210d68cd8bcfbe163fc270cf5b77" data-pjax-transient="true"/><meta name="visitor-payload" content="eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiJDODg2OjIwMTExMjoyMEMyMUUyOjI1QUJEQ0Y6Njc1Q0MxODUiLCJ2aXNpdG9yX2lkIjoiMzc5Mzk2MTQ4ODY2NDU0MzYyMSIsInJlZ2lvbl9lZGdlIjoic291dGhlYXN0YXNpYSIsInJlZ2lvbl9yZW5kZXIiOiJzb3V0aGVhc3Rhc2lhIn0=" data-pjax-transient="true"/><meta name="visitor-hmac" content="1dd2bfe841babf185c310ace34126fae8aaebca09c93cdc1941363e3e3d362b2" data-pjax-transient="true"/> <meta name="hovercard-subject-tag" content="pull_request:1391128438" data-turbo-transient> <meta name="github-keyboard-shortcuts" content="repository,pull-request-list,pull-request-conversation,pull-request-files-changed,copilot" data-turbo-transient="true" /> <meta name="selected-link" value="repo_pulls" data-turbo-transient> <link rel="assets" href="https://github.githubassets.com/"> <meta name="google-site-verification" content="Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I"> <meta name="octolytics-url" content="https://collector.github.com/github/collect" /> <meta name="analytics-location" content="/&lt;user-name&gt;/&lt;repo-name&gt;/voltron/pull_requests_fragments/pull_request_layout" data-turbo-transient="true" /> <meta name="user-login" content=""> <meta name="viewport" content="width=device-width"> <meta name="description" content="For float methods the href argument is usually all we need to uniquely key the request. However when preloading responsive images it is possible that you may need more than one preload for differin..."> <link rel="search" type="application/opensearchdescription+xml" href="/opensearch.xml" title="GitHub"> <link rel="fluid-icon" href="https://github.com/fluidicon.png" title="GitHub"> <meta property="fb:app_id" content="1401488693436528"> <meta name="apple-itunes-app" content="app-id=1477376905, app-argument=https://github.com/_view_fragments/voltron/pull_requests/show/facebook/react/26940/pull_request_layout" /> <meta name="twitter:image" content="https://opengraph.githubassets.com/96233fbad8e5ec6894d0782a34345158fde0bcaad19f1ac758beeb17b8b70469/facebook/react/pull/26940" /><meta name="twitter:site" content="@github" /><meta name="twitter:card" content="summary_large_image" /><meta name="twitter:title" content="[Float][Fizz][Fiber] support imagesrcset and imagesizes for `ReactDOM.preload()` by gnoff · Pull Request #26940 · facebook/react" /><meta name="twitter:description" content="For float methods the href argument is usually all we need to uniquely key the request. However when preloading responsive images it is possible that you may need more than one preload for differin..." /> <meta property="og:image" content="https://opengraph.githubassets.com/96233fbad8e5ec6894d0782a34345158fde0bcaad19f1ac758beeb17b8b70469/facebook/react/pull/26940" /><meta property="og:image:alt" content="For float methods the href argument is usually all we need to uniquely key the request. However when preloading responsive images it is possible that you may need more than one preload for differin..." /><meta property="og:image:width" content="1200" /><meta property="og:image:height" content="600" /><meta property="og:site_name" content="GitHub" /><meta property="og:type" content="object" /><meta property="og:title" content="[Float][Fizz][Fiber] support imagesrcset and imagesizes for `ReactDOM.preload()` by gnoff · Pull Request #26940 · facebook/react" /><meta property="og:url" content="https://github.com/facebook/react/pull/26940" /><meta property="og:description" content="For float methods the href argument is usually all we need to uniquely key the request. However when preloading responsive images it is possible that you may need more than one preload for differin..." /><meta property="og:author:username" content="gnoff" /> <meta name="hostname" content="github.com"> <meta name="expected-hostname" content="github.com"> <meta http-equiv="x-pjax-version" content="9597602658f836459627c031936e283b44df7b3dc7cb9724bd16025543af44c8" data-turbo-track="reload"> <meta http-equiv="x-pjax-csp-version" content="ace39c3b6632770952207593607e6e0be0db363435a8b877b1f96abe6430f345" data-turbo-track="reload"> <meta http-equiv="x-pjax-css-version" content="47c04af5bd21cb61932edc9a6a9416d3e507aeef479f7c520e66545ab5133438" data-turbo-track="reload"> <meta http-equiv="x-pjax-js-version" content="2f04f5b19bb933fb56bda2576752278f8730dad4712bef09176013c195b1fd2c" data-turbo-track="reload"> <meta name="turbo-cache-control" content="no-preview" data-turbo-transient=""> <meta name="voltron-timing" value="1171"> <meta name="go-import" content="github.com/facebook/react git https://github.com/facebook/react.git"> <meta name="octolytics-dimension-user_id" content="69631" /><meta name="octolytics-dimension-user_login" content="facebook" /><meta name="octolytics-dimension-repository_id" content="10270250" /><meta name="octolytics-dimension-repository_nwo" content="facebook/react" /><meta name="octolytics-dimension-repository_public" content="true" /><meta name="octolytics-dimension-repository_is_fork" content="false" /><meta name="octolytics-dimension-repository_network_root_id" content="10270250" /><meta name="octolytics-dimension-repository_network_root_nwo" content="facebook/react" /> <meta name="turbo-body-classes" content="logged-out env-production page-responsive"> <meta name="browser-stats-url" content="https://api.github.com/_private/browser/stats"> <meta name="browser-errors-url" content="https://api.github.com/_private/browser/errors"> <link rel="mask-icon" href="https://github.githubassets.com/assets/pinned-octocat-093da3e6fa40.svg" color="#000000"> <link rel="alternate icon" class="js-site-favicon" type="image/png" href="https://github.githubassets.com/favicons/favicon.png"> <link rel="icon" class="js-site-favicon" type="image/svg+xml" href="https://github.githubassets.com/favicons/favicon.svg" data-base-href="https://github.githubassets.com/favicons/favicon"> <meta name="theme-color" content="#1e2327"> <meta name="color-scheme" content="light dark" /> <link rel="manifest" href="/manifest.json" crossOrigin="use-credentials"> </head> <body class="logged-out env-production page-responsive" style="word-wrap: break-word;"> <div data-turbo-body class="logged-out env-production page-responsive" style="word-wrap: break-word;"> <div class="position-relative header-wrapper js-header-wrapper "> <a href="#start-of-content" data-skip-target-assigned="false" class="px-2 py-4 color-bg-accent-emphasis color-fg-on-emphasis show-on-focus js-skip-to-content">Skip to content</a> <span data-view-component="true" class="progress-pjax-loader Progress position-fixed width-full"> <span style="width: 0%;" data-view-component="true" class="Progress-item progress-pjax-loader-bar left-0 top-0 color-bg-accent-emphasis"></span> </span> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/primer-react-dcbe4742cab1.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/octicons-react-45c3a19dd792.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_emotion_is-prop-valid_dist_emotion-is-prop-valid_esm_js-node_modules_emo-37e3d5-92730c05e718.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_mini-throttle_dist_index_js-node_modules_stacktrace-parser_dist_s-e7dcdd-f7cc96ebae76.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_oddbird_popover-polyfill_dist_popover-fn_js-55fea94174bf.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_ui-commands_ui-commands_ts-ad1e2d0f65cc.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/keyboard-shortcuts-dialog-958cae8ecd6c.js"></script> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-react.978a0e823d7b04f19850.module.css" /> <react-partial partial-name="keyboard-shortcuts-dialog" data-ssr="false" data-attempted-ssr="false" > <script type="application/json" data-target="react-partial.embeddedData">{"props":{"docsUrl":"https://docs.github.com/get-started/accessibility/keyboard-shortcuts"}}</script> <div data-target="react-partial.reactRoot"></div> </react-partial> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_remote-form_dist_index_js-node_modules_delegated-events_dist_inde-94fd67-73b675cf164a.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/sessions-5d6426bbf16a.js"></script> <header class="HeaderMktg header-logged-out js-details-container js-header Details f4 py-3" role="banner" data-is-top="true" data-color-mode=light data-light-theme=light data-dark-theme=dark> <h2 class="sr-only">Navigation Menu</h2> <button type="button" class="HeaderMktg-backdrop d-lg-none border-0 position-fixed top-0 left-0 width-full height-full js-details-target" aria-label="Toggle navigation"> <span class="d-none">Toggle navigation</span> </button> <div class="d-flex flex-column flex-lg-row flex-items-center px-3 px-md-4 px-lg-5 height-full position-relative z-1"> <div class="d-flex flex-justify-between flex-items-center width-full width-lg-auto"> <div class="flex-1"> <button aria-label="Toggle navigation" aria-expanded="false" type="button" data-view-component="true" class="js-details-target js-nav-padding-recalculate js-header-menu-toggle Button--link Button--medium Button d-lg-none color-fg-inherit p-1"> <span class="Button-content"> <span class="Button-label"><div class="HeaderMenu-toggle-bar rounded my-1"></div> <div class="HeaderMenu-toggle-bar rounded my-1"></div> <div class="HeaderMenu-toggle-bar rounded my-1"></div></span> </span> </button> </div> <a class="mr-lg-3 color-fg-inherit flex-order-2 js-prevent-focus-on-mobile-nav" href="/" aria-label="Homepage" data-analytics-event="{&quot;category&quot;:&quot;Marketing nav&quot;,&quot;action&quot;:&quot;click to go to homepage&quot;,&quot;label&quot;:&quot;ref_page:Marketing;ref_cta:Logomark;ref_loc:Header&quot;}"> <svg height="32" aria-hidden="true" viewBox="0 0 24 24" version="1.1" width="32" data-view-component="true" class="octicon octicon-mark-github"> <path d="M12.5.75C6.146.75 1 5.896 1 12.25c0 5.089 3.292 9.387 7.863 10.91.575.101.79-.244.79-.546 0-.273-.014-1.178-.014-2.142-2.889.532-3.636-.704-3.866-1.35-.13-.331-.69-1.352-1.18-1.625-.402-.216-.977-.748-.014-.762.906-.014 1.553.834 1.769 1.179 1.035 1.74 2.688 1.25 3.349.948.1-.747.402-1.25.733-1.538-2.559-.287-5.232-1.279-5.232-5.678 0-1.25.445-2.285 1.178-3.09-.115-.288-.517-1.467.115-3.048 0 0 .963-.302 3.163 1.179.92-.259 1.897-.388 2.875-.388.977 0 1.955.13 2.875.388 2.2-1.495 3.162-1.179 3.162-1.179.633 1.581.23 2.76.115 3.048.733.805 1.179 1.825 1.179 3.09 0 4.413-2.688 5.39-5.247 5.678.417.36.776 1.05.776 2.128 0 1.538-.014 2.774-.014 3.162 0 .302.216.662.79.547C20.709 21.637 24 17.324 24 12.25 24 5.896 18.854.75 12.5.75Z"></path> </svg> </a> <div class="flex-1 flex-order-2 text-right"> <a href="/login?return_to=https%3A%2F%2Fgithub.com%2Ffacebook%2Freact%2Fpull%2F26940" class="HeaderMenu-link HeaderMenu-button d-inline-flex d-lg-none flex-order-1 f5 no-underline border color-border-default rounded-2 px-2 py-1 color-fg-inherit js-prevent-focus-on-mobile-nav" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;site header menu&quot;,&quot;repository_id&quot;:null,&quot;auth_type&quot;:&quot;SIGN_UP&quot;,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="81320b82fc8a978d1773d94a901bd917f51c827fc6ca6e4b3273536137c1ac3e" data-analytics-event="{&quot;category&quot;:&quot;Marketing nav&quot;,&quot;action&quot;:&quot;click to Sign in&quot;,&quot;label&quot;:&quot;ref_page:Marketing;ref_cta:Sign in;ref_loc:Header&quot;}" > Sign in </a> </div> </div> <div class="HeaderMenu js-header-menu height-fit position-lg-relative d-lg-flex flex-column flex-auto top-0"> <div class="HeaderMenu-wrapper d-flex flex-column flex-self-start flex-lg-row flex-auto rounded rounded-lg-0"> <nav class="HeaderMenu-nav" aria-label="Global"> <ul class="d-lg-flex list-style-none"> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <button type="button" class="HeaderMenu-link border-0 width-full width-lg-auto px-0 px-lg-2 py-lg-2 no-wrap d-flex flex-items-center flex-justify-between js-details-target" aria-expanded="false"> Product <svg opacity="0.5" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-down HeaderMenu-icon ml-1"> <path d="M12.78 5.22a.749.749 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.06 0L3.22 6.28a.749.749 0 1 1 1.06-1.06L8 8.939l3.72-3.719a.749.749 0 0 1 1.06 0Z"></path> </svg> </button> <div class="HeaderMenu-dropdown dropdown-menu rounded m-0 p-0 pt-2 pt-lg-4 position-relative position-lg-absolute left-0 left-lg-n3 pb-2 pb-lg-4 d-lg-flex flex-wrap dropdown-menu-wide"> <div class="HeaderMenu-column px-lg-4 border-lg-right mb-4 mb-lg-0 pr-lg-7"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0"> <ul class="list-style-none f5" > <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;github_copilot&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;github_copilot_link_product_navbar&quot;}" href="https://github.com/features/copilot"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-copilot color-fg-subtle mr-3"> <path d="M23.922 16.992c-.861 1.495-5.859 5.023-11.922 5.023-6.063 0-11.061-3.528-11.922-5.023A.641.641 0 0 1 0 16.736v-2.869a.841.841 0 0 1 .053-.22c.372-.935 1.347-2.292 2.605-2.656.167-.429.414-1.055.644-1.517a10.195 10.195 0 0 1-.052-1.086c0-1.331.282-2.499 1.132-3.368.397-.406.89-.717 1.474-.952 1.399-1.136 3.392-2.093 6.122-2.093 2.731 0 4.767.957 6.166 2.093.584.235 1.077.546 1.474.952.85.869 1.132 2.037 1.132 3.368 0 .368-.014.733-.052 1.086.23.462.477 1.088.644 1.517 1.258.364 2.233 1.721 2.605 2.656a.832.832 0 0 1 .053.22v2.869a.641.641 0 0 1-.078.256ZM12.172 11h-.344a4.323 4.323 0 0 1-.355.508C10.703 12.455 9.555 13 7.965 13c-1.725 0-2.989-.359-3.782-1.259a2.005 2.005 0 0 1-.085-.104L4 11.741v6.585c1.435.779 4.514 2.179 8 2.179 3.486 0 6.565-1.4 8-2.179v-6.585l-.098-.104s-.033.045-.085.104c-.793.9-2.057 1.259-3.782 1.259-1.59 0-2.738-.545-3.508-1.492a4.323 4.323 0 0 1-.355-.508h-.016.016Zm.641-2.935c.136 1.057.403 1.913.878 2.497.442.544 1.134.938 2.344.938 1.573 0 2.292-.337 2.657-.751.384-.435.558-1.15.558-2.361 0-1.14-.243-1.847-.705-2.319-.477-.488-1.319-.862-2.824-1.025-1.487-.161-2.192.138-2.533.529-.269.307-.437.808-.438 1.578v.021c0 .265.021.562.063.893Zm-1.626 0c.042-.331.063-.628.063-.894v-.02c-.001-.77-.169-1.271-.438-1.578-.341-.391-1.046-.69-2.533-.529-1.505.163-2.347.537-2.824 1.025-.462.472-.705 1.179-.705 2.319 0 1.211.175 1.926.558 2.361.365.414 1.084.751 2.657.751 1.21 0 1.902-.394 2.344-.938.475-.584.742-1.44.878-2.497Z"></path><path d="M14.5 14.25a1 1 0 0 1 1 1v2a1 1 0 0 1-2 0v-2a1 1 0 0 1 1-1Zm-5 0a1 1 0 0 1 1 1v2a1 1 0 0 1-2 0v-2a1 1 0 0 1 1-1Z"></path> </svg> <div> <div class="color-fg-default h4">GitHub Copilot</div> Write better code with AI </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;security&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;security_link_product_navbar&quot;}" href="https://github.com/features/security"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-shield-check color-fg-subtle mr-3"> <path d="M16.53 9.78a.75.75 0 0 0-1.06-1.06L11 13.19l-1.97-1.97a.75.75 0 0 0-1.06 1.06l2.5 2.5a.75.75 0 0 0 1.06 0l5-5Z"></path><path d="m12.54.637 8.25 2.675A1.75 1.75 0 0 1 22 4.976V10c0 6.19-3.771 10.704-9.401 12.83a1.704 1.704 0 0 1-1.198 0C5.77 20.705 2 16.19 2 10V4.976c0-.758.489-1.43 1.21-1.664L11.46.637a1.748 1.748 0 0 1 1.08 0Zm-.617 1.426-8.25 2.676a.249.249 0 0 0-.173.237V10c0 5.46 3.28 9.483 8.43 11.426a.199.199 0 0 0 .14 0C17.22 19.483 20.5 15.461 20.5 10V4.976a.25.25 0 0 0-.173-.237l-8.25-2.676a.253.253 0 0 0-.154 0Z"></path> </svg> <div> <div class="color-fg-default h4">Security</div> Find and fix vulnerabilities </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;actions&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;actions_link_product_navbar&quot;}" href="https://github.com/features/actions"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-workflow color-fg-subtle mr-3"> <path d="M1 3a2 2 0 0 1 2-2h6.5a2 2 0 0 1 2 2v6.5a2 2 0 0 1-2 2H7v4.063C7 16.355 7.644 17 8.438 17H12.5v-2.5a2 2 0 0 1 2-2H21a2 2 0 0 1 2 2V21a2 2 0 0 1-2 2h-6.5a2 2 0 0 1-2-2v-2.5H8.437A2.939 2.939 0 0 1 5.5 15.562V11.5H3a2 2 0 0 1-2-2Zm2-.5a.5.5 0 0 0-.5.5v6.5a.5.5 0 0 0 .5.5h6.5a.5.5 0 0 0 .5-.5V3a.5.5 0 0 0-.5-.5ZM14.5 14a.5.5 0 0 0-.5.5V21a.5.5 0 0 0 .5.5H21a.5.5 0 0 0 .5-.5v-6.5a.5.5 0 0 0-.5-.5Z"></path> </svg> <div> <div class="color-fg-default h4">Actions</div> Automate any workflow </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;codespaces&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;codespaces_link_product_navbar&quot;}" href="https://github.com/features/codespaces"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-codespaces color-fg-subtle mr-3"> <path d="M3.5 3.75C3.5 2.784 4.284 2 5.25 2h13.5c.966 0 1.75.784 1.75 1.75v7.5A1.75 1.75 0 0 1 18.75 13H5.25a1.75 1.75 0 0 1-1.75-1.75Zm-2 12c0-.966.784-1.75 1.75-1.75h17.5c.966 0 1.75.784 1.75 1.75v4a1.75 1.75 0 0 1-1.75 1.75H3.25a1.75 1.75 0 0 1-1.75-1.75ZM5.25 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h13.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Zm-2 12a.25.25 0 0 0-.25.25v4c0 .138.112.25.25.25h17.5a.25.25 0 0 0 .25-.25v-4a.25.25 0 0 0-.25-.25Z"></path><path d="M10 17.75a.75.75 0 0 1 .75-.75h6.5a.75.75 0 0 1 0 1.5h-6.5a.75.75 0 0 1-.75-.75Zm-4 0a.75.75 0 0 1 .75-.75h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1-.75-.75Z"></path> </svg> <div> <div class="color-fg-default h4">Codespaces</div> Instant dev environments </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;issues&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;issues_link_product_navbar&quot;}" href="https://github.com/features/issues"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-issue-opened color-fg-subtle mr-3"> <path d="M12 1c6.075 0 11 4.925 11 11s-4.925 11-11 11S1 18.075 1 12 5.925 1 12 1ZM2.5 12a9.5 9.5 0 0 0 9.5 9.5 9.5 9.5 0 0 0 9.5-9.5A9.5 9.5 0 0 0 12 2.5 9.5 9.5 0 0 0 2.5 12Zm9.5 2a2 2 0 1 1-.001-3.999A2 2 0 0 1 12 14Z"></path> </svg> <div> <div class="color-fg-default h4">Issues</div> Plan and track work </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;code_review&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;code_review_link_product_navbar&quot;}" href="https://github.com/features/code-review"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-code-review color-fg-subtle mr-3"> <path d="M10.3 6.74a.75.75 0 0 1-.04 1.06l-2.908 2.7 2.908 2.7a.75.75 0 1 1-1.02 1.1l-3.5-3.25a.75.75 0 0 1 0-1.1l3.5-3.25a.75.75 0 0 1 1.06.04Zm3.44 1.06a.75.75 0 1 1 1.02-1.1l3.5 3.25a.75.75 0 0 1 0 1.1l-3.5 3.25a.75.75 0 1 1-1.02-1.1l2.908-2.7-2.908-2.7Z"></path><path d="M1.5 4.25c0-.966.784-1.75 1.75-1.75h17.5c.966 0 1.75.784 1.75 1.75v12.5a1.75 1.75 0 0 1-1.75 1.75h-9.69l-3.573 3.573A1.458 1.458 0 0 1 5 21.043V18.5H3.25a1.75 1.75 0 0 1-1.75-1.75ZM3.25 4a.25.25 0 0 0-.25.25v12.5c0 .138.112.25.25.25h2.5a.75.75 0 0 1 .75.75v3.19l3.72-3.72a.749.749 0 0 1 .53-.22h10a.25.25 0 0 0 .25-.25V4.25a.25.25 0 0 0-.25-.25Z"></path> </svg> <div> <div class="color-fg-default h4">Code Review</div> Manage code changes </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;discussions&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;discussions_link_product_navbar&quot;}" href="https://github.com/features/discussions"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-comment-discussion color-fg-subtle mr-3"> <path d="M1.75 1h12.5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0 1 14.25 14H8.061l-2.574 2.573A1.458 1.458 0 0 1 3 15.543V14H1.75A1.75 1.75 0 0 1 0 12.25v-9.5C0 1.784.784 1 1.75 1ZM1.5 2.75v9.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h6.5a.25.25 0 0 0 .25-.25v-9.5a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25Z"></path><path d="M22.5 8.75a.25.25 0 0 0-.25-.25h-3.5a.75.75 0 0 1 0-1.5h3.5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0 1 22.25 20H21v1.543a1.457 1.457 0 0 1-2.487 1.03L15.939 20H10.75A1.75 1.75 0 0 1 9 18.25v-1.465a.75.75 0 0 1 1.5 0v1.465c0 .138.112.25.25.25h5.5a.75.75 0 0 1 .53.22l2.72 2.72v-2.19a.75.75 0 0 1 .75-.75h2a.25.25 0 0 0 .25-.25v-9.5Z"></path> </svg> <div> <div class="color-fg-default h4">Discussions</div> Collaborate outside of code </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;code_search&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;code_search_link_product_navbar&quot;}" href="https://github.com/features/code-search"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-code-square color-fg-subtle mr-3"> <path d="M10.3 8.24a.75.75 0 0 1-.04 1.06L7.352 12l2.908 2.7a.75.75 0 1 1-1.02 1.1l-3.5-3.25a.75.75 0 0 1 0-1.1l3.5-3.25a.75.75 0 0 1 1.06.04Zm3.44 1.06a.75.75 0 1 1 1.02-1.1l3.5 3.25a.75.75 0 0 1 0 1.1l-3.5 3.25a.75.75 0 1 1-1.02-1.1l2.908-2.7-2.908-2.7Z"></path><path d="M2 3.75C2 2.784 2.784 2 3.75 2h16.5c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0 1 20.25 22H3.75A1.75 1.75 0 0 1 2 20.25Zm1.75-.25a.25.25 0 0 0-.25.25v16.5c0 .138.112.25.25.25h16.5a.25.25 0 0 0 .25-.25V3.75a.25.25 0 0 0-.25-.25Z"></path> </svg> <div> <div class="color-fg-default h4">Code Search</div> Find more, search less </div> </a></li> </ul> </div> </div> <div class="HeaderMenu-column px-lg-4"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0 border-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="product-explore-heading">Explore</span> <ul class="list-style-none f5" aria-labelledby="product-explore-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;all_features&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;all_features_link_product_navbar&quot;}" href="https://github.com/features"> All features </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;documentation&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;documentation_link_product_navbar&quot;}" href="https://docs.github.com"> Documentation <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;github_skills&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;github_skills_link_product_navbar&quot;}" href="https://skills.github.com"> GitHub Skills <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;blog&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;blog_link_product_navbar&quot;}" href="https://github.blog"> Blog <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> </ul> </div> </div> </div> </li> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <button type="button" class="HeaderMenu-link border-0 width-full width-lg-auto px-0 px-lg-2 py-lg-2 no-wrap d-flex flex-items-center flex-justify-between js-details-target" aria-expanded="false"> Solutions <svg opacity="0.5" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-down HeaderMenu-icon ml-1"> <path d="M12.78 5.22a.749.749 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.06 0L3.22 6.28a.749.749 0 1 1 1.06-1.06L8 8.939l3.72-3.719a.749.749 0 0 1 1.06 0Z"></path> </svg> </button> <div class="HeaderMenu-dropdown dropdown-menu rounded m-0 p-0 pt-2 pt-lg-4 position-relative position-lg-absolute left-0 left-lg-n3 d-lg-flex flex-wrap dropdown-menu-wide"> <div class="HeaderMenu-column px-lg-4 border-lg-right mb-4 mb-lg-0 pr-lg-7"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0 pb-lg-3 mb-3 mb-lg-0"> <span class="d-block h4 color-fg-default my-1" id="solutions-by-company-size-heading">By company size</span> <ul class="list-style-none f5" aria-labelledby="solutions-by-company-size-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;enterprises&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;enterprises_link_solutions_navbar&quot;}" href="https://github.com/enterprise"> Enterprises </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;small_and_medium_teams&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;small_and_medium_teams_link_solutions_navbar&quot;}" href="https://github.com/team"> Small and medium teams </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;startups&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;startups_link_solutions_navbar&quot;}" href="https://github.com/enterprise/startups"> Startups </a></li> </ul> </div> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="solutions-by-use-case-heading">By use case</span> <ul class="list-style-none f5" aria-labelledby="solutions-by-use-case-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;devsecops&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;devsecops_link_solutions_navbar&quot;}" href="/solutions/use-case/devsecops"> DevSecOps </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;devops&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;devops_link_solutions_navbar&quot;}" href="/solutions/use-case/devops"> DevOps </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;ci_cd&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;ci_cd_link_solutions_navbar&quot;}" href="/solutions/use-case/ci-cd"> CI/CD </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;view_all_use_cases&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;view_all_use_cases_link_solutions_navbar&quot;}" href="/solutions/use-case"> View all use cases </a></li> </ul> </div> </div> <div class="HeaderMenu-column px-lg-4"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="solutions-by-industry-heading">By industry</span> <ul class="list-style-none f5" aria-labelledby="solutions-by-industry-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;healthcare&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;healthcare_link_solutions_navbar&quot;}" href="/solutions/industry/healthcare"> Healthcare </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;financial_services&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;financial_services_link_solutions_navbar&quot;}" href="/solutions/industry/financial-services"> Financial services </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;manufacturing&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;manufacturing_link_solutions_navbar&quot;}" href="/solutions/industry/manufacturing"> Manufacturing </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;government&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;government_link_solutions_navbar&quot;}" href="/solutions/industry/government"> Government </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;view_all_industries&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;view_all_industries_link_solutions_navbar&quot;}" href="/solutions/industry"> View all industries </a></li> </ul> </div> </div> <div class="HeaderMenu-trailing-link rounded-bottom-2 flex-shrink-0 mt-lg-4 px-lg-4 py-4 py-lg-3 f5 text-semibold"> <a href="/solutions"> View all solutions <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-right HeaderMenu-trailing-link-icon"> <path d="M6.22 3.22a.75.75 0 0 1 1.06 0l4.25 4.25a.75.75 0 0 1 0 1.06l-4.25 4.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L9.94 8 6.22 4.28a.75.75 0 0 1 0-1.06Z"></path> </svg> </a> </div> </div> </li> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <button type="button" class="HeaderMenu-link border-0 width-full width-lg-auto px-0 px-lg-2 py-lg-2 no-wrap d-flex flex-items-center flex-justify-between js-details-target" aria-expanded="false"> Resources <svg opacity="0.5" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-down HeaderMenu-icon ml-1"> <path d="M12.78 5.22a.749.749 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.06 0L3.22 6.28a.749.749 0 1 1 1.06-1.06L8 8.939l3.72-3.719a.749.749 0 0 1 1.06 0Z"></path> </svg> </button> <div class="HeaderMenu-dropdown dropdown-menu rounded m-0 p-0 pt-2 pt-lg-4 position-relative position-lg-absolute left-0 left-lg-n3 pb-2 pb-lg-4 d-lg-flex flex-wrap dropdown-menu-wide"> <div class="HeaderMenu-column px-lg-4 border-lg-right mb-4 mb-lg-0 pr-lg-7"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="resources-topics-heading">Topics</span> <ul class="list-style-none f5" aria-labelledby="resources-topics-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;ai&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;ai_link_resources_navbar&quot;}" href="/resources/articles/ai"> AI </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;devops&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;devops_link_resources_navbar&quot;}" href="/resources/articles/devops"> DevOps </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;security&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;security_link_resources_navbar&quot;}" href="/resources/articles/security"> Security </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;software_development&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;software_development_link_resources_navbar&quot;}" href="/resources/articles/software-development"> Software Development </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;view_all&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;view_all_link_resources_navbar&quot;}" href="/resources/articles"> View all </a></li> </ul> </div> </div> <div class="HeaderMenu-column px-lg-4"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0 border-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="resources-explore-heading">Explore</span> <ul class="list-style-none f5" aria-labelledby="resources-explore-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;learning_pathways&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;learning_pathways_link_resources_navbar&quot;}" href="https://resources.github.com/learn/pathways"> Learning Pathways <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;white_papers_ebooks_webinars&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;white_papers_ebooks_webinars_link_resources_navbar&quot;}" href="https://resources.github.com"> White papers, Ebooks, Webinars <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;customer_stories&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;customer_stories_link_resources_navbar&quot;}" href="https://github.com/customer-stories"> Customer Stories </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;partners&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;partners_link_resources_navbar&quot;}" href="https://partner.github.com"> Partners <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;executive_insights&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;executive_insights_link_resources_navbar&quot;}" href="https://github.com/solutions/executive-insights"> Executive Insights </a></li> </ul> </div> </div> </div> </li> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <button type="button" class="HeaderMenu-link border-0 width-full width-lg-auto px-0 px-lg-2 py-lg-2 no-wrap d-flex flex-items-center flex-justify-between js-details-target" aria-expanded="false"> Open Source <svg opacity="0.5" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-down HeaderMenu-icon ml-1"> <path d="M12.78 5.22a.749.749 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.06 0L3.22 6.28a.749.749 0 1 1 1.06-1.06L8 8.939l3.72-3.719a.749.749 0 0 1 1.06 0Z"></path> </svg> </button> <div class="HeaderMenu-dropdown dropdown-menu rounded m-0 p-0 pt-2 pt-lg-4 position-relative position-lg-absolute left-0 left-lg-n3 pb-2 pb-lg-4 px-lg-4"> <div class="HeaderMenu-column"> <div class="border-bottom pb-3 pb-lg-0 pb-lg-3 mb-3 mb-lg-0 mb-lg-3"> <ul class="list-style-none f5" > <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;github_sponsors&quot;,&quot;context&quot;:&quot;open_source&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;github_sponsors_link_open_source_navbar&quot;}" href="/sponsors"> <div> <div class="color-fg-default h4">GitHub Sponsors</div> Fund open source developers </div> </a></li> </ul> </div> <div class="border-bottom pb-3 pb-lg-0 pb-lg-3 mb-3 mb-lg-0 mb-lg-3"> <ul class="list-style-none f5" > <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;the_readme_project&quot;,&quot;context&quot;:&quot;open_source&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;the_readme_project_link_open_source_navbar&quot;}" href="https://github.com/readme"> <div> <div class="color-fg-default h4">The ReadME Project</div> GitHub community articles </div> </a></li> </ul> </div> <div class="border-bottom pb-3 pb-lg-0 border-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="open-source-repositories-heading">Repositories</span> <ul class="list-style-none f5" aria-labelledby="open-source-repositories-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;topics&quot;,&quot;context&quot;:&quot;open_source&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;topics_link_open_source_navbar&quot;}" href="https://github.com/topics"> Topics </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;trending&quot;,&quot;context&quot;:&quot;open_source&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;trending_link_open_source_navbar&quot;}" href="https://github.com/trending"> Trending </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;collections&quot;,&quot;context&quot;:&quot;open_source&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;collections_link_open_source_navbar&quot;}" href="https://github.com/collections"> Collections </a></li> </ul> </div> </div> </div> </li> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <button type="button" class="HeaderMenu-link border-0 width-full width-lg-auto px-0 px-lg-2 py-lg-2 no-wrap d-flex flex-items-center flex-justify-between js-details-target" aria-expanded="false"> Enterprise <svg opacity="0.5" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-down HeaderMenu-icon ml-1"> <path d="M12.78 5.22a.749.749 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.06 0L3.22 6.28a.749.749 0 1 1 1.06-1.06L8 8.939l3.72-3.719a.749.749 0 0 1 1.06 0Z"></path> </svg> </button> <div class="HeaderMenu-dropdown dropdown-menu rounded m-0 p-0 pt-2 pt-lg-4 position-relative position-lg-absolute left-0 left-lg-n3 pb-2 pb-lg-4 px-lg-4"> <div class="HeaderMenu-column"> <div class="border-bottom pb-3 pb-lg-0 pb-lg-3 mb-3 mb-lg-0 mb-lg-3"> <ul class="list-style-none f5" > <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;enterprise_platform&quot;,&quot;context&quot;:&quot;enterprise&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;enterprise_platform_link_enterprise_navbar&quot;}" href="/enterprise"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-stack color-fg-subtle mr-3"> <path d="M11.063 1.456a1.749 1.749 0 0 1 1.874 0l8.383 5.316a1.751 1.751 0 0 1 0 2.956l-8.383 5.316a1.749 1.749 0 0 1-1.874 0L2.68 9.728a1.751 1.751 0 0 1 0-2.956Zm1.071 1.267a.25.25 0 0 0-.268 0L3.483 8.039a.25.25 0 0 0 0 .422l8.383 5.316a.25.25 0 0 0 .268 0l8.383-5.316a.25.25 0 0 0 0-.422Z"></path><path d="M1.867 12.324a.75.75 0 0 1 1.035-.232l8.964 5.685a.25.25 0 0 0 .268 0l8.964-5.685a.75.75 0 0 1 .804 1.267l-8.965 5.685a1.749 1.749 0 0 1-1.874 0l-8.965-5.685a.75.75 0 0 1-.231-1.035Z"></path><path d="M1.867 16.324a.75.75 0 0 1 1.035-.232l8.964 5.685a.25.25 0 0 0 .268 0l8.964-5.685a.75.75 0 0 1 .804 1.267l-8.965 5.685a1.749 1.749 0 0 1-1.874 0l-8.965-5.685a.75.75 0 0 1-.231-1.035Z"></path> </svg> <div> <div class="color-fg-default h4">Enterprise platform</div> AI-powered developer platform </div> </a></li> </ul> </div> <div class="border-bottom pb-3 pb-lg-0 border-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="enterprise-available-add-ons-heading">Available add-ons</span> <ul class="list-style-none f5" aria-labelledby="enterprise-available-add-ons-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;advanced_security&quot;,&quot;context&quot;:&quot;enterprise&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;advanced_security_link_enterprise_navbar&quot;}" href="https://github.com/enterprise/advanced-security"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-shield-check color-fg-subtle mr-3"> <path d="M16.53 9.78a.75.75 0 0 0-1.06-1.06L11 13.19l-1.97-1.97a.75.75 0 0 0-1.06 1.06l2.5 2.5a.75.75 0 0 0 1.06 0l5-5Z"></path><path d="m12.54.637 8.25 2.675A1.75 1.75 0 0 1 22 4.976V10c0 6.19-3.771 10.704-9.401 12.83a1.704 1.704 0 0 1-1.198 0C5.77 20.705 2 16.19 2 10V4.976c0-.758.489-1.43 1.21-1.664L11.46.637a1.748 1.748 0 0 1 1.08 0Zm-.617 1.426-8.25 2.676a.249.249 0 0 0-.173.237V10c0 5.46 3.28 9.483 8.43 11.426a.199.199 0 0 0 .14 0C17.22 19.483 20.5 15.461 20.5 10V4.976a.25.25 0 0 0-.173-.237l-8.25-2.676a.253.253 0 0 0-.154 0Z"></path> </svg> <div> <div class="color-fg-default h4">Advanced Security</div> Enterprise-grade security features </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;github_copilot&quot;,&quot;context&quot;:&quot;enterprise&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;github_copilot_link_enterprise_navbar&quot;}" href="/features/copilot#enterprise"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-copilot color-fg-subtle mr-3"> <path d="M23.922 16.992c-.861 1.495-5.859 5.023-11.922 5.023-6.063 0-11.061-3.528-11.922-5.023A.641.641 0 0 1 0 16.736v-2.869a.841.841 0 0 1 .053-.22c.372-.935 1.347-2.292 2.605-2.656.167-.429.414-1.055.644-1.517a10.195 10.195 0 0 1-.052-1.086c0-1.331.282-2.499 1.132-3.368.397-.406.89-.717 1.474-.952 1.399-1.136 3.392-2.093 6.122-2.093 2.731 0 4.767.957 6.166 2.093.584.235 1.077.546 1.474.952.85.869 1.132 2.037 1.132 3.368 0 .368-.014.733-.052 1.086.23.462.477 1.088.644 1.517 1.258.364 2.233 1.721 2.605 2.656a.832.832 0 0 1 .053.22v2.869a.641.641 0 0 1-.078.256ZM12.172 11h-.344a4.323 4.323 0 0 1-.355.508C10.703 12.455 9.555 13 7.965 13c-1.725 0-2.989-.359-3.782-1.259a2.005 2.005 0 0 1-.085-.104L4 11.741v6.585c1.435.779 4.514 2.179 8 2.179 3.486 0 6.565-1.4 8-2.179v-6.585l-.098-.104s-.033.045-.085.104c-.793.9-2.057 1.259-3.782 1.259-1.59 0-2.738-.545-3.508-1.492a4.323 4.323 0 0 1-.355-.508h-.016.016Zm.641-2.935c.136 1.057.403 1.913.878 2.497.442.544 1.134.938 2.344.938 1.573 0 2.292-.337 2.657-.751.384-.435.558-1.15.558-2.361 0-1.14-.243-1.847-.705-2.319-.477-.488-1.319-.862-2.824-1.025-1.487-.161-2.192.138-2.533.529-.269.307-.437.808-.438 1.578v.021c0 .265.021.562.063.893Zm-1.626 0c.042-.331.063-.628.063-.894v-.02c-.001-.77-.169-1.271-.438-1.578-.341-.391-1.046-.69-2.533-.529-1.505.163-2.347.537-2.824 1.025-.462.472-.705 1.179-.705 2.319 0 1.211.175 1.926.558 2.361.365.414 1.084.751 2.657.751 1.21 0 1.902-.394 2.344-.938.475-.584.742-1.44.878-2.497Z"></path><path d="M14.5 14.25a1 1 0 0 1 1 1v2a1 1 0 0 1-2 0v-2a1 1 0 0 1 1-1Zm-5 0a1 1 0 0 1 1 1v2a1 1 0 0 1-2 0v-2a1 1 0 0 1 1-1Z"></path> </svg> <div> <div class="color-fg-default h4">GitHub Copilot</div> Enterprise-grade AI features </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;premium_support&quot;,&quot;context&quot;:&quot;enterprise&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;premium_support_link_enterprise_navbar&quot;}" href="/premium-support"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-comment-discussion color-fg-subtle mr-3"> <path d="M1.75 1h12.5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0 1 14.25 14H8.061l-2.574 2.573A1.458 1.458 0 0 1 3 15.543V14H1.75A1.75 1.75 0 0 1 0 12.25v-9.5C0 1.784.784 1 1.75 1ZM1.5 2.75v9.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h6.5a.25.25 0 0 0 .25-.25v-9.5a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25Z"></path><path d="M22.5 8.75a.25.25 0 0 0-.25-.25h-3.5a.75.75 0 0 1 0-1.5h3.5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0 1 22.25 20H21v1.543a1.457 1.457 0 0 1-2.487 1.03L15.939 20H10.75A1.75 1.75 0 0 1 9 18.25v-1.465a.75.75 0 0 1 1.5 0v1.465c0 .138.112.25.25.25h5.5a.75.75 0 0 1 .53.22l2.72 2.72v-2.19a.75.75 0 0 1 .75-.75h2a.25.25 0 0 0 .25-.25v-9.5Z"></path> </svg> <div> <div class="color-fg-default h4">Premium Support</div> Enterprise-grade 24/7 support </div> </a></li> </ul> </div> </div> </div> </li> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <a class="HeaderMenu-link no-underline px-0 px-lg-2 py-3 py-lg-2 d-block d-lg-inline-block" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;pricing&quot;,&quot;context&quot;:&quot;global&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;pricing_link_global_navbar&quot;}" href="https://github.com/pricing">Pricing</a> </li> </ul> </nav> <div class="d-flex flex-column flex-lg-row width-full flex-justify-end flex-lg-items-center text-center mt-3 mt-lg-0 text-lg-left ml-lg-3"> <qbsearch-input class="search-input" data-scope="repo:facebook/react" data-custom-scopes-path="/search/custom_scopes" data-delete-custom-scopes-csrf="SYHzN6od0lx0Tcy8_Gj1NCKCtj51vWxq8GpdWIoPEfbWdQXQj-5u2cFLc5NOEMLbAJgpojDcYbVHJ_YTkXVPSw" data-max-custom-scopes="10" data-header-redesign-enabled="false" data-initial-value="" data-blackbird-suggestions-path="/search/suggestions" data-jump-to-suggestions-path="/_graphql/GetSuggestedNavigationDestinations" data-current-repository="facebook/react" data-current-org="facebook" data-current-owner="" data-logged-in="false" data-copilot-chat-enabled="false" data-nl-search-enabled="false" data-retain-scroll-position="true"> <div class="search-input-container search-with-dialog position-relative d-flex flex-row flex-items-center mr-4 rounded" data-action="click:qbsearch-input#searchInputContainerClicked" > <button type="button" class="header-search-button placeholder input-button form-control d-flex flex-1 flex-self-stretch flex-items-center no-wrap width-full py-0 pl-2 pr-0 text-left border-0 box-shadow-none" data-target="qbsearch-input.inputButton" aria-label="Search or jump to…" aria-haspopup="dialog" placeholder="Search or jump to..." data-hotkey=s,/ autocapitalize="off" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;searchbar&quot;,&quot;context&quot;:&quot;global&quot;,&quot;tag&quot;:&quot;input&quot;,&quot;label&quot;:&quot;searchbar_input_global_navbar&quot;}" data-action="click:qbsearch-input#handleExpand" > <div class="mr-2 color-fg-muted"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-search"> <path d="M10.68 11.74a6 6 0 0 1-7.922-8.982 6 6 0 0 1 8.982 7.922l3.04 3.04a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215ZM11.5 7a4.499 4.499 0 1 0-8.997 0A4.499 4.499 0 0 0 11.5 7Z"></path> </svg> </div> <span class="flex-1" data-target="qbsearch-input.inputButtonText">Search or jump to...</span> <div class="d-flex" data-target="qbsearch-input.hotkeyIndicator"> <svg xmlns="http://www.w3.org/2000/svg" width="22" height="20" aria-hidden="true" class="mr-1"><path fill="none" stroke="#979A9C" opacity=".4" d="M3.5.5h12c1.7 0 3 1.3 3 3v13c0 1.7-1.3 3-3 3h-12c-1.7 0-3-1.3-3-3v-13c0-1.7 1.3-3 3-3z"></path><path fill="#979A9C" d="M11.8 6L8 15.1h-.9L10.8 6h1z"></path></svg> </div> </button> <input type="hidden" name="type" class="js-site-search-type-field"> <div class="Overlay--hidden " data-modal-dialog-overlay> <modal-dialog data-action="close:qbsearch-input#handleClose cancel:qbsearch-input#handleClose" data-target="qbsearch-input.searchSuggestionsDialog" role="dialog" id="search-suggestions-dialog" aria-modal="true" aria-labelledby="search-suggestions-dialog-header" data-view-component="true" class="Overlay Overlay--width-large Overlay--height-auto"> <h1 id="search-suggestions-dialog-header" class="sr-only">Search code, repositories, users, issues, pull requests...</h1> <div class="Overlay-body Overlay-body--paddingNone"> <div data-view-component="true"> <div class="search-suggestions position-fixed width-full color-shadow-large border color-fg-default color-bg-default overflow-hidden d-flex flex-column query-builder-container" style="border-radius: 12px;" data-target="qbsearch-input.queryBuilderContainer" hidden > <!-- '"` --><!-- </textarea></xmp> --></option></form><form id="query-builder-test-form" action="" accept-charset="UTF-8" method="get"> <query-builder data-target="qbsearch-input.queryBuilder" id="query-builder-query-builder-test" data-filter-key=":" data-view-component="true" class="QueryBuilder search-query-builder"> <div class="FormControl FormControl--fullWidth"> <label id="query-builder-test-label" for="query-builder-test" class="FormControl-label sr-only"> Search </label> <div class="QueryBuilder-StyledInput width-fit " data-target="query-builder.styledInput" > <span id="query-builder-test-leadingvisual-wrap" class="FormControl-input-leadingVisualWrap QueryBuilder-leadingVisualWrap"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-search FormControl-input-leadingVisual"> <path d="M10.68 11.74a6 6 0 0 1-7.922-8.982 6 6 0 0 1 8.982 7.922l3.04 3.04a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215ZM11.5 7a4.499 4.499 0 1 0-8.997 0A4.499 4.499 0 0 0 11.5 7Z"></path> </svg> </span> <div data-target="query-builder.styledInputContainer" class="QueryBuilder-StyledInputContainer"> <div aria-hidden="true" class="QueryBuilder-StyledInputContent" data-target="query-builder.styledInputContent" ></div> <div class="QueryBuilder-InputWrapper"> <div aria-hidden="true" class="QueryBuilder-Sizer" data-target="query-builder.sizer"></div> <input id="query-builder-test" name="query-builder-test" value="" autocomplete="off" type="text" role="combobox" spellcheck="false" aria-expanded="false" aria-describedby="validation-31451b81-b8a3-4ac2-96f8-7662bcc578cd" data-target="query-builder.input" data-action=" input:query-builder#inputChange blur:query-builder#inputBlur keydown:query-builder#inputKeydown focus:query-builder#inputFocus " data-view-component="true" class="FormControl-input QueryBuilder-Input FormControl-medium" /> </div> </div> <span class="sr-only" id="query-builder-test-clear">Clear</span> <button role="button" id="query-builder-test-clear-button" aria-labelledby="query-builder-test-clear query-builder-test-label" data-target="query-builder.clearButton" data-action=" click:query-builder#clear focus:query-builder#clearButtonFocus blur:query-builder#clearButtonBlur " variant="small" hidden="hidden" type="button" data-view-component="true" class="Button Button--iconOnly Button--invisible Button--medium mr-1 px-2 py-0 d-flex flex-items-center rounded-1 color-fg-muted"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x-circle-fill Button-visual"> <path d="M2.343 13.657A8 8 0 1 1 13.658 2.343 8 8 0 0 1 2.343 13.657ZM6.03 4.97a.751.751 0 0 0-1.042.018.751.751 0 0 0-.018 1.042L6.94 8 4.97 9.97a.749.749 0 0 0 .326 1.275.749.749 0 0 0 .734-.215L8 9.06l1.97 1.97a.749.749 0 0 0 1.275-.326.749.749 0 0 0-.215-.734L9.06 8l1.97-1.97a.749.749 0 0 0-.326-1.275.749.749 0 0 0-.734.215L8 6.94Z"></path> </svg> </button> </div> <template id="search-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-search"> <path d="M10.68 11.74a6 6 0 0 1-7.922-8.982 6 6 0 0 1 8.982 7.922l3.04 3.04a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215ZM11.5 7a4.499 4.499 0 1 0-8.997 0A4.499 4.499 0 0 0 11.5 7Z"></path> </svg> </template> <template id="code-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-code"> <path d="m11.28 3.22 4.25 4.25a.75.75 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734L13.94 8l-3.72-3.72a.749.749 0 0 1 .326-1.275.749.749 0 0 1 .734.215Zm-6.56 0a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042L2.06 8l3.72 3.72a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L.47 8.53a.75.75 0 0 1 0-1.06Z"></path> </svg> </template> <template id="file-code-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-file-code"> <path d="M4 1.75C4 .784 4.784 0 5.75 0h5.586c.464 0 .909.184 1.237.513l2.914 2.914c.329.328.513.773.513 1.237v8.586A1.75 1.75 0 0 1 14.25 15h-9a.75.75 0 0 1 0-1.5h9a.25.25 0 0 0 .25-.25V6h-2.75A1.75 1.75 0 0 1 10 4.25V1.5H5.75a.25.25 0 0 0-.25.25v2.5a.75.75 0 0 1-1.5 0Zm1.72 4.97a.75.75 0 0 1 1.06 0l2 2a.75.75 0 0 1 0 1.06l-2 2a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l1.47-1.47-1.47-1.47a.75.75 0 0 1 0-1.06ZM3.28 7.78 1.81 9.25l1.47 1.47a.751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018l-2-2a.75.75 0 0 1 0-1.06l2-2a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042Zm8.22-6.218V4.25c0 .138.112.25.25.25h2.688l-.011-.013-2.914-2.914-.013-.011Z"></path> </svg> </template> <template id="history-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-history"> <path d="m.427 1.927 1.215 1.215a8.002 8.002 0 1 1-1.6 5.685.75.75 0 1 1 1.493-.154 6.5 6.5 0 1 0 1.18-4.458l1.358 1.358A.25.25 0 0 1 3.896 6H.25A.25.25 0 0 1 0 5.75V2.104a.25.25 0 0 1 .427-.177ZM7.75 4a.75.75 0 0 1 .75.75v2.992l2.028.812a.75.75 0 0 1-.557 1.392l-2.5-1A.751.751 0 0 1 7 8.25v-3.5A.75.75 0 0 1 7.75 4Z"></path> </svg> </template> <template id="repo-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-repo"> <path d="M2 2.5A2.5 2.5 0 0 1 4.5 0h8.75a.75.75 0 0 1 .75.75v12.5a.75.75 0 0 1-.75.75h-2.5a.75.75 0 0 1 0-1.5h1.75v-2h-8a1 1 0 0 0-.714 1.7.75.75 0 1 1-1.072 1.05A2.495 2.495 0 0 1 2 11.5Zm10.5-1h-8a1 1 0 0 0-1 1v6.708A2.486 2.486 0 0 1 4.5 9h8ZM5 12.25a.25.25 0 0 1 .25-.25h3.5a.25.25 0 0 1 .25.25v3.25a.25.25 0 0 1-.4.2l-1.45-1.087a.249.249 0 0 0-.3 0L5.4 15.7a.25.25 0 0 1-.4-.2Z"></path> </svg> </template> <template id="bookmark-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-bookmark"> <path d="M3 2.75C3 1.784 3.784 1 4.75 1h6.5c.966 0 1.75.784 1.75 1.75v11.5a.75.75 0 0 1-1.227.579L8 11.722l-3.773 3.107A.751.751 0 0 1 3 14.25Zm1.75-.25a.25.25 0 0 0-.25.25v9.91l3.023-2.489a.75.75 0 0 1 .954 0l3.023 2.49V2.75a.25.25 0 0 0-.25-.25Z"></path> </svg> </template> <template id="plus-circle-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-plus-circle"> <path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Zm7.25-3.25v2.5h2.5a.75.75 0 0 1 0 1.5h-2.5v2.5a.75.75 0 0 1-1.5 0v-2.5h-2.5a.75.75 0 0 1 0-1.5h2.5v-2.5a.75.75 0 0 1 1.5 0Z"></path> </svg> </template> <template id="circle-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-dot-fill"> <path d="M8 4a4 4 0 1 1 0 8 4 4 0 0 1 0-8Z"></path> </svg> </template> <template id="trash-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-trash"> <path d="M11 1.75V3h2.25a.75.75 0 0 1 0 1.5H2.75a.75.75 0 0 1 0-1.5H5V1.75C5 .784 5.784 0 6.75 0h2.5C10.216 0 11 .784 11 1.75ZM4.496 6.675l.66 6.6a.25.25 0 0 0 .249.225h5.19a.25.25 0 0 0 .249-.225l.66-6.6a.75.75 0 0 1 1.492.149l-.66 6.6A1.748 1.748 0 0 1 10.595 15h-5.19a1.75 1.75 0 0 1-1.741-1.575l-.66-6.6a.75.75 0 1 1 1.492-.15ZM6.5 1.75V3h3V1.75a.25.25 0 0 0-.25-.25h-2.5a.25.25 0 0 0-.25.25Z"></path> </svg> </template> <template id="team-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-people"> <path d="M2 5.5a3.5 3.5 0 1 1 5.898 2.549 5.508 5.508 0 0 1 3.034 4.084.75.75 0 1 1-1.482.235 4 4 0 0 0-7.9 0 .75.75 0 0 1-1.482-.236A5.507 5.507 0 0 1 3.102 8.05 3.493 3.493 0 0 1 2 5.5ZM11 4a3.001 3.001 0 0 1 2.22 5.018 5.01 5.01 0 0 1 2.56 3.012.749.749 0 0 1-.885.954.752.752 0 0 1-.549-.514 3.507 3.507 0 0 0-2.522-2.372.75.75 0 0 1-.574-.73v-.352a.75.75 0 0 1 .416-.672A1.5 1.5 0 0 0 11 5.5.75.75 0 0 1 11 4Zm-5.5-.5a2 2 0 1 0-.001 3.999A2 2 0 0 0 5.5 3.5Z"></path> </svg> </template> <template id="project-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-project"> <path d="M1.75 0h12.5C15.216 0 16 .784 16 1.75v12.5A1.75 1.75 0 0 1 14.25 16H1.75A1.75 1.75 0 0 1 0 14.25V1.75C0 .784.784 0 1.75 0ZM1.5 1.75v12.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25V1.75a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25ZM11.75 3a.75.75 0 0 1 .75.75v7.5a.75.75 0 0 1-1.5 0v-7.5a.75.75 0 0 1 .75-.75Zm-8.25.75a.75.75 0 0 1 1.5 0v5.5a.75.75 0 0 1-1.5 0ZM8 3a.75.75 0 0 1 .75.75v3.5a.75.75 0 0 1-1.5 0v-3.5A.75.75 0 0 1 8 3Z"></path> </svg> </template> <template id="pencil-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-pencil"> <path d="M11.013 1.427a1.75 1.75 0 0 1 2.474 0l1.086 1.086a1.75 1.75 0 0 1 0 2.474l-8.61 8.61c-.21.21-.47.364-.756.445l-3.251.93a.75.75 0 0 1-.927-.928l.929-3.25c.081-.286.235-.547.445-.758l8.61-8.61Zm.176 4.823L9.75 4.81l-6.286 6.287a.253.253 0 0 0-.064.108l-.558 1.953 1.953-.558a.253.253 0 0 0 .108-.064Zm1.238-3.763a.25.25 0 0 0-.354 0L10.811 3.75l1.439 1.44 1.263-1.263a.25.25 0 0 0 0-.354Z"></path> </svg> </template> <template id="copilot-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-copilot"> <path d="M7.998 15.035c-4.562 0-7.873-2.914-7.998-3.749V9.338c.085-.628.677-1.686 1.588-2.065.013-.07.024-.143.036-.218.029-.183.06-.384.126-.612-.201-.508-.254-1.084-.254-1.656 0-.87.128-1.769.693-2.484.579-.733 1.494-1.124 2.724-1.261 1.206-.134 2.262.034 2.944.765.05.053.096.108.139.165.044-.057.094-.112.143-.165.682-.731 1.738-.899 2.944-.765 1.23.137 2.145.528 2.724 1.261.566.715.693 1.614.693 2.484 0 .572-.053 1.148-.254 1.656.066.228.098.429.126.612.012.076.024.148.037.218.924.385 1.522 1.471 1.591 2.095v1.872c0 .766-3.351 3.795-8.002 3.795Zm0-1.485c2.28 0 4.584-1.11 5.002-1.433V7.862l-.023-.116c-.49.21-1.075.291-1.727.291-1.146 0-2.059-.327-2.71-.991A3.222 3.222 0 0 1 8 6.303a3.24 3.24 0 0 1-.544.743c-.65.664-1.563.991-2.71.991-.652 0-1.236-.081-1.727-.291l-.023.116v4.255c.419.323 2.722 1.433 5.002 1.433ZM6.762 2.83c-.193-.206-.637-.413-1.682-.297-1.019.113-1.479.404-1.713.7-.247.312-.369.789-.369 1.554 0 .793.129 1.171.308 1.371.162.181.519.379 1.442.379.853 0 1.339-.235 1.638-.54.315-.322.527-.827.617-1.553.117-.935-.037-1.395-.241-1.614Zm4.155-.297c-1.044-.116-1.488.091-1.681.297-.204.219-.359.679-.242 1.614.091.726.303 1.231.618 1.553.299.305.784.54 1.638.54.922 0 1.28-.198 1.442-.379.179-.2.308-.578.308-1.371 0-.765-.123-1.242-.37-1.554-.233-.296-.693-.587-1.713-.7Z"></path><path d="M6.25 9.037a.75.75 0 0 1 .75.75v1.501a.75.75 0 0 1-1.5 0V9.787a.75.75 0 0 1 .75-.75Zm4.25.75v1.501a.75.75 0 0 1-1.5 0V9.787a.75.75 0 0 1 1.5 0Z"></path> </svg> </template> <template id="copilot-error-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-copilot-error"> <path d="M16 11.24c0 .112-.072.274-.21.467L13 9.688V7.862l-.023-.116c-.49.21-1.075.291-1.727.291-.198 0-.388-.009-.571-.029L6.833 5.226a4.01 4.01 0 0 0 .17-.782c.117-.935-.037-1.395-.241-1.614-.193-.206-.637-.413-1.682-.297-.683.076-1.115.231-1.395.415l-1.257-.91c.579-.564 1.413-.877 2.485-.996 1.206-.134 2.262.034 2.944.765.05.053.096.108.139.165.044-.057.094-.112.143-.165.682-.731 1.738-.899 2.944-.765 1.23.137 2.145.528 2.724 1.261.566.715.693 1.614.693 2.484 0 .572-.053 1.148-.254 1.656.066.228.098.429.126.612.012.076.024.148.037.218.924.385 1.522 1.471 1.591 2.095Zm-5.083-8.707c-1.044-.116-1.488.091-1.681.297-.204.219-.359.679-.242 1.614.091.726.303 1.231.618 1.553.299.305.784.54 1.638.54.922 0 1.28-.198 1.442-.379.179-.2.308-.578.308-1.371 0-.765-.123-1.242-.37-1.554-.233-.296-.693-.587-1.713-.7Zm2.511 11.074c-1.393.776-3.272 1.428-5.43 1.428-4.562 0-7.873-2.914-7.998-3.749V9.338c.085-.628.677-1.686 1.588-2.065.013-.07.024-.143.036-.218.029-.183.06-.384.126-.612-.18-.455-.241-.963-.252-1.475L.31 4.107A.747.747 0 0 1 0 3.509V3.49a.748.748 0 0 1 .625-.73c.156-.026.306.047.435.139l14.667 10.578a.592.592 0 0 1 .227.264.752.752 0 0 1 .046.249v.022a.75.75 0 0 1-1.19.596Zm-1.367-.991L5.635 7.964a5.128 5.128 0 0 1-.889.073c-.652 0-1.236-.081-1.727-.291l-.023.116v4.255c.419.323 2.722 1.433 5.002 1.433 1.539 0 3.089-.505 4.063-.934Z"></path> </svg> </template> <template id="workflow-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-workflow"> <path d="M0 1.75C0 .784.784 0 1.75 0h3.5C6.216 0 7 .784 7 1.75v3.5A1.75 1.75 0 0 1 5.25 7H4v4a1 1 0 0 0 1 1h4v-1.25C9 9.784 9.784 9 10.75 9h3.5c.966 0 1.75.784 1.75 1.75v3.5A1.75 1.75 0 0 1 14.25 16h-3.5A1.75 1.75 0 0 1 9 14.25v-.75H5A2.5 2.5 0 0 1 2.5 11V7h-.75A1.75 1.75 0 0 1 0 5.25Zm1.75-.25a.25.25 0 0 0-.25.25v3.5c0 .138.112.25.25.25h3.5a.25.25 0 0 0 .25-.25v-3.5a.25.25 0 0 0-.25-.25Zm9 9a.25.25 0 0 0-.25.25v3.5c0 .138.112.25.25.25h3.5a.25.25 0 0 0 .25-.25v-3.5a.25.25 0 0 0-.25-.25Z"></path> </svg> </template> <template id="book-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-book"> <path d="M0 1.75A.75.75 0 0 1 .75 1h4.253c1.227 0 2.317.59 3 1.501A3.743 3.743 0 0 1 11.006 1h4.245a.75.75 0 0 1 .75.75v10.5a.75.75 0 0 1-.75.75h-4.507a2.25 2.25 0 0 0-1.591.659l-.622.621a.75.75 0 0 1-1.06 0l-.622-.621A2.25 2.25 0 0 0 5.258 13H.75a.75.75 0 0 1-.75-.75Zm7.251 10.324.004-5.073-.002-2.253A2.25 2.25 0 0 0 5.003 2.5H1.5v9h3.757a3.75 3.75 0 0 1 1.994.574ZM8.755 4.75l-.004 7.322a3.752 3.752 0 0 1 1.992-.572H14.5v-9h-3.495a2.25 2.25 0 0 0-2.25 2.25Z"></path> </svg> </template> <template id="code-review-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-code-review"> <path d="M1.75 1h12.5c.966 0 1.75.784 1.75 1.75v8.5A1.75 1.75 0 0 1 14.25 13H8.061l-2.574 2.573A1.458 1.458 0 0 1 3 14.543V13H1.75A1.75 1.75 0 0 1 0 11.25v-8.5C0 1.784.784 1 1.75 1ZM1.5 2.75v8.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h6.5a.25.25 0 0 0 .25-.25v-8.5a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25Zm5.28 1.72a.75.75 0 0 1 0 1.06L5.31 7l1.47 1.47a.751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018l-2-2a.75.75 0 0 1 0-1.06l2-2a.75.75 0 0 1 1.06 0Zm2.44 0a.75.75 0 0 1 1.06 0l2 2a.75.75 0 0 1 0 1.06l-2 2a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L10.69 7 9.22 5.53a.75.75 0 0 1 0-1.06Z"></path> </svg> </template> <template id="codespaces-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-codespaces"> <path d="M0 11.25c0-.966.784-1.75 1.75-1.75h12.5c.966 0 1.75.784 1.75 1.75v3A1.75 1.75 0 0 1 14.25 16H1.75A1.75 1.75 0 0 1 0 14.25Zm2-9.5C2 .784 2.784 0 3.75 0h8.5C13.216 0 14 .784 14 1.75v5a1.75 1.75 0 0 1-1.75 1.75h-8.5A1.75 1.75 0 0 1 2 6.75Zm1.75-.25a.25.25 0 0 0-.25.25v5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-5a.25.25 0 0 0-.25-.25Zm-2 9.5a.25.25 0 0 0-.25.25v3c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-3a.25.25 0 0 0-.25-.25Z"></path><path d="M7 12.75a.75.75 0 0 1 .75-.75h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1-.75-.75Zm-4 0a.75.75 0 0 1 .75-.75h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1-.75-.75Z"></path> </svg> </template> <template id="comment-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-comment"> <path d="M1 2.75C1 1.784 1.784 1 2.75 1h10.5c.966 0 1.75.784 1.75 1.75v7.5A1.75 1.75 0 0 1 13.25 12H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 13.543V12H2.75A1.75 1.75 0 0 1 1 10.25Zm1.75-.25a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Z"></path> </svg> </template> <template id="comment-discussion-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-comment-discussion"> <path d="M1.75 1h8.5c.966 0 1.75.784 1.75 1.75v5.5A1.75 1.75 0 0 1 10.25 10H7.061l-2.574 2.573A1.458 1.458 0 0 1 2 11.543V10h-.25A1.75 1.75 0 0 1 0 8.25v-5.5C0 1.784.784 1 1.75 1ZM1.5 2.75v5.5c0 .138.112.25.25.25h1a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h3.5a.25.25 0 0 0 .25-.25v-5.5a.25.25 0 0 0-.25-.25h-8.5a.25.25 0 0 0-.25.25Zm13 2a.25.25 0 0 0-.25-.25h-.5a.75.75 0 0 1 0-1.5h.5c.966 0 1.75.784 1.75 1.75v5.5A1.75 1.75 0 0 1 14.25 12H14v1.543a1.458 1.458 0 0 1-2.487 1.03L9.22 12.28a.749.749 0 0 1 .326-1.275.749.749 0 0 1 .734.215l2.22 2.22v-2.19a.75.75 0 0 1 .75-.75h1a.25.25 0 0 0 .25-.25Z"></path> </svg> </template> <template id="organization-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-organization"> <path d="M1.75 16A1.75 1.75 0 0 1 0 14.25V1.75C0 .784.784 0 1.75 0h8.5C11.216 0 12 .784 12 1.75v12.5c0 .085-.006.168-.018.25h2.268a.25.25 0 0 0 .25-.25V8.285a.25.25 0 0 0-.111-.208l-1.055-.703a.749.749 0 1 1 .832-1.248l1.055.703c.487.325.779.871.779 1.456v5.965A1.75 1.75 0 0 1 14.25 16h-3.5a.766.766 0 0 1-.197-.026c-.099.017-.2.026-.303.026h-3a.75.75 0 0 1-.75-.75V14h-1v1.25a.75.75 0 0 1-.75.75Zm-.25-1.75c0 .138.112.25.25.25H4v-1.25a.75.75 0 0 1 .75-.75h2.5a.75.75 0 0 1 .75.75v1.25h2.25a.25.25 0 0 0 .25-.25V1.75a.25.25 0 0 0-.25-.25h-8.5a.25.25 0 0 0-.25.25ZM3.75 6h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1 0-1.5ZM3 3.75A.75.75 0 0 1 3.75 3h.5a.75.75 0 0 1 0 1.5h-.5A.75.75 0 0 1 3 3.75Zm4 3A.75.75 0 0 1 7.75 6h.5a.75.75 0 0 1 0 1.5h-.5A.75.75 0 0 1 7 6.75ZM7.75 3h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1 0-1.5ZM3 9.75A.75.75 0 0 1 3.75 9h.5a.75.75 0 0 1 0 1.5h-.5A.75.75 0 0 1 3 9.75ZM7.75 9h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1 0-1.5Z"></path> </svg> </template> <template id="rocket-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-rocket"> <path d="M14.064 0h.186C15.216 0 16 .784 16 1.75v.186a8.752 8.752 0 0 1-2.564 6.186l-.458.459c-.314.314-.641.616-.979.904v3.207c0 .608-.315 1.172-.833 1.49l-2.774 1.707a.749.749 0 0 1-1.11-.418l-.954-3.102a1.214 1.214 0 0 1-.145-.125L3.754 9.816a1.218 1.218 0 0 1-.124-.145L.528 8.717a.749.749 0 0 1-.418-1.11l1.71-2.774A1.748 1.748 0 0 1 3.31 4h3.204c.288-.338.59-.665.904-.979l.459-.458A8.749 8.749 0 0 1 14.064 0ZM8.938 3.623h-.002l-.458.458c-.76.76-1.437 1.598-2.02 2.5l-1.5 2.317 2.143 2.143 2.317-1.5c.902-.583 1.74-1.26 2.499-2.02l.459-.458a7.25 7.25 0 0 0 2.123-5.127V1.75a.25.25 0 0 0-.25-.25h-.186a7.249 7.249 0 0 0-5.125 2.123ZM3.56 14.56c-.732.732-2.334 1.045-3.005 1.148a.234.234 0 0 1-.201-.064.234.234 0 0 1-.064-.201c.103-.671.416-2.273 1.15-3.003a1.502 1.502 0 1 1 2.12 2.12Zm6.94-3.935c-.088.06-.177.118-.266.175l-2.35 1.521.548 1.783 1.949-1.2a.25.25 0 0 0 .119-.213ZM3.678 8.116 5.2 5.766c.058-.09.117-.178.176-.266H3.309a.25.25 0 0 0-.213.119l-1.2 1.95ZM12 5a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> </template> <template id="shield-check-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-shield-check"> <path d="m8.533.133 5.25 1.68A1.75 1.75 0 0 1 15 3.48V7c0 1.566-.32 3.182-1.303 4.682-.983 1.498-2.585 2.813-5.032 3.855a1.697 1.697 0 0 1-1.33 0c-2.447-1.042-4.049-2.357-5.032-3.855C1.32 10.182 1 8.566 1 7V3.48a1.75 1.75 0 0 1 1.217-1.667l5.25-1.68a1.748 1.748 0 0 1 1.066 0Zm-.61 1.429.001.001-5.25 1.68a.251.251 0 0 0-.174.237V7c0 1.36.275 2.666 1.057 3.859.784 1.194 2.121 2.342 4.366 3.298a.196.196 0 0 0 .154 0c2.245-.957 3.582-2.103 4.366-3.297C13.225 9.666 13.5 8.358 13.5 7V3.48a.25.25 0 0 0-.174-.238l-5.25-1.68a.25.25 0 0 0-.153 0ZM11.28 6.28l-3.5 3.5a.75.75 0 0 1-1.06 0l-1.5-1.5a.749.749 0 0 1 .326-1.275.749.749 0 0 1 .734.215l.97.97 2.97-2.97a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042Z"></path> </svg> </template> <template id="heart-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-heart"> <path d="m8 14.25.345.666a.75.75 0 0 1-.69 0l-.008-.004-.018-.01a7.152 7.152 0 0 1-.31-.17 22.055 22.055 0 0 1-3.434-2.414C2.045 10.731 0 8.35 0 5.5 0 2.836 2.086 1 4.25 1 5.797 1 7.153 1.802 8 3.02 8.847 1.802 10.203 1 11.75 1 13.914 1 16 2.836 16 5.5c0 2.85-2.045 5.231-3.885 6.818a22.066 22.066 0 0 1-3.744 2.584l-.018.01-.006.003h-.002ZM4.25 2.5c-1.336 0-2.75 1.164-2.75 3 0 2.15 1.58 4.144 3.365 5.682A20.58 20.58 0 0 0 8 13.393a20.58 20.58 0 0 0 3.135-2.211C12.92 9.644 14.5 7.65 14.5 5.5c0-1.836-1.414-3-2.75-3-1.373 0-2.609.986-3.029 2.456a.749.749 0 0 1-1.442 0C6.859 3.486 5.623 2.5 4.25 2.5Z"></path> </svg> </template> <template id="server-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-server"> <path d="M1.75 1h12.5c.966 0 1.75.784 1.75 1.75v4c0 .372-.116.717-.314 1 .198.283.314.628.314 1v4a1.75 1.75 0 0 1-1.75 1.75H1.75A1.75 1.75 0 0 1 0 12.75v-4c0-.358.109-.707.314-1a1.739 1.739 0 0 1-.314-1v-4C0 1.784.784 1 1.75 1ZM1.5 2.75v4c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-4a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25Zm.25 5.75a.25.25 0 0 0-.25.25v4c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-4a.25.25 0 0 0-.25-.25ZM7 4.75A.75.75 0 0 1 7.75 4h4.5a.75.75 0 0 1 0 1.5h-4.5A.75.75 0 0 1 7 4.75ZM7.75 10h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1 0-1.5ZM3 4.75A.75.75 0 0 1 3.75 4h.5a.75.75 0 0 1 0 1.5h-.5A.75.75 0 0 1 3 4.75ZM3.75 10h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1 0-1.5Z"></path> </svg> </template> <template id="globe-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-globe"> <path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM5.78 8.75a9.64 9.64 0 0 0 1.363 4.177c.255.426.542.832.857 1.215.245-.296.551-.705.857-1.215A9.64 9.64 0 0 0 10.22 8.75Zm4.44-1.5a9.64 9.64 0 0 0-1.363-4.177c-.307-.51-.612-.919-.857-1.215a9.927 9.927 0 0 0-.857 1.215A9.64 9.64 0 0 0 5.78 7.25Zm-5.944 1.5H1.543a6.507 6.507 0 0 0 4.666 5.5c-.123-.181-.24-.365-.352-.552-.715-1.192-1.437-2.874-1.581-4.948Zm-2.733-1.5h2.733c.144-2.074.866-3.756 1.58-4.948.12-.197.237-.381.353-.552a6.507 6.507 0 0 0-4.666 5.5Zm10.181 1.5c-.144 2.074-.866 3.756-1.58 4.948-.12.197-.237.381-.353.552a6.507 6.507 0 0 0 4.666-5.5Zm2.733-1.5a6.507 6.507 0 0 0-4.666-5.5c.123.181.24.365.353.552.714 1.192 1.436 2.874 1.58 4.948Z"></path> </svg> </template> <template id="issue-opened-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-issue-opened"> <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path><path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Z"></path> </svg> </template> <template id="device-mobile-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-device-mobile"> <path d="M3.75 0h8.5C13.216 0 14 .784 14 1.75v12.5A1.75 1.75 0 0 1 12.25 16h-8.5A1.75 1.75 0 0 1 2 14.25V1.75C2 .784 2.784 0 3.75 0ZM3.5 1.75v12.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25V1.75a.25.25 0 0 0-.25-.25h-8.5a.25.25 0 0 0-.25.25ZM8 13a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z"></path> </svg> </template> <template id="package-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-package"> <path d="m8.878.392 5.25 3.045c.54.314.872.89.872 1.514v6.098a1.75 1.75 0 0 1-.872 1.514l-5.25 3.045a1.75 1.75 0 0 1-1.756 0l-5.25-3.045A1.75 1.75 0 0 1 1 11.049V4.951c0-.624.332-1.201.872-1.514L7.122.392a1.75 1.75 0 0 1 1.756 0ZM7.875 1.69l-4.63 2.685L8 7.133l4.755-2.758-4.63-2.685a.248.248 0 0 0-.25 0ZM2.5 5.677v5.372c0 .09.047.171.125.216l4.625 2.683V8.432Zm6.25 8.271 4.625-2.683a.25.25 0 0 0 .125-.216V5.677L8.75 8.432Z"></path> </svg> </template> <template id="credit-card-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-credit-card"> <path d="M10.75 9a.75.75 0 0 0 0 1.5h1.5a.75.75 0 0 0 0-1.5h-1.5Z"></path><path d="M0 3.75C0 2.784.784 2 1.75 2h12.5c.966 0 1.75.784 1.75 1.75v8.5A1.75 1.75 0 0 1 14.25 14H1.75A1.75 1.75 0 0 1 0 12.25ZM14.5 6.5h-13v5.75c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25Zm0-2.75a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25V5h13Z"></path> </svg> </template> <template id="play-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-play"> <path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Zm4.879-2.773 4.264 2.559a.25.25 0 0 1 0 .428l-4.264 2.559A.25.25 0 0 1 6 10.559V5.442a.25.25 0 0 1 .379-.215Z"></path> </svg> </template> <template id="gift-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-gift"> <path d="M2 2.75A2.75 2.75 0 0 1 4.75 0c.983 0 1.873.42 2.57 1.232.268.318.497.668.68 1.042.183-.375.411-.725.68-1.044C9.376.42 10.266 0 11.25 0a2.75 2.75 0 0 1 2.45 4h.55c.966 0 1.75.784 1.75 1.75v2c0 .698-.409 1.301-1 1.582v4.918A1.75 1.75 0 0 1 13.25 16H2.75A1.75 1.75 0 0 1 1 14.25V9.332C.409 9.05 0 8.448 0 7.75v-2C0 4.784.784 4 1.75 4h.55c-.192-.375-.3-.8-.3-1.25ZM7.25 9.5H2.5v4.75c0 .138.112.25.25.25h4.5Zm1.5 0v5h4.5a.25.25 0 0 0 .25-.25V9.5Zm0-4V8h5.5a.25.25 0 0 0 .25-.25v-2a.25.25 0 0 0-.25-.25Zm-7 0a.25.25 0 0 0-.25.25v2c0 .138.112.25.25.25h5.5V5.5h-5.5Zm3-4a1.25 1.25 0 0 0 0 2.5h2.309c-.233-.818-.542-1.401-.878-1.793-.43-.502-.915-.707-1.431-.707ZM8.941 4h2.309a1.25 1.25 0 0 0 0-2.5c-.516 0-1 .205-1.43.707-.337.392-.646.975-.879 1.793Z"></path> </svg> </template> <template id="code-square-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-code-square"> <path d="M0 1.75C0 .784.784 0 1.75 0h12.5C15.216 0 16 .784 16 1.75v12.5A1.75 1.75 0 0 1 14.25 16H1.75A1.75 1.75 0 0 1 0 14.25Zm1.75-.25a.25.25 0 0 0-.25.25v12.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25V1.75a.25.25 0 0 0-.25-.25Zm7.47 3.97a.75.75 0 0 1 1.06 0l2 2a.75.75 0 0 1 0 1.06l-2 2a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734L10.69 8 9.22 6.53a.75.75 0 0 1 0-1.06ZM6.78 6.53 5.31 8l1.47 1.47a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215l-2-2a.75.75 0 0 1 0-1.06l2-2a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042Z"></path> </svg> </template> <template id="device-desktop-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-device-desktop"> <path d="M14.25 1c.966 0 1.75.784 1.75 1.75v7.5A1.75 1.75 0 0 1 14.25 12h-3.727c.099 1.041.52 1.872 1.292 2.757A.752.752 0 0 1 11.25 16h-6.5a.75.75 0 0 1-.565-1.243c.772-.885 1.192-1.716 1.292-2.757H1.75A1.75 1.75 0 0 1 0 10.25v-7.5C0 1.784.784 1 1.75 1ZM1.75 2.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25ZM9.018 12H6.982a5.72 5.72 0 0 1-.765 2.5h3.566a5.72 5.72 0 0 1-.765-2.5Z"></path> </svg> </template> <div class="position-relative"> <ul role="listbox" class="ActionListWrap QueryBuilder-ListWrap" aria-label="Suggestions" data-action=" combobox-commit:query-builder#comboboxCommit mousedown:query-builder#resultsMousedown " data-target="query-builder.resultsList" data-persist-list=false id="query-builder-test-results" ></ul> </div> <div class="FormControl-inlineValidation" id="validation-31451b81-b8a3-4ac2-96f8-7662bcc578cd" hidden="hidden"> <span class="FormControl-inlineValidation--visual"> <svg aria-hidden="true" height="12" viewBox="0 0 12 12" version="1.1" width="12" data-view-component="true" class="octicon octicon-alert-fill"> <path d="M4.855.708c.5-.896 1.79-.896 2.29 0l4.675 8.351a1.312 1.312 0 0 1-1.146 1.954H1.33A1.313 1.313 0 0 1 .183 9.058ZM7 7V3H5v4Zm-1 3a1 1 0 1 0 0-2 1 1 0 0 0 0 2Z"></path> </svg> </span> <span></span> </div> </div> <div data-target="query-builder.screenReaderFeedback" aria-live="polite" aria-atomic="true" class="sr-only"></div> </query-builder></form> <div class="d-flex flex-row color-fg-muted px-3 text-small color-bg-default search-feedback-prompt"> <a target="_blank" href="https://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax" data-view-component="true" class="Link color-fg-accent text-normal ml-2">Search syntax tips</a> <div class="d-flex flex-1"></div> </div> </div> </div> </div> </modal-dialog></div> </div> <div data-action="click:qbsearch-input#retract" class="dark-backdrop position-fixed" hidden data-target="qbsearch-input.darkBackdrop"></div> <div class="color-fg-default"> <dialog-helper> <dialog data-target="qbsearch-input.feedbackDialog" data-action="close:qbsearch-input#handleDialogClose cancel:qbsearch-input#handleDialogClose" id="feedback-dialog" aria-modal="true" aria-labelledby="feedback-dialog-title" aria-describedby="feedback-dialog-description" data-view-component="true" class="Overlay Overlay-whenNarrow Overlay--size-medium Overlay--motion-scaleFade Overlay--disableScroll"> <div data-view-component="true" class="Overlay-header"> <div class="Overlay-headerContentWrap"> <div class="Overlay-titleWrap"> <h1 class="Overlay-title " id="feedback-dialog-title"> Provide feedback </h1> </div> <div class="Overlay-actionWrap"> <button data-close-dialog-id="feedback-dialog" aria-label="Close" type="button" data-view-component="true" class="close-button Overlay-closeButton"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg></button> </div> </div> </div> <scrollable-region data-labelled-by="feedback-dialog-title"> <div data-view-component="true" class="Overlay-body"> <!-- '"` --><!-- </textarea></xmp> --></option></form><form id="code-search-feedback-form" data-turbo="false" action="/search/feedback" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="XGSJuEpqjuXNMsMKMOZPEhHGZvvHZdDXQh841tQRLkMseHMmaZmpYfT1MAfq2u/vIhcreOHS9kVQ+3ntnG7DRQ==" /> <p>We read every piece of feedback, and take your input very seriously.</p> <textarea name="feedback" class="form-control width-full mb-2" style="height: 120px" id="feedback"></textarea> <input name="include_email" id="include_email" aria-label="Include my email address so I can be contacted" class="form-control mr-2" type="checkbox"> <label for="include_email" style="font-weight: normal">Include my email address so I can be contacted</label> </form></div> </scrollable-region> <div data-view-component="true" class="Overlay-footer Overlay-footer--alignEnd"> <button data-close-dialog-id="feedback-dialog" type="button" data-view-component="true" class="btn"> Cancel </button> <button form="code-search-feedback-form" data-action="click:qbsearch-input#submitFeedback" type="submit" data-view-component="true" class="btn-primary btn"> Submit feedback </button> </div> </dialog></dialog-helper> <custom-scopes data-target="qbsearch-input.customScopesManager"> <dialog-helper> <dialog data-target="custom-scopes.customScopesModalDialog" data-action="close:qbsearch-input#handleDialogClose cancel:qbsearch-input#handleDialogClose" id="custom-scopes-dialog" aria-modal="true" aria-labelledby="custom-scopes-dialog-title" aria-describedby="custom-scopes-dialog-description" data-view-component="true" class="Overlay Overlay-whenNarrow Overlay--size-medium Overlay--motion-scaleFade Overlay--disableScroll"> <div data-view-component="true" class="Overlay-header Overlay-header--divided"> <div class="Overlay-headerContentWrap"> <div class="Overlay-titleWrap"> <h1 class="Overlay-title " id="custom-scopes-dialog-title"> Saved searches </h1> <h2 id="custom-scopes-dialog-description" class="Overlay-description">Use saved searches to filter your results more quickly</h2> </div> <div class="Overlay-actionWrap"> <button data-close-dialog-id="custom-scopes-dialog" aria-label="Close" type="button" data-view-component="true" class="close-button Overlay-closeButton"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg></button> </div> </div> </div> <scrollable-region data-labelled-by="custom-scopes-dialog-title"> <div data-view-component="true" class="Overlay-body"> <div data-target="custom-scopes.customScopesModalDialogFlash"></div> <div hidden class="create-custom-scope-form" data-target="custom-scopes.createCustomScopeForm"> <!-- '"` --><!-- </textarea></xmp> --></option></form><form id="custom-scopes-dialog-form" data-turbo="false" action="/search/custom_scopes" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="0cx7NyERUVlZ5GF4ZVKvWrjZ97JC91vLW5H+sT7BQP1xfVo+WqYNHGhjuGJbCTqxLXN4G01HRc+J7A3e5sQJsg==" /> <div data-target="custom-scopes.customScopesModalDialogFlash"></div> <input type="hidden" id="custom_scope_id" name="custom_scope_id" data-target="custom-scopes.customScopesIdField"> <div class="form-group"> <label for="custom_scope_name">Name</label> <auto-check src="/search/custom_scopes/check_name" required> <input type="text" name="custom_scope_name" id="custom_scope_name" data-target="custom-scopes.customScopesNameField" class="form-control" autocomplete="off" placeholder="github-ruby" required maxlength="50"> <input type="hidden" data-csrf="true" value="mSkK3rQP224b/52lfHvHogoh/b/8aAdgkRVuo1lzEOsFujwWBLIoc6TgV3TsMRMRXLoIynV1VB3yIuwSh7pskw==" /> </auto-check> </div> <div class="form-group"> <label for="custom_scope_query">Query</label> <input type="text" name="custom_scope_query" id="custom_scope_query" data-target="custom-scopes.customScopesQueryField" class="form-control" autocomplete="off" placeholder="(repo:mona/a OR repo:mona/b) AND lang:python" required maxlength="500"> </div> <p class="text-small color-fg-muted"> To see all available qualifiers, see our <a class="Link--inTextBlock" href="https://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax">documentation</a>. </p> </form> </div> <div data-target="custom-scopes.manageCustomScopesForm"> <div data-target="custom-scopes.list"></div> </div> </div> </scrollable-region> <div data-view-component="true" class="Overlay-footer Overlay-footer--alignEnd Overlay-footer--divided"> <button data-action="click:custom-scopes#customScopesCancel" type="button" data-view-component="true" class="btn"> Cancel </button> <button form="custom-scopes-dialog-form" data-action="click:custom-scopes#customScopesSubmit" data-target="custom-scopes.customScopesSubmitButton" type="submit" data-view-component="true" class="btn-primary btn"> Create saved search </button> </div> </dialog></dialog-helper> </custom-scopes> </div> </qbsearch-input> <div class="position-relative HeaderMenu-link-wrap d-lg-inline-block"> <a href="/login?return_to=https%3A%2F%2Fgithub.com%2Ffacebook%2Freact%2Fpull%2F26940" class="HeaderMenu-link HeaderMenu-link--sign-in HeaderMenu-button flex-shrink-0 no-underline d-none d-lg-inline-flex border border-lg-0 rounded rounded-lg-0 px-2 py-1" style="margin-left: 12px;" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;site header menu&quot;,&quot;repository_id&quot;:null,&quot;auth_type&quot;:&quot;SIGN_UP&quot;,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="81320b82fc8a978d1773d94a901bd917f51c827fc6ca6e4b3273536137c1ac3e" data-analytics-event="{&quot;category&quot;:&quot;Marketing nav&quot;,&quot;action&quot;:&quot;click to go to homepage&quot;,&quot;label&quot;:&quot;ref_page:Marketing;ref_cta:Sign in;ref_loc:Header&quot;}" > Sign in </a> </div> <a href="/signup?ref_cta=Sign+up&amp;ref_loc=header+logged+out&amp;ref_page=%2F%3Cuser-name%3E%2F%3Crepo-name%3E%2Fvoltron%2Fpull_requests_fragments%2Fpull_request_layout&amp;source=header-repo&amp;source_repo=facebook%2Freact" class="HeaderMenu-link HeaderMenu-link--sign-up HeaderMenu-button flex-shrink-0 d-flex d-lg-inline-flex no-underline border color-border-default rounded px-2 py-1" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;site header menu&quot;,&quot;repository_id&quot;:null,&quot;auth_type&quot;:&quot;SIGN_UP&quot;,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="81320b82fc8a978d1773d94a901bd917f51c827fc6ca6e4b3273536137c1ac3e" data-analytics-event="{&quot;category&quot;:&quot;Sign up&quot;,&quot;action&quot;:&quot;click to sign up for account&quot;,&quot;label&quot;:&quot;ref_page:/&lt;user-name&gt;/&lt;repo-name&gt;/voltron/pull_requests_fragments/pull_request_layout;ref_cta:Sign up;ref_loc:header logged out&quot;}" > Sign up </a> <button type="button" class="sr-only js-header-menu-focus-trap d-block d-lg-none">Reseting focus</button> </div> </div> </div> </div> </header> <div hidden="hidden" data-view-component="true" class="js-stale-session-flash stale-session-flash flash flash-warn flash-full"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-alert"> <path d="M6.457 1.047c.659-1.234 2.427-1.234 3.086 0l6.082 11.378A1.75 1.75 0 0 1 14.082 15H1.918a1.75 1.75 0 0 1-1.543-2.575Zm1.763.707a.25.25 0 0 0-.44 0L1.698 13.132a.25.25 0 0 0 .22.368h12.164a.25.25 0 0 0 .22-.368Zm.53 3.996v2.5a.75.75 0 0 1-1.5 0v-2.5a.75.75 0 0 1 1.5 0ZM9 11a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> <span class="js-stale-session-flash-signed-in" hidden>You signed in with another tab or window. <a class="Link--inTextBlock" href="">Reload</a> to refresh your session.</span> <span class="js-stale-session-flash-signed-out" hidden>You signed out in another tab or window. <a class="Link--inTextBlock" href="">Reload</a> to refresh your session.</span> <span class="js-stale-session-flash-switched" hidden>You switched accounts on another tab or window. <a class="Link--inTextBlock" href="">Reload</a> to refresh your session.</span> <button id="icon-button-cf51ebf0-3216-4dc2-bb78-797268f8ba37" aria-labelledby="tooltip-9344454f-3a8d-4ee9-a354-93c8327a2634" type="button" data-view-component="true" class="Button Button--iconOnly Button--invisible Button--medium flash-close js-flash-close"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x Button-visual"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> </button><tool-tip id="tooltip-9344454f-3a8d-4ee9-a354-93c8327a2634" for="icon-button-cf51ebf0-3216-4dc2-bb78-797268f8ba37" popover="manual" data-direction="s" data-type="label" data-view-component="true" class="sr-only position-absolute">Dismiss alert</tool-tip> </div> </div> <div id="start-of-content" class="show-on-focus"></div> <div id="js-flash-container" class="flash-container" data-turbo-replace> <template class="js-flash-template"> <div class="flash flash-full {{ className }}"> <div > <button autofocus class="flash-close js-flash-close" type="button" aria-label="Dismiss this message"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> </button> <div aria-atomic="true" role="alert" class="js-flash-alert"> <div>{{ message }}</div> </div> </div> </div> </template> </div> <div class="application-main " data-commit-hovercards-enabled data-discussion-hovercards-enabled data-issue-and-pr-hovercards-enabled data-project-hovercards-enabled > <div itemscope itemtype="http://schema.org/SoftwareSourceCode" class=""> <main id="js-repo-pjax-container" > <div id="repository-container-header" class="pt-3 hide-full-screen" style="background-color: var(--page-header-bgColor, var(--color-page-header-bg));" data-turbo-replace> <div class="d-flex flex-nowrap flex-justify-end mb-3 px-3 px-lg-5" style="gap: 1rem;"> <div class="flex-auto min-width-0 width-fit"> <div class=" d-flex flex-wrap flex-items-center wb-break-word f3 text-normal"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-repo color-fg-muted mr-2"> <path d="M2 2.5A2.5 2.5 0 0 1 4.5 0h8.75a.75.75 0 0 1 .75.75v12.5a.75.75 0 0 1-.75.75h-2.5a.75.75 0 0 1 0-1.5h1.75v-2h-8a1 1 0 0 0-.714 1.7.75.75 0 1 1-1.072 1.05A2.495 2.495 0 0 1 2 11.5Zm10.5-1h-8a1 1 0 0 0-1 1v6.708A2.486 2.486 0 0 1 4.5 9h8ZM5 12.25a.25.25 0 0 1 .25-.25h3.5a.25.25 0 0 1 .25.25v3.25a.25.25 0 0 1-.4.2l-1.45-1.087a.249.249 0 0 0-.3 0L5.4 15.7a.25.25 0 0 1-.4-.2Z"></path> </svg> <span class="author flex-self-stretch" itemprop="author"> <a class="url fn" rel="author" data-hovercard-type="organization" data-hovercard-url="/orgs/facebook/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/facebook"> facebook </a> </span> <span class="mx-1 flex-self-stretch color-fg-muted">/</span> <strong itemprop="name" class="mr-2 flex-self-stretch"> <a data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" href="/facebook/react">react</a> </strong> <span></span><span class="Label Label--secondary v-align-middle mr-1">Public</span> </div> </div> <div id="repository-details-container" class="flex-shrink-0" data-turbo-replace style="max-width: 70%;"> <ul class="pagehead-actions flex-shrink-0 d-none d-md-inline" style="padding: 2px 0;"> <li> <a href="/login?return_to=%2Ffacebook%2Freact" rel="nofollow" id="repository-details-watch-button" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;notification subscription menu watch&quot;,&quot;repository_id&quot;:null,&quot;auth_type&quot;:&quot;LOG_IN&quot;,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="4a51ca89e2e6c44183c4f23dc5619c627271a7223cfe05bea010088c6943298d" aria-label="You must be signed in to change notification settings" data-view-component="true" class="btn-sm btn"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-bell mr-2"> <path d="M8 16a2 2 0 0 0 1.985-1.75c.017-.137-.097-.25-.235-.25h-3.5c-.138 0-.252.113-.235.25A2 2 0 0 0 8 16ZM3 5a5 5 0 0 1 10 0v2.947c0 .05.015.098.042.139l1.703 2.555A1.519 1.519 0 0 1 13.482 13H2.518a1.516 1.516 0 0 1-1.263-2.36l1.703-2.554A.255.255 0 0 0 3 7.947Zm5-3.5A3.5 3.5 0 0 0 4.5 5v2.947c0 .346-.102.683-.294.97l-1.703 2.556a.017.017 0 0 0-.003.01l.001.006c0 .002.002.004.004.006l.006.004.007.001h10.964l.007-.001.006-.004.004-.006.001-.007a.017.017 0 0 0-.003-.01l-1.703-2.554a1.745 1.745 0 0 1-.294-.97V5A3.5 3.5 0 0 0 8 1.5Z"></path> </svg>Notifications </a> <tool-tip id="tooltip-f7bba6c4-c29b-48e3-93c4-730d806fae2e" for="repository-details-watch-button" popover="manual" data-direction="s" data-type="description" data-view-component="true" class="sr-only position-absolute">You must be signed in to change notification settings</tool-tip> </li> <li> <a icon="repo-forked" id="fork-button" href="/login?return_to=%2Ffacebook%2Freact" rel="nofollow" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;repo details fork button&quot;,&quot;repository_id&quot;:10270250,&quot;auth_type&quot;:&quot;LOG_IN&quot;,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="439df07cc07bdcec41128172cb42a2a50e2fdfc02f4a08ce7afb0bc5245242cf" data-view-component="true" class="btn-sm btn"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-repo-forked mr-2"> <path d="M5 5.372v.878c0 .414.336.75.75.75h4.5a.75.75 0 0 0 .75-.75v-.878a2.25 2.25 0 1 1 1.5 0v.878a2.25 2.25 0 0 1-2.25 2.25h-1.5v2.128a2.251 2.251 0 1 1-1.5 0V8.5h-1.5A2.25 2.25 0 0 1 3.5 6.25v-.878a2.25 2.25 0 1 1 1.5 0ZM5 3.25a.75.75 0 1 0-1.5 0 .75.75 0 0 0 1.5 0Zm6.75.75a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5Zm-3 8.75a.75.75 0 1 0-1.5 0 .75.75 0 0 0 1.5 0Z"></path> </svg>Fork <span id="repo-network-counter" data-pjax-replace="true" data-turbo-replace="true" title="47,187" data-view-component="true" class="Counter">47.2k</span> </a> </li> <li> <div data-view-component="true" class="BtnGroup d-flex"> <a href="/login?return_to=%2Ffacebook%2Freact" rel="nofollow" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;star button&quot;,&quot;repository_id&quot;:10270250,&quot;auth_type&quot;:&quot;LOG_IN&quot;,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="d4671e67eba2ce87e2c18338b272f642e92ac5f589898de47130619aed50a7d5" aria-label="You must be signed in to star a repository" data-view-component="true" class="tooltipped tooltipped-sw btn-sm btn"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-star v-align-text-bottom d-inline-block mr-2"> <path d="M8 .25a.75.75 0 0 1 .673.418l1.882 3.815 4.21.612a.75.75 0 0 1 .416 1.279l-3.046 2.97.719 4.192a.751.751 0 0 1-1.088.791L8 12.347l-3.766 1.98a.75.75 0 0 1-1.088-.79l.72-4.194L.818 6.374a.75.75 0 0 1 .416-1.28l4.21-.611L7.327.668A.75.75 0 0 1 8 .25Zm0 2.445L6.615 5.5a.75.75 0 0 1-.564.41l-3.097.45 2.24 2.184a.75.75 0 0 1 .216.664l-.528 3.084 2.769-1.456a.75.75 0 0 1 .698 0l2.77 1.456-.53-3.084a.75.75 0 0 1 .216-.664l2.24-2.183-3.096-.45a.75.75 0 0 1-.564-.41L8 2.694Z"></path> </svg><span data-view-component="true" class="d-inline"> Star </span> <span id="repo-stars-counter-star" aria-label="230384 users starred this repository" data-singular-suffix="user starred this repository" data-plural-suffix="users starred this repository" data-turbo-replace="true" title="230,384" data-view-component="true" class="Counter js-social-count">230k</span> </a></div> </li> </ul> </div> </div> <div id="responsive-meta-container" data-turbo-replace> </div> <nav data-pjax="#js-repo-pjax-container" aria-label="Repository" data-view-component="true" class="js-repo-nav js-sidenav-container-pjax js-responsive-underlinenav overflow-hidden UnderlineNav px-3 px-md-4 px-lg-5"> <ul data-view-component="true" class="UnderlineNav-body list-style-none"> <li data-view-component="true" class="d-inline-flex"> <a id="code-tab" href="/facebook/react" data-tab-item="i0code-tab" data-selected-links="repo_source repo_downloads repo_commits repo_releases repo_tags repo_branches repo_packages repo_deployments repo_attestations /facebook/react" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g c" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Code&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-code UnderlineNav-octicon d-none d-sm-inline"> <path d="m11.28 3.22 4.25 4.25a.75.75 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734L13.94 8l-3.72-3.72a.749.749 0 0 1 .326-1.275.749.749 0 0 1 .734.215Zm-6.56 0a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042L2.06 8l3.72 3.72a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L.47 8.53a.75.75 0 0 1 0-1.06Z"></path> </svg> <span data-content="Code">Code</span> <span id="code-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="Not available" data-view-component="true" class="Counter"></span> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="issues-tab" href="/facebook/react/issues" data-tab-item="i1issues-tab" data-selected-links="repo_issues repo_labels repo_milestones /facebook/react/issues" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g i" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Issues&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-issue-opened UnderlineNav-octicon d-none d-sm-inline"> <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path><path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Z"></path> </svg> <span data-content="Issues">Issues</span> <span id="issues-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="754" data-view-component="true" class="Counter">754</span> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="pull-requests-tab" href="/facebook/react/pulls" data-tab-item="i2pull-requests-tab" data-selected-links="repo_pulls checks /facebook/react/pulls" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g p" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Pull requests&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" aria-current="page" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item selected"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-git-pull-request UnderlineNav-octicon d-none d-sm-inline"> <path d="M1.5 3.25a2.25 2.25 0 1 1 3 2.122v5.256a2.251 2.251 0 1 1-1.5 0V5.372A2.25 2.25 0 0 1 1.5 3.25Zm5.677-.177L9.573.677A.25.25 0 0 1 10 .854V2.5h1A2.5 2.5 0 0 1 13.5 5v5.628a2.251 2.251 0 1 1-1.5 0V5a1 1 0 0 0-1-1h-1v1.646a.25.25 0 0 1-.427.177L7.177 3.427a.25.25 0 0 1 0-.354ZM3.75 2.5a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Zm0 9.5a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Zm8.25.75a.75.75 0 1 0 1.5 0 .75.75 0 0 0-1.5 0Z"></path> </svg> <span data-content="Pull requests">Pull requests</span> <span id="pull-requests-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="162" data-view-component="true" class="Counter">162</span> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="actions-tab" href="/facebook/react/actions" data-tab-item="i3actions-tab" data-selected-links="repo_actions /facebook/react/actions" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g a" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Actions&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-play UnderlineNav-octicon d-none d-sm-inline"> <path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Zm4.879-2.773 4.264 2.559a.25.25 0 0 1 0 .428l-4.264 2.559A.25.25 0 0 1 6 10.559V5.442a.25.25 0 0 1 .379-.215Z"></path> </svg> <span data-content="Actions">Actions</span> <span id="actions-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="Not available" data-view-component="true" class="Counter"></span> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="projects-tab" href="/facebook/react/projects" data-tab-item="i4projects-tab" data-selected-links="repo_projects new_repo_project repo_project /facebook/react/projects" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g b" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Projects&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-table UnderlineNav-octicon d-none d-sm-inline"> <path d="M0 1.75C0 .784.784 0 1.75 0h12.5C15.216 0 16 .784 16 1.75v12.5A1.75 1.75 0 0 1 14.25 16H1.75A1.75 1.75 0 0 1 0 14.25ZM6.5 6.5v8h7.75a.25.25 0 0 0 .25-.25V6.5Zm8-1.5V1.75a.25.25 0 0 0-.25-.25H6.5V5Zm-13 1.5v7.75c0 .138.112.25.25.25H5v-8ZM5 5V1.5H1.75a.25.25 0 0 0-.25.25V5Z"></path> </svg> <span data-content="Projects">Projects</span> <span id="projects-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="0" hidden="hidden" data-view-component="true" class="Counter">0</span> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="wiki-tab" href="/facebook/react/wiki" data-tab-item="i5wiki-tab" data-selected-links="repo_wiki /facebook/react/wiki" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g w" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Wiki&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-book UnderlineNav-octicon d-none d-sm-inline"> <path d="M0 1.75A.75.75 0 0 1 .75 1h4.253c1.227 0 2.317.59 3 1.501A3.743 3.743 0 0 1 11.006 1h4.245a.75.75 0 0 1 .75.75v10.5a.75.75 0 0 1-.75.75h-4.507a2.25 2.25 0 0 0-1.591.659l-.622.621a.75.75 0 0 1-1.06 0l-.622-.621A2.25 2.25 0 0 0 5.258 13H.75a.75.75 0 0 1-.75-.75Zm7.251 10.324.004-5.073-.002-2.253A2.25 2.25 0 0 0 5.003 2.5H1.5v9h3.757a3.75 3.75 0 0 1 1.994.574ZM8.755 4.75l-.004 7.322a3.752 3.752 0 0 1 1.992-.572H14.5v-9h-3.495a2.25 2.25 0 0 0-2.25 2.25Z"></path> </svg> <span data-content="Wiki">Wiki</span> <span id="wiki-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="Not available" data-view-component="true" class="Counter"></span> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="security-tab" href="/facebook/react/security" data-tab-item="i6security-tab" data-selected-links="security overview alerts policy token_scanning code_scanning /facebook/react/security" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g s" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Security&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-shield UnderlineNav-octicon d-none d-sm-inline"> <path d="M7.467.133a1.748 1.748 0 0 1 1.066 0l5.25 1.68A1.75 1.75 0 0 1 15 3.48V7c0 1.566-.32 3.182-1.303 4.682-.983 1.498-2.585 2.813-5.032 3.855a1.697 1.697 0 0 1-1.33 0c-2.447-1.042-4.049-2.357-5.032-3.855C1.32 10.182 1 8.566 1 7V3.48a1.75 1.75 0 0 1 1.217-1.667Zm.61 1.429a.25.25 0 0 0-.153 0l-5.25 1.68a.25.25 0 0 0-.174.238V7c0 1.358.275 2.666 1.057 3.86.784 1.194 2.121 2.34 4.366 3.297a.196.196 0 0 0 .154 0c2.245-.956 3.582-2.104 4.366-3.298C13.225 9.666 13.5 8.36 13.5 7V3.48a.251.251 0 0 0-.174-.237l-5.25-1.68ZM8.75 4.75v3a.75.75 0 0 1-1.5 0v-3a.75.75 0 0 1 1.5 0ZM9 10.5a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> <span data-content="Security">Security</span> <include-fragment src="/facebook/react/security/overall-count" accept="text/fragment+html"></include-fragment> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="insights-tab" href="/facebook/react/pulse" data-tab-item="i7insights-tab" data-selected-links="repo_graphs repo_contributors dependency_graph dependabot_updates pulse people community /facebook/react/pulse" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Insights&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-graph UnderlineNav-octicon d-none d-sm-inline"> <path d="M1.5 1.75V13.5h13.75a.75.75 0 0 1 0 1.5H.75a.75.75 0 0 1-.75-.75V1.75a.75.75 0 0 1 1.5 0Zm14.28 2.53-5.25 5.25a.75.75 0 0 1-1.06 0L7 7.06 4.28 9.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.25-3.25a.75.75 0 0 1 1.06 0L10 7.94l4.72-4.72a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042Z"></path> </svg> <span data-content="Insights">Insights</span> <span id="insights-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="Not available" data-view-component="true" class="Counter"></span> </a></li> </ul> <div style="visibility:hidden;" data-view-component="true" class="UnderlineNav-actions js-responsive-underlinenav-overflow position-absolute pr-3 pr-md-4 pr-lg-5 right-0"> <action-menu data-select-variant="none" data-view-component="true"> <focus-group direction="vertical" mnemonics retain> <button id="action-menu-9f08e4af-c274-4f1f-883c-238eef30b0c8-button" popovertarget="action-menu-9f08e4af-c274-4f1f-883c-238eef30b0c8-overlay" aria-controls="action-menu-9f08e4af-c274-4f1f-883c-238eef30b0c8-list" aria-haspopup="true" aria-labelledby="tooltip-2c933e87-ff48-4a3f-98a1-fb777ffbd2a0" type="button" data-view-component="true" class="Button Button--iconOnly Button--secondary Button--medium UnderlineNav-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-kebab-horizontal Button-visual"> <path d="M8 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3ZM1.5 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Zm13 0a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path> </svg> </button><tool-tip id="tooltip-2c933e87-ff48-4a3f-98a1-fb777ffbd2a0" for="action-menu-9f08e4af-c274-4f1f-883c-238eef30b0c8-button" popover="manual" data-direction="s" data-type="label" data-view-component="true" class="sr-only position-absolute">Additional navigation options</tool-tip> <anchored-position id="action-menu-9f08e4af-c274-4f1f-883c-238eef30b0c8-overlay" anchor="action-menu-9f08e4af-c274-4f1f-883c-238eef30b0c8-button" align="start" side="outside-bottom" anchor-offset="normal" popover="auto" data-view-component="true"> <div data-view-component="true" class="Overlay Overlay--size-auto"> <div data-view-component="true" class="Overlay-body Overlay-body--paddingNone"> <action-list> <div data-view-component="true"> <ul aria-labelledby="action-menu-9f08e4af-c274-4f1f-883c-238eef30b0c8-button" id="action-menu-9f08e4af-c274-4f1f-883c-238eef30b0c8-list" role="menu" data-view-component="true" class="ActionListWrap--inset ActionListWrap"> <li hidden="hidden" data-menu-item="i0code-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-2186534e-bac5-4d10-a690-778c0166c023" href="/facebook/react" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-code"> <path d="m11.28 3.22 4.25 4.25a.75.75 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734L13.94 8l-3.72-3.72a.749.749 0 0 1 .326-1.275.749.749 0 0 1 .734.215Zm-6.56 0a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042L2.06 8l3.72 3.72a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L.47 8.53a.75.75 0 0 1 0-1.06Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Code </span> </a> </li> <li hidden="hidden" data-menu-item="i1issues-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-69cc85bc-59bc-466e-b755-3bea25b5be3e" href="/facebook/react/issues" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-issue-opened"> <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path><path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Issues </span> </a> </li> <li hidden="hidden" data-menu-item="i2pull-requests-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-764da6bd-19b9-4994-9899-a36e9ef3df67" href="/facebook/react/pulls" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-git-pull-request"> <path d="M1.5 3.25a2.25 2.25 0 1 1 3 2.122v5.256a2.251 2.251 0 1 1-1.5 0V5.372A2.25 2.25 0 0 1 1.5 3.25Zm5.677-.177L9.573.677A.25.25 0 0 1 10 .854V2.5h1A2.5 2.5 0 0 1 13.5 5v5.628a2.251 2.251 0 1 1-1.5 0V5a1 1 0 0 0-1-1h-1v1.646a.25.25 0 0 1-.427.177L7.177 3.427a.25.25 0 0 1 0-.354ZM3.75 2.5a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Zm0 9.5a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Zm8.25.75a.75.75 0 1 0 1.5 0 .75.75 0 0 0-1.5 0Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Pull requests </span> </a> </li> <li hidden="hidden" data-menu-item="i3actions-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-d138e4a9-a469-4fb6-a8bd-6cb909bb2299" href="/facebook/react/actions" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-play"> <path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Zm4.879-2.773 4.264 2.559a.25.25 0 0 1 0 .428l-4.264 2.559A.25.25 0 0 1 6 10.559V5.442a.25.25 0 0 1 .379-.215Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Actions </span> </a> </li> <li hidden="hidden" data-menu-item="i4projects-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-3d6211f9-d798-4f6f-ad32-6226b7f2b466" href="/facebook/react/projects" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-table"> <path d="M0 1.75C0 .784.784 0 1.75 0h12.5C15.216 0 16 .784 16 1.75v12.5A1.75 1.75 0 0 1 14.25 16H1.75A1.75 1.75 0 0 1 0 14.25ZM6.5 6.5v8h7.75a.25.25 0 0 0 .25-.25V6.5Zm8-1.5V1.75a.25.25 0 0 0-.25-.25H6.5V5Zm-13 1.5v7.75c0 .138.112.25.25.25H5v-8ZM5 5V1.5H1.75a.25.25 0 0 0-.25.25V5Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Projects </span> </a> </li> <li hidden="hidden" data-menu-item="i5wiki-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-c5e03627-6ec9-4dda-a56d-26803f6034e9" href="/facebook/react/wiki" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-book"> <path d="M0 1.75A.75.75 0 0 1 .75 1h4.253c1.227 0 2.317.59 3 1.501A3.743 3.743 0 0 1 11.006 1h4.245a.75.75 0 0 1 .75.75v10.5a.75.75 0 0 1-.75.75h-4.507a2.25 2.25 0 0 0-1.591.659l-.622.621a.75.75 0 0 1-1.06 0l-.622-.621A2.25 2.25 0 0 0 5.258 13H.75a.75.75 0 0 1-.75-.75Zm7.251 10.324.004-5.073-.002-2.253A2.25 2.25 0 0 0 5.003 2.5H1.5v9h3.757a3.75 3.75 0 0 1 1.994.574ZM8.755 4.75l-.004 7.322a3.752 3.752 0 0 1 1.992-.572H14.5v-9h-3.495a2.25 2.25 0 0 0-2.25 2.25Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Wiki </span> </a> </li> <li hidden="hidden" data-menu-item="i6security-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-00a656e2-70d7-41f0-8b98-2230fb0792d1" href="/facebook/react/security" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-shield"> <path d="M7.467.133a1.748 1.748 0 0 1 1.066 0l5.25 1.68A1.75 1.75 0 0 1 15 3.48V7c0 1.566-.32 3.182-1.303 4.682-.983 1.498-2.585 2.813-5.032 3.855a1.697 1.697 0 0 1-1.33 0c-2.447-1.042-4.049-2.357-5.032-3.855C1.32 10.182 1 8.566 1 7V3.48a1.75 1.75 0 0 1 1.217-1.667Zm.61 1.429a.25.25 0 0 0-.153 0l-5.25 1.68a.25.25 0 0 0-.174.238V7c0 1.358.275 2.666 1.057 3.86.784 1.194 2.121 2.34 4.366 3.297a.196.196 0 0 0 .154 0c2.245-.956 3.582-2.104 4.366-3.298C13.225 9.666 13.5 8.36 13.5 7V3.48a.251.251 0 0 0-.174-.237l-5.25-1.68ZM8.75 4.75v3a.75.75 0 0 1-1.5 0v-3a.75.75 0 0 1 1.5 0ZM9 10.5a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Security </span> </a> </li> <li hidden="hidden" data-menu-item="i7insights-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-3e3f679e-4cfb-49a8-bc40-3cbb0ee93206" href="/facebook/react/pulse" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-graph"> <path d="M1.5 1.75V13.5h13.75a.75.75 0 0 1 0 1.5H.75a.75.75 0 0 1-.75-.75V1.75a.75.75 0 0 1 1.5 0Zm14.28 2.53-5.25 5.25a.75.75 0 0 1-1.06 0L7 7.06 4.28 9.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.25-3.25a.75.75 0 0 1 1.06 0L10 7.94l4.72-4.72a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Insights </span> </a> </li> </ul> </div></action-list> </div> </div></anchored-position> </focus-group> </action-menu></div> </nav> </div> <turbo-frame id="repo-content-turbo-frame" target="_top" data-turbo-action="advance" class=""> <div id="repo-content-pjax-container" class="repository-content " > <div class="clearfix new-discussion-timeline js-check-all-container container-xl px-3 px-md-4 px-lg-5 mt-4" data-pjax="" data-turbo-frame=""> <div class="clearfix js-issues-results"> <div id="partial-discussion-header" class="gh-header mb-3 js-details-container Details js-socket-channel js-updatable-content pull request js-pull-header-details" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzOTExMjg0MzgiLCJ0IjoxNzM0MTMyMTAyfQ==--64c7562300bdaaaf6ef8924abe47cd1240a38400be35264667f65d26be3fa3a0" data-url="/facebook/react/pull/26940/partials/title?sticky=true" data-channel-event-name="title_updated" data-pull-is-open="false" data-gid="PR_kwDOAJy2Ks5S6u92"> <div class="gh-header-show "> <div class="d-flex flex-column flex-md-row"> <div class="gh-header-actions mt-0 mb-3 mb-md-2 ml-1 flex-md-order-1 flex-shrink-0 d-flex flex-items-center gap-1"> <details class="details-reset details-overlay details-overlay-dark float-right" > <summary class="btn btn-sm btn-primary m-0 ml-0 ml-md-2" > New issue </summary> <details-dialog class="Box Box--overlay d-flex flex-column anim-fade-in fast overflow-auto" aria-label="Sign up for GitHub"> <button aria-label="Close dialog" data-close-dialog="" type="button" data-view-component="true" class="Link--muted btn-link position-absolute p-4 right-0"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> </button> <div class="d-flex flex-column p-4"> <div class="mt-3 mb-2 text-center"> <svg height="60" aria-hidden="true" viewBox="0 0 24 24" version="1.1" width="60" data-view-component="true" class="octicon octicon-comment-discussion color-fg-accent"> <path d="M1.75 1h12.5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0 1 14.25 14H8.061l-2.574 2.573A1.458 1.458 0 0 1 3 15.543V14H1.75A1.75 1.75 0 0 1 0 12.25v-9.5C0 1.784.784 1 1.75 1ZM1.5 2.75v9.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h6.5a.25.25 0 0 0 .25-.25v-9.5a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25Z"></path><path d="M22.5 8.75a.25.25 0 0 0-.25-.25h-3.5a.75.75 0 0 1 0-1.5h3.5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0 1 22.25 20H21v1.543a1.457 1.457 0 0 1-2.487 1.03L15.939 20H10.75A1.75 1.75 0 0 1 9 18.25v-1.465a.75.75 0 0 1 1.5 0v1.465c0 .138.112.25.25.25h5.5a.75.75 0 0 1 .53.22l2.72 2.72v-2.19a.75.75 0 0 1 .75-.75h2a.25.25 0 0 0 .25-.25v-9.5Z"></path> </svg> </div> <div class="px-4"> <p class="text-center mb-4"> <strong>Have a question about this project?</strong> Sign up for a free GitHub account to open an issue and contact its maintainers and the community. </p> <div class="d-flex flex-items-center"> <a href="/signup?return_to=%2Ffacebook%2Freact%2Fissues%2Fnew%2Fchoose" data-view-component="true" class="btn-primary btn mx-auto"> Sign up for GitHub </a> </div> <p class="mt-4 color-fg-muted text-center">By clicking &ldquo;Sign up for GitHub&rdquo;, you agree to our <a class="Link--inTextBlock" href="https://docs.github.com/terms" target="_blank">terms of service</a> and <a class="Link--inTextBlock" href="https://docs.github.com/privacy" target="_blank">privacy statement</a>. We’ll occasionally send you account related emails.</p> <p class="mt-4 color-fg-muted text-center"> Already on GitHub? <a data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;new issue modal&quot;,&quot;repository_id&quot;:null,&quot;auth_type&quot;:&quot;LOG_IN&quot;,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="f504abf83fd97c3afd1f3a415d872733e1abd1eb5274ca482d4ed5de281c8dac" class="Link--inTextBlock" href="/login?return_to=%2Ffacebook%2Freact%2Fissues%2Fnew%2Fchoose">Sign in</a> to your account </p> </div> </div> </details-dialog> </details> <div class="flex-auto text-right d-block d-md-none"> <a href="#issue-comment-box" class="py-1">Jump to bottom</a> </div> </div> <h1 class="gh-header-title mb-2 lh-condensed f1 mr-0 flex-auto wb-break-word"> <bdi class="js-issue-title markdown-title">[Float][Fizz][Fiber] support imagesrcset and imagesizes for <code>ReactDOM.preload()</code></bdi> <span class="f1-light color-fg-muted">#26940</span> </h1> </div> </div> <div class="d-flex flex-items-center flex-wrap mt-0 gh-header-meta"> <div class="flex-shrink-0 mb-2 flex-self-start flex-md-self-center"> <span reviewable_state="ready" title="Status: Merged" data-view-component="true" class="State State--merged"> <svg height="16" class="octicon octicon-git-merge" viewBox="0 0 16 16" version="1.1" width="16" aria-hidden="true"><path d="M5.45 5.154A4.25 4.25 0 0 0 9.25 7.5h1.378a2.251 2.251 0 1 1 0 1.5H9.25A5.734 5.734 0 0 1 5 7.123v3.505a2.25 2.25 0 1 1-1.5 0V5.372a2.25 2.25 0 1 1 1.95-.218ZM4.25 13.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5Zm8.5-4.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5ZM5 3.25a.75.75 0 1 0 0 .005V3.25Z"></path></svg> Merged </span> </div> <div class="flex-auto min-width-0 mb-2"> <a class="author Link--secondary text-bold css-truncate css-truncate-target expandable" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff">gnoff</a> merged 1 commit into <span title="facebook/react:main" class="commit-ref css-truncate user-select-contain expandable "><a title="facebook/react:main" class="no-underline " href="/facebook/react/tree/main"><span class="css-truncate-target">facebook</span>:<span class="css-truncate-target">main</span></a></span><span></span> from <span title="gnoff/react:preload-imagesrcset" class="commit-ref css-truncate user-select-contain expandable head-ref"><a title="gnoff/react:preload-imagesrcset" class="no-underline " href="/gnoff/react/tree/preload-imagesrcset"><span class="css-truncate-target">gnoff</span>:<span class="css-truncate-target">preload-imagesrcset</span></a></span><span><span data-view-component="true"> <clipboard-copy aria-label="Copy" data-copy-feedback="Copied!" value="gnoff:preload-imagesrcset" data-view-component="true" class="Link--onHover js-copy-branch color-fg-muted d-inline-block ml-1"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-copy"> <path d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 0 1 0 1.5h-1.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-1.5a.75.75 0 0 1 1.5 0v1.5A1.75 1.75 0 0 1 9.25 16h-7.5A1.75 1.75 0 0 1 0 14.25Z"></path><path d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0 1 14.25 11h-7.5A1.75 1.75 0 0 1 5 9.25Zm1.75-.25a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Z"></path> </svg> <svg style="display: none;" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-check color-fg-success"> <path d="M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0Z"></path> </svg> </clipboard-copy> <div aria-live="polite" aria-atomic="true" class="sr-only" data-clipboard-copy-feedback></div> </span></span> <relative-time datetime="2023-06-15T21:50:23Z" class="no-wrap">Jun 15, 2023</relative-time> </div> </div> <div class="js-sticky js-sticky-offset-scroll top-0 gh-header-sticky"> <div class="sticky-content"> <div class="d-flex flex-items-center flex-justify-between mt-2"> <div class="d-flex flex-row flex-items-center min-width-0"> <div class="mr-2 mb-2 flex-shrink-0"> <span reviewable_state="ready" title="Status: Merged" data-view-component="true" class="State State--merged"> <svg height="16" class="octicon octicon-git-merge" viewBox="0 0 16 16" version="1.1" width="16" aria-hidden="true"><path d="M5.45 5.154A4.25 4.25 0 0 0 9.25 7.5h1.378a2.251 2.251 0 1 1 0 1.5H9.25A5.734 5.734 0 0 1 5 7.123v3.505a2.25 2.25 0 1 1-1.5 0V5.372a2.25 2.25 0 1 1 1.95-.218ZM4.25 13.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5Zm8.5-4.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5ZM5 3.25a.75.75 0 1 0 0 .005V3.25Z"></path></svg> Merged </span> </div> <div class="min-width-0 mr-2 mb-2"> <h1 class="d-flex text-bold f5"> <a class="js-issue-title css-truncate css-truncate-target Link--primary width-fit markdown-title js-smoothscroll-anchor" href="#top"> [Float][Fizz][Fiber] support imagesrcset and imagesizes for <code>ReactDOM.preload()</code> </a> <span class="gh-header-number color-fg-muted pl-1">#26940</span> </h1> <div class="meta color-fg-muted css-truncate css-truncate-target d-block width-fit"> <a class="author Link--secondary text-bold css-truncate css-truncate-target expandable" data-hovercard-z-index-override="111" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff">gnoff</a> merged 1 commit into <span title="facebook/react:main" class="commit-ref css-truncate user-select-contain expandable "><a title="facebook/react:main" class="no-underline " href="/facebook/react/tree/main"><span class="css-truncate-target">facebook</span>:<span class="css-truncate-target">main</span></a></span><span></span> from <span title="gnoff/react:preload-imagesrcset" class="commit-ref css-truncate user-select-contain expandable head-ref"><a title="gnoff/react:preload-imagesrcset" class="no-underline " href="/gnoff/react/tree/preload-imagesrcset"><span class="css-truncate-target">gnoff</span>:<span class="css-truncate-target">preload-imagesrcset</span></a></span><span><span data-view-component="true"> <clipboard-copy aria-label="Copy" data-copy-feedback="Copied!" value="gnoff:preload-imagesrcset" data-view-component="true" class="Link--onHover js-copy-branch color-fg-muted d-inline-block ml-1"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-copy"> <path d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 0 1 0 1.5h-1.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-1.5a.75.75 0 0 1 1.5 0v1.5A1.75 1.75 0 0 1 9.25 16h-7.5A1.75 1.75 0 0 1 0 14.25Z"></path><path d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0 1 14.25 11h-7.5A1.75 1.75 0 0 1 5 9.25Zm1.75-.25a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Z"></path> </svg> <svg style="display: none;" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-check color-fg-success"> <path d="M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0Z"></path> </svg> </clipboard-copy> <div aria-live="polite" aria-atomic="true" class="sr-only" data-clipboard-copy-feedback></div> </span></span> <relative-time datetime="2023-06-15T21:50:23Z" class="no-wrap">Jun 15, 2023</relative-time> </div> </div> </div> </div> </div> </div> <div class="gh-header-shadow color-shadow-small js-notification-shelf-offset-top"></div> </div> <include-fragment src="/facebook/react/pull/26940/partials/tabs"> <div class="px-3 px-md-0 ml-n3 mr-n3 mx-md-0 tabnav"> <nav class="tabnav-tabs d-flex overflow-auto" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" aria-label="Pull request tabs"> <a href="/facebook/react/pull/26940" class="tabnav-tab flex-shrink-0 selected" aria-current="page"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-comment-discussion d-none d-md-inline-block"> <path d="M1.75 1h8.5c.966 0 1.75.784 1.75 1.75v5.5A1.75 1.75 0 0 1 10.25 10H7.061l-2.574 2.573A1.458 1.458 0 0 1 2 11.543V10h-.25A1.75 1.75 0 0 1 0 8.25v-5.5C0 1.784.784 1 1.75 1ZM1.5 2.75v5.5c0 .138.112.25.25.25h1a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h3.5a.25.25 0 0 0 .25-.25v-5.5a.25.25 0 0 0-.25-.25h-8.5a.25.25 0 0 0-.25.25Zm13 2a.25.25 0 0 0-.25-.25h-.5a.75.75 0 0 1 0-1.5h.5c.966 0 1.75.784 1.75 1.75v5.5A1.75 1.75 0 0 1 14.25 12H14v1.543a1.458 1.458 0 0 1-2.487 1.03L9.22 12.28a.749.749 0 0 1 .326-1.275.749.749 0 0 1 .734.215l2.22 2.22v-2.19a.75.75 0 0 1 .75-.75h1a.25.25 0 0 0 .25-.25Z"></path> </svg> Conversation <span id="conversation_tab_counter" title="2" data-view-component="true" class="Counter">2</span> </a> <a href="/facebook/react/pull/26940/commits" class="tabnav-tab flex-shrink-0 " > <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-git-commit d-none d-md-inline-block"> <path d="M11.93 8.5a4.002 4.002 0 0 1-7.86 0H.75a.75.75 0 0 1 0-1.5h3.32a4.002 4.002 0 0 1 7.86 0h3.32a.75.75 0 0 1 0 1.5Zm-1.43-.75a2.5 2.5 0 1 0-5 0 2.5 2.5 0 0 0 5 0Z"></path> </svg> Commits <span id="commits_tab_counter" title="1" data-view-component="true" class="Counter js-updateable-pull-request-commits-count">1</span> </a> <a href="/facebook/react/pull/26940/checks" class="tabnav-tab flex-shrink-0 "> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-checklist d-none d-md-inline-block"> <path d="M2.5 1.75v11.5c0 .138.112.25.25.25h3.17a.75.75 0 0 1 0 1.5H2.75A1.75 1.75 0 0 1 1 13.25V1.75C1 .784 1.784 0 2.75 0h8.5C12.216 0 13 .784 13 1.75v7.736a.75.75 0 0 1-1.5 0V1.75a.25.25 0 0 0-.25-.25h-8.5a.25.25 0 0 0-.25.25Zm13.274 9.537v-.001l-4.557 4.45a.75.75 0 0 1-1.055-.008l-1.943-1.95a.75.75 0 0 1 1.062-1.058l1.419 1.425 4.026-3.932a.75.75 0 1 1 1.048 1.074ZM4.75 4h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1 0-1.5ZM4 7.75A.75.75 0 0 1 4.75 7h2a.75.75 0 0 1 0 1.5h-2A.75.75 0 0 1 4 7.75Z"></path> </svg> Checks <span id="checks_tab_counter" title="0" data-view-component="true" class="Counter">0</span> </a> <a href="/facebook/react/pull/26940/files" class="tabnav-tab flex-shrink-0 "> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-file-diff d-none d-md-inline-block"> <path d="M1 1.75C1 .784 1.784 0 2.75 0h7.586c.464 0 .909.184 1.237.513l2.914 2.914c.329.328.513.773.513 1.237v9.586A1.75 1.75 0 0 1 13.25 16H2.75A1.75 1.75 0 0 1 1 14.25Zm1.75-.25a.25.25 0 0 0-.25.25v12.5c0 .138.112.25.25.25h10.5a.25.25 0 0 0 .25-.25V4.664a.25.25 0 0 0-.073-.177l-2.914-2.914a.25.25 0 0 0-.177-.073ZM8 3.25a.75.75 0 0 1 .75.75v1.5h1.5a.75.75 0 0 1 0 1.5h-1.5v1.5a.75.75 0 0 1-1.5 0V7h-1.5a.75.75 0 0 1 0-1.5h1.5V4A.75.75 0 0 1 8 3.25Zm-3 8a.75.75 0 0 1 .75-.75h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1-.75-.75Z"></path> </svg> Files changed </a> </nav> </div> </include-fragment> <div id="discussion_bucket" class="pull-request-tab-content is-visible js-socket-channel js-updatable-content" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzOTExMjg0Mzg6dGltZWxpbmUiLCJ0IjoxNzM0MTMyMTAyfQ==--17d35bc64f5898e222e6a6fe8be3eadbebb77332c141944848dd4e383de482bc"> <div data-view-component="true" class="Layout Layout--flowRow-until-md Layout--sidebarPosition-end Layout--sidebarPosition-flowRow-end"> <div data-view-component="true" class="Layout-main"> <h2 class="sr-only">Conversation</h2> <div class="pull-discussion-timeline js-pull-discussion-timeline js-quote-selection-container js-review-state-classes" data-quote-markdown=".js-comment-body" data-discussion-hovercards-enabled data-issue-and-pr-hovercards-enabled data-team-hovercards-enabled data-hpc > <template class="js-file-alert-template"> <div data-view-component="true" class="flash flash-warn flash-full d-flex flex-items-center"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-alert"> <path d="M6.457 1.047c.659-1.234 2.427-1.234 3.086 0l6.082 11.378A1.75 1.75 0 0 1 14.082 15H1.918a1.75 1.75 0 0 1-1.543-2.575Zm1.763.707a.25.25 0 0 0-.44 0L1.698 13.132a.25.25 0 0 0 .22.368h12.164a.25.25 0 0 0 .22-.368Zm.53 3.996v2.5a.75.75 0 0 1-1.5 0v-2.5a.75.75 0 0 1 1.5 0ZM9 11a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> <span> This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. <a class="Link--inTextBlock" href="https://github.co/hiddenchars" target="_blank">Learn more about bidirectional Unicode characters</a> </span> <div data-view-component="true" class="flash-action"> <a href="{{ revealButtonHref }}" data-view-component="true" class="btn-sm btn"> Show hidden characters </a> </div> </div></template> <template class="js-line-alert-template"> <span aria-label="This line has hidden Unicode characters" data-view-component="true" class="line-alert tooltipped tooltipped-e"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-alert"> <path d="M6.457 1.047c.659-1.234 2.427-1.234 3.086 0l6.082 11.378A1.75 1.75 0 0 1 14.082 15H1.918a1.75 1.75 0 0 1-1.543-2.575Zm1.763.707a.25.25 0 0 0-.44 0L1.698 13.132a.25.25 0 0 0 .22.368h12.164a.25.25 0 0 0 .22-.368Zm.53 3.996v2.5a.75.75 0 0 1-1.5 0v-2.5a.75.75 0 0 1 1.5 0ZM9 11a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> </span></template> <div class="js-discussion ml-0 pl-0 ml-md-6 pl-md-3" > <div class="TimelineItem TimelineItem--condensed pt-0 js-comment-container js-socket-channel js-updatable-content js-command-palette-pull-body" data-gid="PR_kwDOAJy2Ks5S6u92" data-url="/facebook/react/pull/26940/partials/body" data-channel-event-name="body_updated" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzOTExMjg0MzgiLCJ0IjoxNzM0MTMyMTAyfQ==--64c7562300bdaaaf6ef8924abe47cd1240a38400be35264667f65d26be3fa3a0"> <div data-view-component="true" class="TimelineItem ml-0 p-0"> <a href="/gnoff" data-view-component="true" class="TimelineItem-avatar avatar circle lh-0 Link"><img data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" src="https://avatars.githubusercontent.com/u/2716369?s=60&amp;v=4" alt="gnoff" size="40" height="40" width="40" data-view-component="true" /></a> </div><div class= "timeline-comment-group js-minimizable-comment-group js-targetable-element TimelineItem-body my-0" id="issue-1755454645"> <div id="pullrequest-1391128438" class="timeline-comment-group js-minimizable-comment-group js-targetable-element my-0 comment previewable-edit js-task-list-container js-comment editable-comment timeline-comment--caret reorderable-task-lists timeline-comment ml-n3 unminimized-comment"> <div class="timeline-comment-header clearfix d-flex" data-morpheus-enabled="false"> <div class="timeline-comment-actions flex-shrink-0 d-flex flex-items-center"> <details class="details-overlay details-reset position-relative d-inline-block"> <summary data-view-component="true" class="timeline-comment-action Link--secondary Button--link Button--medium Button"> <span class="Button-content"> <span class="Button-label"><svg aria-label="Show options" role="img" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-kebab-horizontal"> <path d="M8 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3ZM1.5 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Zm13 0a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path> </svg></span> </span> </summary> <details-menu class="dropdown-menu dropdown-menu-sw show-more-popover color-fg-default" style="width:185px" src="" preload > <span data-view-component="true"> <clipboard-copy aria-label="Copy link" for="issue-1755454645-permalink" role="menuitem" data-view-component="true" class="dropdown-item btn-link"> Copy link </clipboard-copy> <div aria-live="polite" aria-atomic="true" class="sr-only" data-clipboard-copy-feedback></div> </span> </details-menu> </details> </div> <div class="d-none d-sm-flex"> <span aria-label="This user has been invited to collaborate on the react repository." data-view-component="true" class="tooltipped tooltipped-n"> <span data-view-component="true" class="Label ml-1">Collaborator</span> </span> </div> <h3 class="f5 text-normal" style="flex: 1 1 auto"> <div> <img src="https://avatars.githubusercontent.com/u/2716369?s=48&amp;v=4" alt="@gnoff" size="24" height="24" width="24" data-view-component="true" class="avatar circle d-inline-block d-md-none mr-2" /> <strong> <a class="author Link--primary text-bold css-overflow-wrap-anywhere " show_full_name="false" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff">gnoff</a> </strong> commented <a href="#issue-1755454645" id="issue-1755454645-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-13T18:38:00Z" class="no-wrap">Jun 13, 2023</relative-time></a> <span class="js-comment-edit-history"> <span class="d-inline-block color-fg-muted">&#8226;</span> <details class="details-overlay details-reset d-inline-block dropdown hx_dropdown-fullscreen"> <summary class="btn-link no-underline color-fg-muted js-notice"> <div class="position-relative"> <span> edited </span> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-triangle-down v-align-middle"> <path d="m4.427 7.427 3.396 3.396a.25.25 0 0 0 .354 0l3.396-3.396A.25.25 0 0 0 11.396 7H4.604a.25.25 0 0 0-.177.427Z"></path> </svg> </div> </summary> <details-menu class="dropdown-menu dropdown-menu-s width-auto py-0 js-comment-edit-history-menu" style="max-width: 352px; z-index: 99;" src="/user_content_edits/show_edit_history_log/PR_kwDOAJy2Ks5S6u92" preload > <include-fragment class="my-3" style="min-width: 100px;" aria-label="Loading..."> <span data-view-component="true"> <svg style="box-sizing: content-box; color: var(--color-icon-primary);" width="32" height="32" viewBox="0 0 16 16" fill="none" aria-hidden="true" data-view-component="true" class="mx-auto d-block anim-rotate"> <circle cx="8" cy="8" r="7" stroke="currentColor" stroke-opacity="0.25" stroke-width="2" vector-effect="non-scaling-stroke" fill="none" /> <path d="M15 8a7.002 7.002 0 00-7-7" stroke="currentColor" stroke-width="2" stroke-linecap="round" vector-effect="non-scaling-stroke" /> </svg> <span class="sr-only">Loading</span> </span> </include-fragment> </details-menu> </details> </span> </div> </h3> </div> <div> <div class="edit-comment-hide"> <task-lists disabled sortable> <div class="comment-body markdown-body js-comment-body soft-wrap css-overflow-wrap-anywhere user-select-contain d-block"> <p dir="auto">For float methods the href argument is usually all we need to uniquely key the request. However when preloading responsive images it is possible that you may need more than one preload for differing imagesizes attributes. When using imagesrcset for preloads the href attribute acts more like a fallback href. For keying purposes the imagesrcset becomes the primary key conceptually.</p> <p dir="auto">This change updates the keying logic for <code class="notranslate">ReactDOM.preload()</code> when you pass <code class="notranslate">{as: "image"}</code></p> <ol dir="auto"> <li>If <code class="notranslate">options.imageSrcSet</code> is a non-emtpy string the key is defined as <code class="notranslate">options.imageSrcSet + options.imageSizes</code>. The <code class="notranslate">href</code> argument is still required but does not participate in keying.</li> <li>If <code class="notranslate">options.imageSrcSet</code> is empty, missing, or an invalid format the key is defined as the <code class="notranslate">href</code>. Changing the <code class="notranslate">options.imageSizes</code> does not affect the key as this option is inert when not using <code class="notranslate">options.imageSrcSet</code></li> </ol> <p dir="auto">Additionally, currently there is a bug in webkit (Safari) that causes preload links to fail to use imageSrcSet and fallback to href even when the browser will correctly resolve srcset on an <code class="notranslate">&lt;img&gt;</code> tag. Because the drawbacks of preloading the wrong image (href over imagesrcset) in a modern browser outweight the drawbacks of not preloading anything for responsive images in browsers that do not support srcset at all we will omit the <code class="notranslate">href</code> attribute whenever <code class="notranslate">options.imageSrcSet</code> is provided. We still require you provide an href since we want to be able to revert this behavior once all major browsers support it</p> <p dir="auto">bug link: <a href="https://bugs.webkit.org/show_bug.cgi?id=231150" rel="nofollow">https://bugs.webkit.org/show_bug.cgi?id=231150</a></p> </div> </task-lists> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-comment-update" id="issue-1755454645-edit-form" data-type="json" data-turbo="false" action="/facebook/react/issues/26940" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="EjtYv1XJVz64hDhfBaQrPnU_jkYCNT4TGYQKw78ss6ufELwouRTmIswvKDK90s8_o0JY8JH0AALNqZ2eRrJxRg" autocomplete="off" /> <include-fragment loading="lazy" src="/facebook/react/issues/26940/edit_form?textarea_id=issue-1755454645-body&amp;comment_context=" class="previewable-comment-form js-comment-edit-form-deferred-include-fragment" > <p class="text-center mt-3" data-hide-on-error> <span data-view-component="true"> <svg aria-label="Loading..." style="box-sizing: content-box; color: var(--color-icon-primary);" width="32" height="32" viewBox="0 0 16 16" fill="none" role="img" data-view-component="true" class="anim-rotate"> <circle cx="8" cy="8" r="7" stroke="currentColor" stroke-opacity="0.25" stroke-width="2" vector-effect="non-scaling-stroke" fill="none" /> <path d="M15 8a7.002 7.002 0 00-7-7" stroke="currentColor" stroke-width="2" stroke-linecap="round" vector-effect="non-scaling-stroke" /> </svg></span> </p> <p class="ml-1 mb-2 mt-2" data-show-on-error hidden> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-alert"> <path d="M6.457 1.047c.659-1.234 2.427-1.234 3.086 0l6.082 11.378A1.75 1.75 0 0 1 14.082 15H1.918a1.75 1.75 0 0 1-1.543-2.575Zm1.763.707a.25.25 0 0 0-.44 0L1.698 13.132a.25.25 0 0 0 .22.368h12.164a.25.25 0 0 0 .22-.368Zm.53 3.996v2.5a.75.75 0 0 1-1.5 0v-2.5a.75.75 0 0 1 1.5 0ZM9 11a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> Sorry, something went wrong. </p> </include-fragment> </form> <div class="pr-review-reactions"> <div data-view-component="true" class="comment-reactions js-reactions-container js-reaction-buttons-container social-reactions reactions-container has-reactions d-flex"> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-pick-reaction" data-turbo="false" action="/facebook/react/reactions" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="y55Z2YTVNA8MhJda6O6ggKviRG-eQCudimv4IUR6VVVyD4M8knhEp8drUDAcxIPbIehaWgdQlrumfO2G3Lq2eQ" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="PR_kwDOAJy2Ks5S6u92"> <div class="js-comment-reactions-options d-flex flex-items-center flex-row flex-wrap"> <button name="input[content]" id="reactions--reaction_button_component-34af00" value="THUMBS_UP react" data-button-index-position="0" data-reaction-label="+1" data-reaction-content="+1" aria-pressed="false" aria-label="thumbs up (1): gnoff, 06:38PM on June 13, 2023" type="submit" disabled="disabled" data-view-component="true" class="social-reaction-summary-item js-reaction-group-button btn-link d-flex no-underline color-fg-muted flex-items-baseline mr-2"> <g-emoji alias="+1" fallback-src="https://github.githubassets.com/assets/1f44d-41cb66fe1e22.png" class="social-button-emoji">👍</g-emoji> <span class="js-discussion-reaction-group-count">1</span> </button> <tool-tip id="tooltip-7b43195d-0e4c-4d28-87b1-2607425eae5f" for="reactions--reaction_button_component-34af00" popover="manual" data-direction="n" data-type="description" data-view-component="true" class="sr-only position-absolute">styfle reacted with thumbs up emoji</tool-tip> <div class="js-reactions-container"> <details class="dropdown details-reset details-overlay d-inline-block js-all-reactions-popover" hidden> <summary aria-haspopup="true" data-view-component="true" class="Button--link Button--medium Button"> <span class="Button-content"> <span class="Button-label">All reactions</span> </span> </summary> <ul class="dropdown-menu dropdown-menu-se"> <li class="dropdown-item" aria-label="styfle reacted with thumbs up emoji"> <g-emoji alias="+1" fallback-src="https://github.githubassets.com/assets/1f44d-41cb66fe1e22.png" class="social-button-emoji mr-2">👍</g-emoji> <span>1 reaction</span> </li> </ul> </details> </div> </div> </form></div> </div> </div> </div> </div> <div id="js-timeline-progressive-loader" data-timeline-item-src="facebook/react/timeline_focused_item?after_cursor=Y3Vyc29yOnYyOpPPAAABjvJxpXABqzEyNTI3MzUyMDUz&amp;id=PR_kwDOAJy2Ks5S6u92" ></div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="LE_lADOAJy2Ks5oohy1zwAAAAI3bHCj"> <div class="TimelineItem js-targetable-element" data-team-hovercards-enabled id="event-9519788195"> <div class="TimelineItem-badge "> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-tag color-fg-inherit"> <path d="M1 7.775V2.75C1 1.784 1.784 1 2.75 1h5.025c.464 0 .91.184 1.238.513l6.25 6.25a1.75 1.75 0 0 1 0 2.474l-5.026 5.026a1.75 1.75 0 0 1-2.474 0l-6.25-6.25A1.752 1.752 0 0 1 1 7.775Zm1.5 0c0 .066.026.13.073.177l6.25 6.25a.25.25 0 0 0 .354 0l5.025-5.025a.25.25 0 0 0 0-.354l-6.25-6.25a.25.25 0 0 0-.177-.073H2.75a.25.25 0 0 0-.25.25ZM6 5a1 1 0 1 1 0 2 1 1 0 0 1 0-2Z"></path> </svg> </div> <div class="TimelineItem-body"> <a class="d-inline-block" data-hovercard-type="user" data-hovercard-url="/users/facebook-github-bot/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/facebook-github-bot"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/6422482?s=40&amp;u=1e8724230d8d2a259d754a1b580af5e52db552f4&amp;v=4" width="20" height="20" alt="@facebook-github-bot" /></a> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/facebook-github-bot/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/facebook-github-bot">facebook-github-bot</a> added the <a id="label-6b6e3b" href="/facebook/react/labels/CLA%20Signed" data-name="CLA Signed" style="--label-r:231;--label-g:231;--label-b:231;--label-h:0;--label-s:0;--label-l:90;" data-view-component="true" class="IssueLabel hx_IssueLabel d-inline-block v-align-middle"> CLA Signed </a> label <a href="#event-9519788195" class="Link--secondary"><relative-time datetime="2023-06-13T18:38:05Z" class="no-wrap">Jun 13, 2023</relative-time></a> </div> </div> <div id="event-9519788370" data-view-component="true" class="TimelineItem js-targetable-element"> <div data-view-component="true" class="TimelineItem-badge"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-eye"> <path d="M8 2c1.981 0 3.671.992 4.933 2.078 1.27 1.091 2.187 2.345 2.637 3.023a1.62 1.62 0 0 1 0 1.798c-.45.678-1.367 1.932-2.637 3.023C11.67 13.008 9.981 14 8 14c-1.981 0-3.671-.992-4.933-2.078C1.797 10.83.88 9.576.43 8.898a1.62 1.62 0 0 1 0-1.798c.45-.677 1.367-1.931 2.637-3.022C4.33 2.992 6.019 2 8 2ZM1.679 7.932a.12.12 0 0 0 0 .136c.411.622 1.241 1.75 2.366 2.717C5.176 11.758 6.527 12.5 8 12.5c1.473 0 2.825-.742 3.955-1.715 1.124-.967 1.954-2.096 2.366-2.717a.12.12 0 0 0 0-.136c-.412-.621-1.242-1.75-2.366-2.717C10.824 4.242 9.473 3.5 8 3.5c-1.473 0-2.825.742-3.955 1.715-1.124.967-1.954 2.096-2.366 2.717ZM8 10a2 2 0 1 1-.001-3.999A2 2 0 0 1 8 10Z"></path> </svg></div> <div data-view-component="true" class="TimelineItem-body"> <a class="d-inline-block" data-test-selector="pr-timeline-events-actor-avatar" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/2716369?s=40&amp;u=374de0b478358fee43af93a3b0dc08d84cd1b5d0&amp;v=4" width="20" height="20" alt="@gnoff" /></a> <a class="author Link--primary text-bold" data-test-selector="pr-timeline-events-actor-profile-link" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff">gnoff</a> requested review from <a data-hovercard-type="user" data-hovercard-url="/users/sophiebits/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sophiebits"><span class="Link--primary text-bold">sophiebits</span></a> and <a data-hovercard-type="user" data-hovercard-url="/users/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage"><span class="Link--primary text-bold">sebmarkbage</span></a> <a href="#event-9519788370" data-view-component="true" class="css-truncate css-truncate-target Link--secondary Link"><relative-time tense="past" datetime="2023-06-13T18:38:06Z" data-view-component="true">June 13, 2023 18:38</relative-time></a> </div> </div> <div class="TimelineItem js-targetable-element" data-team-hovercards-enabled id="event-9519789026"> <div class="TimelineItem-badge "> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-tag color-fg-inherit"> <path d="M1 7.775V2.75C1 1.784 1.784 1 2.75 1h5.025c.464 0 .91.184 1.238.513l6.25 6.25a1.75 1.75 0 0 1 0 2.474l-5.026 5.026a1.75 1.75 0 0 1-2.474 0l-6.25-6.25A1.752 1.752 0 0 1 1 7.775Zm1.5 0c0 .066.026.13.073.177l6.25 6.25a.25.25 0 0 0 .354 0l5.025-5.025a.25.25 0 0 0 0-.354l-6.25-6.25a.25.25 0 0 0-.177-.073H2.75a.25.25 0 0 0-.25.25ZM6 5a1 1 0 1 1 0 2 1 1 0 0 1 0-2Z"></path> </svg> </div> <div class="TimelineItem-body"> <a class="d-inline-block" data-hovercard-type="user" data-hovercard-url="/users/facebook-github-bot/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/facebook-github-bot"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/6422482?s=40&amp;u=1e8724230d8d2a259d754a1b580af5e52db552f4&amp;v=4" width="20" height="20" alt="@facebook-github-bot" /></a> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/facebook-github-bot/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/facebook-github-bot">facebook-github-bot</a> added the <a id="label-23f47d" href="/facebook/react/labels/React%20Core%20Team" data-name="React Core Team" style="--label-r:145;--label-g:73;--label-b:209;--label-h:271;--label-s:59;--label-l:55;" data-view-component="true" class="IssueLabel hx_IssueLabel d-inline-block v-align-middle"> React Core Team </a> <tool-tip id="tooltip-555af29e-f17d-4e0a-9895-907df0c1903a" for="label-23f47d" popover="manual" data-direction="s" data-type="description" data-view-component="true" class="sr-only position-absolute">Opened by a member of the React Core Team</tool-tip> label <a href="#event-9519789026" class="Link--secondary"><relative-time datetime="2023-06-13T18:38:11Z" class="no-wrap">Jun 13, 2023</relative-time></a> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="IC_kwDOAJy2Ks5ewxTF"> <div class="TimelineItem js-comment-container" data-gid="IC_kwDOAJy2Ks5ewxTF" data-url="/facebook/react/comments/IC_kwDOAJy2Ks5ewxTF/partials/timeline_issue_comment" > <div class="avatar-parent-child TimelineItem-avatar d-none d-md-block"> <a class="d-inline-block" data-hovercard-type="user" data-hovercard-url="/users/react-sizebot/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/react-sizebot"><img class="avatar rounded-2 avatar-user" src="https://avatars.githubusercontent.com/u/123762883?s=80&amp;v=4" width="40" height="40" alt="@react-sizebot" /></a> </div> <div class=" timeline-comment-group js-minimizable-comment-group js-targetable-element TimelineItem-body my-0 " id="issuecomment-1589843141"> <div class="ml-n3 timeline-comment unminimized-comment comment previewable-edit js-task-list-container js-comment timeline-comment--caret" data-body-version="896246ad455314235dfa1006082cd85df04122c562659080508f42793363d8c9"> <div class="timeline-comment-header clearfix d-flex" data-morpheus-enabled="false"> <div class="timeline-comment-actions flex-shrink-0 d-flex flex-items-center"> <details class="details-overlay details-reset position-relative d-inline-block"> <summary data-view-component="true" class="timeline-comment-action Link--secondary Button--link Button--medium Button"> <span class="Button-content"> <span class="Button-label"><svg aria-label="Show options" role="img" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-kebab-horizontal"> <path d="M8 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3ZM1.5 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Zm13 0a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path> </svg></span> </span> </summary> <details-menu class="dropdown-menu dropdown-menu-sw show-more-popover color-fg-default" style="width:185px" src="" preload > <span data-view-component="true"> <clipboard-copy aria-label="Copy link" for="issuecomment-1589843141-permalink" role="menuitem" data-view-component="true" class="dropdown-item btn-link"> Copy link </clipboard-copy> <div aria-live="polite" aria-atomic="true" class="sr-only" data-clipboard-copy-feedback></div> </span> </details-menu> </details> </div> <div class="d-none d-sm-flex"> </div> <h3 class="f5 text-normal" style="flex: 1 1 auto"> <div> <strong> <a class="author Link--primary text-bold css-overflow-wrap-anywhere " show_full_name="false" data-hovercard-type="user" data-hovercard-url="/users/react-sizebot/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/react-sizebot">react-sizebot</a> </strong> commented <a href="#issuecomment-1589843141" id="issuecomment-1589843141-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-13T18:41:46Z" class="no-wrap">Jun 13, 2023</relative-time></a> <span class="js-comment-edit-history"> <span class="d-inline-block color-fg-muted">&#8226;</span> <details class="details-overlay details-reset d-inline-block dropdown hx_dropdown-fullscreen"> <summary class="btn-link no-underline color-fg-muted js-notice"> <div class="position-relative"> <span> edited </span> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-triangle-down v-align-middle"> <path d="m4.427 7.427 3.396 3.396a.25.25 0 0 0 .354 0l3.396-3.396A.25.25 0 0 0 11.396 7H4.604a.25.25 0 0 0-.177.427Z"></path> </svg> </div> </summary> <details-menu class="dropdown-menu dropdown-menu-s width-auto py-0 js-comment-edit-history-menu" style="max-width: 352px; z-index: 99;" src="/user_content_edits/show_edit_history_log/IC_kwDOAJy2Ks5ewxTF" preload > <include-fragment class="my-3" style="min-width: 100px;" aria-label="Loading..."> <span data-view-component="true"> <svg style="box-sizing: content-box; color: var(--color-icon-primary);" width="32" height="32" viewBox="0 0 16 16" fill="none" aria-hidden="true" data-view-component="true" class="mx-auto d-block anim-rotate"> <circle cx="8" cy="8" r="7" stroke="currentColor" stroke-opacity="0.25" stroke-width="2" vector-effect="non-scaling-stroke" fill="none" /> <path d="M15 8a7.002 7.002 0 00-7-7" stroke="currentColor" stroke-width="2" stroke-linecap="round" vector-effect="non-scaling-stroke" /> </svg> <span class="sr-only">Loading</span> </span> </include-fragment> </details-menu> </details> </span> </div> </h3> </div> <div class="edit-comment-hide"> <task-lists disabled sortable> <table class="d-block user-select-contain" data-paste-markdown-skip> <tbody class="d-block"> <tr class="d-block"> <td class="d-block comment-body markdown-body js-comment-body"> <p dir="auto">Comparing: <a class="commit-link" href="https://github.com/facebook/react/compare/86acc10f2596e1a6fe2fd57a5b325de85175800b...2ac8183f05887edf383718850bcb299d005b8f87"><tt>86acc10...2ac8183</tt></a></p> <h2 dir="auto">Critical size changes</h2> <p dir="auto">Includes critical production bundles, as well as any change greater than 2%:</p> <markdown-accessiblity-table><table role="table"> <thead> <tr> <th>Name</th> <th>+/-</th> <th>Base</th> <th>Current</th> <th>+/- gzip</th> <th>Base gzip</th> <th>Current gzip</th> </tr> </thead> <tbody> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom.production.min.js</a></td> <td><strong>+0.19%</strong></td> <td>164.24 kB</td> <td>164.56 kB</td> <td>+0.20%</td> <td>51.73 kB</td> <td>51.83 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom.production.min.js</a></td> <td><strong>+0.18%</strong></td> <td>171.68 kB</td> <td>172.00 kB</td> <td>+0.18%</td> <td>53.97 kB</td> <td>54.07 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/facebook-www/ReactDOM-prod.classic.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">facebook-www/ReactDOM-prod.classic.js</a></td> <td><strong>+0.17%</strong></td> <td>570.15 kB</td> <td>571.13 kB</td> <td>+0.18%</td> <td>100.58 kB</td> <td>100.75 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/facebook-www/ReactDOM-prod.modern.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">facebook-www/ReactDOM-prod.modern.js</a></td> <td><strong>+0.18%</strong></td> <td>553.93 kB</td> <td>554.91 kB</td> <td>+0.18%</td> <td>97.75 kB</td> <td>97.93 kB</td> </tr> </tbody> </table></markdown-accessiblity-table> <h2 dir="auto">Significant size changes</h2> <p dir="auto">Includes any change greater than 0.2%:</p> <details> <summary>Expand to show</summary> <markdown-accessiblity-table><table role="table"> <thead> <tr> <th>Name</th> <th>+/-</th> <th>Base</th> <th>Current</th> <th>+/- gzip</th> <th>Base gzip</th> <th>Current gzip</th> </tr> </thead> <tbody> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server-legacy.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server-legacy.browser.production.min.js</a></td> <td><strong>+0.45%</strong></td> <td>58.18 kB</td> <td>58.44 kB</td> <td>+0.55%</td> <td>17.23 kB</td> <td>17.32 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server-legacy.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server-legacy.browser.production.min.js</a></td> <td><strong>+0.45%</strong></td> <td>58.21 kB</td> <td>58.47 kB</td> <td>+0.55%</td> <td>17.25 kB</td> <td>17.34 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/umd/react-dom-server-legacy.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/umd/react-dom-server-legacy.browser.production.min.js</a></td> <td><strong>+0.45%</strong></td> <td>58.35 kB</td> <td>58.61 kB</td> <td>+0.59%</td> <td>17.48 kB</td> <td>17.58 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/umd/react-dom-server-legacy.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/umd/react-dom-server-legacy.browser.production.min.js</a></td> <td><strong>+0.45%</strong></td> <td>58.38 kB</td> <td>58.64 kB</td> <td>+0.59%</td> <td>17.50 kB</td> <td>17.61 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/facebook-www/ReactDOMServer-prod.modern.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">facebook-www/ReactDOMServer-prod.modern.js</a></td> <td><strong>+0.44%</strong></td> <td>135.89 kB</td> <td>136.49 kB</td> <td>+0.66%</td> <td>25.24 kB</td> <td>25.40 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server.browser.production.min.js</a></td> <td><strong>+0.43%</strong></td> <td>60.26 kB</td> <td>60.52 kB</td> <td>+0.52%</td> <td>18.52 kB</td> <td>18.62 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server.browser.production.min.js</a></td> <td><strong>+0.43%</strong></td> <td>60.28 kB</td> <td>60.54 kB</td> <td>+0.51%</td> <td>18.55 kB</td> <td>18.64 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/umd/react-dom-server.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/umd/react-dom-server.browser.production.min.js</a></td> <td><strong>+0.43%</strong></td> <td>60.42 kB</td> <td>60.68 kB</td> <td>+0.53%</td> <td>18.79 kB</td> <td>18.89 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/umd/react-dom-server.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/umd/react-dom-server.browser.production.min.js</a></td> <td><strong>+0.43%</strong></td> <td>60.45 kB</td> <td>60.71 kB</td> <td>+0.53%</td> <td>18.81 kB</td> <td>18.91 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/facebook-www/ReactDOMServer-prod.classic.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">facebook-www/ReactDOMServer-prod.classic.js</a></td> <td><strong>+0.43%</strong></td> <td>139.41 kB</td> <td>140.01 kB</td> <td>+0.67%</td> <td>25.91 kB</td> <td>26.09 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/umd/react-dom-server-legacy.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/umd/react-dom-server-legacy.browser.production.min.js</a></td> <td><strong>+0.43%</strong></td> <td>60.86 kB</td> <td>61.12 kB</td> <td>+0.53%</td> <td>18.66 kB</td> <td>18.76 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server-legacy.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server-legacy.browser.production.min.js</a></td> <td><strong>+0.43%</strong></td> <td>60.69 kB</td> <td>60.95 kB</td> <td>+0.48%</td> <td>18.35 kB</td> <td>18.44 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/facebook-www/ReactDOMServerStreaming-prod.modern.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">facebook-www/ReactDOMServerStreaming-prod.modern.js</a></td> <td><strong>+0.42%</strong></td> <td>142.50 kB</td> <td>143.10 kB</td> <td>+0.60%</td> <td>26.90 kB</td> <td>27.07 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-static.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-static.browser.production.min.js</a></td> <td><strong>+0.42%</strong></td> <td>62.12 kB</td> <td>62.38 kB</td> <td>+0.50%</td> <td>19.35 kB</td> <td>19.45 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server.browser.production.min.js</a></td> <td><strong>+0.42%</strong></td> <td>62.24 kB</td> <td>62.50 kB</td> <td>+0.49%</td> <td>19.41 kB</td> <td>19.50 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/umd/react-dom-server.browser.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/umd/react-dom-server.browser.production.min.js</a></td> <td><strong>+0.42%</strong></td> <td>62.40 kB</td> <td>62.66 kB</td> <td>+0.56%</td> <td>19.65 kB</td> <td>19.76 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-static.edge.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-static.edge.production.min.js</a></td> <td><strong>+0.42%</strong></td> <td>62.45 kB</td> <td>62.71 kB</td> <td>+0.46%</td> <td>19.46 kB</td> <td>19.55 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server.bun.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server.bun.production.min.js</a></td> <td><strong>+0.41%</strong></td> <td>62.67 kB</td> <td>62.93 kB</td> <td>+0.52%</td> <td>18.95 kB</td> <td>19.05 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server.bun.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server.bun.production.min.js</a></td> <td><strong>+0.41%</strong></td> <td>62.70 kB</td> <td>62.96 kB</td> <td>+0.52%</td> <td>18.97 kB</td> <td>19.07 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server-legacy.node.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server-legacy.node.production.min.js</a></td> <td><strong>+0.41%</strong></td> <td>62.96 kB</td> <td>63.22 kB</td> <td>+0.51%</td> <td>18.79 kB</td> <td>18.89 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server-legacy.node.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server-legacy.node.production.min.js</a></td> <td><strong>+0.41%</strong></td> <td>62.99 kB</td> <td>63.25 kB</td> <td>+0.51%</td> <td>18.82 kB</td> <td>18.91 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server.edge.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server.edge.production.min.js</a></td> <td><strong>+0.40%</strong></td> <td>64.50 kB</td> <td>64.76 kB</td> <td>+0.48%</td> <td>19.95 kB</td> <td>20.04 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server.edge.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server.edge.production.min.js</a></td> <td><strong>+0.40%</strong></td> <td>64.53 kB</td> <td>64.79 kB</td> <td>+0.49%</td> <td>19.97 kB</td> <td>20.07 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server.node.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server.node.production.min.js</a></td> <td><strong>+0.40%</strong></td> <td>64.62 kB</td> <td>64.88 kB</td> <td>+0.50%</td> <td>19.98 kB</td> <td>20.08 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server.node.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server.node.production.min.js</a></td> <td><strong>+0.40%</strong></td> <td>64.65 kB</td> <td>64.91 kB</td> <td>+0.49%</td> <td>20.00 kB</td> <td>20.10 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server.bun.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server.bun.production.min.js</a></td> <td><strong>+0.40%</strong></td> <td>65.30 kB</td> <td>65.56 kB</td> <td>+0.45%</td> <td>20.11 kB</td> <td>20.20 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server-legacy.node.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server-legacy.node.production.min.js</a></td> <td><strong>+0.40%</strong></td> <td>65.58 kB</td> <td>65.84 kB</td> <td>+0.47%</td> <td>19.97 kB</td> <td>20.07 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server.edge.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server.edge.production.min.js</a></td> <td><strong>+0.39%</strong></td> <td>66.59 kB</td> <td>66.85 kB</td> <td>+0.45%</td> <td>20.87 kB</td> <td>20.96 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-static.node.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-static.node.production.min.js</a></td> <td><strong>+0.39%</strong></td> <td>66.68 kB</td> <td>66.94 kB</td> <td>+0.43%</td> <td>20.92 kB</td> <td>21.02 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server.node.production.min.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server.node.production.min.js</a></td> <td><strong>+0.39%</strong></td> <td>66.70 kB</td> <td>66.96 kB</td> <td>+0.44%</td> <td>20.90 kB</td> <td>21.00 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server.bun.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server.bun.development.js</a></td> <td><strong>+0.32%</strong></td> <td>357.55 kB</td> <td>358.70 kB</td> <td>+0.60%</td> <td>78.66 kB</td> <td>79.13 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server.bun.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server.bun.development.js</a></td> <td><strong>+0.32%</strong></td> <td>357.58 kB</td> <td>358.73 kB</td> <td>+0.60%</td> <td>78.68 kB</td> <td>79.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/umd/react-dom-server.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/umd/react-dom-server.browser.development.js</a></td> <td><strong>+0.32%</strong></td> <td>377.37 kB</td> <td>378.58 kB</td> <td>+0.60%</td> <td>80.51 kB</td> <td>80.99 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/umd/react-dom-server.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/umd/react-dom-server.browser.development.js</a></td> <td><strong>+0.32%</strong></td> <td>377.40 kB</td> <td>378.61 kB</td> <td>+0.61%</td> <td>80.53 kB</td> <td>81.02 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/facebook-www/ReactDOMServerStreaming-dev.modern.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">facebook-www/ReactDOMServerStreaming-dev.modern.js</a></td> <td><strong>+0.32%</strong></td> <td>366.80 kB</td> <td>367.98 kB</td> <td>+0.61%</td> <td>79.44 kB</td> <td>79.92 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/umd/react-dom-server-legacy.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/umd/react-dom-server-legacy.browser.development.js</a></td> <td><strong>+0.32%</strong></td> <td>377.65 kB</td> <td>378.86 kB</td> <td>+0.61%</td> <td>80.19 kB</td> <td>80.68 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/umd/react-dom-server-legacy.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/umd/react-dom-server-legacy.browser.development.js</a></td> <td><strong>+0.32%</strong></td> <td>377.68 kB</td> <td>378.89 kB</td> <td>+0.61%</td> <td>80.21 kB</td> <td>80.71 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server.browser.development.js</a></td> <td><strong>+0.32%</strong></td> <td>360.31 kB</td> <td>361.46 kB</td> <td>+0.60%</td> <td>79.56 kB</td> <td>80.04 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server.browser.development.js</a></td> <td><strong>+0.32%</strong></td> <td>360.33 kB</td> <td>361.48 kB</td> <td>+0.59%</td> <td>79.59 kB</td> <td>80.06 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server-legacy.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server-legacy.browser.development.js</a></td> <td><strong>+0.32%</strong></td> <td>360.57 kB</td> <td>361.72 kB</td> <td>+0.60%</td> <td>79.26 kB</td> <td>79.74 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server-legacy.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server-legacy.browser.development.js</a></td> <td><strong>+0.32%</strong></td> <td>360.60 kB</td> <td>361.75 kB</td> <td>+0.60%</td> <td>79.29 kB</td> <td>79.77 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server.edge.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server.edge.development.js</a></td> <td><strong>+0.32%</strong></td> <td>360.72 kB</td> <td>361.87 kB</td> <td>+0.61%</td> <td>79.68 kB</td> <td>80.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server.edge.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server.edge.development.js</a></td> <td><strong>+0.32%</strong></td> <td>360.74 kB</td> <td>361.89 kB</td> <td>+0.61%</td> <td>79.70 kB</td> <td>80.19 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server.node.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server.node.development.js</a></td> <td><strong>+0.32%</strong></td> <td>361.80 kB</td> <td>362.95 kB</td> <td>+0.60%</td> <td>79.61 kB</td> <td>80.08 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server.node.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server.node.development.js</a></td> <td><strong>+0.32%</strong></td> <td>361.83 kB</td> <td>362.98 kB</td> <td>+0.60%</td> <td>79.63 kB</td> <td>80.11 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable-semver/react-dom/cjs/react-dom-server-legacy.node.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable-semver/react-dom/cjs/react-dom-server-legacy.node.development.js</a></td> <td><strong>+0.32%</strong></td> <td>362.39 kB</td> <td>363.54 kB</td> <td>+0.60%</td> <td>79.72 kB</td> <td>80.20 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-stable/react-dom/cjs/react-dom-server-legacy.node.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-stable/react-dom/cjs/react-dom-server-legacy.node.development.js</a></td> <td><strong>+0.32%</strong></td> <td>362.42 kB</td> <td>363.57 kB</td> <td>+0.60%</td> <td>79.75 kB</td> <td>80.23 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/facebook-www/ReactDOMServer-dev.modern.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">facebook-www/ReactDOMServer-dev.modern.js</a></td> <td><strong>+0.32%</strong></td> <td>371.98 kB</td> <td>373.16 kB</td> <td>+0.64%</td> <td>80.69 kB</td> <td>81.21 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server.bun.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server.bun.development.js</a></td> <td><strong>+0.31%</strong></td> <td>367.33 kB</td> <td>368.48 kB</td> <td>+0.59%</td> <td>80.86 kB</td> <td>81.34 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/umd/react-dom-server.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/umd/react-dom-server.browser.development.js</a></td> <td><strong>+0.31%</strong></td> <td>386.99 kB</td> <td>388.20 kB</td> <td>+0.59%</td> <td>82.72 kB</td> <td>83.21 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/umd/react-dom-server-legacy.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/umd/react-dom-server-legacy.browser.development.js</a></td> <td><strong>+0.31%</strong></td> <td>387.85 kB</td> <td>389.06 kB</td> <td>+0.59%</td> <td>82.62 kB</td> <td>83.11 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-static.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-static.browser.development.js</a></td> <td><strong>+0.31%</strong></td> <td>368.81 kB</td> <td>369.96 kB</td> <td>+0.58%</td> <td>81.36 kB</td> <td>81.83 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-static.edge.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-static.edge.development.js</a></td> <td><strong>+0.31%</strong></td> <td>369.22 kB</td> <td>370.37 kB</td> <td>+0.58%</td> <td>81.47 kB</td> <td>81.94 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server.browser.development.js</a></td> <td><strong>+0.31%</strong></td> <td>369.51 kB</td> <td>370.66 kB</td> <td>+0.58%</td> <td>81.54 kB</td> <td>82.01 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server.edge.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server.edge.development.js</a></td> <td><strong>+0.31%</strong></td> <td>369.92 kB</td> <td>371.07 kB</td> <td>+0.58%</td> <td>81.65 kB</td> <td>82.12 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server-legacy.browser.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server-legacy.browser.development.js</a></td> <td><strong>+0.31%</strong></td> <td>370.36 kB</td> <td>371.51 kB</td> <td>+0.59%</td> <td>81.46 kB</td> <td>81.94 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-static.node.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-static.node.development.js</a></td> <td><strong>+0.31%</strong></td> <td>370.97 kB</td> <td>372.12 kB</td> <td>+0.58%</td> <td>81.68 kB</td> <td>82.15 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server.node.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server.node.development.js</a></td> <td><strong>+0.31%</strong></td> <td>371.01 kB</td> <td>372.16 kB</td> <td>+0.58%</td> <td>81.59 kB</td> <td>82.06 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/facebook-www/ReactDOMServer-dev.classic.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">facebook-www/ReactDOMServer-dev.classic.js</a></td> <td><strong>+0.31%</strong></td> <td>379.40 kB</td> <td>380.58 kB</td> <td>+0.60%</td> <td>82.35 kB</td> <td>82.85 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/2ac8183f05887edf383718850bcb299d005b8f87/files/oss-experimental/react-dom/cjs/react-dom-server-legacy.node.development.js?compare=86acc10f2596e1a6fe2fd57a5b325de85175800b" rel="nofollow">oss-experimental/react-dom/cjs/react-dom-server-legacy.node.development.js</a></td> <td><strong>+0.31%</strong></td> <td>372.17 kB</td> <td>373.32 kB</td> <td>+0.59%</td> <td>81.93 kB</td> <td>82.41 kB</td> </tr> </tbody> </table></markdown-accessiblity-table> </details> <p align="right" dir="auto"> Generated by 🚫 <a href="https://danger.systems/js" rel="nofollow">dangerJS</a> against <a class="commit-link" data-hovercard-type="commit" data-hovercard-url="https://github.com/facebook/react/commit/2ac8183f05887edf383718850bcb299d005b8f87/hovercard" href="https://github.com/facebook/react/commit/2ac8183f05887edf383718850bcb299d005b8f87"><tt>2ac8183</tt></a> </p> </td> </tr> </tbody> </table> </task-lists> <div class="d-flex"> <div class="pr-review-reactions"> <div data-view-component="true" class="comment-reactions js-reactions-container js-reaction-buttons-container social-reactions reactions-container d-none"> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-pick-reaction" data-turbo="false" action="/facebook/react/reactions" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="3vXMlXQR8k681UKKSvUJyicVOiEQHBXc1xd0BvjnDTrKH2TXdDxX9pFbS5ogNEhUvaINDIgOlUItG8_CF4nszg" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="IC_kwDOAJy2Ks5ewxTF"> <input type="hidden" name="input[context]" value="" > <div class="js-comment-reactions-options d-flex flex-items-center flex-row flex-wrap"> <div class="js-reactions-container"> <details class="dropdown details-reset details-overlay d-inline-block js-all-reactions-popover" hidden> <summary aria-haspopup="true" data-view-component="true" class="Button--link Button--medium Button"> <span class="Button-content"> <span class="Button-label">All reactions</span> </span> </summary> <ul class="dropdown-menu dropdown-menu-se"> </ul> </details> </div> </div> </form></div> </div> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-comment-update" id="issuecomment-1589843141-edit-form" data-turbo="false" action="/facebook/react/issue_comments/1589843141" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" data-csrf="true" name="authenticity_token" value="yqHgOwky7DbbfKN/FoLkiUvaxZ3r27k15fAp4Mjjv0E6dlom7OCF+fgoje42bgrGArA/wR9PBdd+g0sovE2Eww==" /> <include-fragment loading="lazy" src="/facebook/react/issue_comments/1589843141/edit_form?textarea_id=issuecomment-1589843141-body&amp;comment_context=" class="previewable-comment-form js-comment-edit-form-deferred-include-fragment" > <p class="text-center mt-3" data-hide-on-error> <span data-view-component="true"> <svg aria-label="Loading..." style="box-sizing: content-box; color: var(--color-icon-primary);" width="32" height="32" viewBox="0 0 16 16" fill="none" role="img" data-view-component="true" class="anim-rotate"> <circle cx="8" cy="8" r="7" stroke="currentColor" stroke-opacity="0.25" stroke-width="2" vector-effect="non-scaling-stroke" fill="none" /> <path d="M15 8a7.002 7.002 0 00-7-7" stroke="currentColor" stroke-width="2" stroke-linecap="round" vector-effect="non-scaling-stroke" /> </svg></span> </p> <p class="ml-1 mb-2 mt-2" data-show-on-error hidden> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-alert"> <path d="M6.457 1.047c.659-1.234 2.427-1.234 3.086 0l6.082 11.378A1.75 1.75 0 0 1 14.082 15H1.918a1.75 1.75 0 0 1-1.543-2.575Zm1.763.707a.25.25 0 0 0-.44 0L1.698 13.132a.25.25 0 0 0 .22.368h12.164a.25.25 0 0 0 .22-.368Zm.53 3.996v2.5a.75.75 0 0 1-1.5 0v-2.5a.75.75 0 0 1 1.5 0ZM9 11a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> Sorry, something went wrong. </p> </include-fragment> </form> </div> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="HRFPE_lADOAJy2Ks5oohy1zwAAAAI3ej07"> <div id="event-9520946827" data-view-component="true" class="TimelineItem js-targetable-element"> <div data-view-component="true" class="TimelineItem-badge"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-repo-push"> <path d="M1 2.5A2.5 2.5 0 0 1 3.5 0h8.75a.75.75 0 0 1 .75.75v3.5a.75.75 0 0 1-1.5 0V1.5h-8a1 1 0 0 0-1 1v6.708A2.493 2.493 0 0 1 3.5 9h3.25a.75.75 0 0 1 0 1.5H3.5a1 1 0 0 0 0 2h5.75a.75.75 0 0 1 0 1.5H3.5A2.5 2.5 0 0 1 1 11.5Zm13.23 7.79h-.001l-1.224-1.224v6.184a.75.75 0 0 1-1.5 0V9.066L10.28 10.29a.75.75 0 0 1-1.06-1.061l2.505-2.504a.75.75 0 0 1 1.06 0L15.29 9.23a.751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018Z"></path> </svg></div> <div data-view-component="true" class="TimelineItem-body"> <a class="d-inline-block" data-test-selector="pr-timeline-events-actor-avatar" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/2716369?s=40&amp;u=374de0b478358fee43af93a3b0dc08d84cd1b5d0&amp;v=4" width="20" height="20" alt="@gnoff" /></a> <a class="author Link--primary text-bold" data-test-selector="pr-timeline-events-actor-profile-link" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff">gnoff</a> <a data-hydro-click="{&quot;event_type&quot;:&quot;force_push_timeline_diff.click&quot;,&quot;payload&quot;:{&quot;pull_request_id&quot;:1391128438,&quot;repository_id&quot;:10270250,&quot;event_id&quot;:9520946827,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="6ab21d03205033bbfca21b27c889c9400f2ab39c6988a8da2b644da1d19bcd70" href="/facebook/react/compare/8d8bcde1c21293145db05219b024eebde910ec97..80a7f09da8c426364930520c59ef941b1ee9c81e" data-view-component="true" class="Link--inTextBlock Link--secondary Link">force-pushed</a> the <span class="commit-ref user-select-contain"> <span > <span class=" css-truncate-target">preload-imagesrcset</span> </span> </span> branch 3 times, most recently from <a href="/facebook/react/commit/8d8bcde1c21293145db05219b024eebde910ec97" data-view-component="true" class="Link--primary Link text-bold"><code>8d8bcde</code></a> to <a href="/facebook/react/commit/80a7f09da8c426364930520c59ef941b1ee9c81e" data-view-component="true" class="Link--primary Link text-bold"><code>80a7f09</code></a> <a href="/facebook/react/compare/8d8bcde1c21293145db05219b024eebde910ec97..80a7f09da8c426364930520c59ef941b1ee9c81e" data-hydro-click="{&quot;event_type&quot;:&quot;force_push_timeline_diff.click&quot;,&quot;payload&quot;:{&quot;pull_request_id&quot;:1391128438,&quot;repository_id&quot;:10270250,&quot;event_id&quot;:9520946827,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="6ab21d03205033bbfca21b27c889c9400f2ab39c6988a8da2b644da1d19bcd70" data-view-component="true" class="Button--invisible Button--small Button Button--invisible-noVisuals float-right ml-2"> <span class="Button-content"> <span class="Button-label">Compare</span> </span> </a> <a href="#event-9520946827" data-view-component="true" class="css-truncate css-truncate-target Link--secondary Link"><relative-time tense="past" datetime="2023-06-13T21:03:45Z" data-view-component="true">June 13, 2023 21:03</relative-time></a> </div> </div> <div class="TimelineItem"> <div class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </div> <div class="TimelineItem-body" > <div > <a class="d-inline-block" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/2716369?s=40&amp;u=374de0b478358fee43af93a3b0dc08d84cd1b5d0&amp;v=4" width="20" height="20" alt="@gnoff" /></a> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff">gnoff</a> mentioned this pull request <a class="Link--secondary" href="#ref-pullrequest-1700978841" > <relative-time datetime="2023-06-14T15:50:17Z" class="no-wrap">Jun 14, 2023</relative-time> </a> </div> <div class="mt-2 d-flex flex-items-start flex-column flex-md-row"> <div class="flex-auto wb-break-word" id="ref-pullrequest-1700978841" > <a href="/facebook/react/pull/26795" class="Link--primary f4 text-bold markdown-title" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26795/hovercard"> [Flight] Preinitialize Imports <span class="color-fg-muted text-normal" >#26795</span> </a> </div> <div class="flex-shrink-0 my-1 my-md-0 ml-md-3"> <span title="Status: Closed" data-view-component="true" class="State State--closed State--small"> <svg height="14" class="octicon octicon-git-pull-request-closed" viewBox="0 0 16 16" version="1.1" width="14" aria-hidden="true"><path d="M3.25 1A2.25 2.25 0 0 1 4 5.372v5.256a2.251 2.251 0 1 1-1.5 0V5.372A2.251 2.251 0 0 1 3.25 1Zm9.5 5.5a.75.75 0 0 1 .75.75v3.378a2.251 2.251 0 1 1-1.5 0V7.25a.75.75 0 0 1 .75-.75Zm-2.03-5.273a.75.75 0 0 1 1.06 0l.97.97.97-.97a.748.748 0 0 1 1.265.332.75.75 0 0 1-.205.729l-.97.97.97.97a.751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018l-.97-.97-.97.97a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l.97-.97-.97-.97a.75.75 0 0 1 0-1.06ZM2.5 3.25a.75.75 0 1 0 1.5 0 .75.75 0 0 0-1.5 0ZM3.25 12a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Zm9.5 0a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Z"></path></svg> Closed </span> </div> </div> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="PRR_kwDOAJy2Ks5YWhAA"> <div class=""> <div id="pullrequestreview-1482297344" class="js-comment js-updatable-content js-socket-channel js-targetable-element js-minimize-container" data-gid="PRR_kwDOAJy2Ks5YWhAA" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0X3JldmlldzoxNDgyMjk3MzQ0IiwidCI6MTczNDEzMjEwM30=--af8ada386ed3990242f0eb4e963b2df3d073d3f2cb0759d1e5fb105b3fc6420f" data-url="/facebook/react/pull/26940/partials/reviews/1482297344" > <div data-view-component="true" class="TimelineItem"> <a href="/sebmarkbage" data-view-component="true" class="TimelineItem-avatar avatar circle lh-0 Link"><img data-hovercard-type="user" data-hovercard-url="/users/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" src="https://avatars.githubusercontent.com/u/63648?s=60&amp;v=4" alt="sebmarkbage" size="40" height="40" width="40" data-view-component="true" /></a> <div aria-role="image" data-view-component="true" class="TimelineItem-badge color-bg-success-emphasis color-fg-on-emphasis"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-check"> <path d="M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0Z"></path> </svg></div> <div data-view-component="true" class="TimelineItem-body d-flex flex-column flex-md-row flex-justify-start"> <div class="flex-auto flex-md-self-center"> <strong> <a class="author Link--primary text-bold css-overflow-wrap-anywhere " show_full_name="false" data-hovercard-type="user" data-hovercard-url="/users/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage">sebmarkbage</a> </strong> approved these changes <span class="color-fg-muted"> <a href="#pullrequestreview-1482297344" class="js-timestamp Link--secondary" id="pullrequestreview-1482297344-permalink"> <relative-time datetime="2023-06-15T19:58:07Z" class="no-wrap">Jun 15, 2023</relative-time> </a> </span> </div> <div class="ml-md-2 mt-md-0 mt-2 flex-shrink-0"> <a href="/facebook/react/pull/26940/files" data-view-component="true" class="Button--invisible Button--small Button Button--invisible-noVisuals ml-0 ml-md-2"> <span class="Button-content"> <span class="Button-label">View reviewed changes</span> </span> </a> </div> </div> </div> <div data-view-component="true" class="TimelineItem pt-0"> <div data-view-component="true" class="TimelineItem-body"> <div id="pullrequestreview-1482297344" class="timeline-comment-group js-minimizable-comment-group js-targetable-element my-0 comment previewable-edit js-task-list-container js-comment timeline-comment--caret timeline-comment--caret-nw timeline-comment ml-n3 unminimized-comment"> <div class="timeline-comment-header clearfix d-flex" data-morpheus-enabled="false"> <div class="timeline-comment-actions flex-shrink-0 d-flex flex-items-center"> <details class="details-overlay details-reset position-relative d-inline-block"> <summary data-view-component="true" class="timeline-comment-action Link--secondary Button--link Button--medium Button"> <span class="Button-content"> <span class="Button-label"><svg aria-label="Show options" role="img" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-kebab-horizontal"> <path d="M8 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3ZM1.5 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Zm13 0a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path> </svg></span> </span> </summary> <details-menu class="dropdown-menu dropdown-menu-sw show-more-popover color-fg-default" style="width:185px" src="" preload > <span data-view-component="true"> <clipboard-copy aria-label="Copy link" for="pullrequestreview-1482297344-permalink" role="menuitem" data-view-component="true" class="dropdown-item btn-link"> Copy link </clipboard-copy> <div aria-live="polite" aria-atomic="true" class="sr-only" data-clipboard-copy-feedback></div> </span> </details-menu> </details> </div> <div class="d-none d-sm-flex"> <span aria-label="This user has been invited to collaborate on the react repository." data-view-component="true" class="tooltipped tooltipped-n"> <span data-view-component="true" class="Label ml-1">Collaborator</span> </span> </div> <h3 class="f5 text-normal" style="flex: 1 1 auto"> <div> <img src="https://avatars.githubusercontent.com/u/63648?s=48&amp;v=4" alt="@sebmarkbage" size="24" height="24" width="24" data-view-component="true" class="avatar circle d-inline-block d-md-none mr-2" /> <strong> <a class="author Link--primary text-bold css-overflow-wrap-anywhere " show_full_name="false" data-hovercard-type="user" data-hovercard-url="/users/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage">sebmarkbage</a> </strong> left a comment <span class="js-comment-edit-history"> <span class="d-inline-block color-fg-muted">&#8226;</span> <details class="details-overlay details-reset d-inline-block dropdown hx_dropdown-fullscreen"> <summary class="btn-link no-underline color-fg-muted js-notice"> <div class="position-relative"> <span> edited </span> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-triangle-down v-align-middle"> <path d="m4.427 7.427 3.396 3.396a.25.25 0 0 0 .354 0l3.396-3.396A.25.25 0 0 0 11.396 7H4.604a.25.25 0 0 0-.177.427Z"></path> </svg> </div> </summary> <details-menu class="dropdown-menu dropdown-menu-s width-auto py-0 js-comment-edit-history-menu" style="max-width: 352px; z-index: 99;" src="/user_content_edits/show_edit_history_log/PRR_kwDOAJy2Ks5YWhAA" preload > <include-fragment class="my-3" style="min-width: 100px;" aria-label="Loading..."> <span data-view-component="true"> <svg style="box-sizing: content-box; color: var(--color-icon-primary);" width="32" height="32" viewBox="0 0 16 16" fill="none" aria-hidden="true" data-view-component="true" class="mx-auto d-block anim-rotate"> <circle cx="8" cy="8" r="7" stroke="currentColor" stroke-opacity="0.25" stroke-width="2" vector-effect="non-scaling-stroke" fill="none" /> <path d="M15 8a7.002 7.002 0 00-7-7" stroke="currentColor" stroke-width="2" stroke-linecap="round" vector-effect="non-scaling-stroke" /> </svg> <span class="sr-only">Loading</span> </span> </include-fragment> </details-menu> </details> </span> </div> </h3> </div> <a href="#pullrequestreview-1482297344" class="d-none"></a> <div class="edit-comment-hide"> <div class="js-minimize-comment d-none"> <div hidden="hidden" data-view-component="true" class="js-comment-show-on-error flash flash-error flash-full"> <button class="flash-close js-comment-hide-minimize-form" type="button"> <svg aria-label="Cancel hiding comment" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> </button> <p>There was a problem hiding this comment.</p> </div> <div data-view-component="true" class="js-comment-hide-on-error flash flash-warn flash-full"> <button class="flash-close js-comment-hide-minimize-form" type="button"> <svg aria-label="Cancel hiding comment" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> </button> <h3 class="f4">Choose a reason for hiding this comment</h3> <p class="mb-3"> The reason will be displayed to describe this comment to others. <a class="Link--inTextBlock" href="https://docs.github.com/articles/managing-disruptive-comments/#hiding-a-comment" aria-label="Learn more about hiding disruptive comments">Learn more</a>. </p> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-timeline-comment-minimize d-md-inline-block d-flex" data-turbo="false" action="/facebook/react/pull/26940/reviews/1482297344/minimize" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="bvNYnH4L8f5fjS21JEbeuyt_l_7ON08a8uVGge5xVFetEOQHJUi93HRpc4f44kI3C2tCLR08F9-FxB3URhKtIg" autocomplete="off" /> <select name="classifier" class="form-select mr-2" aria-label="Reason" required> <option value> Choose a reason </option> <option value="SPAM">Spam</option> <option value="ABUSE">Abuse</option> <option value="OFF_TOPIC">Off Topic</option> <option value="OUTDATED">Outdated</option> <option value="DUPLICATE">Duplicate</option> <option value="RESOLVED">Resolved</option> </select> <button type="submit" data-view-component="true" class="Button--secondary Button--medium Button d-inline-block"> <span class="Button-content"> <span class="Button-label">Hide <span class="d-md-inline-block d-none">comment</span></span> </span> </button> </form> </div></div> <task-lists disabled sortable> <div class="comment-body markdown-body js-comment-body soft-wrap css-overflow-wrap-anywhere user-select-contain d-block"> <p dir="auto">As discussed, we're just going to never render "href" when imagesrcset is specified because that will double load in Safari which is worse than missing a preload in very old browsers. However, if Safari fixes that, we'll be able to reenable it so the option will still be there in our API.</p> </div> </task-lists> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-comment-update" data-type="json" data-turbo="false" action="/facebook/react/pull/26940/reviews/1482297344/update" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="fJNgx63odP371s4xIJQnlhgWEF4-eVhlgAJU98iKiWt0dy-JhHTH0F4pzYkwPPDcMR40SuA-NRleTV_2YkGlDw" autocomplete="off" /> <include-fragment loading="lazy" src="/facebook/react/pull/26940/reviews/1482297344/update/edit_form?textarea_id=pullrequestreview-1482297344-body&amp;comment_context=discussion" class="previewable-comment-form js-comment-edit-form-deferred-include-fragment" > <p class="text-center mt-3" data-hide-on-error> <span data-view-component="true"> <svg aria-label="Loading..." style="box-sizing: content-box; color: var(--color-icon-primary);" width="32" height="32" viewBox="0 0 16 16" fill="none" role="img" data-view-component="true" class="anim-rotate"> <circle cx="8" cy="8" r="7" stroke="currentColor" stroke-opacity="0.25" stroke-width="2" vector-effect="non-scaling-stroke" fill="none" /> <path d="M15 8a7.002 7.002 0 00-7-7" stroke="currentColor" stroke-width="2" stroke-linecap="round" vector-effect="non-scaling-stroke" /> </svg></span> </p> <p class="ml-1 mb-2 mt-2" data-show-on-error hidden> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-alert"> <path d="M6.457 1.047c.659-1.234 2.427-1.234 3.086 0l6.082 11.378A1.75 1.75 0 0 1 14.082 15H1.918a1.75 1.75 0 0 1-1.543-2.575Zm1.763.707a.25.25 0 0 0-.44 0L1.698 13.132a.25.25 0 0 0 .22.368h12.164a.25.25 0 0 0 .22-.368Zm.53 3.996v2.5a.75.75 0 0 1-1.5 0v-2.5a.75.75 0 0 1 1.5 0ZM9 11a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> Sorry, something went wrong. </p> </include-fragment> </form> <div class="pr-review-reactions"> <div data-view-component="true" class="comment-reactions js-reactions-container js-reaction-buttons-container social-reactions reactions-container has-reactions d-flex"> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-pick-reaction" data-turbo="false" action="/facebook/react/reactions" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="m8gfI5xeBoWq39iLDbpnfE4s_IhlTJxGgMFJe_N4imiPIrdhnHOjPYdR0Ztneybi1JvLpf1eHNh6zfK_HBZrnA" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="PRR_kwDOAJy2Ks5YWhAA"> <div class="js-comment-reactions-options d-flex flex-items-center flex-row flex-wrap"> <button name="input[content]" id="reactions--reaction_button_component-e84f51" value="THUMBS_UP react" data-button-index-position="0" data-reaction-label="+1" data-reaction-content="+1" aria-pressed="false" aria-label="thumbs up (1): sebmarkbage, 07:58PM on June 15, 2023" type="submit" disabled="disabled" data-view-component="true" class="social-reaction-summary-item js-reaction-group-button btn-link d-flex no-underline color-fg-muted flex-items-baseline mr-2"> <g-emoji alias="+1" fallback-src="https://github.githubassets.com/assets/1f44d-41cb66fe1e22.png" class="social-button-emoji">👍</g-emoji> <span class="js-discussion-reaction-group-count">1</span> </button> <tool-tip id="tooltip-9bb3bb41-ca40-4548-8b2b-936baffab563" for="reactions--reaction_button_component-e84f51" popover="manual" data-direction="n" data-type="description" data-view-component="true" class="sr-only position-absolute">styfle reacted with thumbs up emoji</tool-tip> <div class="js-reactions-container"> <details class="dropdown details-reset details-overlay d-inline-block js-all-reactions-popover" hidden> <summary aria-haspopup="true" data-view-component="true" class="Button--link Button--medium Button"> <span class="Button-content"> <span class="Button-label">All reactions</span> </span> </summary> <ul class="dropdown-menu dropdown-menu-se"> <li class="dropdown-item" aria-label="styfle reacted with thumbs up emoji"> <g-emoji alias="+1" fallback-src="https://github.githubassets.com/assets/1f44d-41cb66fe1e22.png" class="social-button-emoji mr-2">👍</g-emoji> <span>1 reaction</span> </li> </ul> </details> </div> </div> </form></div> </div> </div> </div> </div> <div data-view-component="true" class="TimelineItem py-0 pl-4"> <div data-view-component="true" class="TimelineItem-body my-0"> </div> </div> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="HRFPE_lADOAJy2Ks5oohy1zwAAAAI47SAQ"> <div id="event-9545128722" data-view-component="true" class="TimelineItem js-targetable-element"> <div data-view-component="true" class="TimelineItem-badge"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-repo-push"> <path d="M1 2.5A2.5 2.5 0 0 1 3.5 0h8.75a.75.75 0 0 1 .75.75v3.5a.75.75 0 0 1-1.5 0V1.5h-8a1 1 0 0 0-1 1v6.708A2.493 2.493 0 0 1 3.5 9h3.25a.75.75 0 0 1 0 1.5H3.5a1 1 0 0 0 0 2h5.75a.75.75 0 0 1 0 1.5H3.5A2.5 2.5 0 0 1 1 11.5Zm13.23 7.79h-.001l-1.224-1.224v6.184a.75.75 0 0 1-1.5 0V9.066L10.28 10.29a.75.75 0 0 1-1.06-1.061l2.505-2.504a.75.75 0 0 1 1.06 0L15.29 9.23a.751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018Z"></path> </svg></div> <div data-view-component="true" class="TimelineItem-body"> <a class="d-inline-block" data-test-selector="pr-timeline-events-actor-avatar" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/2716369?s=40&amp;u=374de0b478358fee43af93a3b0dc08d84cd1b5d0&amp;v=4" width="20" height="20" alt="@gnoff" /></a> <a class="author Link--primary text-bold" data-test-selector="pr-timeline-events-actor-profile-link" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff">gnoff</a> <a data-hydro-click="{&quot;event_type&quot;:&quot;force_push_timeline_diff.click&quot;,&quot;payload&quot;:{&quot;pull_request_id&quot;:1391128438,&quot;repository_id&quot;:10270250,&quot;event_id&quot;:9545128722,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="655b9c0dfd3f40f9038982d0473d56b3d5a285114c5ba93e62153396a0129db9" href="/facebook/react/compare/0ec641d41eaa3af102acb3f02789993335facc5d..f0e6dbd9755ad63d3c4656ce050f6e67dfbd2d34" data-view-component="true" class="Link--inTextBlock Link--secondary Link">force-pushed</a> the <span class="commit-ref user-select-contain"> <span > <span class=" css-truncate-target">preload-imagesrcset</span> </span> </span> branch 3 times, most recently from <a href="/facebook/react/commit/0ec641d41eaa3af102acb3f02789993335facc5d" data-view-component="true" class="Link--primary Link text-bold"><code>0ec641d</code></a> to <a href="/facebook/react/commit/f0e6dbd9755ad63d3c4656ce050f6e67dfbd2d34" data-view-component="true" class="Link--primary Link text-bold"><code>f0e6dbd</code></a> <a href="/facebook/react/compare/0ec641d41eaa3af102acb3f02789993335facc5d..f0e6dbd9755ad63d3c4656ce050f6e67dfbd2d34" data-hydro-click="{&quot;event_type&quot;:&quot;force_push_timeline_diff.click&quot;,&quot;payload&quot;:{&quot;pull_request_id&quot;:1391128438,&quot;repository_id&quot;:10270250,&quot;event_id&quot;:9545128722,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="655b9c0dfd3f40f9038982d0473d56b3d5a285114c5ba93e62153396a0129db9" data-view-component="true" class="Button--invisible Button--small Button Button--invisible-noVisuals float-right ml-2"> <span class="Button-content"> <span class="Button-label">Compare</span> </span> </a> <a href="#event-9545128722" data-view-component="true" class="css-truncate css-truncate-target Link--secondary Link"><relative-time tense="past" datetime="2023-06-15T21:33:19Z" data-view-component="true">June 15, 2023 21:33</relative-time></a> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="C_kwDOCUPMLdoAKDJhYzgxODNmMDU4ODdlZGYzODM3MTg4NTBiY2IyOTlkMDA1YjhmODc"> <div> <div > <div data-view-component="true" class="TimelineItem TimelineItem--condensed"> <div data-view-component="true" class="TimelineItem-badge"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-git-commit"> <path d="M11.93 8.5a4.002 4.002 0 0 1-7.86 0H.75a.75.75 0 0 1 0-1.5h3.32a4.002 4.002 0 0 1 7.86 0h3.32a.75.75 0 0 1 0 1.5Zm-1.43-.75a2.5 2.5 0 1 0-5 0 2.5 2.5 0 0 0 5 0Z"></path> </svg></div> <div data-view-component="true" class="TimelineItem-body"> <div class="js-details-container Details js-socket-channel js-updatable-content"> <div class="d-flex flex-md-row flex-column"> <div class="d-flex flex-auto"> <div class="AvatarStack flex-self-start " > <div class="AvatarStack-body" > <a class="avatar avatar-user" style="width:20px;height:20px;" data-test-selector="commits-avatar-stack-avatar-link" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/2716369?s=40&amp;v=4" width="20" height="20" alt="@gnoff" class=" avatar-user" /> </a> </div> </div> <div class="pr-1 flex-auto min-width-0" > <code> <a title="extends image preloading to accept imagesrcset and imagesizes to handle cases where srcset and sizes are used over src. Normally we key off an href however in the case of responsive images it is possible that no src attribute is desired. Right now this happens most prominently with Safari which does understand srcset for the img tag but not for the link preload tag. Because of this it can be detrimental to preload with a fallback src since Safari will end up downloading the wrong image 100% of the time. The solution to this is to allow the user to omit the href if they provide imagesrcset (and optionally) imagesizes. Effectively the key for image preloads will become the union of src (href), imagesrcset, and imagesizes." data-pjax="true" class="Link--secondary markdown-title" href="/facebook/react/pull/26940/commits/2ac8183f05887edf383718850bcb299d005b8f87">extends image preloading to accept imagesrcset and imagesizes to hand…</a> </code> <span class="hidden-text-expander inline"> <button aria-expanded="false" type="button" data-view-component="true" class="ellipsis-expander js-details-target btn"> &hellip; </button> </span> </div> <div class="pr-1 d-md-inline-block d-none"> <batch-deferred-content class="d-inline-block" data-url="/commits/badges"> <input type="hidden" name="id" value="C_kwDOCUPMLdoAKDJhYzgxODNmMDU4ODdlZGYzODM3MTg4NTBiY2IyOTlkMDA1YjhmODc" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="badge_size" value="small" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="dropdown_direction" value="s" data-targets="batch-deferred-content.inputs" autocomplete="off" /> </batch-deferred-content> </div> <div class="pr-1 flex-shrink-0" style="width: 16px;"> <div class="js-socket-channel js-updatable-content" data-channel="eyJjIjoicmVwbzoxMDI3MDI1MDpjb21taXQ6MmFjODE4M2YwNTg4N2VkZjM4MzcxODg1MGJjYjI5OWQwMDViOGY4NyIsInQiOjE3MzQxMzIxMDN9--e7f36a72be40db3a9c96b036f32ac3b01174582917801c6743b6272822d3ff5a" data-url="/facebook/react/pull/26940/partials/commit_status_icon?oid=2ac8183f05887edf383718850bcb299d005b8f87"> <batch-deferred-content class="d-inline-block" data-url="/facebook/react/commits/checks-statuses-rollups"> <input type="hidden" name="oid" value="2ac8183f05887edf383718850bcb299d005b8f87" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="dropdown_direction" value="w" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="disable_live_updates" value="false" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <div class="commit-build-statuses"> <span class="Skeleton d-inline-block" style="width:12px; height:12px;"></span> </div> </batch-deferred-content> </div> </div> <div class="text-right ml-1"> <code> <a href="/facebook/react/pull/26940/commits/2ac8183f05887edf383718850bcb299d005b8f87" class="Link--secondary">2ac8183</a> </code> </div> </div> </div> <div class="Details-content--hidden mt-2"> <pre class="color-fg-muted ws-pre-wrap">…le cases where srcset and sizes are used over src. Normally we key off an href however in the case of responsive images it is possible that no src attribute is desired. Right now this happens most prominently with Safari which does understand srcset for the img tag but not for the link preload tag. Because of this it can be detrimental to preload with a fallback src since Safari will end up downloading the wrong image 100% of the time. The solution to this is to allow the user to omit the href if they provide imagesrcset (and optionally) imagesizes. Effectively the key for image preloads will become the union of src (href), imagesrcset, and imagesizes.</pre> </div> </div> </div> </div> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="HRFPE_lADOAJy2Ks5oohy1zwAAAAI479d5"> <div id="event-9545176953" data-view-component="true" class="TimelineItem js-targetable-element"> <div data-view-component="true" class="TimelineItem-badge"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-repo-push"> <path d="M1 2.5A2.5 2.5 0 0 1 3.5 0h8.75a.75.75 0 0 1 .75.75v3.5a.75.75 0 0 1-1.5 0V1.5h-8a1 1 0 0 0-1 1v6.708A2.493 2.493 0 0 1 3.5 9h3.25a.75.75 0 0 1 0 1.5H3.5a1 1 0 0 0 0 2h5.75a.75.75 0 0 1 0 1.5H3.5A2.5 2.5 0 0 1 1 11.5Zm13.23 7.79h-.001l-1.224-1.224v6.184a.75.75 0 0 1-1.5 0V9.066L10.28 10.29a.75.75 0 0 1-1.06-1.061l2.505-2.504a.75.75 0 0 1 1.06 0L15.29 9.23a.751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018Z"></path> </svg></div> <div data-view-component="true" class="TimelineItem-body"> <a class="d-inline-block" data-test-selector="pr-timeline-events-actor-avatar" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/2716369?s=40&amp;u=374de0b478358fee43af93a3b0dc08d84cd1b5d0&amp;v=4" width="20" height="20" alt="@gnoff" /></a> <a class="author Link--primary text-bold" data-test-selector="pr-timeline-events-actor-profile-link" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff">gnoff</a> <a data-hydro-click="{&quot;event_type&quot;:&quot;force_push_timeline_diff.click&quot;,&quot;payload&quot;:{&quot;pull_request_id&quot;:1391128438,&quot;repository_id&quot;:10270250,&quot;event_id&quot;:9545176953,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="e1c96e957c2df0009caad2e5f8e35f0ad5df88f361a9e49191132ab8fae9eb1a" href="/facebook/react/compare/f0e6dbd9755ad63d3c4656ce050f6e67dfbd2d34..2ac8183f05887edf383718850bcb299d005b8f87" data-view-component="true" class="Link--inTextBlock Link--secondary Link">force-pushed</a> the <span class="commit-ref user-select-contain"> <span > <span class=" css-truncate-target">preload-imagesrcset</span> </span> </span> branch from <a href="/facebook/react/commit/f0e6dbd9755ad63d3c4656ce050f6e67dfbd2d34" data-view-component="true" class="Link--primary Link text-bold"><code>f0e6dbd</code></a> to <a href="/facebook/react/commit/2ac8183f05887edf383718850bcb299d005b8f87" data-view-component="true" class="Link--primary Link text-bold"><code>2ac8183</code></a> <a href="/facebook/react/compare/f0e6dbd9755ad63d3c4656ce050f6e67dfbd2d34..2ac8183f05887edf383718850bcb299d005b8f87" data-hydro-click="{&quot;event_type&quot;:&quot;force_push_timeline_diff.click&quot;,&quot;payload&quot;:{&quot;pull_request_id&quot;:1391128438,&quot;repository_id&quot;:10270250,&quot;event_id&quot;:9545176953,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="e1c96e957c2df0009caad2e5f8e35f0ad5df88f361a9e49191132ab8fae9eb1a" data-view-component="true" class="Button--invisible Button--small Button Button--invisible-noVisuals float-right ml-2"> <span class="Button-content"> <span class="Button-label">Compare</span> </span> </a> <a href="#event-9545176953" data-view-component="true" class="css-truncate css-truncate-target Link--secondary Link"><relative-time tense="past" datetime="2023-06-15T21:41:01Z" data-view-component="true">June 15, 2023 21:41</relative-time></a> </div> </div> <div class="TimelineItem js-details-container Details" id="event-9545223664" > <div class="TimelineItem-badge color-fg-on-emphasis color-bg-done-emphasis"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-git-merge"> <path d="M5.45 5.154A4.25 4.25 0 0 0 9.25 7.5h1.378a2.251 2.251 0 1 1 0 1.5H9.25A5.734 5.734 0 0 1 5 7.123v3.505a2.25 2.25 0 1 1-1.5 0V5.372a2.25 2.25 0 1 1 1.95-.218ZM4.25 13.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5Zm8.5-4.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5ZM5 3.25a.75.75 0 1 0 0 .005V3.25Z"></path> </svg> </div> <div class="TimelineItem-body"> <a class="d-inline-block" data-test-selector="pr-timeline-events-actor-avatar" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/2716369?s=40&amp;u=374de0b478358fee43af93a3b0dc08d84cd1b5d0&amp;v=4" width="20" height="20" alt="@gnoff" /></a> <a class="author Link--primary text-bold" data-test-selector="pr-timeline-events-actor-profile-link" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff">gnoff</a> merged commit <a href="/facebook/react/commit/fc929cf4ead35f99c4e9612a95e8a0bb8f5df25d"><code class="Link--primary text-bold">fc929cf</code></a> into <span class="commit-ref user-select-contain"> <span class="base-ref"> <span class="css-truncate-target user">facebook</span>:<span class="css-truncate-target">main</span> </span> </span> <a href="https://github.com/facebook/react/pull/26940#event-9545223664" class="Link--secondary"><relative-time datetime="2023-06-15T21:50:23Z" class="no-wrap">Jun 15, 2023</relative-time></a> </div> </div> <div class="TimelineItem-break"></div> <div id="event-9545223917" data-view-component="true" class="TimelineItem js-targetable-element"> <div data-view-component="true" class="TimelineItem-badge"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-git-branch"> <path d="M9.5 3.25a2.25 2.25 0 1 1 3 2.122V6A2.5 2.5 0 0 1 10 8.5H6a1 1 0 0 0-1 1v1.128a2.251 2.251 0 1 1-1.5 0V5.372a2.25 2.25 0 1 1 1.5 0v1.836A2.493 2.493 0 0 1 6 7h4a1 1 0 0 0 1-1v-.628A2.25 2.25 0 0 1 9.5 3.25Zm-6 0a.75.75 0 1 0 1.5 0 .75.75 0 0 0-1.5 0Zm8.25-.75a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5ZM4.25 12a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Z"></path> </svg></div> <div data-view-component="true" class="TimelineItem-body"> <a class="d-inline-block" data-test-selector="pr-timeline-events-actor-avatar" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/2716369?s=40&amp;u=374de0b478358fee43af93a3b0dc08d84cd1b5d0&amp;v=4" width="20" height="20" alt="@gnoff" /></a> <a class="author Link--primary text-bold" data-test-selector="pr-timeline-events-actor-profile-link" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff">gnoff</a> deleted the <span class="commit-ref user-select-contain width-fit"> <span data-view-component="true" class="css-truncate css-truncate-target width-fit"> preload-imagesrcset </span> </span> branch <a href="#event-9545223917" data-view-component="true" class="css-truncate css-truncate-target Link--secondary Link"><relative-time tense="past" datetime="2023-06-15T21:50:26Z" data-view-component="true">June 15, 2023 21:50</relative-time></a> </div> </div> <div class="TimelineItem" > <span class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </span> <div class="TimelineItem-body" id="ref-commit-fc485c3"> <a class="author Link--primary text-bold" href="/apps/github-actions">github-actions</a> <span class="Label Label--secondary">bot</span> pushed a commit that referenced this pull request <a href="#ref-commit-fc485c3" class="Link--secondary"> <relative-time datetime="2023-06-15T21:56:23Z" class="no-wrap">Jun 15, 2023</relative-time> </a> <div class="mt-3"> <div class="js-details-container Details js-socket-channel js-updatable-content" data-channel="eyJjIjoicmVwbzoxMDI3MDI1MDpjb21taXQ6ZmM0ODVjMzc2YjFjNzFhMDQ5NzU5YzBlMjllYjU4NjlhZjNjZWZhYyIsInQiOjE3MzQxMzIxMDN9--32d688846281496570c4256a281eb9d9ccc3e4357fd17a2d0b42ca77f2e8eaf6" data-url="/facebook/react/commit/fc485c376b1c71a049759c0e29eb5869af3cefac/show_partial?partial=commit%2Fcondensed_details"> <div class="d-flex flex-md-row flex-column"> <div class="d-flex flex-auto"> <div class="AvatarStack flex-self-start " > <div class="AvatarStack-body" > <a class="avatar avatar-user" style="width:20px;height:20px;" data-test-selector="commits-avatar-stack-avatar-link" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/2716369?s=40&amp;u=374de0b478358fee43af93a3b0dc08d84cd1b5d0&amp;v=4" width="20" height="20" alt="@gnoff" class=" avatar-user" /> </a> </div> </div> <div class="pr-1 flex-auto min-width-0" > <code> <a title="[Float][Fizz][Fiber] support imagesrcset and imagesizes for `ReactDOM.preload()` (#26940) For float methods the href argument is usually all we need to uniquely key the request. However when preloading responsive images it is possible that you may need more than one preload for differing imagesizes attributes. When using imagesrcset for preloads the href attribute acts more like a fallback href. For keying purposes the imagesrcset becomes the primary key conceptually. This change updates the keying logic for `ReactDOM.preload()` when you pass `{as: &quot;image&quot;}` 1. If `options.imageSrcSet` is a non-emtpy string the key is defined as `options.imageSrcSet + options.imageSizes`. The `href` argument is still required but does not participate in keying. 2. If `options.imageSrcSet` is empty, missing, or an invalid format the key is defined as the `href`. Changing the `options.imageSizes` does not affect the key as this option is inert when not using `options.imageSrcSet` Additionally, currently there is a bug in webkit (Safari) that causes preload links to fail to use imageSrcSet and fallback to href even when the browser will correctly resolve srcset on an `&lt;img&gt;` tag. Because the drawbacks of preloading the wrong image (href over imagesrcset) in a modern browser outweight the drawbacks of not preloading anything for responsive images in browsers that do not support srcset at all we will omit the `href` attribute whenever `options.imageSrcSet` is provided. We still require you provide an href since we want to be able to revert this behavior once all major browsers support it bug link: https://bugs.webkit.org/show_bug.cgi?id=231150 DiffTrain build for [fc929cf4ead35f99c4e9612a95e8a0bb8f5df25d](https://github.com/facebook/react/commit/fc929cf4ead35f99c4e9612a95e8a0bb8f5df25d)" data-pjax="true" class="Link--secondary markdown-title" href="/facebook/react/commit/fc485c376b1c71a049759c0e29eb5869af3cefac">[Float][Fizz][Fiber] support imagesrcset and imagesizes for `ReactDOM…</a> </code> <span class="hidden-text-expander inline"> <button type="button" class="ellipsis-expander js-details-target" aria-expanded="false">&hellip;</button> </span> </div> <div class="pr-1 d-md-inline-block d-none"> <batch-deferred-content class="d-inline-block" data-url="/commits/badges"> <input type="hidden" name="id" value="C_kwDOAJy2KtoAKGZjNDg1YzM3NmIxYzcxYTA0OTc1OWMwZTI5ZWI1ODY5YWYzY2VmYWM" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="badge_size" value="small" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="dropdown_direction" value="w" data-targets="batch-deferred-content.inputs" autocomplete="off" /> </batch-deferred-content> </div> <div class="pr-1 flex-shrink-0" style="width: 16px;"> </div> <!-- ml-1 is added to accommodate "clock" icon --> <div class="text-right ml-1"> <code> <a href="/facebook/react/commit/fc485c376b1c71a049759c0e29eb5869af3cefac" class="Link--secondary">fc485c3</a> </code> </div> </div> </div> <div class="Details-content--hidden mt-2"> <pre class="color-fg-muted ws-pre-wrap">….preload()` (<a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755454645" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26940" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26940/hovercard" href="https://github.com/facebook/react/pull/26940">#26940</a>) For float methods the href argument is usually all we need to uniquely key the request. However when preloading responsive images it is possible that you may need more than one preload for differing imagesizes attributes. When using imagesrcset for preloads the href attribute acts more like a fallback href. For keying purposes the imagesrcset becomes the primary key conceptually. This change updates the keying logic for `ReactDOM.preload()` when you pass `{as: "image"}` 1. If `options.imageSrcSet` is a non-emtpy string the key is defined as `options.imageSrcSet + options.imageSizes`. The `href` argument is still required but does not participate in keying. 2. If `options.imageSrcSet` is empty, missing, or an invalid format the key is defined as the `href`. Changing the `options.imageSizes` does not affect the key as this option is inert when not using `options.imageSrcSet` Additionally, currently there is a bug in webkit (Safari) that causes preload links to fail to use imageSrcSet and fallback to href even when the browser will correctly resolve srcset on an `&lt;img&gt;` tag. Because the drawbacks of preloading the wrong image (href over imagesrcset) in a modern browser outweight the drawbacks of not preloading anything for responsive images in browsers that do not support srcset at all we will omit the `href` attribute whenever `options.imageSrcSet` is provided. We still require you provide an href since we want to be able to revert this behavior once all major browsers support it bug link: <a href="https://bugs.webkit.org/show_bug.cgi?id=231150" rel="nofollow">https://bugs.webkit.org/show_bug.cgi?id=231150</a> DiffTrain build for [<a class="commit-link" data-hovercard-type="commit" data-hovercard-url="https://github.com/facebook/react/commit/fc929cf4ead35f99c4e9612a95e8a0bb8f5df25d/hovercard" href="https://github.com/facebook/react/commit/fc929cf4ead35f99c4e9612a95e8a0bb8f5df25d"><tt>fc929cf</tt></a>](<a class="commit-link" data-hovercard-type="commit" data-hovercard-url="https://github.com/facebook/react/commit/fc929cf4ead35f99c4e9612a95e8a0bb8f5df25d/hovercard" href="https://github.com/facebook/react/commit/fc929cf4ead35f99c4e9612a95e8a0bb8f5df25d"><tt>fc929cf</tt></a>)</pre> </div> </div> </div> </div> </div> <div class="TimelineItem"> <div class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </div> <div class="TimelineItem-body" > <div > <a class="d-inline-block" data-hovercard-type="user" data-hovercard-url="/users/styfle/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/styfle"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/229881?s=40&amp;v=4" width="20" height="20" alt="@styfle" /></a> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/styfle/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/styfle">styfle</a> mentioned this pull request <a class="Link--secondary" href="#ref-pullrequest-1781535478" > <relative-time datetime="2023-06-30T18:10:15Z" class="no-wrap">Jun 30, 2023</relative-time> </a> </div> <div class="mt-2 d-flex flex-items-start flex-column flex-md-row"> <div class="flex-auto wb-break-word" id="ref-pullrequest-1781535478" > <a href="/vercel/next.js/pull/52005" class="Link--primary f4 text-bold markdown-title" data-hovercard-type="pull_request" data-hovercard-url="/vercel/next.js/pull/52005/hovercard"> chore(deps): bump react <code>18.3.0-canary-1fdacbefd-20230630</code> <span class="color-fg-muted text-normal" >vercel/next.js#52005</span> </a> </div> <div class="flex-shrink-0 my-1 my-md-0 ml-md-3"> <span title="Status: Merged" data-view-component="true" class="State State--merged State--small"> <svg height="14" class="octicon octicon-git-merge" viewBox="0 0 16 16" version="1.1" width="14" aria-hidden="true"><path d="M5.45 5.154A4.25 4.25 0 0 0 9.25 7.5h1.378a2.251 2.251 0 1 1 0 1.5H9.25A5.734 5.734 0 0 1 5 7.123v3.505a2.25 2.25 0 1 1-1.5 0V5.372a2.25 2.25 0 1 1 1.95-.218ZM4.25 13.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5Zm8.5-4.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5ZM5 3.25a.75.75 0 1 0 0 .005V3.25Z"></path></svg> Merged </span> </div> </div> </div> </div> <div class="TimelineItem" > <span class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </span> <div class="TimelineItem-body" id="ref-commit-9e4b87d"> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/timneutkens/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/timneutkens">timneutkens</a> pushed a commit to vercel/next.js that referenced this pull request <a href="#ref-commit-9e4b87d" class="Link--secondary"> <relative-time datetime="2023-07-04T09:32:39Z" class="no-wrap">Jul 4, 2023</relative-time> </a> <div class="mt-3"> <div class="js-details-container Details js-socket-channel js-updatable-content" data-channel="eyJjIjoicmVwbzo3MDEwNzc4Njpjb21taXQ6OWU0Yjg3ZDUwMmUxZTIwMzUxZTExMWQ5MmU3MGIyZTU0YWMwMzUxYSIsInQiOjE3MzQxMzIxMDN9--72de2100cfef08da71f9e6a7fccdbc473e16bbe9617057562d9ff66fb5999766" data-url="/vercel/next.js/commit/9e4b87d502e1e20351e111d92e70b2e54ac0351a/show_partial?partial=commit%2Fcondensed_details"> <div class="d-flex flex-md-row flex-column"> <div class="d-flex flex-auto"> <div class="AvatarStack flex-self-start AvatarStack--two " > <div class="AvatarStack-body" > <a class="avatar avatar-user" style="width:20px;height:20px;" data-test-selector="commits-avatar-stack-avatar-link" data-hovercard-type="user" data-hovercard-url="/users/styfle/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/styfle"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/229881?s=40&amp;u=58675cc3f9993517e5f29209ccba960d79b719ad&amp;v=4" width="20" height="20" alt="@styfle" class=" avatar-user" /> </a> <a class="avatar avatar-user" style="width:20px;height:20px;" data-test-selector="commits-avatar-stack-avatar-link" data-hovercard-type="user" data-hovercard-url="/users/shuding/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/shuding"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/3676859?s=40&amp;u=a866d19c4fce64bf67a084eb32f29bb6e84020a5&amp;v=4" width="20" height="20" alt="@shuding" class=" avatar-user" /> </a> </div> </div> <div class="pr-1 flex-auto min-width-0" > <code> <a title="chore(deps): bump react `18.3.0-canary-1fdacbefd-20230630` (#52005) This PR updates the vendored react dependencies using `pnpm sync-react` ### React upstream changes - https://github.com/facebook/react/pull/27028 - https://github.com/facebook/react/pull/27027 - https://github.com/facebook/react/pull/27019 - https://github.com/facebook/react/pull/26954 - https://github.com/facebook/react/pull/26987 - https://github.com/facebook/react/pull/26985 - https://github.com/facebook/react/pull/26933 - https://github.com/facebook/react/pull/26625 - https://github.com/facebook/react/pull/27011 - https://github.com/facebook/react/pull/27008 - https://github.com/facebook/react/pull/26997 - https://github.com/facebook/react/pull/26989 - https://github.com/facebook/react/pull/26955 - https://github.com/facebook/react/pull/26963 - https://github.com/facebook/react/pull/26983 - https://github.com/facebook/react/pull/26914 - https://github.com/facebook/react/pull/26951 - https://github.com/facebook/react/pull/26977 - https://github.com/facebook/react/pull/26958 - https://github.com/facebook/react/pull/26940 - https://github.com/facebook/react/pull/26939 - https://github.com/facebook/react/pull/26887 - https://github.com/facebook/react/pull/26947 - https://github.com/facebook/react/pull/26945 - https://github.com/facebook/react/pull/26942 - https://github.com/facebook/react/pull/26938 - https://github.com/facebook/react/pull/26844 - https://github.com/facebook/react/pull/25510 - https://github.com/facebook/react/pull/26932 - https://github.com/facebook/react/pull/26896 - https://github.com/facebook/react/pull/26913 - https://github.com/facebook/react/pull/26888 - https://github.com/facebook/react/pull/26827 - https://github.com/facebook/react/pull/26889 - https://github.com/facebook/react/pull/26877 - https://github.com/facebook/react/pull/26873 - https://github.com/facebook/react/pull/26880 - https://github.com/facebook/react/pull/26842 - https://github.com/facebook/react/pull/26858 - https://github.com/facebook/react/pull/26754 - https://github.com/facebook/react/pull/26753 - https://github.com/facebook/react/pull/26881 ### Related Closes #49409 (by https://github.com/facebook/react/pull/26977) fix NEXT-1189 Co-authored-by: Shu Ding &lt;g@shud.in&gt;" data-pjax="true" class="Link--secondary markdown-title" href="/vercel/next.js/commit/9e4b87d502e1e20351e111d92e70b2e54ac0351a">chore(deps): bump react</a> <code><a title="chore(deps): bump react `18.3.0-canary-1fdacbefd-20230630` (#52005) This PR updates the vendored react dependencies using `pnpm sync-react` ### React upstream changes - https://github.com/facebook/react/pull/27028 - https://github.com/facebook/react/pull/27027 - https://github.com/facebook/react/pull/27019 - https://github.com/facebook/react/pull/26954 - https://github.com/facebook/react/pull/26987 - https://github.com/facebook/react/pull/26985 - https://github.com/facebook/react/pull/26933 - https://github.com/facebook/react/pull/26625 - https://github.com/facebook/react/pull/27011 - https://github.com/facebook/react/pull/27008 - https://github.com/facebook/react/pull/26997 - https://github.com/facebook/react/pull/26989 - https://github.com/facebook/react/pull/26955 - https://github.com/facebook/react/pull/26963 - https://github.com/facebook/react/pull/26983 - https://github.com/facebook/react/pull/26914 - https://github.com/facebook/react/pull/26951 - https://github.com/facebook/react/pull/26977 - https://github.com/facebook/react/pull/26958 - https://github.com/facebook/react/pull/26940 - https://github.com/facebook/react/pull/26939 - https://github.com/facebook/react/pull/26887 - https://github.com/facebook/react/pull/26947 - https://github.com/facebook/react/pull/26945 - https://github.com/facebook/react/pull/26942 - https://github.com/facebook/react/pull/26938 - https://github.com/facebook/react/pull/26844 - https://github.com/facebook/react/pull/25510 - https://github.com/facebook/react/pull/26932 - https://github.com/facebook/react/pull/26896 - https://github.com/facebook/react/pull/26913 - https://github.com/facebook/react/pull/26888 - https://github.com/facebook/react/pull/26827 - https://github.com/facebook/react/pull/26889 - https://github.com/facebook/react/pull/26877 - https://github.com/facebook/react/pull/26873 - https://github.com/facebook/react/pull/26880 - https://github.com/facebook/react/pull/26842 - https://github.com/facebook/react/pull/26858 - https://github.com/facebook/react/pull/26754 - https://github.com/facebook/react/pull/26753 - https://github.com/facebook/react/pull/26881 ### Related Closes #49409 (by https://github.com/facebook/react/pull/26977) fix NEXT-1189 Co-authored-by: Shu Ding &lt;g@shud.in&gt;" data-pjax="true" class="Link--secondary markdown-title" href="/vercel/next.js/commit/9e4b87d502e1e20351e111d92e70b2e54ac0351a">18.3.0-canary-1fdacbefd-20230630</a></code> <a title="chore(deps): bump react `18.3.0-canary-1fdacbefd-20230630` (#52005) This PR updates the vendored react dependencies using `pnpm sync-react` ### React upstream changes - https://github.com/facebook/react/pull/27028 - https://github.com/facebook/react/pull/27027 - https://github.com/facebook/react/pull/27019 - https://github.com/facebook/react/pull/26954 - https://github.com/facebook/react/pull/26987 - https://github.com/facebook/react/pull/26985 - https://github.com/facebook/react/pull/26933 - https://github.com/facebook/react/pull/26625 - https://github.com/facebook/react/pull/27011 - https://github.com/facebook/react/pull/27008 - https://github.com/facebook/react/pull/26997 - https://github.com/facebook/react/pull/26989 - https://github.com/facebook/react/pull/26955 - https://github.com/facebook/react/pull/26963 - https://github.com/facebook/react/pull/26983 - https://github.com/facebook/react/pull/26914 - https://github.com/facebook/react/pull/26951 - https://github.com/facebook/react/pull/26977 - https://github.com/facebook/react/pull/26958 - https://github.com/facebook/react/pull/26940 - https://github.com/facebook/react/pull/26939 - https://github.com/facebook/react/pull/26887 - https://github.com/facebook/react/pull/26947 - https://github.com/facebook/react/pull/26945 - https://github.com/facebook/react/pull/26942 - https://github.com/facebook/react/pull/26938 - https://github.com/facebook/react/pull/26844 - https://github.com/facebook/react/pull/25510 - https://github.com/facebook/react/pull/26932 - https://github.com/facebook/react/pull/26896 - https://github.com/facebook/react/pull/26913 - https://github.com/facebook/react/pull/26888 - https://github.com/facebook/react/pull/26827 - https://github.com/facebook/react/pull/26889 - https://github.com/facebook/react/pull/26877 - https://github.com/facebook/react/pull/26873 - https://github.com/facebook/react/pull/26880 - https://github.com/facebook/react/pull/26842 - https://github.com/facebook/react/pull/26858 - https://github.com/facebook/react/pull/26754 - https://github.com/facebook/react/pull/26753 - https://github.com/facebook/react/pull/26881 ### Related Closes #49409 (by https://github.com/facebook/react/pull/26977) fix NEXT-1189 Co-authored-by: Shu Ding &lt;g@shud.in&gt;" data-pjax="true" class="Link--secondary markdown-title" href="/vercel/next.js/commit/9e4b87d502e1e20351e111d92e70b2e54ac0351a">(</a><a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1781535478" data-permission-text="Title is private" data-url="https://github.com/vercel/next.js/issues/52005" data-hovercard-type="pull_request" data-hovercard-url="/vercel/next.js/pull/52005/hovercard" href="https://github.com/vercel/next.js/pull/52005">#52005</a><a title="chore(deps): bump react `18.3.0-canary-1fdacbefd-20230630` (#52005) This PR updates the vendored react dependencies using `pnpm sync-react` ### React upstream changes - https://github.com/facebook/react/pull/27028 - https://github.com/facebook/react/pull/27027 - https://github.com/facebook/react/pull/27019 - https://github.com/facebook/react/pull/26954 - https://github.com/facebook/react/pull/26987 - https://github.com/facebook/react/pull/26985 - https://github.com/facebook/react/pull/26933 - https://github.com/facebook/react/pull/26625 - https://github.com/facebook/react/pull/27011 - https://github.com/facebook/react/pull/27008 - https://github.com/facebook/react/pull/26997 - https://github.com/facebook/react/pull/26989 - https://github.com/facebook/react/pull/26955 - https://github.com/facebook/react/pull/26963 - https://github.com/facebook/react/pull/26983 - https://github.com/facebook/react/pull/26914 - https://github.com/facebook/react/pull/26951 - https://github.com/facebook/react/pull/26977 - https://github.com/facebook/react/pull/26958 - https://github.com/facebook/react/pull/26940 - https://github.com/facebook/react/pull/26939 - https://github.com/facebook/react/pull/26887 - https://github.com/facebook/react/pull/26947 - https://github.com/facebook/react/pull/26945 - https://github.com/facebook/react/pull/26942 - https://github.com/facebook/react/pull/26938 - https://github.com/facebook/react/pull/26844 - https://github.com/facebook/react/pull/25510 - https://github.com/facebook/react/pull/26932 - https://github.com/facebook/react/pull/26896 - https://github.com/facebook/react/pull/26913 - https://github.com/facebook/react/pull/26888 - https://github.com/facebook/react/pull/26827 - https://github.com/facebook/react/pull/26889 - https://github.com/facebook/react/pull/26877 - https://github.com/facebook/react/pull/26873 - https://github.com/facebook/react/pull/26880 - https://github.com/facebook/react/pull/26842 - https://github.com/facebook/react/pull/26858 - https://github.com/facebook/react/pull/26754 - https://github.com/facebook/react/pull/26753 - https://github.com/facebook/react/pull/26881 ### Related Closes #49409 (by https://github.com/facebook/react/pull/26977) fix NEXT-1189 Co-authored-by: Shu Ding &lt;g@shud.in&gt;" data-pjax="true" class="Link--secondary markdown-title" href="/vercel/next.js/commit/9e4b87d502e1e20351e111d92e70b2e54ac0351a">)</a> </code> <span class="hidden-text-expander inline"> <button type="button" class="ellipsis-expander js-details-target" aria-expanded="false">&hellip;</button> </span> </div> <div class="pr-1 d-md-inline-block d-none"> <batch-deferred-content class="d-inline-block" data-url="/commits/badges"> <input type="hidden" name="id" value="C_kwDOBC3CitoAKDllNGI4N2Q1MDJlMWUyMDM1MWUxMTFkOTJlNzBiMmU1NGFjMDM1MWE" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="badge_size" value="small" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="dropdown_direction" value="w" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <span class="Skeleton d-inline-block mr-1" style="width:75px; height:14px; margin-bottom:-4px;"></span> </batch-deferred-content> </div> <div class="pr-1 flex-shrink-0" style="width: 16px;"> </div> <!-- ml-1 is added to accommodate "clock" icon --> <div class="text-right ml-1"> <code> <a href="/vercel/next.js/commit/9e4b87d502e1e20351e111d92e70b2e54ac0351a" class="Link--secondary">9e4b87d</a> </code> </div> </div> </div> <div class="Details-content--hidden mt-2"> <pre class="color-fg-muted ws-pre-wrap">This PR updates the vendored react dependencies using `pnpm sync-react` ### React upstream changes - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1782939428" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27028" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27028/hovercard" href="https://github.com/facebook/react/pull/27028">facebook/react#27028</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1782841559" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27027" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27027/hovercard" href="https://github.com/facebook/react/pull/27027">facebook/react#27027</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1777824145" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27019" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27019/hovercard" href="https://github.com/facebook/react/pull/27019">facebook/react#27019</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1757986467" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26954" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26954/hovercard" href="https://github.com/facebook/react/pull/26954">facebook/react#26954</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1768499460" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26987" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26987/hovercard" href="https://github.com/facebook/react/pull/26987">facebook/react#26987</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1766612739" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26985" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26985/hovercard" href="https://github.com/facebook/react/pull/26985">facebook/react#26985</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1753979617" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26933" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26933/hovercard" href="https://github.com/facebook/react/pull/26933">facebook/react#26933</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1667470771" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26625" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26625/hovercard" href="https://github.com/facebook/react/pull/26625">facebook/react#26625</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1775332680" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27011" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27011/hovercard" href="https://github.com/facebook/react/pull/27011">facebook/react#27011</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1774037842" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27008" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27008/hovercard" href="https://github.com/facebook/react/pull/27008">facebook/react#27008</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1771522020" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26997" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26997/hovercard" href="https://github.com/facebook/react/pull/26997">facebook/react#26997</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1768668977" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26989" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26989/hovercard" href="https://github.com/facebook/react/pull/26989">facebook/react#26989</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1758654127" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26955" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26955/hovercard" href="https://github.com/facebook/react/pull/26955">facebook/react#26955</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1761105577" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26963" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26963/hovercard" href="https://github.com/facebook/react/pull/26963">facebook/react#26963</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1765963685" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26983" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26983/hovercard" href="https://github.com/facebook/react/pull/26983">facebook/react#26983</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1748395523" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26914" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26914/hovercard" href="https://github.com/facebook/react/pull/26914">facebook/react#26914</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1757328915" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26951" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26951/hovercard" href="https://github.com/facebook/react/pull/26951">facebook/react#26951</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1764415870" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26977" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26977/hovercard" href="https://github.com/facebook/react/pull/26977">facebook/react#26977</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1759539292" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26958" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26958/hovercard" href="https://github.com/facebook/react/pull/26958">facebook/react#26958</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755454645" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26940" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26940/hovercard" href="https://github.com/facebook/react/pull/26940">facebook/react#26940</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755439923" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26939" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26939/hovercard" href="https://github.com/facebook/react/pull/26939">facebook/react#26939</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1736622554" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26887" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26887/hovercard" href="https://github.com/facebook/react/pull/26887">facebook/react#26887</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1756577660" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26947" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26947/hovercard" href="https://github.com/facebook/react/pull/26947">facebook/react#26947</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1756019442" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26945" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26945/hovercard" href="https://github.com/facebook/react/pull/26945">facebook/react#26945</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755631933" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26942" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26942/hovercard" href="https://github.com/facebook/react/pull/26942">facebook/react#26942</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755438312" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26938" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26938/hovercard" href="https://github.com/facebook/react/pull/26938">facebook/react#26938</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1724264943" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26844" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26844/hovercard" href="https://github.com/facebook/react/pull/26844">facebook/react#26844</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1415039829" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/25510" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/25510/hovercard" href="https://github.com/facebook/react/pull/25510">facebook/react#25510</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1753499754" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26932" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26932/hovercard" href="https://github.com/facebook/react/pull/26932">facebook/react#26932</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1739996259" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26896" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26896/hovercard" href="https://github.com/facebook/react/pull/26896">facebook/react#26896</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1748152912" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26913" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26913/hovercard" href="https://github.com/facebook/react/pull/26913">facebook/react#26913</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1736856514" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26888" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26888/hovercard" href="https://github.com/facebook/react/pull/26888">facebook/react#26888</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1714655178" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26827" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26827/hovercard" href="https://github.com/facebook/react/pull/26827">facebook/react#26827</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1737420670" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26889" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26889/hovercard" href="https://github.com/facebook/react/pull/26889">facebook/react#26889</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1734505889" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26877" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26877/hovercard" href="https://github.com/facebook/react/pull/26877">facebook/react#26877</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1733106308" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26873" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26873/hovercard" href="https://github.com/facebook/react/pull/26873">facebook/react#26873</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1734756974" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26880" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26880/hovercard" href="https://github.com/facebook/react/pull/26880">facebook/react#26880</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1723052045" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26842" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26842/hovercard" href="https://github.com/facebook/react/pull/26842">facebook/react#26842</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1726757217" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26858" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26858/hovercard" href="https://github.com/facebook/react/pull/26858">facebook/react#26858</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1691360257" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26754" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26754/hovercard" href="https://github.com/facebook/react/pull/26754">facebook/react#26754</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1691357057" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26753" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26753/hovercard" href="https://github.com/facebook/react/pull/26753">facebook/react#26753</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1734764060" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26881" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26881/hovercard" href="https://github.com/facebook/react/pull/26881">facebook/react#26881</a> ### Related <span class="issue-keyword tooltipped tooltipped-se" aria-label="This commit closes issue #49409.">Closes</span> <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1699132724" data-permission-text="Title is private" data-url="https://github.com/vercel/next.js/issues/49409" data-hovercard-type="issue" data-hovercard-url="/vercel/next.js/issues/49409/hovercard" href="https://github.com/vercel/next.js/issues/49409">#49409</a> (by <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1764415870" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26977" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26977/hovercard" href="https://github.com/facebook/react/pull/26977">facebook/react#26977</a>) fix <a class="issue-link js-issue-link notranslate" rel="noopener noreferrer nofollow" href="https://linear.app/vercel/issue/NEXT-1189">NEXT-1189</a> Co-authored-by: Shu Ding &lt;g@shud.in&gt;</pre> </div> </div> </div> </div> </div> <div class="TimelineItem"> <div class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </div> <div class="TimelineItem-body" > <div > <a class="d-inline-block" data-hovercard-type="user" data-hovercard-url="/users/styfle/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/styfle"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/229881?s=40&amp;v=4" width="20" height="20" alt="@styfle" /></a> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/styfle/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/styfle">styfle</a> mentioned this pull request <a class="Link--secondary" href="#ref-pullrequest-1790168410" > <relative-time datetime="2023-07-05T19:36:52Z" class="no-wrap">Jul 5, 2023</relative-time> </a> </div> <div class="mt-2 d-flex flex-items-start flex-column flex-md-row"> <div class="flex-auto wb-break-word" id="ref-pullrequest-1790168410" > <a href="/vercel/next.js/pull/52282" class="Link--primary f4 text-bold markdown-title" data-hovercard-type="pull_request" data-hovercard-url="/vercel/next.js/pull/52282/hovercard"> chore(deps): bump react to 7118f5dd7 <span class="color-fg-muted text-normal" >vercel/next.js#52282</span> </a> </div> <div class="flex-shrink-0 my-1 my-md-0 ml-md-3"> <span title="Status: Merged" data-view-component="true" class="State State--merged State--small"> <svg height="14" class="octicon octicon-git-merge" viewBox="0 0 16 16" version="1.1" width="14" aria-hidden="true"><path d="M5.45 5.154A4.25 4.25 0 0 0 9.25 7.5h1.378a2.251 2.251 0 1 1 0 1.5H9.25A5.734 5.734 0 0 1 5 7.123v3.505a2.25 2.25 0 1 1-1.5 0V5.372a2.25 2.25 0 1 1 1.95-.218ZM4.25 13.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5Zm8.5-4.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5ZM5 3.25a.75.75 0 1 0 0 .005V3.25Z"></path></svg> Merged </span> </div> </div> </div> </div> <div class="TimelineItem" > <span class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </span> <div class="TimelineItem-body" id="ref-commit-6dafc42"> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/timneutkens/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/timneutkens">timneutkens</a> pushed a commit to vercel/next.js that referenced this pull request <a href="#ref-commit-6dafc42" class="Link--secondary"> <relative-time datetime="2023-07-06T12:04:29Z" class="no-wrap">Jul 6, 2023</relative-time> </a> <div class="mt-3"> <div class="js-details-container Details js-socket-channel js-updatable-content" data-channel="eyJjIjoicmVwbzo3MDEwNzc4Njpjb21taXQ6NmRhZmM0MjI5ZDFiYmNmMTFiOWE1YzI0M2YzOWE4ZTc2ZGU1YTI3ZiIsInQiOjE3MzQxMzIxMDN9--7a3ce2dec3edafc4e16263174fcd1b9bd8cd2799d64f59766ec9966c73315317" data-url="/vercel/next.js/commit/6dafc4229d1bbcf11b9a5c243f39a8e76de5a27f/show_partial?partial=commit%2Fcondensed_details"> <div class="d-flex flex-md-row flex-column"> <div class="d-flex flex-auto"> <div class="AvatarStack flex-self-start AvatarStack--two " > <div class="AvatarStack-body" > <a class="avatar avatar-user" style="width:20px;height:20px;" data-test-selector="commits-avatar-stack-avatar-link" data-hovercard-type="user" data-hovercard-url="/users/styfle/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/styfle"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/229881?s=40&amp;u=58675cc3f9993517e5f29209ccba960d79b719ad&amp;v=4" width="20" height="20" alt="@styfle" class=" avatar-user" /> </a> <a class="avatar avatar-user" style="width:20px;height:20px;" data-test-selector="commits-avatar-stack-avatar-link" data-hovercard-type="user" data-hovercard-url="/users/huozhi/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/huozhi"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/4800338?s=40&amp;u=5c7d0191db95e34c1a1d8495ad828e6a034d7c76&amp;v=4" width="20" height="20" alt="@huozhi" class=" avatar-user" /> </a> </div> </div> <div class="pr-1 flex-auto min-width-0" > <code> <a title="chore(deps): bump react to 7118f5dd7 (#52282) Fixes #49409 ### React upstream changes - https://github.com/facebook/react/pull/27045 - https://github.com/facebook/react/pull/27051 - https://github.com/facebook/react/pull/27032 - https://github.com/facebook/react/pull/27031 - https://github.com/facebook/react/pull/27029 - https://github.com/facebook/react/pull/27028 - https://github.com/facebook/react/pull/27027 - https://github.com/facebook/react/pull/27019 - https://github.com/facebook/react/pull/26954 - https://github.com/facebook/react/pull/26987 - https://github.com/facebook/react/pull/26985 - https://github.com/facebook/react/pull/26933 - https://github.com/facebook/react/pull/26625 - https://github.com/facebook/react/pull/27011 - https://github.com/facebook/react/pull/27008 - https://github.com/facebook/react/pull/26997 - https://github.com/facebook/react/pull/26989 - https://github.com/facebook/react/pull/26955 - https://github.com/facebook/react/pull/26963 - https://github.com/facebook/react/pull/26983 - https://github.com/facebook/react/pull/26914 - https://github.com/facebook/react/pull/26951 - https://github.com/facebook/react/pull/26977 - https://github.com/facebook/react/pull/26958 - https://github.com/facebook/react/pull/26940 - https://github.com/facebook/react/pull/26939 - https://github.com/facebook/react/pull/26887 - https://github.com/facebook/react/pull/26947 - https://github.com/facebook/react/pull/26945 - https://github.com/facebook/react/pull/26942 - https://github.com/facebook/react/pull/26938 - https://github.com/facebook/react/pull/26844 - https://github.com/facebook/react/pull/25510 - https://github.com/facebook/react/pull/26932 - https://github.com/facebook/react/pull/26896 - https://github.com/facebook/react/pull/26913 - https://github.com/facebook/react/pull/26888 - https://github.com/facebook/react/pull/26827 - https://github.com/facebook/react/pull/26889 - https://github.com/facebook/react/pull/26877 - https://github.com/facebook/react/pull/26873 - https://github.com/facebook/react/pull/26880 - https://github.com/facebook/react/pull/26842 - https://github.com/facebook/react/pull/26858 - https://github.com/facebook/react/pull/26754 - https://github.com/facebook/react/pull/26753 - https://github.com/facebook/react/pull/26881 --------- Co-authored-by: Jiachi Liu &lt;inbox@huozhi.im&gt;" data-pjax="true" class="Link--secondary markdown-title" href="/vercel/next.js/commit/6dafc4229d1bbcf11b9a5c243f39a8e76de5a27f">chore(deps): bump react to 7118f5dd7 (</a><a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1790168410" data-permission-text="Title is private" data-url="https://github.com/vercel/next.js/issues/52282" data-hovercard-type="pull_request" data-hovercard-url="/vercel/next.js/pull/52282/hovercard" href="https://github.com/vercel/next.js/pull/52282">#52282</a><a title="chore(deps): bump react to 7118f5dd7 (#52282) Fixes #49409 ### React upstream changes - https://github.com/facebook/react/pull/27045 - https://github.com/facebook/react/pull/27051 - https://github.com/facebook/react/pull/27032 - https://github.com/facebook/react/pull/27031 - https://github.com/facebook/react/pull/27029 - https://github.com/facebook/react/pull/27028 - https://github.com/facebook/react/pull/27027 - https://github.com/facebook/react/pull/27019 - https://github.com/facebook/react/pull/26954 - https://github.com/facebook/react/pull/26987 - https://github.com/facebook/react/pull/26985 - https://github.com/facebook/react/pull/26933 - https://github.com/facebook/react/pull/26625 - https://github.com/facebook/react/pull/27011 - https://github.com/facebook/react/pull/27008 - https://github.com/facebook/react/pull/26997 - https://github.com/facebook/react/pull/26989 - https://github.com/facebook/react/pull/26955 - https://github.com/facebook/react/pull/26963 - https://github.com/facebook/react/pull/26983 - https://github.com/facebook/react/pull/26914 - https://github.com/facebook/react/pull/26951 - https://github.com/facebook/react/pull/26977 - https://github.com/facebook/react/pull/26958 - https://github.com/facebook/react/pull/26940 - https://github.com/facebook/react/pull/26939 - https://github.com/facebook/react/pull/26887 - https://github.com/facebook/react/pull/26947 - https://github.com/facebook/react/pull/26945 - https://github.com/facebook/react/pull/26942 - https://github.com/facebook/react/pull/26938 - https://github.com/facebook/react/pull/26844 - https://github.com/facebook/react/pull/25510 - https://github.com/facebook/react/pull/26932 - https://github.com/facebook/react/pull/26896 - https://github.com/facebook/react/pull/26913 - https://github.com/facebook/react/pull/26888 - https://github.com/facebook/react/pull/26827 - https://github.com/facebook/react/pull/26889 - https://github.com/facebook/react/pull/26877 - https://github.com/facebook/react/pull/26873 - https://github.com/facebook/react/pull/26880 - https://github.com/facebook/react/pull/26842 - https://github.com/facebook/react/pull/26858 - https://github.com/facebook/react/pull/26754 - https://github.com/facebook/react/pull/26753 - https://github.com/facebook/react/pull/26881 --------- Co-authored-by: Jiachi Liu &lt;inbox@huozhi.im&gt;" data-pjax="true" class="Link--secondary markdown-title" href="/vercel/next.js/commit/6dafc4229d1bbcf11b9a5c243f39a8e76de5a27f">)</a> </code> <span class="hidden-text-expander inline"> <button type="button" class="ellipsis-expander js-details-target" aria-expanded="false">&hellip;</button> </span> </div> <div class="pr-1 d-md-inline-block d-none"> <batch-deferred-content class="d-inline-block" data-url="/commits/badges"> <input type="hidden" name="id" value="C_kwDOBC3CitoAKDZkYWZjNDIyOWQxYmJjZjExYjlhNWMyNDNmMzlhOGU3NmRlNWEyN2Y" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="badge_size" value="small" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="dropdown_direction" value="w" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <span class="Skeleton d-inline-block mr-1" style="width:75px; height:14px; margin-bottom:-4px;"></span> </batch-deferred-content> </div> <div class="pr-1 flex-shrink-0" style="width: 16px;"> </div> <!-- ml-1 is added to accommodate "clock" icon --> <div class="text-right ml-1"> <code> <a href="/vercel/next.js/commit/6dafc4229d1bbcf11b9a5c243f39a8e76de5a27f" class="Link--secondary">6dafc42</a> </code> </div> </div> </div> <div class="Details-content--hidden mt-2"> <pre class="color-fg-muted ws-pre-wrap"><span class="issue-keyword tooltipped tooltipped-se" aria-label="This commit closes issue #49409.">Fixes</span> <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1699132724" data-permission-text="Title is private" data-url="https://github.com/vercel/next.js/issues/49409" data-hovercard-type="issue" data-hovercard-url="/vercel/next.js/issues/49409/hovercard" href="https://github.com/vercel/next.js/issues/49409">#49409</a> ### React upstream changes - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1786540450" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27045" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27045/hovercard" href="https://github.com/facebook/react/pull/27045">facebook/react#27045</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1787350140" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27051" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27051/hovercard" href="https://github.com/facebook/react/pull/27051">facebook/react#27051</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1783484287" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27032" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27032/hovercard" href="https://github.com/facebook/react/pull/27032">facebook/react#27032</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1783131434" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27031" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27031/hovercard" href="https://github.com/facebook/react/pull/27031">facebook/react#27031</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1783112899" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27029" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27029/hovercard" href="https://github.com/facebook/react/pull/27029">facebook/react#27029</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1782939428" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27028" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27028/hovercard" href="https://github.com/facebook/react/pull/27028">facebook/react#27028</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1782841559" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27027" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27027/hovercard" href="https://github.com/facebook/react/pull/27027">facebook/react#27027</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1777824145" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27019" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27019/hovercard" href="https://github.com/facebook/react/pull/27019">facebook/react#27019</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1757986467" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26954" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26954/hovercard" href="https://github.com/facebook/react/pull/26954">facebook/react#26954</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1768499460" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26987" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26987/hovercard" href="https://github.com/facebook/react/pull/26987">facebook/react#26987</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1766612739" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26985" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26985/hovercard" href="https://github.com/facebook/react/pull/26985">facebook/react#26985</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1753979617" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26933" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26933/hovercard" href="https://github.com/facebook/react/pull/26933">facebook/react#26933</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1667470771" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26625" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26625/hovercard" href="https://github.com/facebook/react/pull/26625">facebook/react#26625</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1775332680" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27011" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27011/hovercard" href="https://github.com/facebook/react/pull/27011">facebook/react#27011</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1774037842" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27008" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27008/hovercard" href="https://github.com/facebook/react/pull/27008">facebook/react#27008</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1771522020" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26997" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26997/hovercard" href="https://github.com/facebook/react/pull/26997">facebook/react#26997</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1768668977" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26989" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26989/hovercard" href="https://github.com/facebook/react/pull/26989">facebook/react#26989</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1758654127" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26955" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26955/hovercard" href="https://github.com/facebook/react/pull/26955">facebook/react#26955</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1761105577" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26963" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26963/hovercard" href="https://github.com/facebook/react/pull/26963">facebook/react#26963</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1765963685" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26983" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26983/hovercard" href="https://github.com/facebook/react/pull/26983">facebook/react#26983</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1748395523" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26914" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26914/hovercard" href="https://github.com/facebook/react/pull/26914">facebook/react#26914</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1757328915" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26951" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26951/hovercard" href="https://github.com/facebook/react/pull/26951">facebook/react#26951</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1764415870" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26977" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26977/hovercard" href="https://github.com/facebook/react/pull/26977">facebook/react#26977</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1759539292" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26958" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26958/hovercard" href="https://github.com/facebook/react/pull/26958">facebook/react#26958</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755454645" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26940" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26940/hovercard" href="https://github.com/facebook/react/pull/26940">facebook/react#26940</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755439923" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26939" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26939/hovercard" href="https://github.com/facebook/react/pull/26939">facebook/react#26939</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1736622554" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26887" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26887/hovercard" href="https://github.com/facebook/react/pull/26887">facebook/react#26887</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1756577660" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26947" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26947/hovercard" href="https://github.com/facebook/react/pull/26947">facebook/react#26947</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1756019442" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26945" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26945/hovercard" href="https://github.com/facebook/react/pull/26945">facebook/react#26945</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755631933" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26942" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26942/hovercard" href="https://github.com/facebook/react/pull/26942">facebook/react#26942</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755438312" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26938" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26938/hovercard" href="https://github.com/facebook/react/pull/26938">facebook/react#26938</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1724264943" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26844" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26844/hovercard" href="https://github.com/facebook/react/pull/26844">facebook/react#26844</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1415039829" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/25510" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/25510/hovercard" href="https://github.com/facebook/react/pull/25510">facebook/react#25510</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1753499754" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26932" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26932/hovercard" href="https://github.com/facebook/react/pull/26932">facebook/react#26932</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1739996259" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26896" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26896/hovercard" href="https://github.com/facebook/react/pull/26896">facebook/react#26896</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1748152912" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26913" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26913/hovercard" href="https://github.com/facebook/react/pull/26913">facebook/react#26913</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1736856514" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26888" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26888/hovercard" href="https://github.com/facebook/react/pull/26888">facebook/react#26888</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1714655178" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26827" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26827/hovercard" href="https://github.com/facebook/react/pull/26827">facebook/react#26827</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1737420670" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26889" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26889/hovercard" href="https://github.com/facebook/react/pull/26889">facebook/react#26889</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1734505889" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26877" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26877/hovercard" href="https://github.com/facebook/react/pull/26877">facebook/react#26877</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1733106308" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26873" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26873/hovercard" href="https://github.com/facebook/react/pull/26873">facebook/react#26873</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1734756974" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26880" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26880/hovercard" href="https://github.com/facebook/react/pull/26880">facebook/react#26880</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1723052045" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26842" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26842/hovercard" href="https://github.com/facebook/react/pull/26842">facebook/react#26842</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1726757217" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26858" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26858/hovercard" href="https://github.com/facebook/react/pull/26858">facebook/react#26858</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1691360257" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26754" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26754/hovercard" href="https://github.com/facebook/react/pull/26754">facebook/react#26754</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1691357057" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26753" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26753/hovercard" href="https://github.com/facebook/react/pull/26753">facebook/react#26753</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1734764060" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26881" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26881/hovercard" href="https://github.com/facebook/react/pull/26881">facebook/react#26881</a> --------- Co-authored-by: Jiachi Liu &lt;inbox@huozhi.im&gt;</pre> </div> </div> </div> </div> </div> <div class="TimelineItem" > <span class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </span> <div class="TimelineItem-body" id="ref-commit-1ae3f42"> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/shuding/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/shuding">shuding</a> added a commit to vercel/next.js that referenced this pull request <a href="#ref-commit-1ae3f42" class="Link--secondary"> <relative-time datetime="2023-07-08T21:48:24Z" class="no-wrap">Jul 8, 2023</relative-time> </a> <div class="mt-3"> <div class="js-details-container Details js-socket-channel js-updatable-content" data-channel="eyJjIjoicmVwbzo3MDEwNzc4Njpjb21taXQ6MWFlM2Y0MmMxYTA0YzgwMDM3MmJlZDJhM2MyNjM4OTgxNTMyNTgzNiIsInQiOjE3MzQxMzIxMDN9--0c22e299e0f930790bfd24f5bfd21f8f5d0f5e92d7dc4a28d5e013b62ad16f9a" data-url="/vercel/next.js/commit/1ae3f42c1a04c800372bed2a3c26389815325836/show_partial?partial=commit%2Fcondensed_details"> <div class="d-flex flex-md-row flex-column"> <div class="d-flex flex-auto"> <div class="AvatarStack flex-self-start AvatarStack--two " > <div class="AvatarStack-body" > <a class="avatar avatar-user" style="width:20px;height:20px;" data-test-selector="commits-avatar-stack-avatar-link" data-hovercard-type="user" data-hovercard-url="/users/styfle/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/styfle"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/229881?s=40&amp;u=58675cc3f9993517e5f29209ccba960d79b719ad&amp;v=4" width="20" height="20" alt="@styfle" class=" avatar-user" /> </a> <a class="avatar avatar-user" style="width:20px;height:20px;" data-test-selector="commits-avatar-stack-avatar-link" data-hovercard-type="user" data-hovercard-url="/users/shuding/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/shuding"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/3676859?s=40&amp;u=a866d19c4fce64bf67a084eb32f29bb6e84020a5&amp;v=4" width="20" height="20" alt="@shuding" class=" avatar-user" /> </a> </div> </div> <div class="pr-1 flex-auto min-width-0" > <code> <a title="chore(deps): bump react `18.3.0-canary-1fdacbefd-20230630` (#52005) This PR updates the vendored react dependencies using `pnpm sync-react` ### React upstream changes - https://github.com/facebook/react/pull/27028 - https://github.com/facebook/react/pull/27027 - https://github.com/facebook/react/pull/27019 - https://github.com/facebook/react/pull/26954 - https://github.com/facebook/react/pull/26987 - https://github.com/facebook/react/pull/26985 - https://github.com/facebook/react/pull/26933 - https://github.com/facebook/react/pull/26625 - https://github.com/facebook/react/pull/27011 - https://github.com/facebook/react/pull/27008 - https://github.com/facebook/react/pull/26997 - https://github.com/facebook/react/pull/26989 - https://github.com/facebook/react/pull/26955 - https://github.com/facebook/react/pull/26963 - https://github.com/facebook/react/pull/26983 - https://github.com/facebook/react/pull/26914 - https://github.com/facebook/react/pull/26951 - https://github.com/facebook/react/pull/26977 - https://github.com/facebook/react/pull/26958 - https://github.com/facebook/react/pull/26940 - https://github.com/facebook/react/pull/26939 - https://github.com/facebook/react/pull/26887 - https://github.com/facebook/react/pull/26947 - https://github.com/facebook/react/pull/26945 - https://github.com/facebook/react/pull/26942 - https://github.com/facebook/react/pull/26938 - https://github.com/facebook/react/pull/26844 - https://github.com/facebook/react/pull/25510 - https://github.com/facebook/react/pull/26932 - https://github.com/facebook/react/pull/26896 - https://github.com/facebook/react/pull/26913 - https://github.com/facebook/react/pull/26888 - https://github.com/facebook/react/pull/26827 - https://github.com/facebook/react/pull/26889 - https://github.com/facebook/react/pull/26877 - https://github.com/facebook/react/pull/26873 - https://github.com/facebook/react/pull/26880 - https://github.com/facebook/react/pull/26842 - https://github.com/facebook/react/pull/26858 - https://github.com/facebook/react/pull/26754 - https://github.com/facebook/react/pull/26753 - https://github.com/facebook/react/pull/26881 ### Related Closes #49409 (by https://github.com/facebook/react/pull/26977) fix NEXT-1189 Co-authored-by: Shu Ding &lt;g@shud.in&gt;" data-pjax="true" class="Link--secondary markdown-title" href="/vercel/next.js/commit/1ae3f42c1a04c800372bed2a3c26389815325836">chore(deps): bump react</a> <code><a title="chore(deps): bump react `18.3.0-canary-1fdacbefd-20230630` (#52005) This PR updates the vendored react dependencies using `pnpm sync-react` ### React upstream changes - https://github.com/facebook/react/pull/27028 - https://github.com/facebook/react/pull/27027 - https://github.com/facebook/react/pull/27019 - https://github.com/facebook/react/pull/26954 - https://github.com/facebook/react/pull/26987 - https://github.com/facebook/react/pull/26985 - https://github.com/facebook/react/pull/26933 - https://github.com/facebook/react/pull/26625 - https://github.com/facebook/react/pull/27011 - https://github.com/facebook/react/pull/27008 - https://github.com/facebook/react/pull/26997 - https://github.com/facebook/react/pull/26989 - https://github.com/facebook/react/pull/26955 - https://github.com/facebook/react/pull/26963 - https://github.com/facebook/react/pull/26983 - https://github.com/facebook/react/pull/26914 - https://github.com/facebook/react/pull/26951 - https://github.com/facebook/react/pull/26977 - https://github.com/facebook/react/pull/26958 - https://github.com/facebook/react/pull/26940 - https://github.com/facebook/react/pull/26939 - https://github.com/facebook/react/pull/26887 - https://github.com/facebook/react/pull/26947 - https://github.com/facebook/react/pull/26945 - https://github.com/facebook/react/pull/26942 - https://github.com/facebook/react/pull/26938 - https://github.com/facebook/react/pull/26844 - https://github.com/facebook/react/pull/25510 - https://github.com/facebook/react/pull/26932 - https://github.com/facebook/react/pull/26896 - https://github.com/facebook/react/pull/26913 - https://github.com/facebook/react/pull/26888 - https://github.com/facebook/react/pull/26827 - https://github.com/facebook/react/pull/26889 - https://github.com/facebook/react/pull/26877 - https://github.com/facebook/react/pull/26873 - https://github.com/facebook/react/pull/26880 - https://github.com/facebook/react/pull/26842 - https://github.com/facebook/react/pull/26858 - https://github.com/facebook/react/pull/26754 - https://github.com/facebook/react/pull/26753 - https://github.com/facebook/react/pull/26881 ### Related Closes #49409 (by https://github.com/facebook/react/pull/26977) fix NEXT-1189 Co-authored-by: Shu Ding &lt;g@shud.in&gt;" data-pjax="true" class="Link--secondary markdown-title" href="/vercel/next.js/commit/1ae3f42c1a04c800372bed2a3c26389815325836">18.3.0-canary-1fdacbefd-20230630</a></code> <a title="chore(deps): bump react `18.3.0-canary-1fdacbefd-20230630` (#52005) This PR updates the vendored react dependencies using `pnpm sync-react` ### React upstream changes - https://github.com/facebook/react/pull/27028 - https://github.com/facebook/react/pull/27027 - https://github.com/facebook/react/pull/27019 - https://github.com/facebook/react/pull/26954 - https://github.com/facebook/react/pull/26987 - https://github.com/facebook/react/pull/26985 - https://github.com/facebook/react/pull/26933 - https://github.com/facebook/react/pull/26625 - https://github.com/facebook/react/pull/27011 - https://github.com/facebook/react/pull/27008 - https://github.com/facebook/react/pull/26997 - https://github.com/facebook/react/pull/26989 - https://github.com/facebook/react/pull/26955 - https://github.com/facebook/react/pull/26963 - https://github.com/facebook/react/pull/26983 - https://github.com/facebook/react/pull/26914 - https://github.com/facebook/react/pull/26951 - https://github.com/facebook/react/pull/26977 - https://github.com/facebook/react/pull/26958 - https://github.com/facebook/react/pull/26940 - https://github.com/facebook/react/pull/26939 - https://github.com/facebook/react/pull/26887 - https://github.com/facebook/react/pull/26947 - https://github.com/facebook/react/pull/26945 - https://github.com/facebook/react/pull/26942 - https://github.com/facebook/react/pull/26938 - https://github.com/facebook/react/pull/26844 - https://github.com/facebook/react/pull/25510 - https://github.com/facebook/react/pull/26932 - https://github.com/facebook/react/pull/26896 - https://github.com/facebook/react/pull/26913 - https://github.com/facebook/react/pull/26888 - https://github.com/facebook/react/pull/26827 - https://github.com/facebook/react/pull/26889 - https://github.com/facebook/react/pull/26877 - https://github.com/facebook/react/pull/26873 - https://github.com/facebook/react/pull/26880 - https://github.com/facebook/react/pull/26842 - https://github.com/facebook/react/pull/26858 - https://github.com/facebook/react/pull/26754 - https://github.com/facebook/react/pull/26753 - https://github.com/facebook/react/pull/26881 ### Related Closes #49409 (by https://github.com/facebook/react/pull/26977) fix NEXT-1189 Co-authored-by: Shu Ding &lt;g@shud.in&gt;" data-pjax="true" class="Link--secondary markdown-title" href="/vercel/next.js/commit/1ae3f42c1a04c800372bed2a3c26389815325836">(</a><a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1781535478" data-permission-text="Title is private" data-url="https://github.com/vercel/next.js/issues/52005" data-hovercard-type="pull_request" data-hovercard-url="/vercel/next.js/pull/52005/hovercard" href="https://github.com/vercel/next.js/pull/52005">#52005</a><a title="chore(deps): bump react `18.3.0-canary-1fdacbefd-20230630` (#52005) This PR updates the vendored react dependencies using `pnpm sync-react` ### React upstream changes - https://github.com/facebook/react/pull/27028 - https://github.com/facebook/react/pull/27027 - https://github.com/facebook/react/pull/27019 - https://github.com/facebook/react/pull/26954 - https://github.com/facebook/react/pull/26987 - https://github.com/facebook/react/pull/26985 - https://github.com/facebook/react/pull/26933 - https://github.com/facebook/react/pull/26625 - https://github.com/facebook/react/pull/27011 - https://github.com/facebook/react/pull/27008 - https://github.com/facebook/react/pull/26997 - https://github.com/facebook/react/pull/26989 - https://github.com/facebook/react/pull/26955 - https://github.com/facebook/react/pull/26963 - https://github.com/facebook/react/pull/26983 - https://github.com/facebook/react/pull/26914 - https://github.com/facebook/react/pull/26951 - https://github.com/facebook/react/pull/26977 - https://github.com/facebook/react/pull/26958 - https://github.com/facebook/react/pull/26940 - https://github.com/facebook/react/pull/26939 - https://github.com/facebook/react/pull/26887 - https://github.com/facebook/react/pull/26947 - https://github.com/facebook/react/pull/26945 - https://github.com/facebook/react/pull/26942 - https://github.com/facebook/react/pull/26938 - https://github.com/facebook/react/pull/26844 - https://github.com/facebook/react/pull/25510 - https://github.com/facebook/react/pull/26932 - https://github.com/facebook/react/pull/26896 - https://github.com/facebook/react/pull/26913 - https://github.com/facebook/react/pull/26888 - https://github.com/facebook/react/pull/26827 - https://github.com/facebook/react/pull/26889 - https://github.com/facebook/react/pull/26877 - https://github.com/facebook/react/pull/26873 - https://github.com/facebook/react/pull/26880 - https://github.com/facebook/react/pull/26842 - https://github.com/facebook/react/pull/26858 - https://github.com/facebook/react/pull/26754 - https://github.com/facebook/react/pull/26753 - https://github.com/facebook/react/pull/26881 ### Related Closes #49409 (by https://github.com/facebook/react/pull/26977) fix NEXT-1189 Co-authored-by: Shu Ding &lt;g@shud.in&gt;" data-pjax="true" class="Link--secondary markdown-title" href="/vercel/next.js/commit/1ae3f42c1a04c800372bed2a3c26389815325836">)</a> </code> <span class="hidden-text-expander inline"> <button type="button" class="ellipsis-expander js-details-target" aria-expanded="false">&hellip;</button> </span> </div> <div class="pr-1 d-md-inline-block d-none"> <batch-deferred-content class="d-inline-block" data-url="/commits/badges"> <input type="hidden" name="id" value="C_kwDOBC3CitoAKDFhZTNmNDJjMWEwNGM4MDAzNzJiZWQyYTNjMjYzODk4MTUzMjU4MzY" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="badge_size" value="small" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="dropdown_direction" value="w" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <span class="Skeleton d-inline-block mr-1" style="width:75px; height:14px; margin-bottom:-4px;"></span> </batch-deferred-content> </div> <div class="pr-1 flex-shrink-0" style="width: 16px;"> </div> <!-- ml-1 is added to accommodate "clock" icon --> <div class="text-right ml-1"> <code> <a href="/vercel/next.js/commit/1ae3f42c1a04c800372bed2a3c26389815325836" class="Link--secondary">1ae3f42</a> </code> </div> </div> </div> <div class="Details-content--hidden mt-2"> <pre class="color-fg-muted ws-pre-wrap">This PR updates the vendored react dependencies using `pnpm sync-react` ### React upstream changes - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1782939428" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27028" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27028/hovercard" href="https://github.com/facebook/react/pull/27028">facebook/react#27028</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1782841559" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27027" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27027/hovercard" href="https://github.com/facebook/react/pull/27027">facebook/react#27027</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1777824145" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27019" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27019/hovercard" href="https://github.com/facebook/react/pull/27019">facebook/react#27019</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1757986467" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26954" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26954/hovercard" href="https://github.com/facebook/react/pull/26954">facebook/react#26954</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1768499460" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26987" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26987/hovercard" href="https://github.com/facebook/react/pull/26987">facebook/react#26987</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1766612739" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26985" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26985/hovercard" href="https://github.com/facebook/react/pull/26985">facebook/react#26985</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1753979617" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26933" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26933/hovercard" href="https://github.com/facebook/react/pull/26933">facebook/react#26933</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1667470771" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26625" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26625/hovercard" href="https://github.com/facebook/react/pull/26625">facebook/react#26625</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1775332680" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27011" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27011/hovercard" href="https://github.com/facebook/react/pull/27011">facebook/react#27011</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1774037842" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/27008" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/27008/hovercard" href="https://github.com/facebook/react/pull/27008">facebook/react#27008</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1771522020" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26997" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26997/hovercard" href="https://github.com/facebook/react/pull/26997">facebook/react#26997</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1768668977" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26989" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26989/hovercard" href="https://github.com/facebook/react/pull/26989">facebook/react#26989</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1758654127" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26955" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26955/hovercard" href="https://github.com/facebook/react/pull/26955">facebook/react#26955</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1761105577" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26963" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26963/hovercard" href="https://github.com/facebook/react/pull/26963">facebook/react#26963</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1765963685" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26983" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26983/hovercard" href="https://github.com/facebook/react/pull/26983">facebook/react#26983</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1748395523" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26914" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26914/hovercard" href="https://github.com/facebook/react/pull/26914">facebook/react#26914</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1757328915" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26951" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26951/hovercard" href="https://github.com/facebook/react/pull/26951">facebook/react#26951</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1764415870" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26977" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26977/hovercard" href="https://github.com/facebook/react/pull/26977">facebook/react#26977</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1759539292" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26958" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26958/hovercard" href="https://github.com/facebook/react/pull/26958">facebook/react#26958</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755454645" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26940" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26940/hovercard" href="https://github.com/facebook/react/pull/26940">facebook/react#26940</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755439923" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26939" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26939/hovercard" href="https://github.com/facebook/react/pull/26939">facebook/react#26939</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1736622554" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26887" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26887/hovercard" href="https://github.com/facebook/react/pull/26887">facebook/react#26887</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1756577660" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26947" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26947/hovercard" href="https://github.com/facebook/react/pull/26947">facebook/react#26947</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1756019442" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26945" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26945/hovercard" href="https://github.com/facebook/react/pull/26945">facebook/react#26945</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755631933" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26942" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26942/hovercard" href="https://github.com/facebook/react/pull/26942">facebook/react#26942</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755438312" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26938" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26938/hovercard" href="https://github.com/facebook/react/pull/26938">facebook/react#26938</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1724264943" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26844" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26844/hovercard" href="https://github.com/facebook/react/pull/26844">facebook/react#26844</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1415039829" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/25510" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/25510/hovercard" href="https://github.com/facebook/react/pull/25510">facebook/react#25510</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1753499754" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26932" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26932/hovercard" href="https://github.com/facebook/react/pull/26932">facebook/react#26932</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1739996259" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26896" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26896/hovercard" href="https://github.com/facebook/react/pull/26896">facebook/react#26896</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1748152912" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26913" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26913/hovercard" href="https://github.com/facebook/react/pull/26913">facebook/react#26913</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1736856514" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26888" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26888/hovercard" href="https://github.com/facebook/react/pull/26888">facebook/react#26888</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1714655178" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26827" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26827/hovercard" href="https://github.com/facebook/react/pull/26827">facebook/react#26827</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1737420670" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26889" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26889/hovercard" href="https://github.com/facebook/react/pull/26889">facebook/react#26889</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1734505889" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26877" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26877/hovercard" href="https://github.com/facebook/react/pull/26877">facebook/react#26877</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1733106308" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26873" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26873/hovercard" href="https://github.com/facebook/react/pull/26873">facebook/react#26873</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1734756974" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26880" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26880/hovercard" href="https://github.com/facebook/react/pull/26880">facebook/react#26880</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1723052045" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26842" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26842/hovercard" href="https://github.com/facebook/react/pull/26842">facebook/react#26842</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1726757217" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26858" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26858/hovercard" href="https://github.com/facebook/react/pull/26858">facebook/react#26858</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1691360257" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26754" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26754/hovercard" href="https://github.com/facebook/react/pull/26754">facebook/react#26754</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1691357057" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26753" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26753/hovercard" href="https://github.com/facebook/react/pull/26753">facebook/react#26753</a> - <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1734764060" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26881" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26881/hovercard" href="https://github.com/facebook/react/pull/26881">facebook/react#26881</a> ### Related <span class="issue-keyword tooltipped tooltipped-se" aria-label="This commit closes issue #49409.">Closes</span> <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1699132724" data-permission-text="Title is private" data-url="https://github.com/vercel/next.js/issues/49409" data-hovercard-type="issue" data-hovercard-url="/vercel/next.js/issues/49409/hovercard" href="https://github.com/vercel/next.js/issues/49409">#49409</a> (by <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1764415870" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26977" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26977/hovercard" href="https://github.com/facebook/react/pull/26977">facebook/react#26977</a>) fix <a class="issue-link js-issue-link notranslate" rel="noopener noreferrer nofollow" href="https://linear.app/vercel/issue/NEXT-1189">NEXT-1189</a> Co-authored-by: Shu Ding &lt;g@shud.in&gt;</pre> </div> </div> </div> </div> </div> <div class="TimelineItem"> <div class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </div> <div class="TimelineItem-body" > <div > <a class="d-inline-block" data-hovercard-type="user" data-hovercard-url="/users/styfle/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/styfle"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/229881?s=40&amp;v=4" width="20" height="20" alt="@styfle" /></a> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/styfle/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/styfle">styfle</a> mentioned this pull request <a class="Link--secondary" href="#ref-pullrequest-1794552116" > <relative-time datetime="2023-07-21T19:07:08Z" class="no-wrap">Jul 21, 2023</relative-time> </a> </div> <div class="mt-2 d-flex flex-items-start flex-column flex-md-row"> <div class="flex-auto wb-break-word" id="ref-pullrequest-1794552116" > <a href="/vercel/next.js/pull/52425" class="Link--primary f4 text-bold markdown-title" data-hovercard-type="pull_request" data-hovercard-url="/vercel/next.js/pull/52425/hovercard"> fix: add missing <code>&lt;preload&gt;</code> for <code>next/image</code> in App Router <span class="color-fg-muted text-normal" >vercel/next.js#52425</span> </a> </div> <div class="flex-shrink-0 my-1 my-md-0 ml-md-3"> <span title="Status: Merged" data-view-component="true" class="State State--merged State--small"> <svg height="14" class="octicon octicon-git-merge" viewBox="0 0 16 16" version="1.1" width="14" aria-hidden="true"><path d="M5.45 5.154A4.25 4.25 0 0 0 9.25 7.5h1.378a2.251 2.251 0 1 1 0 1.5H9.25A5.734 5.734 0 0 1 5 7.123v3.505a2.25 2.25 0 1 1-1.5 0V5.372a2.25 2.25 0 1 1 1.95-.218ZM4.25 13.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5Zm8.5-4.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5ZM5 3.25a.75.75 0 1 0 0 .005V3.25Z"></path></svg> Merged </span> </div> </div> </div> </div> <div class="TimelineItem"> <div class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </div> <div class="TimelineItem-body" > <div > <a class="d-inline-block" data-hovercard-type="user" data-hovercard-url="/users/sookmax/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sookmax"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/71210554?s=40&amp;v=4" width="20" height="20" alt="@sookmax" /></a> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/sookmax/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sookmax">sookmax</a> mentioned this pull request <a class="Link--secondary" href="#ref-issue-1828760164" > <relative-time datetime="2023-07-31T13:21:51Z" class="no-wrap">Jul 31, 2023</relative-time> </a> </div> <div class="mt-2 d-flex flex-items-start flex-column flex-md-row"> <div class="flex-auto wb-break-word" id="ref-issue-1828760164" > <a href="/storybookjs/storybook/issues/23661" class="Link--primary f4 text-bold markdown-title" data-hovercard-type="issue" data-hovercard-url="/storybookjs/storybook/issues/23661/hovercard"> [Bug]: Using appDirectory in preview.ts causes reactdom.preload error with Next.js framework <span class="color-fg-muted text-normal" >storybookjs/storybook#23661</span> </a> </div> <div class="flex-shrink-0 my-1 my-md-0 ml-md-3"> <span title="Status: Closed" data-view-component="true" class="State State--merged State--small d-flex flex-items-center"> <svg aria-hidden="true" height="12" viewBox="0 0 16 16" version="1.1" width="12" data-view-component="true" class="octicon octicon-issue-closed flex-items-center mr-1"> <path d="M11.28 6.78a.75.75 0 0 0-1.06-1.06L7.25 8.69 5.78 7.22a.75.75 0 0 0-1.06 1.06l2 2a.75.75 0 0 0 1.06 0l3.5-3.5Z"></path><path d="M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0Zm-1.5 0a6.5 6.5 0 1 0-13 0 6.5 6.5 0 0 0 13 0Z"></path> </svg> Closed </span> </div> </div> </div> </div> <div class="TimelineItem"> <div class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </div> <div class="TimelineItem-body" > <div > <a class="d-inline-block" data-hovercard-type="user" data-hovercard-url="/users/eps1lon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/eps1lon"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/12292047?s=40&amp;v=4" width="20" height="20" alt="@eps1lon" /></a> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/eps1lon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/eps1lon">eps1lon</a> mentioned this pull request <a class="Link--secondary" href="#ref-pullrequest-1921874856" > <relative-time datetime="2023-10-02T14:35:56Z" class="no-wrap">Oct 2, 2023</relative-time> </a> </div> <div class="mt-2 d-flex flex-items-start flex-column flex-md-row"> <div class="flex-auto wb-break-word" id="ref-pullrequest-1921874856" > <a href="/DefinitelyTyped/DefinitelyTyped/pull/66896" class="Link--primary f4 text-bold markdown-title" data-hovercard-type="pull_request" data-hovercard-url="/DefinitelyTyped/DefinitelyTyped/pull/66896/hovercard"> [react-dom] Update types for latest state of Float <span class="color-fg-muted text-normal" >DefinitelyTyped/DefinitelyTyped#66896</span> </a> </div> <div class="flex-shrink-0 my-1 my-md-0 ml-md-3"> <span title="Status: Merged" data-view-component="true" class="State State--merged State--small"> <svg height="14" class="octicon octicon-git-merge" viewBox="0 0 16 16" version="1.1" width="14" aria-hidden="true"><path d="M5.45 5.154A4.25 4.25 0 0 0 9.25 7.5h1.378a2.251 2.251 0 1 1 0 1.5H9.25A5.734 5.734 0 0 1 5 7.123v3.505a2.25 2.25 0 1 1-1.5 0V5.372a2.25 2.25 0 1 1 1.95-.218ZM4.25 13.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5Zm8.5-4.5a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5ZM5 3.25a.75.75 0 1 0 0 .005V3.25Z"></path></svg> Merged </span> </div> </div> </div> </div> <div class="TimelineItem" > <span class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </span> <div class="TimelineItem-body" id="ref-commit-95b0277"> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/EdisonVan/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/EdisonVan">EdisonVan</a> pushed a commit to EdisonVan/react that referenced this pull request <a href="#ref-commit-95b0277" class="Link--secondary"> <relative-time datetime="2024-04-15T01:45:34Z" class="no-wrap">Apr 15, 2024</relative-time> </a> <div class="mt-3"> <div class="js-details-container Details js-socket-channel js-updatable-content" data-channel="eyJjIjoicmVwbzo2MTgxODI2NTA6Y29tbWl0Ojk1YjAyNzdlODA0OWI3MzgxMDZkMDcwMTM3YTc0NDc0MWYwNjY1ZjciLCJ0IjoxNzM0MTMyMTAzfQ==--d0c886a0e21839471dc4086b8643f73509a8872a46890581b1f56176289ea282" data-url="/EdisonVan/react/commit/95b0277e8049b738106d070137a744741f0665f7/show_partial?partial=commit%2Fcondensed_details"> <div class="d-flex flex-md-row flex-column"> <div class="d-flex flex-auto"> <div class="AvatarStack flex-self-start AvatarStack--two " > <div class="AvatarStack-body" > <a class="avatar avatar-user" style="width:20px;height:20px;" data-test-selector="commits-avatar-stack-avatar-link" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/2716369?s=40&amp;u=374de0b478358fee43af93a3b0dc08d84cd1b5d0&amp;v=4" width="20" height="20" alt="@gnoff" class=" avatar-user" /> </a> <a class="avatar avatar-user" style="width:20px;height:20px;" data-test-selector="commits-avatar-stack-avatar-link" data-hovercard-type="user" data-hovercard-url="/users/AndyPengc12/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/AndyPengc12"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/119281168?s=40&amp;v=4" width="20" height="20" alt="@AndyPengc12" class=" avatar-user" /> </a> </div> </div> <div class="pr-1 flex-auto min-width-0" > <code> <a title="[Float][Fizz][Fiber] support imagesrcset and imagesizes for `ReactDOM.preload()` (#26940) For float methods the href argument is usually all we need to uniquely key the request. However when preloading responsive images it is possible that you may need more than one preload for differing imagesizes attributes. When using imagesrcset for preloads the href attribute acts more like a fallback href. For keying purposes the imagesrcset becomes the primary key conceptually. This change updates the keying logic for `ReactDOM.preload()` when you pass `{as: &quot;image&quot;}` 1. If `options.imageSrcSet` is a non-emtpy string the key is defined as `options.imageSrcSet + options.imageSizes`. The `href` argument is still required but does not participate in keying. 2. If `options.imageSrcSet` is empty, missing, or an invalid format the key is defined as the `href`. Changing the `options.imageSizes` does not affect the key as this option is inert when not using `options.imageSrcSet` Additionally, currently there is a bug in webkit (Safari) that causes preload links to fail to use imageSrcSet and fallback to href even when the browser will correctly resolve srcset on an `&lt;img&gt;` tag. Because the drawbacks of preloading the wrong image (href over imagesrcset) in a modern browser outweight the drawbacks of not preloading anything for responsive images in browsers that do not support srcset at all we will omit the `href` attribute whenever `options.imageSrcSet` is provided. We still require you provide an href since we want to be able to revert this behavior once all major browsers support it bug link: https://bugs.webkit.org/show_bug.cgi?id=231150" data-pjax="true" class="Link--secondary markdown-title" href="/EdisonVan/react/commit/95b0277e8049b738106d070137a744741f0665f7">[Float][Fizz][Fiber] support imagesrcset and imagesizes for `ReactDOM…</a> </code> <span class="hidden-text-expander inline"> <button type="button" class="ellipsis-expander js-details-target" aria-expanded="false">&hellip;</button> </span> </div> <div class="pr-1 d-md-inline-block d-none"> <batch-deferred-content class="d-inline-block" data-url="/commits/badges"> <input type="hidden" name="id" value="C_kwDOJNi3-toAKDk1YjAyNzdlODA0OWI3MzgxMDZkMDcwMTM3YTc0NDc0MWYwNjY1Zjc" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="badge_size" value="small" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="dropdown_direction" value="w" data-targets="batch-deferred-content.inputs" autocomplete="off" /> </batch-deferred-content> </div> <div class="pr-1 flex-shrink-0" style="width: 16px;"> </div> <!-- ml-1 is added to accommodate "clock" icon --> <div class="text-right ml-1"> <code> <a href="/EdisonVan/react/commit/95b0277e8049b738106d070137a744741f0665f7" class="Link--secondary">95b0277</a> </code> </div> </div> </div> <div class="Details-content--hidden mt-2"> <pre class="color-fg-muted ws-pre-wrap">….preload()` (<a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755454645" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26940" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26940/hovercard" href="https://github.com/facebook/react/pull/26940">facebook#26940</a>) For float methods the href argument is usually all we need to uniquely key the request. However when preloading responsive images it is possible that you may need more than one preload for differing imagesizes attributes. When using imagesrcset for preloads the href attribute acts more like a fallback href. For keying purposes the imagesrcset becomes the primary key conceptually. This change updates the keying logic for `ReactDOM.preload()` when you pass `{as: "image"}` 1. If `options.imageSrcSet` is a non-emtpy string the key is defined as `options.imageSrcSet + options.imageSizes`. The `href` argument is still required but does not participate in keying. 2. If `options.imageSrcSet` is empty, missing, or an invalid format the key is defined as the `href`. Changing the `options.imageSizes` does not affect the key as this option is inert when not using `options.imageSrcSet` Additionally, currently there is a bug in webkit (Safari) that causes preload links to fail to use imageSrcSet and fallback to href even when the browser will correctly resolve srcset on an `&lt;img&gt;` tag. Because the drawbacks of preloading the wrong image (href over imagesrcset) in a modern browser outweight the drawbacks of not preloading anything for responsive images in browsers that do not support srcset at all we will omit the `href` attribute whenever `options.imageSrcSet` is provided. We still require you provide an href since we want to be able to revert this behavior once all major browsers support it bug link: <a href="https://bugs.webkit.org/show_bug.cgi?id=231150" rel="nofollow">https://bugs.webkit.org/show_bug.cgi?id=231150</a></pre> </div> </div> </div> </div> </div> <div class="TimelineItem" > <span class="TimelineItem-badge"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-cross-reference"> <path d="M2.75 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 13H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 14.543V13H2.75A1.75 1.75 0 0 1 1 11.25v-7.5C1 2.784 1.784 2 2.75 2h5.5a.75.75 0 0 1 0 1.5ZM16 1.25v4.146a.25.25 0 0 1-.427.177L14.03 4.03l-3.75 3.75a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l3.75-3.75-1.543-1.543A.25.25 0 0 1 11.604 1h4.146a.25.25 0 0 1 .25.25Z"></path> </svg> </span> <div class="TimelineItem-body" id="ref-commit-43a609b"> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/bigfootjon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/bigfootjon">bigfootjon</a> pushed a commit that referenced this pull request <a href="#ref-commit-43a609b" class="Link--secondary"> <relative-time datetime="2024-04-18T18:21:58Z" class="no-wrap">Apr 18, 2024</relative-time> </a> <div class="mt-3"> <div class="js-details-container Details js-socket-channel js-updatable-content" data-channel="eyJjIjoicmVwbzoxMDI3MDI1MDpjb21taXQ6NDNhNjA5YjQxOGY1NTljNTI5YTc4YWVmMDIyYTQxOTBkMDM3ZWVjYSIsInQiOjE3MzQxMzIxMDN9--665024eb25da0b191c1005a43e082a4b69776052222a8a0c8cabbaf627d1f908" data-url="/facebook/react/commit/43a609b418f559c529a78aef022a4190d037eeca/show_partial?partial=commit%2Fcondensed_details"> <div class="d-flex flex-md-row flex-column"> <div class="d-flex flex-auto"> <div class="AvatarStack flex-self-start " > <div class="AvatarStack-body" > <a class="avatar avatar-user" style="width:20px;height:20px;" data-test-selector="commits-avatar-stack-avatar-link" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/2716369?s=40&amp;u=374de0b478358fee43af93a3b0dc08d84cd1b5d0&amp;v=4" width="20" height="20" alt="@gnoff" class=" avatar-user" /> </a> </div> </div> <div class="pr-1 flex-auto min-width-0" > <code> <a title="[Float][Fizz][Fiber] support imagesrcset and imagesizes for `ReactDOM.preload()` (#26940) For float methods the href argument is usually all we need to uniquely key the request. However when preloading responsive images it is possible that you may need more than one preload for differing imagesizes attributes. When using imagesrcset for preloads the href attribute acts more like a fallback href. For keying purposes the imagesrcset becomes the primary key conceptually. This change updates the keying logic for `ReactDOM.preload()` when you pass `{as: &quot;image&quot;}` 1. If `options.imageSrcSet` is a non-emtpy string the key is defined as `options.imageSrcSet + options.imageSizes`. The `href` argument is still required but does not participate in keying. 2. If `options.imageSrcSet` is empty, missing, or an invalid format the key is defined as the `href`. Changing the `options.imageSizes` does not affect the key as this option is inert when not using `options.imageSrcSet` Additionally, currently there is a bug in webkit (Safari) that causes preload links to fail to use imageSrcSet and fallback to href even when the browser will correctly resolve srcset on an `&lt;img&gt;` tag. Because the drawbacks of preloading the wrong image (href over imagesrcset) in a modern browser outweight the drawbacks of not preloading anything for responsive images in browsers that do not support srcset at all we will omit the `href` attribute whenever `options.imageSrcSet` is provided. We still require you provide an href since we want to be able to revert this behavior once all major browsers support it bug link: https://bugs.webkit.org/show_bug.cgi?id=231150 DiffTrain build for commit https://github.com/facebook/react/commit/fc929cf4ead35f99c4e9612a95e8a0bb8f5df25d." data-pjax="true" class="Link--secondary markdown-title" href="/facebook/react/commit/43a609b418f559c529a78aef022a4190d037eeca">[Float][Fizz][Fiber] support imagesrcset and imagesizes for `ReactDOM…</a> </code> <span class="hidden-text-expander inline"> <button type="button" class="ellipsis-expander js-details-target" aria-expanded="false">&hellip;</button> </span> </div> <div class="pr-1 d-md-inline-block d-none"> <batch-deferred-content class="d-inline-block" data-url="/commits/badges"> <input type="hidden" name="id" value="C_kwDOAJy2KtoAKDQzYTYwOWI0MThmNTU5YzUyOWE3OGFlZjAyMmE0MTkwZDAzN2VlY2E" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="badge_size" value="small" data-targets="batch-deferred-content.inputs" autocomplete="off" /> <input type="hidden" name="dropdown_direction" value="w" data-targets="batch-deferred-content.inputs" autocomplete="off" /> </batch-deferred-content> </div> <div class="pr-1 flex-shrink-0" style="width: 16px;"> </div> <!-- ml-1 is added to accommodate "clock" icon --> <div class="text-right ml-1"> <code> <a href="/facebook/react/commit/43a609b418f559c529a78aef022a4190d037eeca" class="Link--secondary">43a609b</a> </code> </div> </div> </div> <div class="Details-content--hidden mt-2"> <pre class="color-fg-muted ws-pre-wrap">….preload()` (<a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1755454645" data-permission-text="Title is private" data-url="https://github.com/facebook/react/issues/26940" data-hovercard-type="pull_request" data-hovercard-url="/facebook/react/pull/26940/hovercard" href="https://github.com/facebook/react/pull/26940">#26940</a>) For float methods the href argument is usually all we need to uniquely key the request. However when preloading responsive images it is possible that you may need more than one preload for differing imagesizes attributes. When using imagesrcset for preloads the href attribute acts more like a fallback href. For keying purposes the imagesrcset becomes the primary key conceptually. This change updates the keying logic for `ReactDOM.preload()` when you pass `{as: "image"}` 1. If `options.imageSrcSet` is a non-emtpy string the key is defined as `options.imageSrcSet + options.imageSizes`. The `href` argument is still required but does not participate in keying. 2. If `options.imageSrcSet` is empty, missing, or an invalid format the key is defined as the `href`. Changing the `options.imageSizes` does not affect the key as this option is inert when not using `options.imageSrcSet` Additionally, currently there is a bug in webkit (Safari) that causes preload links to fail to use imageSrcSet and fallback to href even when the browser will correctly resolve srcset on an `&lt;img&gt;` tag. Because the drawbacks of preloading the wrong image (href over imagesrcset) in a modern browser outweight the drawbacks of not preloading anything for responsive images in browsers that do not support srcset at all we will omit the `href` attribute whenever `options.imageSrcSet` is provided. We still require you provide an href since we want to be able to revert this behavior once all major browsers support it bug link: <a href="https://bugs.webkit.org/show_bug.cgi?id=231150" rel="nofollow">https://bugs.webkit.org/show_bug.cgi?id=231150</a> DiffTrain build for commit <a class="commit-link" data-hovercard-type="commit" data-hovercard-url="https://github.com/facebook/react/commit/fc929cf4ead35f99c4e9612a95e8a0bb8f5df25d/hovercard" href="https://github.com/facebook/react/commit/fc929cf4ead35f99c4e9612a95e8a0bb8f5df25d"><tt>fc929cf</tt></a>.</pre> </div> </div> </div> </div> </div> </div> <!-- Rendered timeline since 2024-04-18 11:21:58 --> <div id="partial-timeline" class="js-timeline-marker js-socket-channel js-updatable-content" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzOTExMjg0MzgiLCJ0IjoxNzM0MTMyMTAzfQ==--dbd4e97a14852abb9efd70881c25a72e23f178357ff3026cb170915e6b63557f" data-url="/facebook/react/pull/26940/partials/unread_timeline?since=2024-04-18T11%3A21%3A58.000000000-07%3A00" data-channel-event-name="timeline_updated" data-last-modified="2024-04-18T11:21:58.000000000-07:00" data-gid="PR_kwDOAJy2Ks5S6u92"> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="d-none js-timeline-marker-form" data-turbo="false" action="/_graphql/MarkNotificationSubjectAsRead" accept-charset="UTF-8" data-remote="true" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="oUtGoiMKALjM+kMq2NTjslevVEHeJUGAxhoi18NlTil/iDxNJVsJPgQpgXoqPxn2wSb6pVwI003PjkghSUqw8Q==" /> <input type="hidden" name="variables[subjectId]" value="PR_kwDOAJy2Ks5S6u92"> </form> </div> </div> <div class="discussion-timeline-actions"> <div id="issue-comment-box"> <div data-view-component="true" class="flash flash-warn mt-3"> <a rel="nofollow" class="btn btn-primary" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;signed out comment&quot;,&quot;repository_id&quot;:10270250,&quot;auth_type&quot;:&quot;SIGN_UP&quot;,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="b72a107c892dbeae493ffce20c27eb7514367ab2db1128c4a18af161140bd376" href="/join?source=comment-repo">Sign up for free</a> <strong>to join this conversation on GitHub</strong>. Already have an account? <a rel="nofollow" class="Link--inTextBlock" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;signed out comment&quot;,&quot;repository_id&quot;:10270250,&quot;auth_type&quot;:&quot;LOG_IN&quot;,&quot;originating_url&quot;:&quot;https://github.com/facebook/react/pull/26940&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="1dd3e5ce8df5dcd361b89fc51400c06de9f11176a0e379dc685195a418234443" data-test-selector="comments-sign-in-link" href="/login?return_to=https%3A%2F%2Fgithub.com%2Ffacebook%2Freact%2Fpull%2F26940">Sign in to comment</a> </div> </div> </div> </div> </div> <div data-view-component="true" class="Layout-sidebar"> <div id="partial-discussion-sidebar" class="js-socket-channel js-updatable-content" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzOTExMjg0MzgiLCJ0IjoxNzM0MTMyMTAyfQ==--64c7562300bdaaaf6ef8924abe47cd1240a38400be35264667f65d26be3fa3a0" data-gid="PR_kwDOAJy2Ks5S6u92" data-channel-event-name="sidebar_updated" data-url="/facebook/react/issues/26940/show_partial?partial=issues%2Fsidebar" data-project-hovercards-enabled> <div class="discussion-sidebar-item sidebar-assignee js-discussion-sidebar-item position-relative js-socket-channel js-updatable-content" data-team-hovercards-enabled data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzOTExMjg0MzgiLCJ0IjoxNzM0MTMyMTAyfQ==--64c7562300bdaaaf6ef8924abe47cd1240a38400be35264667f65d26be3fa3a0" data-gid="PR_kwDOAJy2Ks5S6u92" data-url="/facebook/react/issues/26940/show_partial?partial=pull_requests%2Fsidebar%2Fshow%2Freviewers" data-channel-event-name="reviewers_updated" > <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-issue-sidebar-form" aria-label="Select reviewers" data-reviewers-team-size-check-url="/facebook/react/pull/26940/review-requests/team-size-check" data-turbo="false" action="/facebook/react/pull/26940/review-requests" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="BXUupVDllLqKym3ZFwcLihFzqT6dIR8qf6YRe4e8nmkK4sspXcCLynF6vCN2mLJH+X0QyNajh1iN4PP+6vJkCQ==" /> <input type="hidden" name="partial_last_updated" id="partial_last_updated" value="1734132102" autocomplete="off" class="form-control" /> <div class="js-large-teams-check-warning-container"></div> <div class="discussion-sidebar-heading text-bold"> Reviewers </div> <span class="css-truncate"> <p class="d-flex"> <span class="d-flex min-width-0 flex-1 js-hovercard-left" data-hovercard-type="user" data-hovercard-url="/users/sebmarkbage/hovercard?bot=copilot-pull-request-reviewer" data-assignee-name="sebmarkbage"> <a class="no-underline" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage"> <img class="avatar mr-1 avatar-user" src="https://avatars.githubusercontent.com/u/63648?s=40&amp;v=4" width="20" height="20" alt="@sebmarkbage" /> </a> <a class="assignee Link--primary css-truncate-target width-fit" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage"> <span class="css-truncate-target width-fit v-align-middle">sebmarkbage</span> </a></span> <a id="review-status-sebmarkbage" class="flex-order-1" href="/facebook/react/pull/26940/files/80a7f09da8c426364930520c59ef941b1ee9c81e"> <span class="reviewers-status-icon text-center"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-check color-fg-success"> <path d="M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0Z"></path> </svg> </span> </a> <tool-tip id="tooltip-67520ff1-ba90-49d4-85a6-133224eaab51" for="review-status-sebmarkbage" popover="manual" data-direction="nw" data-type="label" data-view-component="true" class="sr-only position-absolute">sebmarkbage approved these changes</tool-tip> </p> <p class="d-flex"> <span class="d-flex min-width-0 flex-1 js-hovercard-left" data-hovercard-type="user" data-hovercard-url="/users/sophiebits/hovercard?bot=copilot-pull-request-reviewer" data-assignee-name="sophiebits"> <a class="no-underline" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sophiebits"> <img class="avatar mr-1 avatar-user" src="https://avatars.githubusercontent.com/u/6820?s=40&amp;v=4" width="20" height="20" alt="@sophiebits" /> </a> <a class="assignee Link--primary css-truncate-target width-fit" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sophiebits"> <span class="css-truncate-target width-fit v-align-middle">sophiebits</span> </a></span> <button name="button" type="button" id="awaiting-review-sophiebits" class="btn-link flex-order-2"> <span class="reviewers-status-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-dot-fill hx_dot-fill-pending-icon"> <path d="M8 4a4 4 0 1 1 0 8 4 4 0 0 1 0-8Z"></path> </svg> </span> </button> <tool-tip id="tooltip-578e38c7-131f-42a3-9ec3-cfd21bc8a9b5" for="awaiting-review-sophiebits" popover="manual" data-direction="nw" data-type="label" data-view-component="true" class="sr-only position-absolute">Awaiting requested review from sophiebits</tool-tip> </p> </span> </form></div> <div class="discussion-sidebar-item sidebar-assignee js-discussion-sidebar-item js-socket-channel js-updatable-content" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzOTExMjg0MzgiLCJ0IjoxNzM0MTMyMTAyfQ==--64c7562300bdaaaf6ef8924abe47cd1240a38400be35264667f65d26be3fa3a0" data-gid="PR_kwDOAJy2Ks5S6u92" data-url="/facebook/react/issues/26940/show_partial?partial=issues%2Fsidebar%2Fshow%2Fassignees" data-channel-event-name="assignees_updated" > <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-issue-sidebar-form" aria-label="Select assignees" data-turbo="false" action="/facebook/react/issues/26940/assignees" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" data-csrf="true" name="authenticity_token" value="r297yS4IPVKrzAaS9xM77GUF+k8LXoww+Fa+d8Xd5Lq5mrg59ftzevaUiH34ZBOfxqf5tSlo7rMe9udT0v8lIw==" /> <div class="discussion-sidebar-heading text-bold"> Assignees </div> <span class="css-truncate js-issue-assignees"> No one assigned </span> </form></div> <div class="discussion-sidebar-item js-discussion-sidebar-item js-socket-channel js-updatable-content" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzOTExMjg0MzgiLCJ0IjoxNzM0MTMyMTAyfQ==--64c7562300bdaaaf6ef8924abe47cd1240a38400be35264667f65d26be3fa3a0" data-gid="PR_kwDOAJy2Ks5S6u92" data-url="/facebook/react/issues/26940/show_partial?partial=issues%2Fsidebar%2Fshow%2Flabels" data-channel-event-name="labels_updated" > <div class="discussion-sidebar-heading text-bold"> Labels </div> <div class="js-issue-labels d-flex flex-wrap"> <a id="label-bbc771" href="/facebook/react/labels/CLA%20Signed" data-name="CLA Signed" style="--label-r:231;--label-g:231;--label-b:231;--label-h:0;--label-s:0;--label-l:90;" data-view-component="true" class="IssueLabel hx_IssueLabel width-fit mb-1 mr-1"> <span class="css-truncate css-truncate-target width-fit">CLA Signed</span> </a> <a id="label-14992f" href="/facebook/react/labels/React%20Core%20Team" data-name="React Core Team" style="--label-r:145;--label-g:73;--label-b:209;--label-h:271;--label-s:59;--label-l:55;" data-view-component="true" class="IssueLabel hx_IssueLabel width-fit mb-1 mr-1"> <span class="css-truncate css-truncate-target width-fit">React Core Team</span> </a> <tool-tip id="tooltip-7ed7cdd1-dd9f-4089-a3b3-6d0becdc0cf0" for="label-14992f" popover="manual" data-direction="s" data-type="description" data-view-component="true" class="sr-only position-absolute">Opened by a member of the React Core Team</tool-tip> </div> </div> <div class="discussion-sidebar-item js-discussion-sidebar-item js-socket-channel js-updatable-content" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzOTExMjg0MzgiLCJ0IjoxNzM0MTMyMTAyfQ==--64c7562300bdaaaf6ef8924abe47cd1240a38400be35264667f65d26be3fa3a0" data-gid="PR_kwDOAJy2Ks5S6u92" data-url="/facebook/react/issues/26940/show_partial?partial=issues%2Fsidebar%2Fshow%2Fprojects" data-channel-event-name="projects_updated" > <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-issue-sidebar-form" aria-label="Select projects" data-turbo="false" action="/facebook/react/projects/issues/26940" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" data-csrf="true" name="authenticity_token" value="y6T/b4rbUnMf/ZdIu6I5FtN/7HnflqiDwjqhHei1oUs7Gi7LS0z22IJ3dVbVoTDxXupJDCZ2+3NW7uwlw7mlfQ==" /> <div class="discussion-sidebar-heading text-bold"> Projects </div> <div aria-live="polite"> </div> <span class="css-truncate sidebar-progress-bar"> None yet </span> </form> </div> <div class="discussion-sidebar-item sidebar-progress-bar js-discussion-sidebar-item js-socket-channel js-updatable-content" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzOTExMjg0MzgiLCJ0IjoxNzM0MTMyMTAyfQ==--64c7562300bdaaaf6ef8924abe47cd1240a38400be35264667f65d26be3fa3a0" data-gid="PR_kwDOAJy2Ks5S6u92" data-url="/facebook/react/issues/26940/show_partial?partial=issues%2Fsidebar%2Fshow%2Fmilestone" data-channel-event-name="milestone_updated" > <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-issue-sidebar-form" aria-label="Select milestones" data-turbo="false" action="/facebook/react/issues/26940/set_milestone?partial=issues%2Fsidebar%2Fshow%2Fmilestone" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" data-csrf="true" name="authenticity_token" value="og1nAhnJoSnUTpqwaNcT/r6WanbvbJjYlRGpfzyg7Tw/g6YOhrucEFrpvq8kY7XpK6t7LUL5Ji0+iN631PomYQ==" /> <div class="discussion-sidebar-heading text-bold"> Milestone </div> No milestone </form></div> <create-branch data-default-repo="facebook/react" data-selected-nwo="facebook/react" data-default-source-branch="main" data-sidebar-url="/facebook/react/issues/closing_references/partials/sidebar?source_id=1755454645&amp;source_type=ISSUE" class="discussion-sidebar-item d-block"> <div class="js-discussion-sidebar-item" data-target="create-branch.sidebarContainer"> <div data-issue-and-pr-hovercards-enabled > <development-menu> <!-- '"` --><!-- </textarea></xmp> --></option></form><form data-target="create-branch.developmentForm" data-turbo="false" class="js-issue-sidebar-form" aria-label="Link issues" action="/facebook/react/issues/closing_references?source_id=1391128438&amp;source_type=PULL_REQUEST" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" data-csrf="true" name="authenticity_token" value="MezK0CS9GiKAjEicPDfJQzLCrE0l+bFwsBdmbnCAdwNN5a23rGIGH1It+nZ+DRue5CFobW6H/l13ltKNGp/Ohg==" /> <div class="discussion-sidebar-heading text-bold"> Development </div> <p>Successfully merging this pull request may close these issues.</p> <include-fragment src="/facebook/react/pull/26940/partials/links?has_github_issues=false"></include-fragment> </form> </development-menu> </div> </div> </create-branch> <div id="partial-users-participants" class="discussion-sidebar-item"> <div class="participation"> <div class="discussion-sidebar-heading text-bold"> 4 participants </div> <div class="participation-avatars d-flex flex-wrap"> <a class="participant-avatar" data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"> <img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/2716369?s=52&amp;v=4" width="26" height="26" alt="@gnoff" /> </a> <a class="participant-avatar" data-hovercard-type="user" data-hovercard-url="/users/react-sizebot/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/react-sizebot"> <img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/123762883?s=52&amp;v=4" width="26" height="26" alt="@react-sizebot" /> </a> <a class="participant-avatar" data-hovercard-type="user" data-hovercard-url="/users/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage"> <img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/63648?s=52&amp;v=4" width="26" height="26" alt="@sebmarkbage" /> </a> <a class="participant-avatar" data-hovercard-type="user" data-hovercard-url="/users/facebook-github-bot/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/facebook-github-bot"> <img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/6422482?s=52&amp;v=4" width="26" height="26" alt="@facebook-github-bot" /> </a> </div> </div> </div> </div> </div> </div> </div> </div> <div hidden> <span class="js-add-to-batch-enabled">Add this suggestion to a batch that can be applied as a single commit.</span> <span class="js-unchanged-suggestion">This suggestion is invalid because no changes were made to the code.</span> <span class="js-closed-pull">Suggestions cannot be applied while the pull request is closed.</span> <span class="js-viewing-subset-changes">Suggestions cannot be applied while viewing a subset of changes.</span> <span class="js-one-suggestion-per-line">Only one suggestion per line can be applied in a batch.</span> <span class="js-reenable-add-to-batch">Add this suggestion to a batch that can be applied as a single commit.</span> <span class="js-validation-on-left-blob">Applying suggestions on deleted lines is not supported.</span> <span class="js-validation-on-right-blob">You must change the existing code in this line in order to create a valid suggestion.</span> <span class="js-outdated-comment">Outdated suggestions cannot be applied.</span> <span class="js-resolved-thread">This suggestion has been applied or marked resolved.</span> <span class="js-pending-review">Suggestions cannot be applied from pending reviews.</span> <span class="js-is-multiline">Suggestions cannot be applied on multi-line comments.</span> <span class="js-in-merge-queue">Suggestions cannot be applied while the pull request is queued to merge.</span> <span class="js-head-oid-not-loaded">Suggestion cannot be applied right now. Please check back later.</span> <div class="form-group errored m-0 error js-suggested-changes-inline-validation-template d-flex" style="cursor: default;"> <span class="js-suggested-changes-inline-error-message position-relative error m-0" style="max-width: inherit;"></span> </div> </div> </div> </div> </turbo-frame> </main> </div> </div> <footer class="footer pt-8 pb-6 f6 color-fg-muted p-responsive" role="contentinfo" > <h2 class='sr-only'>Footer</h2> <div class="d-flex flex-justify-center flex-items-center flex-column-reverse flex-lg-row flex-wrap flex-lg-nowrap"> <div class="d-flex flex-items-center flex-shrink-0 mx-2"> <a aria-label="Homepage" title="GitHub" class="footer-octicon mr-2" href="https://github.com"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-mark-github"> <path d="M12.5.75C6.146.75 1 5.896 1 12.25c0 5.089 3.292 9.387 7.863 10.91.575.101.79-.244.79-.546 0-.273-.014-1.178-.014-2.142-2.889.532-3.636-.704-3.866-1.35-.13-.331-.69-1.352-1.18-1.625-.402-.216-.977-.748-.014-.762.906-.014 1.553.834 1.769 1.179 1.035 1.74 2.688 1.25 3.349.948.1-.747.402-1.25.733-1.538-2.559-.287-5.232-1.279-5.232-5.678 0-1.25.445-2.285 1.178-3.09-.115-.288-.517-1.467.115-3.048 0 0 .963-.302 3.163 1.179.92-.259 1.897-.388 2.875-.388.977 0 1.955.13 2.875.388 2.2-1.495 3.162-1.179 3.162-1.179.633 1.581.23 2.76.115 3.048.733.805 1.179 1.825 1.179 3.09 0 4.413-2.688 5.39-5.247 5.678.417.36.776 1.05.776 2.128 0 1.538-.014 2.774-.014 3.162 0 .302.216.662.79.547C20.709 21.637 24 17.324 24 12.25 24 5.896 18.854.75 12.5.75Z"></path> </svg> </a> <span> &copy; 2024 GitHub,&nbsp;Inc. </span> </div> <nav aria-label="Footer"> <h3 class="sr-only" id="sr-footer-heading">Footer navigation</h3> <ul class="list-style-none d-flex flex-justify-center flex-wrap mb-2 mb-lg-0" aria-labelledby="sr-footer-heading"> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to Terms&quot;,&quot;label&quot;:&quot;text:terms&quot;}" href="https://docs.github.com/site-policy/github-terms/github-terms-of-service" data-view-component="true" class="Link--secondary Link">Terms</a> </li> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to privacy&quot;,&quot;label&quot;:&quot;text:privacy&quot;}" href="https://docs.github.com/site-policy/privacy-policies/github-privacy-statement" data-view-component="true" class="Link--secondary Link">Privacy</a> </li> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to security&quot;,&quot;label&quot;:&quot;text:security&quot;}" href="https://github.com/security" data-view-component="true" class="Link--secondary Link">Security</a> </li> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to status&quot;,&quot;label&quot;:&quot;text:status&quot;}" href="https://www.githubstatus.com/" data-view-component="true" class="Link--secondary Link">Status</a> </li> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to docs&quot;,&quot;label&quot;:&quot;text:docs&quot;}" href="https://docs.github.com/" data-view-component="true" class="Link--secondary Link">Docs</a> </li> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to contact&quot;,&quot;label&quot;:&quot;text:contact&quot;}" href="https://support.github.com?tags=dotcom-footer" data-view-component="true" class="Link--secondary Link">Contact</a> </li> <li class="mx-2" > <cookie-consent-link> <button type="button" class="Link--secondary underline-on-hover border-0 p-0 color-bg-transparent" data-action="click:cookie-consent-link#showConsentManagement" data-analytics-event="{&quot;location&quot;:&quot;footer&quot;,&quot;action&quot;:&quot;cookies&quot;,&quot;context&quot;:&quot;subfooter&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;cookies_link_subfooter_footer&quot;}" > Manage cookies </button> </cookie-consent-link> </li> <li class="mx-2"> <cookie-consent-link> <button type="button" class="Link--secondary underline-on-hover border-0 p-0 color-bg-transparent" data-action="click:cookie-consent-link#showConsentManagement" data-analytics-event="{&quot;location&quot;:&quot;footer&quot;,&quot;action&quot;:&quot;dont_share_info&quot;,&quot;context&quot;:&quot;subfooter&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;dont_share_info_link_subfooter_footer&quot;}" > Do not share my personal information </button> </cookie-consent-link> </li> </ul> </nav> </div> </footer> <ghcc-consent id="ghcc" class="position-fixed bottom-0 left-0" style="z-index: 999999" data-initial-cookie-consent-allowed="" data-cookie-consent-required="false"></ghcc-consent> <div id="ajax-error-message" class="ajax-error-message flash flash-error" hidden> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-alert"> <path d="M6.457 1.047c.659-1.234 2.427-1.234 3.086 0l6.082 11.378A1.75 1.75 0 0 1 14.082 15H1.918a1.75 1.75 0 0 1-1.543-2.575Zm1.763.707a.25.25 0 0 0-.44 0L1.698 13.132a.25.25 0 0 0 .22.368h12.164a.25.25 0 0 0 .22-.368Zm.53 3.996v2.5a.75.75 0 0 1-1.5 0v-2.5a.75.75 0 0 1 1.5 0ZM9 11a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> <button type="button" class="flash-close js-ajax-error-dismiss" aria-label="Dismiss error"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> </button> You can’t perform that action at this time. </div> <template id="site-details-dialog"> <details class="details-reset details-overlay details-overlay-dark lh-default color-fg-default hx_rsm" open> <summary role="button" aria-label="Close dialog"></summary> <details-dialog class="Box Box--overlay d-flex flex-column anim-fade-in fast hx_rsm-dialog hx_rsm-modal"> <button class="Box-btn-octicon m-0 btn-octicon position-absolute right-0 top-0" type="button" aria-label="Close dialog" data-close-dialog> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> </button> <div class="octocat-spinner my-6 js-details-dialog-spinner"></div> </details-dialog> </details> </template> <div class="Popover js-hovercard-content position-absolute" style="display: none; outline: none;"> <div class="Popover-message Popover-message--bottom-left Popover-message--large Box color-shadow-large" style="width:360px;"> </div> </div> <template id="snippet-clipboard-copy-button"> <div class="zeroclipboard-container position-absolute right-0 top-0"> <clipboard-copy aria-label="Copy" class="ClipboardButton btn js-clipboard-copy m-2 p-0" data-copy-feedback="Copied!" data-tooltip-direction="w"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-copy js-clipboard-copy-icon m-2"> <path d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 0 1 0 1.5h-1.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-1.5a.75.75 0 0 1 1.5 0v1.5A1.75 1.75 0 0 1 9.25 16h-7.5A1.75 1.75 0 0 1 0 14.25Z"></path><path d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0 1 14.25 11h-7.5A1.75 1.75 0 0 1 5 9.25Zm1.75-.25a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Z"></path> </svg> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-check js-clipboard-check-icon color-fg-success d-none m-2"> <path d="M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0Z"></path> </svg> </clipboard-copy> </div> </template> <template id="snippet-clipboard-copy-button-unpositioned"> <div class="zeroclipboard-container"> <clipboard-copy aria-label="Copy" class="ClipboardButton btn btn-invisible js-clipboard-copy m-2 p-0 d-flex flex-justify-center flex-items-center" data-copy-feedback="Copied!" data-tooltip-direction="w"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-copy js-clipboard-copy-icon"> <path d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 0 1 0 1.5h-1.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-1.5a.75.75 0 0 1 1.5 0v1.5A1.75 1.75 0 0 1 9.25 16h-7.5A1.75 1.75 0 0 1 0 14.25Z"></path><path d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0 1 14.25 11h-7.5A1.75 1.75 0 0 1 5 9.25Zm1.75-.25a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Z"></path> </svg> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-check js-clipboard-check-icon color-fg-success d-none"> <path d="M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0Z"></path> </svg> </clipboard-copy> </div> </template> </div> <div id="js-global-screen-reader-notice" class="sr-only mt-n1" aria-live="polite" aria-atomic="true" ></div> <div id="js-global-screen-reader-notice-assertive" class="sr-only mt-n1" aria-live="assertive" aria-atomic="true"></div> </body> </html>

Pages: 1 2 3 4 5 6 7 8 9 10