CINXE.COM
[Flight] Add bundler-less version of RSC using plain ESM by sebmarkbage · Pull Request #26889 · 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","report_hydro_web_vitals","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-0bdc8e6a0ba5.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-a5fee13a2775.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>[Flight] Add bundler-less version of RSC using plain ESM by sebmarkbage · Pull Request #26889 · 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="C6BE:2750D4:90048B:A8DED1:675BBC24" data-pjax-transient="true"/><meta name="html-safe-nonce" content="0d4c61a29cf84e0a67e61c42dc0c0f8168ef6a34302ed64478ffc521ff365c3e" data-pjax-transient="true"/><meta name="visitor-payload" content="eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiJDNkJFOjI3NTBENDo5MDA0OEI6QThERUQxOjY3NUJCQzI0IiwidmlzaXRvcl9pZCI6IjE1NTg5NTY4NTI1MzI0NjA1ODAiLCJyZWdpb25fZWRnZSI6InNvdXRoZWFzdGFzaWEiLCJyZWdpb25fcmVuZGVyIjoic291dGhlYXN0YXNpYSJ9" data-pjax-transient="true"/><meta name="visitor-hmac" content="6368b90084dca22b09cf4a0bf549d07a9afd8a7d4f49bdde95d2f2c82a3d6cb3" data-pjax-transient="true"/> <meta name="hovercard-subject-tag" content="pull_request:1375076672" 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="/<user-name>/<repo-name>/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="This isn't really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It's a new reference implementation package react-server-..."> <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/26889/pull_request_layout" /> <meta name="twitter:image" content="https://opengraph.githubassets.com/6b7e0ec6e21ae95a2175973e04760002a57294a917b487ff6c314ed16fffc332/facebook/react/pull/26889" /><meta name="twitter:site" content="@github" /><meta name="twitter:card" content="summary_large_image" /><meta name="twitter:title" content="[Flight] Add bundler-less version of RSC using plain ESM by sebmarkbage · Pull Request #26889 · facebook/react" /><meta name="twitter:description" content="This isn&amp;#39;t really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It&amp;#39;s a new reference implementation packa..." /> <meta property="og:image" content="https://opengraph.githubassets.com/6b7e0ec6e21ae95a2175973e04760002a57294a917b487ff6c314ed16fffc332/facebook/react/pull/26889" /><meta property="og:image:alt" content="This isn&#39;t really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It&#39;s a new reference implementation package react..." /><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="[Flight] Add bundler-less version of RSC using plain ESM by sebmarkbage · Pull Request #26889 · facebook/react" /><meta property="og:url" content="https://github.com/facebook/react/pull/26889" /><meta property="og:description" content="This isn&#39;t really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It&#39;s a new reference implementation package react..." /><meta property="og:author:username" content="sebmarkbage" /> <meta name="hostname" content="github.com"> <meta name="expected-hostname" content="github.com"> <meta http-equiv="x-pjax-version" content="1fd8066426daf43df8e41ff4aa20cf8c4e3bebf3e6aaa7a39879afbba6b446a5" 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="7f7c59348a040deb15f17231f3edddb2843a930c821d9822020109bbc3daeaa8" data-turbo-track="reload"> <meta name="turbo-cache-control" content="no-preview" data-turbo-transient=""> <meta name="voltron-timing" value="1714"> <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="{"category":"Marketing nav","action":"click to go to homepage","label":"ref_page:Marketing;ref_cta:Logomark;ref_loc:Header"}"> <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%2F26889" 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="{"event_type":"authentication.click","payload":{"location_in_page":"site header menu","repository_id":null,"auth_type":"SIGN_UP","originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="087cff76e6523bfc8b46a48809959436198043132e0672e69d309dac4e22f4fb" data-analytics-event="{"category":"Marketing nav","action":"click to Sign in","label":"ref_page:Marketing;ref_cta:Sign in;ref_loc:Header"}" > 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="{"location":"navbar","action":"github_copilot","context":"product","tag":"link","label":"github_copilot_link_product_navbar"}" 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="{"location":"navbar","action":"security","context":"product","tag":"link","label":"security_link_product_navbar"}" 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="{"location":"navbar","action":"actions","context":"product","tag":"link","label":"actions_link_product_navbar"}" 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="{"location":"navbar","action":"codespaces","context":"product","tag":"link","label":"codespaces_link_product_navbar"}" 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="{"location":"navbar","action":"issues","context":"product","tag":"link","label":"issues_link_product_navbar"}" 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="{"location":"navbar","action":"code_review","context":"product","tag":"link","label":"code_review_link_product_navbar"}" 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="{"location":"navbar","action":"discussions","context":"product","tag":"link","label":"discussions_link_product_navbar"}" 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="{"location":"navbar","action":"code_search","context":"product","tag":"link","label":"code_search_link_product_navbar"}" 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="{"location":"navbar","action":"all_features","context":"product","tag":"link","label":"all_features_link_product_navbar"}" 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="{"location":"navbar","action":"documentation","context":"product","tag":"link","label":"documentation_link_product_navbar"}" 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="{"location":"navbar","action":"github_skills","context":"product","tag":"link","label":"github_skills_link_product_navbar"}" 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="{"location":"navbar","action":"blog","context":"product","tag":"link","label":"blog_link_product_navbar"}" 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="{"location":"navbar","action":"enterprises","context":"solutions","tag":"link","label":"enterprises_link_solutions_navbar"}" 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="{"location":"navbar","action":"small_and_medium_teams","context":"solutions","tag":"link","label":"small_and_medium_teams_link_solutions_navbar"}" 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="{"location":"navbar","action":"startups","context":"solutions","tag":"link","label":"startups_link_solutions_navbar"}" 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="{"location":"navbar","action":"devsecops","context":"solutions","tag":"link","label":"devsecops_link_solutions_navbar"}" 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="{"location":"navbar","action":"devops","context":"solutions","tag":"link","label":"devops_link_solutions_navbar"}" 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="{"location":"navbar","action":"ci_cd","context":"solutions","tag":"link","label":"ci_cd_link_solutions_navbar"}" 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="{"location":"navbar","action":"view_all_use_cases","context":"solutions","tag":"link","label":"view_all_use_cases_link_solutions_navbar"}" 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="{"location":"navbar","action":"healthcare","context":"solutions","tag":"link","label":"healthcare_link_solutions_navbar"}" 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="{"location":"navbar","action":"financial_services","context":"solutions","tag":"link","label":"financial_services_link_solutions_navbar"}" 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="{"location":"navbar","action":"manufacturing","context":"solutions","tag":"link","label":"manufacturing_link_solutions_navbar"}" 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="{"location":"navbar","action":"government","context":"solutions","tag":"link","label":"government_link_solutions_navbar"}" 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="{"location":"navbar","action":"view_all_industries","context":"solutions","tag":"link","label":"view_all_industries_link_solutions_navbar"}" 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="{"location":"navbar","action":"ai","context":"resources","tag":"link","label":"ai_link_resources_navbar"}" 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="{"location":"navbar","action":"devops","context":"resources","tag":"link","label":"devops_link_resources_navbar"}" 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="{"location":"navbar","action":"security","context":"resources","tag":"link","label":"security_link_resources_navbar"}" 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="{"location":"navbar","action":"software_development","context":"resources","tag":"link","label":"software_development_link_resources_navbar"}" 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="{"location":"navbar","action":"view_all","context":"resources","tag":"link","label":"view_all_link_resources_navbar"}" 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="{"location":"navbar","action":"learning_pathways","context":"resources","tag":"link","label":"learning_pathways_link_resources_navbar"}" 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="{"location":"navbar","action":"white_papers_ebooks_webinars","context":"resources","tag":"link","label":"white_papers_ebooks_webinars_link_resources_navbar"}" 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="{"location":"navbar","action":"customer_stories","context":"resources","tag":"link","label":"customer_stories_link_resources_navbar"}" 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="{"location":"navbar","action":"partners","context":"resources","tag":"link","label":"partners_link_resources_navbar"}" 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="{"location":"navbar","action":"executive_insights","context":"resources","tag":"link","label":"executive_insights_link_resources_navbar"}" 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="{"location":"navbar","action":"github_sponsors","context":"open_source","tag":"link","label":"github_sponsors_link_open_source_navbar"}" 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="{"location":"navbar","action":"the_readme_project","context":"open_source","tag":"link","label":"the_readme_project_link_open_source_navbar"}" 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="{"location":"navbar","action":"topics","context":"open_source","tag":"link","label":"topics_link_open_source_navbar"}" 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="{"location":"navbar","action":"trending","context":"open_source","tag":"link","label":"trending_link_open_source_navbar"}" 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="{"location":"navbar","action":"collections","context":"open_source","tag":"link","label":"collections_link_open_source_navbar"}" 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="{"location":"navbar","action":"enterprise_platform","context":"enterprise","tag":"link","label":"enterprise_platform_link_enterprise_navbar"}" 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="{"location":"navbar","action":"advanced_security","context":"enterprise","tag":"link","label":"advanced_security_link_enterprise_navbar"}" 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="{"location":"navbar","action":"github_copilot","context":"enterprise","tag":"link","label":"github_copilot_link_enterprise_navbar"}" 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="{"location":"navbar","action":"premium_support","context":"enterprise","tag":"link","label":"premium_support_link_enterprise_navbar"}" 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="{"location":"navbar","action":"pricing","context":"global","tag":"link","label":"pricing_link_global_navbar"}" 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="CW7GYD9GdSqYdv-QHdxKSpC0TXkbOvWUD3vOJn2gViU6FTNwhEjN7R3aYJNIRQJtC89-mG8kNh-AkVjpmRK1vA" 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="{"location":"navbar","action":"searchbar","context":"global","tag":"input","label":"searchbar_input_global_navbar"}" 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-ef75eb2e-3b84-4611-9a3c-4ba3802cafc0" 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-ef75eb2e-3b84-4611-9a3c-4ba3802cafc0" 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="e4x2bXSsIA7TfSU027AP2fzkXUNuffAMYaVXhwGs+5EIQfnabeqxgkwk/r7ztYhqNg062W4Xr3JTFrFDFA+HeA==" /> <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="ibSGWVcyzqlGAYI5Zv1FpQjesBTvaBRvU1VE+mOCx42AxlSdWlSl/gUsH/t+5xROSpb0S2+bQYZAyPJhnp+IgA==" /> <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="b6+faOcs6SgqGhw1Q/qxi4qbYQOp12n0Y0kSyDQaqQvNkD6C8NPnP7Pg3dc3CIaxbI94BAMOAB3gNrqA+eNuuw==" /> </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%2F26889" 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="{"event_type":"authentication.click","payload":{"location_in_page":"site header menu","repository_id":null,"auth_type":"SIGN_UP","originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="087cff76e6523bfc8b46a48809959436198043132e0672e69d309dac4e22f4fb" data-analytics-event="{"category":"Marketing nav","action":"click to go to homepage","label":"ref_page:Marketing;ref_cta:Sign in;ref_loc:Header"}" > Sign in </a> </div> <a href="/signup?ref_cta=Sign+up&ref_loc=header+logged+out&ref_page=%2F%3Cuser-name%3E%2F%3Crepo-name%3E%2Fvoltron%2Fpull_requests_fragments%2Fpull_request_layout&source=header-repo&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="{"event_type":"authentication.click","payload":{"location_in_page":"site header menu","repository_id":null,"auth_type":"SIGN_UP","originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="087cff76e6523bfc8b46a48809959436198043132e0672e69d309dac4e22f4fb" data-analytics-event="{"category":"Sign up","action":"click to sign up for account","label":"ref_page:/<user-name>/<repo-name>/voltron/pull_requests_fragments/pull_request_layout;ref_cta:Sign up;ref_loc:header logged out"}" > 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-45c6c51c-73e0-4028-afcd-bd4729a17faf" aria-labelledby="tooltip-ecfe6a23-7070-4110-acf2-3d00f1836147" 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-ecfe6a23-7070-4110-acf2-3d00f1836147" for="icon-button-45c6c51c-73e0-4028-afcd-bd4729a17faf" 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="{"event_type":"authentication.click","payload":{"location_in_page":"notification subscription menu watch","repository_id":null,"auth_type":"LOG_IN","originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="1ac2c69afe2a4daa9fb61f9b014abbec6c9d633ffad7b043a307586fc3324c57" 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-91bc1166-4f1b-481e-9c52-d526ce88c963" 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="{"event_type":"authentication.click","payload":{"location_in_page":"repo details fork button","repository_id":10270250,"auth_type":"LOG_IN","originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="9c655dbffaf776c41de83bd109f317cbcd48e948ed6b0c098a511b5c4e504c01" 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,639" data-view-component="true" class="Counter">47.6k</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="{"event_type":"authentication.click","payload":{"location_in_page":"star button","repository_id":10270250,"auth_type":"LOG_IN","originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="faf0ccaa04b8801990536dcfb3c998726f69b3372397b650b1e212753305c95e" 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="230370 users starred this repository" data-singular-suffix="user starred this repository" data-plural-suffix="users starred this repository" data-turbo-replace="true" title="230,370" 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="{"category":"Underline navbar","action":"Click tab","label":"Code","target":"UNDERLINE_NAV.TAB"}" 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="{"category":"Underline navbar","action":"Click tab","label":"Issues","target":"UNDERLINE_NAV.TAB"}" 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="753" data-view-component="true" class="Counter">753</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="{"category":"Underline navbar","action":"Click tab","label":"Pull requests","target":"UNDERLINE_NAV.TAB"}" 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="157" data-view-component="true" class="Counter">157</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="{"category":"Underline navbar","action":"Click tab","label":"Actions","target":"UNDERLINE_NAV.TAB"}" 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="{"category":"Underline navbar","action":"Click tab","label":"Projects","target":"UNDERLINE_NAV.TAB"}" 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="{"category":"Underline navbar","action":"Click tab","label":"Wiki","target":"UNDERLINE_NAV.TAB"}" 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="{"category":"Underline navbar","action":"Click tab","label":"Security","target":"UNDERLINE_NAV.TAB"}" 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="{"category":"Underline navbar","action":"Click tab","label":"Insights","target":"UNDERLINE_NAV.TAB"}" 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-db0a946d-864c-4db7-940c-fd4d127c0e5d-button" popovertarget="action-menu-db0a946d-864c-4db7-940c-fd4d127c0e5d-overlay" aria-controls="action-menu-db0a946d-864c-4db7-940c-fd4d127c0e5d-list" aria-haspopup="true" aria-labelledby="tooltip-54cea39f-0c8c-4dae-b61a-6356a90022db" 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-54cea39f-0c8c-4dae-b61a-6356a90022db" for="action-menu-db0a946d-864c-4db7-940c-fd4d127c0e5d-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-db0a946d-864c-4db7-940c-fd4d127c0e5d-overlay" anchor="action-menu-db0a946d-864c-4db7-940c-fd4d127c0e5d-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-db0a946d-864c-4db7-940c-fd4d127c0e5d-button" id="action-menu-db0a946d-864c-4db7-940c-fd4d127c0e5d-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-9f38a05d-7ad8-4896-9f97-4094aba03576" 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-2f37a504-b9d7-4e2a-a461-33b7ce1b3de8" 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-09c7e762-9194-4830-b00b-7bb28675899f" 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-66360546-6404-45ed-9708-d641877262dc" 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-a68deee9-83c1-4904-86fa-a0bbdcf9985f" 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-133c00ec-0d49-48ed-9f2b-21bb6c869ed0" 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-ca1aadcb-2ce9-4200-a99a-eb68331900e2" 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-8980b633-b44e-49e6-8837-7b54dd67ca46" 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="eyJjIjoicHVsbF9yZXF1ZXN0OjEzNzUwNzY2NzIiLCJ0IjoxNzM0MDY1MTg4fQ==--3b326ab95edaeee418eae9cadf053193bdba32edd382057472a083bdcd2f6d9d" data-url="/facebook/react/pull/26889/partials/title?sticky=true" data-channel-event-name="title_updated" data-pull-is-open="false" data-gid="PR_kwDOAJy2Ks5R9gFA"> <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 “Sign up for GitHub”, 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="{"event_type":"authentication.click","payload":{"location_in_page":"new issue modal","repository_id":null,"auth_type":"LOG_IN","originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="3156204b346863050f809c695dfae55615bdd7def1028d5f5689d85954122869" 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">[Flight] Add bundler-less version of RSC using plain ESM</bdi> <span class="f1-light color-fg-muted">#26889</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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage">sebmarkbage</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="sebmarkbage/react:esmbundler" class="commit-ref css-truncate user-select-contain expandable head-ref"><a title="sebmarkbage/react:esmbundler" class="no-underline " href="/sebmarkbage/react/tree/esmbundler"><span class="css-truncate-target">sebmarkbage</span>:<span class="css-truncate-target">esmbundler</span></a></span><span><span data-view-component="true"> <clipboard-copy aria-label="Copy" data-copy-feedback="Copied!" value="sebmarkbage:esmbundler" 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-03T19:58:24Z" class="no-wrap">Jun 3, 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"> [Flight] Add bundler-less version of RSC using plain ESM </a> <span class="gh-header-number color-fg-muted pl-1">#26889</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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage">sebmarkbage</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="sebmarkbage/react:esmbundler" class="commit-ref css-truncate user-select-contain expandable head-ref"><a title="sebmarkbage/react:esmbundler" class="no-underline " href="/sebmarkbage/react/tree/esmbundler"><span class="css-truncate-target">sebmarkbage</span>:<span class="css-truncate-target">esmbundler</span></a></span><span><span data-view-component="true"> <clipboard-copy aria-label="Copy" data-copy-feedback="Copied!" value="sebmarkbage:esmbundler" 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-03T19:58:24Z" class="no-wrap">Jun 3, 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/26889/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/26889" 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="16" data-view-component="true" class="Counter">16</span> </a> <a href="/facebook/react/pull/26889/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/26889/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/26889/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="eyJjIjoicHVsbF9yZXF1ZXN0OjEzNzUwNzY2NzI6dGltZWxpbmUiLCJ0IjoxNzM0MDY1MTg4fQ==--c7edf0c9126587736367752ae7d7f68b8bac31045e88fb9c456e163de3d32776"> <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_kwDOAJy2Ks5R9gFA" data-url="/facebook/react/pull/26889/partials/body" data-channel-event-name="body_updated" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzNzUwNzY2NzIiLCJ0IjoxNzM0MDY1MTg4fQ==--3b326ab95edaeee418eae9cadf053193bdba32edd382057472a083bdcd2f6d9d"> <div data-view-component="true" class="TimelineItem ml-0 p-0"> <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&v=4" alt="sebmarkbage" 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-1737420670"> <div id="pullrequest-1375076672" 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-1737420670-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&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> commented <a href="#issue-1737420670" id="issue-1737420670-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-02T03:55:30Z" class="no-wrap">Jun 2, 2023</relative-time></a> <span class="js-comment-edit-history"> <span class="d-inline-block color-fg-muted">•</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_kwDOAJy2Ks5R9gFA" 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">This isn't really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept.</p> <p dir="auto">It's a new reference implementation package <code class="notranslate">react-server-dom-esm</code> as well as a fixture in <code class="notranslate">fixtures/flight-esm</code> (fork of <code class="notranslate">fixtures/flight</code>). This works pretty much the same as pieces we already have in the Webpack implementation but instead of loading modules using Webpack on the client it uses native browser ESM.</p> <p dir="auto">To really show it off, I don't use any JSX in the fixture and so it also doesn't use Babel or any compilation of the files.</p> <p dir="auto">This works because we don't actually bundle the server in the reference implementation in the first place. We instead use <a href="https://nodejs.org/api/esm.html#loaders" rel="nofollow">Node.js Loaders</a> to intercept files that contain <code class="notranslate">"use client"</code> and <code class="notranslate">"use server"</code> and replace them. There's a simple check for those exact bytes, and no parsing, so this is very fast.</p> <p dir="auto">Since the client isn't actually bundled, there's no module map needed. We can just send the file path to the file we want to load in the RSC payload for client references.</p> <p dir="auto">Since the existing reference implementation for Node.js already used ESM to load modules on the server, that all works the same, including Server Actions. No bundling.</p> <p dir="auto">There is one case that isn't implemented here. Importing a <code class="notranslate">"use server"</code> file from a Client Component. We don't have that implemented in the Webpack reference implementation neither - only in Next.js atm. In Webpack it would be implemented as a Webpack loader.</p> <p dir="auto">There are a few ways this can be implemented without a bundler:</p> <ul dir="auto"> <li>We can intercept the request from the browser importing this file in the HTTP server, and do a quick scan for <code class="notranslate">"use server"</code> in the file and replace it just like we do with loaders in Node.js. This is effectively how Vite works and likely how anyone using this technique would have to support JSX anyway.</li> <li>We can use native browser "loaders" once that's eventually available in the same way as in Node.js.</li> <li>We can generate import maps for each file and replace it with a pointer to a placeholder file. This requires scanning these ahead of time which defeats the purposes.</li> </ul> <p dir="auto">Another case that's not implemented is the inline <code class="notranslate">"use server"</code> closure in a Server Component. That would require the existing loader to be a bit smarter but would still only "compile" files that contains those bytes in the fast path check. This would also happen in the loader that already exists so wouldn't do anything substantially different than what we currently have here.</p> </div> </task-lists> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-comment-update" id="issue-1737420670-edit-form" data-type="json" data-turbo="false" action="/facebook/react/issues/26889" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="nmnSqGDCq3WSdVsfxu-v6Ngwdu2BkxJtpaAofihwcV60vkt7CBWsIhINv0mb6-sRZolM8vr-5sPSETCbAAJzLg" autocomplete="off" /> <include-fragment loading="lazy" src="/facebook/react/issues/26889/edit_form?textarea_id=issue-1737420670-body&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="Q-H_-zFojTYglDI28TZUIKCtFOcNrMqUkScS5g4Pt2SmvtLFzY2CT9snKmVF3aJgtuN2NRboDDz01wTNvpdD9w" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="PR_kwDOAJy2Ks5R9gFA"> <div class="js-comment-reactions-options d-flex flex-items-center flex-row flex-wrap"> <button name="input[content]" id="reactions--reaction_button_component-9be82d" value="THUMBS_UP react" data-button-index-position="0" data-reaction-label="+1" data-reaction-content="+1" aria-pressed="false" aria-label="thumbs up (8): sebmarkbage, 03:55AM on June 02, 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">8</span> </button> <tool-tip id="tooltip-c8168910-47d3-4a7d-b4ca-6a44e5e9b6ab" for="reactions--reaction_button_component-9be82d" popover="manual" data-direction="n" data-type="description" data-view-component="true" class="sr-only position-absolute">childrentime, lili21, kasperpeulen, Fabricio499, wongmjane, nickserv, iddan, and xc1427 reacted with thumbs up emoji</tool-tip> <button name="input[content]" id="reactions--reaction_button_component-d2a5f6" value="HEART react" data-button-index-position="5" data-reaction-label="Heart" data-reaction-content="heart" aria-pressed="false" aria-label="heart (17): sebmarkbage, 03:55AM on June 02, 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="heart" fallback-src="https://github.githubassets.com/assets/2764-982dc91ea48a.png" class="social-button-emoji">❤️</g-emoji> <span class="js-discussion-reaction-group-count">17</span> </button> <tool-tip id="tooltip-ae30a3fe-a207-4626-a0e1-3056ab4bf083" for="reactions--reaction_button_component-d2a5f6" popover="manual" data-direction="n" data-type="description" data-view-component="true" class="sr-only position-absolute">ryanflorence, jazzypants1989, sballesteros, BasixKOR, siddheshkothadi, nksaraf, yanndinendal, incepter, alvarlagerlof, childrentime, and 7 more reacted with heart 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="childrentime, lili21, kasperpeulen, Fabricio499, wongmjane, nickserv, iddan, and xc1427 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>8 reactions</span> </li> <li class="dropdown-item" aria-label="ryanflorence, jazzypants1989, sballesteros, BasixKOR, siddheshkothadi, nksaraf, yanndinendal, incepter, alvarlagerlof, childrentime, and 7 more reacted with heart emoji"> <g-emoji alias="heart" fallback-src="https://github.githubassets.com/assets/2764-982dc91ea48a.png" class="social-button-emoji mr-2">❤️</g-emoji> <span>17 reactions</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=Y3Vyc29yOnYyOpPPAAABjvJxmbgBqzEyNTI3MzUxNjA1&id=PR_kwDOAJy2Ks5R9gFA" ></div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="RRE_lADOAJy2Ks5nju9-zwAAAAIw4DLI"> <div id="event-9409934024" 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/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=40&u=f1387d49fb1d3a6e7b26f0e5847eca5fa82c26a5&v=4" width="20" height="20" alt="@sebmarkbage" /></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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage">sebmarkbage</a> requested review from <a data-hovercard-type="user" data-hovercard-url="/users/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon"><span class="Link--primary text-bold">gaearon</span></a>, <a data-hovercard-type="user" data-hovercard-url="/users/gnoff/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"><span class="Link--primary text-bold">gnoff</span></a> and <a data-hovercard-type="user" data-hovercard-url="/users/acdlite/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/acdlite"><span class="Link--primary text-bold">acdlite</span></a> <a href="#event-9409934024" data-view-component="true" class="css-truncate css-truncate-target Link--secondary Link"><relative-time tense="past" datetime="2023-06-02T03:55:30Z" data-view-component="true">June 2, 2023 03:55</relative-time></a> </div> </div> <div class="TimelineItem js-targetable-element" data-team-hovercards-enabled id="event-9409934363"> <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&u=1e8724230d8d2a259d754a1b580af5e52db552f4&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 <a id="label-cea073" 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> <a id="label-1b677f" 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-71f62150-8fe7-4d57-b249-365c9f27b7db" for="label-1b677f" 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> labels <a href="#event-9409934363" class="Link--secondary"><relative-time datetime="2023-06-02T03:55:36Z" class="no-wrap">Jun 2, 2023</relative-time></a> </div> </div> <div id="event-9409950462" 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/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=40&u=f1387d49fb1d3a6e7b26f0e5847eca5fa82c26a5&v=4" width="20" height="20" alt="@sebmarkbage" /></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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage">sebmarkbage</a> <a data-hydro-click="{"event_type":"force_push_timeline_diff.click","payload":{"pull_request_id":1375076672,"repository_id":10270250,"event_id":9409950462,"originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="f07d154915529634db94e9d5b6d11d03a8567684d30b7aafc4777a106dd78c47" href="/facebook/react/compare/7ad3e2aa3d303cc21ab21bb8597532738b192398..b95e2ac45ebd77929ac5aadfc9d70fbfc9f00db7" 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">esmbundler</span> </span> </span> branch from <a href="/facebook/react/commit/7ad3e2aa3d303cc21ab21bb8597532738b192398" data-view-component="true" class="Link--primary Link text-bold"><code>7ad3e2a</code></a> to <a href="/facebook/react/commit/b95e2ac45ebd77929ac5aadfc9d70fbfc9f00db7" data-view-component="true" class="Link--primary Link text-bold"><code>b95e2ac</code></a> <a href="/facebook/react/compare/7ad3e2aa3d303cc21ab21bb8597532738b192398..b95e2ac45ebd77929ac5aadfc9d70fbfc9f00db7" data-hydro-click="{"event_type":"force_push_timeline_diff.click","payload":{"pull_request_id":1375076672,"repository_id":10270250,"event_id":9409950462,"originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="f07d154915529634db94e9d5b6d11d03a8567684d30b7aafc4777a106dd78c47" 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-9409950462" data-view-component="true" class="css-truncate css-truncate-target Link--secondary Link"><relative-time tense="past" datetime="2023-06-02T03:58:47Z" data-view-component="true">June 2, 2023 03:58</relative-time></a> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="IC_kwDOAJy2Ks5dw89K"> <div class="TimelineItem js-comment-container" data-gid="IC_kwDOAJy2Ks5dw89K" data-url="/facebook/react/comments/IC_kwDOAJy2Ks5dw89K/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&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-1573113674"> <div class="ml-n3 timeline-comment unminimized-comment comment previewable-edit js-task-list-container js-comment timeline-comment--caret" data-body-version="14cfd45958847019a8b8bb7d42401cbcddfef597dd1e1c4bbfda830306edd19c"> <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-1573113674-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-1573113674" id="issuecomment-1573113674-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-02T04:04:38Z" class="no-wrap">Jun 2, 2023</relative-time></a> <span class="js-comment-edit-history"> <span class="d-inline-block color-fg-muted">•</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_kwDOAJy2Ks5dw89K" 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/e1ad4aa3615333009d76f947ff05ddeff01039c6...acad290d5c02f1f417be0f739f2598cf3913ef46"><tt>e1ad4aa...acad290</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/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-dom/cjs/react-dom.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-dom/cjs/react-dom.production.min.js</a></td> <td><strong>=</strong></td> <td>164.23 kB</td> <td>164.23 kB</td> <td>=</td> <td>51.73 kB</td> <td>51.72 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-dom/cjs/react-dom.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-dom/cjs/react-dom.production.min.js</a></td> <td><strong>=</strong></td> <td>171.67 kB</td> <td>171.67 kB</td> <td>=</td> <td>53.97 kB</td> <td>53.97 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/facebook-www/ReactDOM-prod.classic.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">facebook-www/ReactDOM-prod.classic.js</a></td> <td><strong>=</strong></td> <td>570.12 kB</td> <td>570.12 kB</td> <td>=</td> <td>100.57 kB</td> <td>100.58 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/facebook-www/ReactDOM-prod.modern.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">facebook-www/ReactDOM-prod.modern.js</a></td> <td><strong>=</strong></td> <td>553.90 kB</td> <td>553.90 kB</td> <td>=</td> <td>97.75 kB</td> <td>97.75 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.31 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.66 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.51 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.72 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>46.70 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.58 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.39 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.68 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>92.75 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>22.11 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>22.89 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.03 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/client.browser.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/client.browser.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.25 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.17 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/client.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/client.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.06 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.08 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/client.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/client.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.15 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.61 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>35.02 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.91 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>12.52 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/index.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/index.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.28 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.22 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/server.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/server.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.19 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/server.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/server.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.31 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.66 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.51 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.72 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>46.70 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.58 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.39 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.68 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>92.75 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>22.11 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>22.89 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.03 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/client.browser.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/client.browser.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.25 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.17 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/client.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/client.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.06 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.08 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/client.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/client.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.15 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.61 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>35.02 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.91 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>12.52 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/index.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/index.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.28 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.22 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/server.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/server.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.19 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/server.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/server.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.31 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.66 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.51 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.72 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>46.70 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.58 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.39 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.68 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>92.75 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>22.11 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>22.89 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.03 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/client.browser.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/client.browser.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.25 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.17 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/client.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/client.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.06 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.08 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/client.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/client.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.15 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.61 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>35.02 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.91 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>12.52 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/index.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/index.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.28 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.22 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/server.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/server.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.19 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/server.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/server.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 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/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.31 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.66 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.51 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.72 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>46.70 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.58 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.39 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.68 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>92.75 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>22.11 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>22.89 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.03 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/client.browser.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/client.browser.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.25 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.17 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/client.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/client.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.06 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.08 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/client.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/client.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.15 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.61 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>35.02 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.91 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>12.52 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/index.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/index.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.28 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.22 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/server.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/server.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.19 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-experimental/react-server-dom-esm/server.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-experimental/react-server-dom-esm/server.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.31 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.66 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.51 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.72 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>46.70 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.58 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.39 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.68 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>92.75 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>22.11 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>22.89 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.03 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/client.browser.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/client.browser.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.25 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.17 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/client.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/client.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.06 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.08 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/client.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/client.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.15 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.61 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>35.02 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.91 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>12.52 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/index.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/index.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.28 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.22 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/server.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/server.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.19 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable-semver/react-server-dom-esm/server.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable-semver/react-server-dom-esm/server.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.31 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.66 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.51 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.72 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>46.70 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.58 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>9.39 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.68 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>92.75 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>22.11 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>22.89 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.03 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/client.browser.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/client.browser.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.25 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.17 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/client.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/client.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.06 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.08 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/client.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/client.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>47.15 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>11.61 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>35.02 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>8.91 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.min.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>12.52 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>3.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/index.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/index.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.28 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.22 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/server.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/server.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.19 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 kB</td> </tr> <tr> <td><a href="https://react-builds.vercel.app/commits/acad290d5c02f1f417be0f739f2598cf3913ef46/files/oss-stable/react-server-dom-esm/server.node.js?compare=e1ad4aa3615333009d76f947ff05ddeff01039c6" rel="nofollow">oss-stable/react-server-dom-esm/server.node.js</a></td> <td><strong>+∞%</strong></td> <td>0.00 kB</td> <td>0.24 kB</td> <td>+∞%</td> <td>0.00 kB</td> <td>0.16 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/acad290d5c02f1f417be0f739f2598cf3913ef46/hovercard" href="https://github.com/facebook/react/commit/acad290d5c02f1f417be0f739f2598cf3913ef46"><tt>acad290</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="WY30hGMv4tE75x-aY4tU6ok9dV06rgYvfmZDAtFQzJ38yjHFVc-b8_2_JD39VZ5dUqAhHJhayn1nSqkRJdHYrA" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="IC_kwDOAJy2Ks5dw89K"> <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-1573113674-edit-form" data-turbo="false" action="/facebook/react/issue_comments/1573113674" 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="E0xzqtR4pw3H5d1zUwcB254cA8hUWnOkm+fvB5QXcuQcIzZzUf2Oyg1oKnqA80LsqAlVZwkEiKUOkxhOR/bhGg==" /> <include-fragment loading="lazy" src="/facebook/react/issue_comments/1573113674/edit_form?textarea_id=issuecomment-1573113674-body&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="IC_kwDOAJy2Ks5dxCSk"> <div class="TimelineItem js-comment-container" data-gid="IC_kwDOAJy2Ks5dxCSk" data-url="/facebook/react/comments/IC_kwDOAJy2Ks5dxCSk/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/dai-shi/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/dai-shi"><img class="avatar rounded-2 avatar-user" src="https://avatars.githubusercontent.com/u/490574?s=80&u=3b4c1b7f1db9c6a43eafbe0b5c341c05d2dc93a1&v=4" width="40" height="40" alt="@dai-shi" /></a> </div> <div class=" timeline-comment-group js-minimizable-comment-group js-targetable-element TimelineItem-body my-0 " id="issuecomment-1573135524"> <div class="ml-n3 timeline-comment unminimized-comment comment previewable-edit js-task-list-container js-comment timeline-comment--caret" data-body-version="87740f1b3e246aca2d82ad4b30367eb42704192b597390f7309d0104cc1d3836"> <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-1573135524-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 previously committed to the react repository." data-view-component="true" class="tooltipped tooltipped-n"> <span data-view-component="true" class="Label ml-1">Contributor</span> </span> </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/dai-shi/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/dai-shi">dai-shi</a> </strong> commented <a href="#issuecomment-1573135524" id="issuecomment-1573135524-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-02T04:42:07Z" class="no-wrap">Jun 2, 2023</relative-time></a> </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"> <blockquote> <p dir="auto">This isn't really meant to be actually used</p> </blockquote> <p dir="auto">I'm currently using <code class="notranslate">react-server-dom-webpack</code> reference implementation with hacks with Vite. I was hoping to have a non-bundler-specific implementation, something like <code class="notranslate">react-server-dom-esm</code>.</p> <blockquote> <p dir="auto">there are many issues with this approach</p> </blockquote> <p dir="auto">Are those issues specific to the <code class="notranslate">-esm</code> ref impl, or do they also apply to <code class="notranslate">-webpack</code> one?<br> So, my question is, what are things <code class="notranslate">-esm</code> one can't do, but <code class="notranslate">-webpack</code> one can?</p> <p dir="auto">The general question should be: How strongly would you suggest to avoid using <code class="notranslate">-esm</code> or even <code class="notranslate">-webpack</code>?</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="86eSwf7nJKLYM0aVzusn8L33g0ZJ_biCJ8BL4d-ZAnBW4FeAyAddgB5rfTJQNe1HZmrXB-sJdNA-7KHyKxgWQQ" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="IC_kwDOAJy2Ks5dxCSk"> <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-1573135524-edit-form" data-turbo="false" action="/facebook/react/issue_comments/1573135524" 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="nSvMgusxJGAqL1RXsyIcOGWmjd9VmHQLj0oVlEMEOixxL/ckT2ne5URgU3u85ftXSfRhkECFzRIth7iY80I7Rw==" /> <include-fragment loading="lazy" src="/facebook/react/issue_comments/1573135524/edit_form?textarea_id=issuecomment-1573135524-body&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="IC_kwDOAJy2Ks5dxDDB"> <div class="TimelineItem js-comment-container" data-gid="IC_kwDOAJy2Ks5dxDDB" data-url="/facebook/react/comments/IC_kwDOAJy2Ks5dxDDB/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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage"><img class="avatar rounded-2 avatar-user" src="https://avatars.githubusercontent.com/u/63648?s=80&u=f1387d49fb1d3a6e7b26f0e5847eca5fa82c26a5&v=4" width="40" height="40" alt="@sebmarkbage" /></a> </div> <div class=" timeline-comment-group js-minimizable-comment-group js-targetable-element TimelineItem-body my-0 " id="issuecomment-1573138625"> <div class="ml-n3 timeline-comment unminimized-comment comment previewable-edit js-task-list-container js-comment timeline-comment--caret" data-body-version="94bf5f5ec48410b0586f0880d3f76b9e1db9be828f91a823790e0e7293925546"> <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-1573138625-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> <span aria-label="This user is the author of this pull request." data-view-component="true" class="tooltipped tooltipped-n"> <span data-view-component="true" class="Label ml-1">Author</span> </span> </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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage">sebmarkbage</a> </strong> commented <a href="#issuecomment-1573138625" id="issuecomment-1573138625-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-02T04:48:03Z" class="no-wrap">Jun 2, 2023</relative-time></a> </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">It’s not so much that you can’t use it, after all the <code class="notranslate">-webpack</code> on is what Next.js uses, but more that you probably need a lot more in addition in practice for efficiency and compatibility.</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="llXM3lMcyiGAinrJ_n6ojmW6hprbelhRDbTVoHZAjJszEgmfZfyzA0bSQW5goGI5vifS23mOlAMUmD-zgsGYqg" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="IC_kwDOAJy2Ks5dxDDB"> <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-1573138625-edit-form" data-turbo="false" action="/facebook/react/issue_comments/1573138625" 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="AXT+3HVJGU/RYi6o11vXvUKMWTUZw3wmp75w73pPj6hcqBNNjTMJxVU5o8so9Qv/MgIgz1w/Ta8kZCfvLu8gXw==" /> <include-fragment loading="lazy" src="/facebook/react/issue_comments/1573138625/edit_form?textarea_id=issuecomment-1573138625-body&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="IC_kwDOAJy2Ks5dxDLm"> <div class="TimelineItem js-comment-container" data-gid="IC_kwDOAJy2Ks5dxDLm" data-url="/facebook/react/comments/IC_kwDOAJy2Ks5dxDLm/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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage"><img class="avatar rounded-2 avatar-user" src="https://avatars.githubusercontent.com/u/63648?s=80&u=f1387d49fb1d3a6e7b26f0e5847eca5fa82c26a5&v=4" width="40" height="40" alt="@sebmarkbage" /></a> </div> <div class=" timeline-comment-group js-minimizable-comment-group js-targetable-element TimelineItem-body my-0 " id="issuecomment-1573139174"> <div class="ml-n3 timeline-comment unminimized-comment comment previewable-edit js-task-list-container js-comment timeline-comment--caret" data-body-version="5a2e71a4ebf85bb5eb2c2d778d97ea891501acd69bc01888fa590149f93cf1e5"> <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-1573139174-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> <span aria-label="This user is the author of this pull request." data-view-component="true" class="tooltipped tooltipped-n"> <span data-view-component="true" class="Label ml-1">Author</span> </span> </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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage">sebmarkbage</a> </strong> commented <a href="#issuecomment-1573139174" id="issuecomment-1573139174-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-02T04:49:12Z" class="no-wrap">Jun 2, 2023</relative-time></a> </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">Btw we’re happy to host a Vite version upstream without hacks if a reasonably reusable and compatible version that follows the patterns of the others.</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 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="kCuv9CirwiDPW-IR-XOA5qKohqo5mulNoKy45BtD8bU1bGq1Hku7AgkD2bZnrUpReTXS65tuJR-5gFL378LlhA" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="IC_kwDOAJy2Ks5dxDLm"> <input type="hidden" name="input[context]" value="" > <div class="js-comment-reactions-options d-flex flex-items-center flex-row flex-wrap"> <button name="input[content]" id="reactions--reaction_button_component-e12732" value="THUMBS_UP react" data-button-index-position="0" data-reaction-label="+1" data-reaction-content="+1" aria-pressed="false" aria-label="react with thumbs up" 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">5</span> </button> <tool-tip id="tooltip-1cbd0f09-4868-44ae-b281-a6b72260eb5f" for="reactions--reaction_button_component-e12732" popover="manual" data-direction="n" data-type="description" data-view-component="true" class="sr-only position-absolute">lindelleric, iamsuneeth, nickserv, jazzypants1989, and himself65 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="lindelleric, iamsuneeth, nickserv, jazzypants1989, and himself65 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>5 reactions</span> </li> </ul> </details> </div> </div> </form></div> </div> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-comment-update" id="issuecomment-1573139174-edit-form" data-turbo="false" action="/facebook/react/issue_comments/1573139174" 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="n2WaHUYHwbBUT1kmEcYNDXmzeeduhQ7tL2GzEf5tySNzZFd0ch/azfFBPNG2z1kSVVzTVwdIhUcajM/V/sBJtg==" /> <include-fragment loading="lazy" src="/facebook/react/issue_comments/1573139174/edit_form?textarea_id=issuecomment-1573139174-body&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="IC_kwDOAJy2Ks5dxGwX"> <div class="TimelineItem js-comment-container" data-gid="IC_kwDOAJy2Ks5dxGwX" data-url="/facebook/react/comments/IC_kwDOAJy2Ks5dxGwX/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/dai-shi/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/dai-shi"><img class="avatar rounded-2 avatar-user" src="https://avatars.githubusercontent.com/u/490574?s=80&u=3b4c1b7f1db9c6a43eafbe0b5c341c05d2dc93a1&v=4" width="40" height="40" alt="@dai-shi" /></a> </div> <div class=" timeline-comment-group js-minimizable-comment-group js-targetable-element TimelineItem-body my-0 " id="issuecomment-1573153815"> <div class="ml-n3 timeline-comment unminimized-comment comment previewable-edit js-task-list-container js-comment timeline-comment--caret" data-body-version="6618ada96ae249068b0f37cd87ff0ab9d439646fdc33b911bb195f1f02e8579c"> <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-1573153815-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 previously committed to the react repository." data-view-component="true" class="tooltipped tooltipped-n"> <span data-view-component="true" class="Label ml-1">Contributor</span> </span> </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/dai-shi/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/dai-shi">dai-shi</a> </strong> commented <a href="#issuecomment-1573153815" id="issuecomment-1573153815-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-02T05:06:41Z" class="no-wrap">Jun 2, 2023</relative-time></a> </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"> <blockquote> <p dir="auto">more that you probably need a lot more in addition in practice for efficiency and compatibility.</p> </blockquote> <p dir="auto">That makes sense. (that's something I'm interested in.)</p> <blockquote> <p dir="auto">happy to host a Vite version upstream without hacks</p> </blockquote> <p dir="auto">It would be great! I'd first explore if <code class="notranslate">react-server-dom-esm</code> works for my case, and will see.<br> cc <a class="user-mention notranslate" data-hovercard-type="user" data-hovercard-url="/users/cyco130/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="https://github.com/cyco130">@cyco130</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="OqeeVPqt7ntKnrdPILayb6bUMUxvk9IMASg7RGSXyE6f4FsVzE2XWYzGjOi-aHjYfUllDc1nHl4YBNFXkBbcfw" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="IC_kwDOAJy2Ks5dxGwX"> <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-1573153815-edit-form" data-turbo="false" action="/facebook/react/issue_comments/1573153815" 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="druDo9VrM7dfT4k82Z8ogX0y9pNIhqCHsYp3GT0MN/AByAxQrFW1nke84TchY8rxYsypAJoq+t2Gg5oolq3SKA==" /> <include-fragment loading="lazy" src="/facebook/react/issue_comments/1573153815/edit_form?textarea_id=issuecomment-1573153815-body&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="IC_kwDOAJy2Ks5dxRee"> <div class="TimelineItem js-comment-container" data-gid="IC_kwDOAJy2Ks5dxRee" data-url="/facebook/react/comments/IC_kwDOAJy2Ks5dxRee/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/nksaraf/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/nksaraf"><img class="avatar rounded-2 avatar-user" src="https://avatars.githubusercontent.com/u/11255148?s=80&u=0f946cc4ba8603a3aba8e876352647790f97a07e&v=4" width="40" height="40" alt="@nksaraf" /></a> </div> <div class=" timeline-comment-group js-minimizable-comment-group js-targetable-element TimelineItem-body my-0 " id="issuecomment-1573197726"> <div class="ml-n3 timeline-comment unminimized-comment comment previewable-edit js-task-list-container js-comment timeline-comment--caret" data-body-version="726044eeb7226ec2e84a9546d634b493dc389ba696d8544262243ec6a6742356"> <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-1573197726-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/nksaraf/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/nksaraf">nksaraf</a> </strong> commented <a href="#issuecomment-1573197726" id="issuecomment-1573197726-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-02T06:00:32Z" class="no-wrap">Jun 2, 2023</relative-time></a> </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"> <blockquote> <p dir="auto">Btw we’re happy to host a Vite version upstream without hacks if a reasonably reusable and compatible version that follows the patterns of the others.</p> </blockquote> <p dir="auto">I have been working on something. I didn't know if the react team is down for an integration there but ill assemble the pieces and put out a PR if the interest is there</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 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="r1zmiLQR7t7YVRARjNIT5JZDKWx8eyeqaXCBT3DzEEIKGyPJgvGX_B4NK7YSDNlTTd59Ld6P6_hwXGtchHIEcw" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="IC_kwDOAJy2Ks5dxRee"> <input type="hidden" name="input[context]" value="" > <div class="js-comment-reactions-options d-flex flex-items-center flex-row flex-wrap"> <button name="input[content]" id="reactions--reaction_button_component-7366a5" value="THUMBS_UP react" data-button-index-position="0" data-reaction-label="+1" data-reaction-content="+1" aria-pressed="false" aria-label="react with thumbs up" 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">5</span> </button> <tool-tip id="tooltip-853ae7e7-eae7-48ac-8a99-c5e98e739924" for="reactions--reaction_button_component-7366a5" popover="manual" data-direction="n" data-type="description" data-view-component="true" class="sr-only position-absolute">dai-shi, childrentime, lindelleric, nickserv, and jazzypants1989 reacted with thumbs up emoji</tool-tip> <button name="input[content]" id="reactions--reaction_button_component-5a7fd8" value="HEART react" data-button-index-position="5" data-reaction-label="Heart" data-reaction-content="heart" aria-pressed="false" aria-label="react with heart" 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="heart" fallback-src="https://github.githubassets.com/assets/2764-982dc91ea48a.png" class="social-button-emoji">❤️</g-emoji> <span class="js-discussion-reaction-group-count">2</span> </button> <tool-tip id="tooltip-ead63e47-6b7a-4617-a3db-ab17f94b59d5" for="reactions--reaction_button_component-5a7fd8" popover="manual" data-direction="n" data-type="description" data-view-component="true" class="sr-only position-absolute">gaearon and karlhorky reacted with heart 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="dai-shi, childrentime, lindelleric, nickserv, and jazzypants1989 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>5 reactions</span> </li> <li class="dropdown-item" aria-label="gaearon and karlhorky reacted with heart emoji"> <g-emoji alias="heart" fallback-src="https://github.githubassets.com/assets/2764-982dc91ea48a.png" class="social-button-emoji mr-2">❤️</g-emoji> <span>2 reactions</span> </li> </ul> </details> </div> </div> </form></div> </div> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-comment-update" id="issuecomment-1573197726-edit-form" data-turbo="false" action="/facebook/react/issue_comments/1573197726" 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="PB0na2jFwyvC+svw0muwIiQBdtfLJH1aRrTJRJTlNG1Xo8tNMUZSpGWRBy7qbe4kbR4N399nxGy1vqaDB6EKKA==" /> <include-fragment loading="lazy" src="/facebook/react/issue_comments/1573197726/edit_form?textarea_id=issuecomment-1573197726-body&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="PRR_kwDOAJy2Ks5W36qD"> <div class=""> <div id="pullrequestreview-1457498755" class="js-comment js-updatable-content js-socket-channel js-targetable-element js-minimize-container" data-gid="PRR_kwDOAJy2Ks5W36qD" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0X3JldmlldzoxNDU3NDk4NzU1IiwidCI6MTczNDA2NTE4OX0=--6dca99972c39a6e895026f8d60898c41c0661fefcb26b9d80d5e81b3533fc4c5" data-url="/facebook/react/pull/26889/partials/reviews/1457498755" > <div data-view-component="true" class="TimelineItem"> <a href="/gaearon" data-view-component="true" class="TimelineItem-avatar avatar circle lh-0 Link"><img data-hovercard-type="user" data-hovercard-url="/users/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" src="https://avatars.githubusercontent.com/u/810438?s=60&v=4" alt="gaearon" size="40" height="40" width="40" data-view-component="true" /></a> <div aria-role="image" 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 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/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon">gaearon</a> </strong> reviewed <span class="color-fg-muted"> <a href="#pullrequestreview-1457498755" class="js-timestamp Link--secondary" id="pullrequestreview-1457498755-permalink"> <relative-time datetime="2023-06-02T13:42:44Z" class="no-wrap">Jun 2, 2023</relative-time> </a> </span> </div> <div class="ml-md-2 mt-md-0 mt-2 flex-shrink-0"> <a href="/facebook/react/pull/26889/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 py-0 pl-4"> <div data-view-component="true" class="TimelineItem-body my-0"> <turbo-frame id="review-thread-or-comment-id-776562230" target="_top"> <details data-resolved="true" data-deferred-details-content-url="/facebook/react/pull/26889/threads/776562230?rendering_on_files_tab=false" data-hidden-comment-ids="1214398261,1214616456" data-view-component="true" class="review-thread-component js-comment-container js-resolvable-timeline-thread-container Details-element details-reset mb-3 border rounded-2"> <summary role="button" data-view-component="true" class="js-toggle-outdated-comments py-2 px-3 rounded-2 color-bg-subtle"> <div class="d-flex flex-items-center"> <span class="flex-auto mr-3 d-flex flex-items-center"> <a href="/facebook/react/pull/26889/files#diff-d6173f891b84be82c717426c445adb54bd2c3915eee6f5afdeb4e72683256267" class="text-mono text-small Link--primary wb-break-all mr-2">fixtures/flight-esm/server/region.js</a> <span title="Label: Outdated" data-view-component="true" class="Label Label--secondary"> Outdated </span> </span> <span class="btn-link color-fg-muted f6 Details-content--closed"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-unfold mr-1"> <path d="m8.177.677 2.896 2.896a.25.25 0 0 1-.177.427H8.75v1.25a.75.75 0 0 1-1.5 0V4H5.104a.25.25 0 0 1-.177-.427L7.823.677a.25.25 0 0 1 .354 0ZM7.25 10.75a.75.75 0 0 1 1.5 0V12h2.146a.25.25 0 0 1 .177.427l-2.896 2.896a.25.25 0 0 1-.354 0l-2.896-2.896A.25.25 0 0 1 5.104 12H7.25v-1.25Zm-5-2a.75.75 0 0 0 0-1.5h-.5a.75.75 0 0 0 0 1.5h.5ZM6 8a.75.75 0 0 1-.75.75h-.5a.75.75 0 0 1 0-1.5h.5A.75.75 0 0 1 6 8Zm2.25.75a.75.75 0 0 0 0-1.5h-.5a.75.75 0 0 0 0 1.5h.5ZM12 8a.75.75 0 0 1-.75.75h-.5a.75.75 0 0 1 0-1.5h.5A.75.75 0 0 1 12 8Zm2.25.75a.75.75 0 0 0 0-1.5h-.5a.75.75 0 0 0 0 1.5h.5Z"></path> </svg>Show resolved</span> <span class="btn-link color-fg-muted f6 Details-content--open"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-fold mr-1"> <path d="M10.896 2H8.75V.75a.75.75 0 0 0-1.5 0V2H5.104a.25.25 0 0 0-.177.427l2.896 2.896a.25.25 0 0 0 .354 0l2.896-2.896A.25.25 0 0 0 10.896 2ZM8.75 15.25a.75.75 0 0 1-1.5 0V14H5.104a.25.25 0 0 1-.177-.427l2.896-2.896a.25.25 0 0 1 .354 0l2.896 2.896a.25.25 0 0 1-.177.427H8.75v1.25Zm-6.5-6.5a.75.75 0 0 0 0-1.5h-.5a.75.75 0 0 0 0 1.5h.5ZM6 8a.75.75 0 0 1-.75.75h-.5a.75.75 0 0 1 0-1.5h.5A.75.75 0 0 1 6 8Zm2.25.75a.75.75 0 0 0 0-1.5h-.5a.75.75 0 0 0 0 1.5h.5ZM12 8a.75.75 0 0 1-.75.75h-.5a.75.75 0 0 1 0-1.5h.5A.75.75 0 0 1 12 8Zm2.25.75a.75.75 0 0 0 0-1.5h-.5a.75.75 0 0 0 0 1.5h.5Z"></path> </svg>Hide resolved</span> </div> </summary> <div data-view-component="true"> <include-fragment> <span data-view-component="true"> <svg aria-label="Loading" style="box-sizing: content-box; color: var(--color-icon-primary);" width="64" height="64" viewBox="0 0 16 16" fill="none" role="img" data-view-component="true" class="my-3 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> </include-fragment> </div> </details></turbo-frame> </div> </div> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="C_kwDOAJ5MqtoAKGFjYWQyOTBkNWMwMmYxZjQxN2JlMGY3MzlmMjU5OGNmMzkxM2VmNDY"> <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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/63648?s=40&v=4" width="20" height="20" alt="@sebmarkbage" class=" avatar-user" /> </a> </div> </div> <div class="pr-1 flex-auto min-width-0" > <code> <a title="Add Flight ESM implementation and fixture" data-pjax="true" class="Link--secondary markdown-title" href="/facebook/react/pull/26889/commits/acad290d5c02f1f417be0f739f2598cf3913ef46">Add Flight ESM implementation and fixture</a> </code> </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_kwDOAJ5MqtoAKGFjYWQyOTBkNWMwMmYxZjQxN2JlMGY3MzlmMjU5OGNmMzkxM2VmNDY" 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="eyJjIjoicmVwbzoxMDI3MDI1MDpjb21taXQ6YWNhZDI5MGQ1YzAyZjFmNDE3YmUwZjczOWYyNTk4Y2YzOTEzZWY0NiIsInQiOjE3MzQwNjUxODl9--0c4682d7250c9d55a57a88ff5eaa56c7c4669c9623a6da7412420b60a0cd66c0" data-url="/facebook/react/pull/26889/partials/commit_status_icon?oid=acad290d5c02f1f417be0f739f2598cf3913ef46"> <batch-deferred-content class="d-inline-block" data-url="/facebook/react/commits/checks-statuses-rollups"> <input type="hidden" name="oid" value="acad290d5c02f1f417be0f739f2598cf3913ef46" 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/26889/commits/acad290d5c02f1f417be0f739f2598cf3913ef46" class="Link--secondary">acad290</a> </code> </div> </div> </div> </div> </div> </div> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="HRFPE_lADOAJy2Ks5nju9-zwAAAAIxM7pG"> <div id="event-9415408198" 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/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=40&u=f1387d49fb1d3a6e7b26f0e5847eca5fa82c26a5&v=4" width="20" height="20" alt="@sebmarkbage" /></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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage">sebmarkbage</a> <a data-hydro-click="{"event_type":"force_push_timeline_diff.click","payload":{"pull_request_id":1375076672,"repository_id":10270250,"event_id":9415408198,"originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="0e818a0c7442dc4c82cd9bfd9deabb35f8521f079532250dd4a72987130696b8" href="/facebook/react/compare/b95e2ac45ebd77929ac5aadfc9d70fbfc9f00db7..acad290d5c02f1f417be0f739f2598cf3913ef46" 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">esmbundler</span> </span> </span> branch from <a href="/facebook/react/commit/b95e2ac45ebd77929ac5aadfc9d70fbfc9f00db7" data-view-component="true" class="Link--primary Link text-bold"><code>b95e2ac</code></a> to <a href="/facebook/react/commit/acad290d5c02f1f417be0f739f2598cf3913ef46" data-view-component="true" class="Link--primary Link text-bold"><code>acad290</code></a> <a href="/facebook/react/compare/b95e2ac45ebd77929ac5aadfc9d70fbfc9f00db7..acad290d5c02f1f417be0f739f2598cf3913ef46" data-hydro-click="{"event_type":"force_push_timeline_diff.click","payload":{"pull_request_id":1375076672,"repository_id":10270250,"event_id":9415408198,"originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="0e818a0c7442dc4c82cd9bfd9deabb35f8521f079532250dd4a72987130696b8" 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-9415408198" data-view-component="true" class="css-truncate css-truncate-target Link--secondary Link"><relative-time tense="past" datetime="2023-06-02T15:08:18Z" data-view-component="true">June 2, 2023 15:08</relative-time></a> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="PRR_kwDOAJy2Ks5W8_pe"> <div class=""> <div id="pullrequestreview-1458829918" class="js-comment js-updatable-content js-socket-channel js-targetable-element js-minimize-container" data-gid="PRR_kwDOAJy2Ks5W8_pe" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0X3JldmlldzoxNDU4ODI5OTE4IiwidCI6MTczNDA2NTE4OX0=--61412b8b1309feec7565f258d6f0a9c2b210b321a563a130d6592086fd9acb04" data-url="/facebook/react/pull/26889/partials/reviews/1458829918" > <div data-view-component="true" class="TimelineItem"> <a href="/gaearon" data-view-component="true" class="TimelineItem-avatar avatar circle lh-0 Link"><img data-hovercard-type="user" data-hovercard-url="/users/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" src="https://avatars.githubusercontent.com/u/810438?s=60&v=4" alt="gaearon" size="40" height="40" width="40" data-view-component="true" /></a> <div aria-role="image" 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 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/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon">gaearon</a> </strong> reviewed <span class="color-fg-muted"> <a href="#pullrequestreview-1458829918" class="js-timestamp Link--secondary" id="pullrequestreview-1458829918-permalink"> <relative-time datetime="2023-06-03T03:20:18Z" class="no-wrap">Jun 3, 2023</relative-time> </a> </span> </div> <div class="ml-md-2 mt-md-0 mt-2 flex-shrink-0"> <a href="/facebook/react/pull/26889/files/acad290d5c02f1f417be0f739f2598cf3913ef46" 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 py-0 pl-4"> <div data-view-component="true" class="TimelineItem-body my-0"> <turbo-frame id="review-thread-or-comment-id-777064614" target="_top"> <details open="open" data-resolved="false" data-view-component="true" class="review-thread-component js-comment-container js-resolvable-timeline-thread-container Details-element details-reset mb-3 border rounded-2"> <summary role="button" data-view-component="true" class="py-2 px-3 rounded-2 color-bg-subtle"> <div class="d-flex flex-items-center"> <span class="flex-auto mr-3 d-flex flex-items-center"> <a href="/facebook/react/pull/26889/files/acad290d5c02f1f417be0f739f2598cf3913ef46#diff-d6173f891b84be82c717426c445adb54bd2c3915eee6f5afdeb4e72683256267" class="text-mono text-small Link--primary wb-break-all mr-2">fixtures/flight-esm/server/region.js</a> </span> </div> </summary> <div data-view-component="true"> <div class="blob-wrapper border-bottom js-check-bidi"> <deferred-diff-lines class="awaiting-highlight" data-url="/facebook/react/pull/26889/review_thread_syntax_highlighted_diff_lines"> <input type="hidden" name="pull_request_review_thread_id" value="777064614" data-targets="deferred-diff-lines.inputs" autocomplete="off" /> <table class="diff-table tab-size js-diff-table" data-tab-size="8" data-paste-markdown-skip> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="57" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition"> const action = (await import(filepath))[name];</span> </td> </tr> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="58" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition"> // Validate that this is actually a function we intended to expose and</span> </td> </tr> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="59" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition"> // not the client trying to invoke arbitrary functions. In a real app,</span> </td> </tr> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="60" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition"> // you'd have a manifest verifying this before even importing it.</span> </td> </tr> </table> </deferred-diff-lines></div> <div class="js-inline-comments-container"> <div class="js-line-comments js-suggested-changes-container js-suggested-changes-contents js-quote-selection-container" data-quote-markdown=".js-comment-body"> <div class="js-comments-holder" > <div id="discussion_r1215158824" class="timeline-comment-group js-minimizable-comment-group js-targetable-element my-0 comment previewable-edit js-task-list-container js-comment review-comment js-minimize-container unminimized-comment"> <div class="ml-n1 flex-items-center flex-row-reverse 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="discussion_r1215158824-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/810438?s=48&v=4" alt="@gaearon" size="24" height="24" width="24" data-view-component="true" class="avatar circle d-inline-block 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/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon">gaearon</a> </strong> <a href="#discussion_r1215158824" id="discussion_r1215158824-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-03T03:20:17Z" class="no-wrap">Jun 3, 2023</relative-time></a> </div> </h3> </div> <div class="ml-5"> <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/26889/review_comment/1215158824/minimize" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="xbRW2z6mhAC4tabcqUBr97luTC4rklMXH3Zx7ZHBElkVMRhhS-qev6Tq-tzqN8Ddnval7wuLSUV95Ket8NlXcg" 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">This would require a bundler, right? Just to confirm. Or does the loader do this somehow</p> </div> </task-lists> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="mt-2 js-comment-update" data-type="json" data-turbo="false" action="/facebook/react/pull/26889/review_comment/1215158824" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="i3LTGFsJW4z-VEGKHSlw0efluD1Wsf2d9pLRaaarSWwa8ZYSVAiWYwF9XbulGLqXPZLHZDYnC6hJP16b_wsD_A" autocomplete="off" /> <include-fragment loading="lazy" src="/facebook/react/pull/26889/review_comment/1215158824/edit_form?textarea_id=discussion_r1215158824-body&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="ml-5 edit-comment-hide"> <div data-view-component="true" class="comment-reactions js-reactions-container js-reaction-buttons-container social-reactions reactions-container 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="ppZk6Sey6ON2dWhVR1Fsey7YNw5WrALaCBKaVa5ljJwD0aGoEVKRwbAtU_LZj6bM9UVjT_RYzogRPnBGWuSYrQ" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="PRRC_kwDOAJy2Ks5Ibdoo"> <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 id="discussion_r1215776532" class="timeline-comment-group js-minimizable-comment-group js-targetable-element my-0 comment previewable-edit js-task-list-container js-comment review-comment js-minimize-container unminimized-comment"> <div class="ml-n1 flex-items-center flex-row-reverse 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="discussion_r1215776532-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> <span aria-label="This user is the author of this pull request." data-view-component="true" class="tooltipped tooltipped-n"> <span data-view-component="true" class="Label ml-1">Author</span> </span> </div> <h3 class="f5 text-normal" style="flex: 1 1 auto"> <div> <img src="https://avatars.githubusercontent.com/u/63648?s=48&v=4" alt="@sebmarkbage" size="24" height="24" width="24" data-view-component="true" class="avatar circle d-inline-block 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> <a href="#discussion_r1215776532" id="discussion_r1215776532-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-03T19:57:22Z" class="no-wrap">Jun 3, 2023</relative-time></a> </div> </h3> </div> <div class="ml-5"> <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/26889/review_comment/1215776532/minimize" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="t7f_ohQEmwRGaeWIb78NqmYC1GgfWEK65R3s5zB5bdDQiAXOvCIg7aYLFQ4vBOlePiVdu3Fz7THoC3Ha83p_Aw" 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">It's pretty simple because it'll have been tagged as a server reference by the loader. So verifying is trivial. The decodeReply/decodeAction also has this issue atm.</p> </div> </task-lists> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="mt-2 js-comment-update" data-type="json" data-turbo="false" action="/facebook/react/pull/26889/review_comment/1215776532" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="U3wkicPF1OmeuoPmmoibcVPapQ1XGRGJEZZ7oDTq_runH9OOnU3dnpvWT95g9kzeqDcayt2F1qZgWcesOUYEBA" autocomplete="off" /> <include-fragment loading="lazy" src="/facebook/react/pull/26889/review_comment/1215776532/edit_form?textarea_id=discussion_r1215776532-body&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="ml-5 edit-comment-hide"> <div data-view-component="true" class="comment-reactions js-reactions-container js-reaction-buttons-container social-reactions reactions-container 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="qsgjLEQqUDSxksTpH8FTmbDByefjmZfQOR_vr-OsTEYPj-ZtcsopFnfK_06BH5kua1ydpkFtW4IgMwW8Fy1Ydw" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="PRRC_kwDOAJy2Ks5Id0cU"> <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 id="discussion_r1215890479" class="timeline-comment-group js-minimizable-comment-group js-targetable-element my-0 comment previewable-edit js-task-list-container js-comment review-comment js-minimize-container unminimized-comment"> <div class="ml-n1 flex-items-center flex-row-reverse 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="discussion_r1215890479-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/810438?s=48&v=4" alt="@gaearon" size="24" height="24" width="24" data-view-component="true" class="avatar circle d-inline-block 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/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon">gaearon</a> </strong> <a href="#discussion_r1215890479" id="discussion_r1215890479-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-03T22:27:56Z" class="no-wrap">Jun 3, 2023</relative-time></a> </div> </h3> </div> <div class="ml-5"> <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/26889/review_comment/1215890479/minimize" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="1eh-JNszB9N5X8aqO8QwcWlFD_C2lD8_MZjclVcXlKKJ5JisE1Jej9wUhqYS25i1rrqoMk0T4x83P3do2HOxDQ" 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">The part I'm missing is, importing a file calls its top-level side effects, so isn't this a possible vector if the filename is arbitrary?</p> </div> </task-lists> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="mt-2 js-comment-update" data-type="json" data-turbo="false" action="/facebook/react/pull/26889/review_comment/1215890479" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="2eShX7H-YElumXLHVGyplG8NEgoSqSvJyj2bSQwojAO_LzaoC1kxDeXKoUE_6G_LyZ1DLum1W1QiwLEvQLDjXg" autocomplete="off" /> <include-fragment loading="lazy" src="/facebook/react/pull/26889/review_comment/1215890479/edit_form?textarea_id=discussion_r1215890479-body&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="ml-5 edit-comment-hide"> <div data-view-component="true" class="comment-reactions js-reactions-container js-reaction-buttons-container social-reactions reactions-container 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="fFMZxEbAfsjzTwO8zmJUPgL0ZFtofhU68__1NLakLmHZFNyFcCAH6jUXOBtQvJ6J2WkwGsqK2Wjq0x8nQiU6UA" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="PRRC_kwDOAJy2Ks5IeQQv"> <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> </div> </div> </div> </details></turbo-frame> </div> </div> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="PRR_kwDOAJy2Ks5W8_8S"> <div class=""> <div id="pullrequestreview-1458831122" class="js-comment js-updatable-content js-socket-channel js-targetable-element js-minimize-container" data-gid="PRR_kwDOAJy2Ks5W8_8S" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0X3JldmlldzoxNDU4ODMxMTIyIiwidCI6MTczNDA2NTE4OX0=--3c764dbaf1c00ccbbdcd3a529c358bf1c17b16a7c53088c07e539a726bfe6e94" data-url="/facebook/react/pull/26889/partials/reviews/1458831122" > <div data-view-component="true" class="TimelineItem"> <a href="/gaearon" data-view-component="true" class="TimelineItem-avatar avatar circle lh-0 Link"><img data-hovercard-type="user" data-hovercard-url="/users/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" src="https://avatars.githubusercontent.com/u/810438?s=60&v=4" alt="gaearon" size="40" height="40" width="40" data-view-component="true" /></a> <div aria-role="image" 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 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/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon">gaearon</a> </strong> reviewed <span class="color-fg-muted"> <a href="#pullrequestreview-1458831122" class="js-timestamp Link--secondary" id="pullrequestreview-1458831122-permalink"> <relative-time datetime="2023-06-03T03:23:51Z" class="no-wrap">Jun 3, 2023</relative-time> </a> </span> </div> <div class="ml-md-2 mt-md-0 mt-2 flex-shrink-0"> <a href="/facebook/react/pull/26889/files/acad290d5c02f1f417be0f739f2598cf3913ef46" 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 py-0 pl-4"> <div data-view-component="true" class="TimelineItem-body my-0"> <turbo-frame id="review-thread-or-comment-id-777065096" target="_top"> <details open="open" data-resolved="false" data-view-component="true" class="review-thread-component js-comment-container js-resolvable-timeline-thread-container Details-element details-reset mb-3 border rounded-2"> <summary role="button" data-view-component="true" class="py-2 px-3 rounded-2 color-bg-subtle"> <div class="d-flex flex-items-center"> <span class="flex-auto mr-3 d-flex flex-items-center"> <a href="/facebook/react/pull/26889/files/acad290d5c02f1f417be0f739f2598cf3913ef46#diff-bb94d010a011e13d6408af3dc4dcdf397f2805227799ed9c548a217722ca2671" class="text-mono text-small Link--primary wb-break-all mr-2">packages/react-server-dom-esm/src/ReactFlightClientConfigESMBundler.js</a> </span> </div> </summary> <div data-view-component="true"> <div class="blob-wrapper border-bottom js-check-bidi"> <deferred-diff-lines class="awaiting-highlight" data-url="/facebook/react/pull/26889/review_thread_syntax_highlighted_diff_lines"> <input type="hidden" name="pull_request_review_thread_id" value="777065096" data-targets="deferred-diff-lines.inputs" autocomplete="off" /> <table class="diff-table tab-size js-diff-table" data-tab-size="8" data-paste-markdown-skip> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="13" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition"> RejectedThenable,</span> </td> </tr> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="14" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition">} from 'shared/ReactTypes';</span> </td> </tr> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="15" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition"><br></span> </td> </tr> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="16" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition">export type SSRManifest = string; // Module root path</span> </td> </tr> </table> </deferred-diff-lines></div> <div class="js-inline-comments-container"> <div class="js-line-comments js-suggested-changes-container js-suggested-changes-contents js-quote-selection-container" data-quote-markdown=".js-comment-body"> <div class="js-comments-holder" > <div id="discussion_r1215159630" class="timeline-comment-group js-minimizable-comment-group js-targetable-element my-0 comment previewable-edit js-task-list-container js-comment review-comment js-minimize-container unminimized-comment"> <div class="ml-n1 flex-items-center flex-row-reverse 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="discussion_r1215159630-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/810438?s=48&v=4" alt="@gaearon" size="24" height="24" width="24" data-view-component="true" class="avatar circle d-inline-block 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/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon">gaearon</a> </strong> <a href="#discussion_r1215159630" id="discussion_r1215159630-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-03T03:23:51Z" class="no-wrap">Jun 3, 2023</relative-time></a> </div> </h3> </div> <div class="ml-5"> <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/26889/review_comment/1215159630/minimize" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="KqSlDNhXWvtY09X1I-XfR-p5DvNe7ZbNRrcGO2moYi48zgEycAqnBROWFn68AVNHWY0pTe_p_BUuqPRkE3FMfA" 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">woah</p> </div> </task-lists> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="mt-2 js-comment-update" data-type="json" data-turbo="false" action="/facebook/react/pull/26889/review_comment/1215159630" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="PurkWte0uMoqOXjSinLMUDypjYwNN6LQEWSyP2a14O5I9s5TarkflJpQxOLKD0EdJLAxuRzGXHbj2CXkOeAOVw" autocomplete="off" /> <include-fragment loading="lazy" src="/facebook/react/pull/26889/review_comment/1215159630/edit_form?textarea_id=discussion_r1215159630-body&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="ml-5 edit-comment-hide"> <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="equ1BqA0Mkt7SLPXaLBzhzhlEejd1uB6QHDZ66RRFH7f7HBHltRLab0QiHD2brkw4_hFqX8iLChZXDP4UNAATw" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="PRRC_kwDOAJy2Ks5Ibd1O"> <div class="js-comment-reactions-options d-flex flex-items-center flex-row flex-wrap"> <button name="input[content]" id="reactions--reaction_button_component-37e075" value="LAUGH react" data-button-index-position="2" data-reaction-label="Laugh" data-reaction-content="smile" aria-pressed="false" aria-label="laugh (1): gaearon, 03:23AM on June 03, 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="smile" fallback-src="https://github.githubassets.com/assets/1f604-7528822fb4c5.png" class="social-button-emoji">😄</g-emoji> <span class="js-discussion-reaction-group-count">1</span> </button> <tool-tip id="tooltip-7a286d44-31f6-497b-b12f-18a04f563091" for="reactions--reaction_button_component-37e075" popover="manual" data-direction="n" data-type="description" data-view-component="true" class="sr-only position-absolute">lubieowoce reacted with laugh 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="lubieowoce reacted with laugh emoji"> <g-emoji alias="smile" fallback-src="https://github.githubassets.com/assets/1f604-7528822fb4c5.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> </div> </details></turbo-frame> </div> </div> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="PRR_kwDOAJy2Ks5W9AAi"> <div class=""> <div id="pullrequestreview-1458831394" class="js-comment js-updatable-content js-socket-channel js-targetable-element js-minimize-container" data-gid="PRR_kwDOAJy2Ks5W9AAi" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0X3JldmlldzoxNDU4ODMxMzk0IiwidCI6MTczNDA2NTE4OX0=--e0fe16692f92d541ea6c2988f7f286b927fce60e3dad68ab4f3939ae3758a0c3" data-url="/facebook/react/pull/26889/partials/reviews/1458831394" > <div data-view-component="true" class="TimelineItem"> <a href="/gaearon" data-view-component="true" class="TimelineItem-avatar avatar circle lh-0 Link"><img data-hovercard-type="user" data-hovercard-url="/users/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" src="https://avatars.githubusercontent.com/u/810438?s=60&v=4" alt="gaearon" size="40" height="40" width="40" data-view-component="true" /></a> <div aria-role="image" 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 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/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon">gaearon</a> </strong> reviewed <span class="color-fg-muted"> <a href="#pullrequestreview-1458831394" class="js-timestamp Link--secondary" id="pullrequestreview-1458831394-permalink"> <relative-time datetime="2023-06-03T03:26:27Z" class="no-wrap">Jun 3, 2023</relative-time> </a> </span> </div> <div class="ml-md-2 mt-md-0 mt-2 flex-shrink-0"> <a href="/facebook/react/pull/26889/files/acad290d5c02f1f417be0f739f2598cf3913ef46" 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 py-0 pl-4"> <div data-view-component="true" class="TimelineItem-body my-0"> <turbo-frame id="review-thread-or-comment-id-777065334" target="_top"> <details open="open" data-resolved="false" data-view-component="true" class="review-thread-component js-comment-container js-resolvable-timeline-thread-container Details-element details-reset mb-3 border rounded-2"> <summary role="button" data-view-component="true" class="py-2 px-3 rounded-2 color-bg-subtle"> <div class="d-flex flex-items-center"> <span class="flex-auto mr-3 d-flex flex-items-center"> <a href="/facebook/react/pull/26889/files/acad290d5c02f1f417be0f739f2598cf3913ef46#diff-e520f20d808d7251d6c6bbf95a8b92b15bd145b4994818c8e9855ca03923b35e" class="text-mono text-small Link--primary wb-break-all mr-2">packages/react-server-dom-esm/src/ReactFlightESMNodeLoader.js</a> </span> </div> </summary> <div data-view-component="true"> <div class="blob-wrapper border-bottom js-check-bidi"> <deferred-diff-lines class="awaiting-highlight" data-url="/facebook/react/pull/26889/review_thread_syntax_highlighted_diff_lines"> <input type="hidden" name="pull_request_review_thread_id" value="777065334" data-targets="deferred-diff-lines.inputs" autocomplete="off" /> <table class="diff-table tab-size js-diff-table" data-tab-size="8" data-paste-markdown-skip> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="59" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition"><br></span> </td> </tr> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="60" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition">let stashedGetSource: null | GetSourceFunction = null;</span> </td> </tr> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="61" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition">let stashedResolve: null | ResolveFunction = null;</span> </td> </tr> <tr> <td class="blob-num blob-num-addition empty-cell"></td> <td data-line-number="62" class="blob-num blob-num-addition"></td> <td class="blob-code blob-code-addition"> <span class="blob-code-inner blob-code-marker-addition"><br></span> </td> </tr> </table> </deferred-diff-lines></div> <div class="js-inline-comments-container"> <div class="js-line-comments js-suggested-changes-container js-suggested-changes-contents js-quote-selection-container" data-quote-markdown=".js-comment-body"> <div class="js-comments-holder" > <div id="discussion_r1215159908" class="timeline-comment-group js-minimizable-comment-group js-targetable-element my-0 comment previewable-edit js-task-list-container js-comment review-comment js-minimize-container unminimized-comment"> <div class="ml-n1 flex-items-center flex-row-reverse 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="discussion_r1215159908-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/810438?s=48&v=4" alt="@gaearon" size="24" height="24" width="24" data-view-component="true" class="avatar circle d-inline-block 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/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon">gaearon</a> </strong> <a href="#discussion_r1215159908" id="discussion_r1215159908-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-03T03:26:27Z" class="no-wrap">Jun 3, 2023</relative-time></a> </div> </h3> </div> <div class="ml-5"> <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/26889/review_comment/1215159908/minimize" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="IJuS3VB44z_e8n1ssn05T5qtYwVfmGkXtjF0TVHgmJfgnfzGFe-eGOP6C0Zrlas9MN8jUsTz0UBibsW3KympYQ" 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">Are all of these exports needed or is some targeting older Nodes? Should we start dropping those?</p> </div> </task-lists> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="mt-2 js-comment-update" data-type="json" data-turbo="false" action="/facebook/react/pull/26889/review_comment/1215159908" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="yjuZohNsRVEe1gKrobkDhFCEg-IRB374-mVz9ihehCmx0yAyjD-yGsmz3NudEt3-MZMi8Cn_L4vNm3S0cIhE_A" autocomplete="off" /> <include-fragment loading="lazy" src="/facebook/react/pull/26889/review_comment/1215159908/edit_form?textarea_id=discussion_r1215159908-body&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="ml-5 edit-comment-hide"> <div data-view-component="true" class="comment-reactions js-reactions-container js-reaction-buttons-container social-reactions reactions-container 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="FpuYzaAiqOSbSPw9iOTlBPFn0gIXCMnIRG6NHG0dd1-z3F2MlsLRxl0Qx5oWOi-zKvqGQ7X8BZpdQmcPmZxjbg" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="PRRC_kwDOAJy2Ks5Ibd5k"> <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 id="discussion_r1215777678" class="timeline-comment-group js-minimizable-comment-group js-targetable-element my-0 comment previewable-edit js-task-list-container js-comment review-comment js-minimize-container unminimized-comment"> <div class="ml-n1 flex-items-center flex-row-reverse 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="discussion_r1215777678-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> <span aria-label="This user is the author of this pull request." data-view-component="true" class="tooltipped tooltipped-n"> <span data-view-component="true" class="Label ml-1">Author</span> </span> </div> <h3 class="f5 text-normal" style="flex: 1 1 auto"> <div> <img src="https://avatars.githubusercontent.com/u/63648?s=48&v=4" alt="@sebmarkbage" size="24" height="24" width="24" data-view-component="true" class="avatar circle d-inline-block 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> <a href="#discussion_r1215777678" id="discussion_r1215777678-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-03T19:58:18Z" class="no-wrap">Jun 3, 2023</relative-time></a> </div> </h3> </div> <div class="ml-5"> <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/26889/review_comment/1215777678/minimize" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="LOKp94CZzlplCT6Y8HZBTf7HS-WZdrP0zePac0RFe1QcJv9TPYTRQy51hq867nsY2mbZmWORW6z9xt9ZiUOR7A" 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">Some are targeting older Node yea.</p> </div> </task-lists> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="mt-2 js-comment-update" data-type="json" data-turbo="false" action="/facebook/react/pull/26889/review_comment/1215777678" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="cGCdQt4eHOx890z-npFp1MiPYo11p7Q9d_nKk6Rqq2AK501JU1_Dq3GSOoYxreIpyFH8513liuz-S4bc-ZqdDg" autocomplete="off" /> <include-fragment loading="lazy" src="/facebook/react/pull/26889/review_comment/1215777678/edit_form?textarea_id=discussion_r1215777678-body&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="ml-5 edit-comment-hide"> <div data-view-component="true" class="comment-reactions js-reactions-container js-reaction-buttons-container social-reactions reactions-container 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="ixE_Gezojf6BSUakpJH9GAcBNIUjVmZF3f1fOfhflzEuVvpY2gj03EcRfQM6Tzev3JxgxIGiqhfE0bUqDN6DAA" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="PRRC_kwDOAJy2Ks5Id0uO"> <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> </div> </div> </div> </details></turbo-frame> </div> </div> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="PRR_kwDOAJy2Ks5W9AC6"> <div class=""> <div id="pullrequestreview-1458831546" class="js-comment js-updatable-content js-socket-channel js-targetable-element js-minimize-container" data-gid="PRR_kwDOAJy2Ks5W9AC6" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0X3JldmlldzoxNDU4ODMxNTQ2IiwidCI6MTczNDA2NTE4OX0=--0861e383a552a4d0154b2da26c49c371f9e39253255788832f68fb900858640f" data-url="/facebook/react/pull/26889/partials/reviews/1458831546" > <div data-view-component="true" class="TimelineItem"> <a href="/gaearon" data-view-component="true" class="TimelineItem-avatar avatar circle lh-0 Link"><img data-hovercard-type="user" data-hovercard-url="/users/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" src="https://avatars.githubusercontent.com/u/810438?s=60&v=4" alt="gaearon" 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/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon">gaearon</a> </strong> approved these changes <span class="color-fg-muted"> <a href="#pullrequestreview-1458831546" class="js-timestamp Link--secondary" id="pullrequestreview-1458831546-permalink"> <relative-time datetime="2023-06-03T03:27:46Z" class="no-wrap">Jun 3, 2023</relative-time> </a> </span> </div> <div class="ml-md-2 mt-md-0 mt-2 flex-shrink-0"> <a href="/facebook/react/pull/26889/files/acad290d5c02f1f417be0f739f2598cf3913ef46" 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-1458831546" 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-1458831546-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/810438?s=48&v=4" alt="@gaearon" 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/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon">gaearon</a> </strong> left a comment </div> </h3> </div> <a href="#pullrequestreview-1458831546" 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/26889/reviews/1458831546/minimize" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="nSGRDdEFJT8ejtVj40UCbozqdGt4BNArXvZfc7WQr-DIjrvPPBnAuTGDceknzfXSFSMfq3YQ1EAggxK4B-_IZw" 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">very cool</p> </div> </task-lists> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-comment-update" data-type="json" data-turbo="false" action="/facebook/react/pull/26889/reviews/1458831546/update" accept-charset="UTF-8" method="post"><input type="hidden" name="_method" value="put" autocomplete="off" /><input type="hidden" name="authenticity_token" value="H4GRVLj-SxkYO3GQONF7E8MeVw9P3PdVtSL9x607TOyQQgdO8H4M5EQtHPhL5bgcfJB81DikzWmOvWEtJNJXog" autocomplete="off" /> <include-fragment loading="lazy" src="/facebook/react/pull/26889/reviews/1458831546/update/edit_form?textarea_id=pullrequestreview-1458831546-body&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="xMEERtRIPf-nrUAb10HXB3Xck-9AZ2jNHCdmZJSAnkBhhsEH4qhE3WH1e7xJnx2wrkHHruKTpJ8FC4x3YAGKcQ" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="PRR_kwDOAJy2Ks5W9AC6"> <div class="js-comment-reactions-options d-flex flex-items-center flex-row flex-wrap"> <button name="input[content]" id="reactions--reaction_button_component-d317bf" value="HOORAY react" data-button-index-position="3" data-reaction-label="Hooray" data-reaction-content="tada" aria-pressed="false" aria-label="hooray (2): gaearon, 03:27AM on June 03, 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="tada" fallback-src="https://github.githubassets.com/assets/1f389-36899a2cb781.png" class="social-button-emoji">🎉</g-emoji> <span class="js-discussion-reaction-group-count">2</span> </button> <tool-tip id="tooltip-6e8b5bd1-c356-4731-b8fc-337bf37a49ad" for="reactions--reaction_button_component-d317bf" popover="manual" data-direction="n" data-type="description" data-view-component="true" class="sr-only position-absolute">dai-shi and kachkaev reacted with hooray 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="dai-shi and kachkaev reacted with hooray emoji"> <g-emoji alias="tada" fallback-src="https://github.githubassets.com/assets/1f389-36899a2cb781.png" class="social-button-emoji mr-2">🎉</g-emoji> <span>2 reactions</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="ME_lADOAJy2Ks5nju9-zwAAAAIxn-if"> <div class="TimelineItem js-details-container Details" id="event-9422497951" > <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/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=40&u=f1387d49fb1d3a6e7b26f0e5847eca5fa82c26a5&v=4" width="20" height="20" alt="@sebmarkbage" /></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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage">sebmarkbage</a> merged commit <a href="/facebook/react/commit/f181ba8aa6339d62f6e2572109c61242606f16b3"><code class="Link--primary text-bold">f181ba8</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/26889#event-9422497951" class="Link--secondary"><relative-time datetime="2023-06-03T19:58:24Z" class="no-wrap">Jun 3, 2023</relative-time></a> </div> </div> <div class="TimelineItem-break"></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-b2a908f"> <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-b2a908f" class="Link--secondary"> <relative-time datetime="2023-06-03T20:03:50Z" class="no-wrap">Jun 3, 2023</relative-time> </a> <div class="mt-3"> <div class="js-details-container Details js-socket-channel js-updatable-content" data-channel="eyJjIjoicmVwbzoxMDI3MDI1MDpjb21taXQ6YjJhOTA4ZmU0MmVjZDg3YzcxY2EzYWU0YmVkZjc0Y2UwMWMxOWI5ZCIsInQiOjE3MzQwNjUxODl9--cceb6fb98956bcb542e2f38a2824490c360ce38b58f14d9cc737bb06a081372f" data-url="/facebook/react/commit/b2a908fe42ecd87c71ca3ae4bedf74ce01c19b9d/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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/63648?s=40&u=f1387d49fb1d3a6e7b26f0e5847eca5fa82c26a5&v=4" width="20" height="20" alt="@sebmarkbage" class=" avatar-user" /> </a> </div> </div> <div class="pr-1 flex-auto min-width-0" > <code> <a title="[Flight] Add bundler-less version of RSC using plain ESM (#26889) This isn't really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It's a new reference implementation package `react-server-dom-esm` as well as a fixture in `fixtures/flight-esm` (fork of `fixtures/flight`). This works pretty much the same as pieces we already have in the Webpack implementation but instead of loading modules using Webpack on the client it uses native browser ESM. To really show it off, I don't use any JSX in the fixture and so it also doesn't use Babel or any compilation of the files. This works because we don't actually bundle the server in the reference implementation in the first place. We instead use [Node.js Loaders](https://nodejs.org/api/esm.html#loaders) to intercept files that contain `"use client"` and `"use server"` and replace them. There's a simple check for those exact bytes, and no parsing, so this is very fast. Since the client isn't actually bundled, there's no module map needed. We can just send the file path to the file we want to load in the RSC payload for client references. Since the existing reference implementation for Node.js already used ESM to load modules on the server, that all works the same, including Server Actions. No bundling. There is one case that isn't implemented here. Importing a `"use server"` file from a Client Component. We don't have that implemented in the Webpack reference implementation neither - only in Next.js atm. In Webpack it would be implemented as a Webpack loader. There are a few ways this can be implemented without a bundler: - We can intercept the request from the browser importing this file in the HTTP server, and do a quick scan for `"use server"` in the file and replace it just like we do with loaders in Node.js. This is effectively how Vite works and likely how anyone using this technique would have to support JSX anyway. - We can use native browser "loaders" once that's eventually available in the same way as in Node.js. - We can generate import maps for each file and replace it with a pointer to a placeholder file. This requires scanning these ahead of time which defeats the purposes. Another case that's not implemented is the inline `"use server"` closure in a Server Component. That would require the existing loader to be a bit smarter but would still only "compile" files that contains those bytes in the fast path check. This would also happen in the loader that already exists so wouldn't do anything substantially different than what we currently have here. DiffTrain build for [f181ba8aa6339d62f6e2572109c61242606f16b3](https://github.com/facebook/react/commit/f181ba8aa6339d62f6e2572109c61242606f16b3)" data-pjax="true" class="Link--secondary markdown-title" href="/facebook/react/commit/b2a908fe42ecd87c71ca3ae4bedf74ce01c19b9d">[Flight] Add bundler-less version of RSC using plain ESM (</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">#26889</a><a title="[Flight] Add bundler-less version of RSC using plain ESM (#26889) This isn't really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It's a new reference implementation package `react-server-dom-esm` as well as a fixture in `fixtures/flight-esm` (fork of `fixtures/flight`). This works pretty much the same as pieces we already have in the Webpack implementation but instead of loading modules using Webpack on the client it uses native browser ESM. To really show it off, I don't use any JSX in the fixture and so it also doesn't use Babel or any compilation of the files. This works because we don't actually bundle the server in the reference implementation in the first place. We instead use [Node.js Loaders](https://nodejs.org/api/esm.html#loaders) to intercept files that contain `"use client"` and `"use server"` and replace them. There's a simple check for those exact bytes, and no parsing, so this is very fast. Since the client isn't actually bundled, there's no module map needed. We can just send the file path to the file we want to load in the RSC payload for client references. Since the existing reference implementation for Node.js already used ESM to load modules on the server, that all works the same, including Server Actions. No bundling. There is one case that isn't implemented here. Importing a `"use server"` file from a Client Component. We don't have that implemented in the Webpack reference implementation neither - only in Next.js atm. In Webpack it would be implemented as a Webpack loader. There are a few ways this can be implemented without a bundler: - We can intercept the request from the browser importing this file in the HTTP server, and do a quick scan for `"use server"` in the file and replace it just like we do with loaders in Node.js. This is effectively how Vite works and likely how anyone using this technique would have to support JSX anyway. - We can use native browser "loaders" once that's eventually available in the same way as in Node.js. - We can generate import maps for each file and replace it with a pointer to a placeholder file. This requires scanning these ahead of time which defeats the purposes. Another case that's not implemented is the inline `"use server"` closure in a Server Component. That would require the existing loader to be a bit smarter but would still only "compile" files that contains those bytes in the fast path check. This would also happen in the loader that already exists so wouldn't do anything substantially different than what we currently have here. DiffTrain build for [f181ba8aa6339d62f6e2572109c61242606f16b3](https://github.com/facebook/react/commit/f181ba8aa6339d62f6e2572109c61242606f16b3)" data-pjax="true" class="Link--secondary markdown-title" href="/facebook/react/commit/b2a908fe42ecd87c71ca3ae4bedf74ce01c19b9d">)</a> </code> <span class="hidden-text-expander inline"> <button type="button" class="ellipsis-expander js-details-target" aria-expanded="false">…</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_kwDOAJy2KtoAKGIyYTkwOGZlNDJlY2Q4N2M3MWNhM2FlNGJlZGY3NGNlMDFjMTliOWQ" 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/b2a908fe42ecd87c71ca3ae4bedf74ce01c19b9d" class="Link--secondary">b2a908f</a> </code> </div> </div> </div> <div class="Details-content--hidden mt-2"> <pre class="color-fg-muted ws-pre-wrap">This isn't really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It's a new reference implementation package `react-server-dom-esm` as well as a fixture in `fixtures/flight-esm` (fork of `fixtures/flight`). This works pretty much the same as pieces we already have in the Webpack implementation but instead of loading modules using Webpack on the client it uses native browser ESM. To really show it off, I don't use any JSX in the fixture and so it also doesn't use Babel or any compilation of the files. This works because we don't actually bundle the server in the reference implementation in the first place. We instead use [Node.js Loaders](<a href="https://nodejs.org/api/esm.html#loaders" rel="nofollow">https://nodejs.org/api/esm.html#loaders</a>) to intercept files that contain `"use client"` and `"use server"` and replace them. There's a simple check for those exact bytes, and no parsing, so this is very fast. Since the client isn't actually bundled, there's no module map needed. We can just send the file path to the file we want to load in the RSC payload for client references. Since the existing reference implementation for Node.js already used ESM to load modules on the server, that all works the same, including Server Actions. No bundling. There is one case that isn't implemented here. Importing a `"use server"` file from a Client Component. We don't have that implemented in the Webpack reference implementation neither - only in Next.js atm. In Webpack it would be implemented as a Webpack loader. There are a few ways this can be implemented without a bundler: - We can intercept the request from the browser importing this file in the HTTP server, and do a quick scan for `"use server"` in the file and replace it just like we do with loaders in Node.js. This is effectively how Vite works and likely how anyone using this technique would have to support JSX anyway. - We can use native browser "loaders" once that's eventually available in the same way as in Node.js. - We can generate import maps for each file and replace it with a pointer to a placeholder file. This requires scanning these ahead of time which defeats the purposes. Another case that's not implemented is the inline `"use server"` closure in a Server Component. That would require the existing loader to be a bit smarter but would still only "compile" files that contains those bytes in the fast path check. This would also happen in the loader that already exists so wouldn't do anything substantially different than what we currently have here. DiffTrain build for [<a class="commit-link" data-hovercard-type="commit" data-hovercard-url="https://github.com/facebook/react/commit/f181ba8aa6339d62f6e2572109c61242606f16b3/hovercard" href="https://github.com/facebook/react/commit/f181ba8aa6339d62f6e2572109c61242606f16b3"><tt>f181ba8</tt></a>](<a class="commit-link" data-hovercard-type="commit" data-hovercard-url="https://github.com/facebook/react/commit/f181ba8aa6339d62f6e2572109c61242606f16b3/hovercard" href="https://github.com/facebook/react/commit/f181ba8aa6339d62f6e2572109c61242606f16b3"><tt>f181ba8</tt></a>)</pre> </div> </div> </div> </div> </div> </div> <div class="js-timeline-item js-timeline-progressive-focus-container" data-gid="IC_kwDOAJy2Ks5egLMs"> <div class="TimelineItem js-comment-container" data-gid="IC_kwDOAJy2Ks5egLMs" data-url="/facebook/react/comments/IC_kwDOAJy2Ks5egLMs/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/dai-shi/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/dai-shi"><img class="avatar rounded-2 avatar-user" src="https://avatars.githubusercontent.com/u/490574?s=80&u=3b4c1b7f1db9c6a43eafbe0b5c341c05d2dc93a1&v=4" width="40" height="40" alt="@dai-shi" /></a> </div> <div class=" timeline-comment-group js-minimizable-comment-group js-targetable-element TimelineItem-body my-0 " id="issuecomment-1585492780"> <div class="ml-n3 timeline-comment unminimized-comment comment previewable-edit js-task-list-container js-comment timeline-comment--caret" data-body-version="2966398bd9ec8f73352b960d3033a54d1f5eeeac02546e661e34700f7773ac85"> <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-1585492780-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 previously committed to the react repository." data-view-component="true" class="tooltipped tooltipped-n"> <span data-view-component="true" class="Label ml-1">Contributor</span> </span> </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/dai-shi/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/dai-shi">dai-shi</a> </strong> commented <a href="#issuecomment-1585492780" id="issuecomment-1585492780-permalink" class="Link--secondary js-timestamp"><relative-time datetime="2023-06-10T05:23:58Z" class="no-wrap">Jun 10, 2023</relative-time></a> </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">Could you please publish <code class="notranslate">react-server-dom-esm@canary</code>?</p> <p dir="auto">(btw, found this: <a href="https://www.npmjs.com/package/@jacob-ebey/react-server-dom-esm" rel="nofollow">https://www.npmjs.com/package/@jacob-ebey/react-server-dom-esm</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 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="N5BppHl7DH_eF8r02AQdKmt31VrMh5FsNjWgOChXI6OS16zlT5t1XRhP8VNG2tedsOqBG25zXT4vGUor3NY3kg" autocomplete="off" /> <input type="hidden" name="input[subjectId]" value="IC_kwDOAJy2Ks5egLMs"> <input type="hidden" name="input[context]" value="" > <div class="js-comment-reactions-options d-flex flex-items-center flex-row flex-wrap"> <button name="input[content]" id="reactions--reaction_button_component-71f339" value="THUMBS_UP react" data-button-index-position="0" data-reaction-label="+1" data-reaction-content="+1" aria-pressed="false" aria-label="react with thumbs up" 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">8</span> </button> <tool-tip id="tooltip-5d4e7789-2722-492a-b6ad-54b8bbf2d4fd" for="reactions--reaction_button_component-71f339" popover="manual" data-direction="n" data-type="description" data-view-component="true" class="sr-only position-absolute">nickserv, tom-sherman, jazzypants1989, connorward93, himself65, eser, lili21, and ojj1123 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="nickserv, tom-sherman, jazzypants1989, connorward93, himself65, eser, lili21, and ojj1123 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>8 reactions</span> </li> </ul> </details> </div> </div> </form></div> </div> </div> </div> <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-comment-update" id="issuecomment-1585492780-edit-form" data-turbo="false" action="/facebook/react/issue_comments/1585492780" 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="DH2gBUiXAJmwEwA1iTW2uYEuFlSRfpa8e/xhzT0XFTTqn2CR9oms0N95DOWifgYiP8MYVW9tfQKJ4JSmCE7x3A==" /> <include-fragment loading="lazy" src="/facebook/react/issue_comments/1585492780/edit_form?textarea_id=issuecomment-1585492780-body&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="CRE_kwDOBC3Cis5NUqg9"> <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&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:40Z" 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="eyJjIjoicmVwbzo3MDEwNzc4Njpjb21taXQ6OWU0Yjg3ZDUwMmUxZTIwMzUxZTExMWQ5MmU3MGIyZTU0YWMwMzUxYSIsInQiOjE3MzQwNjUxODl9--8ec2b082e3de5026102e43757e652f88a9657e3e10aae3cebf9a7ed6faa80535" 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&u=58675cc3f9993517e5f29209ccba960d79b719ad&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&u=a866d19c4fce64bf67a084eb32f29bb6e84020a5&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 <g@shud.in>" 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 <g@shud.in>" 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 <g@shud.in>" 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 <g@shud.in>" 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">…</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 <g@shud.in></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&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:30Z" 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="eyJjIjoicmVwbzo3MDEwNzc4Njpjb21taXQ6NmRhZmM0MjI5ZDFiYmNmMTFiOWE1YzI0M2YzOWE4ZTc2ZGU1YTI3ZiIsInQiOjE3MzQwNjUxODl9--5a7dd6d670b8b675b519dba5d5b47d918317fe7a7dc2a3db2acacb132c42999e" 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&u=58675cc3f9993517e5f29209ccba960d79b719ad&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&u=5c7d0191db95e34c1a1d8495ad828e6a034d7c76&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 <inbox@huozhi.im>" 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 <inbox@huozhi.im>" 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">…</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 <inbox@huozhi.im></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:25Z" 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="eyJjIjoicmVwbzo3MDEwNzc4Njpjb21taXQ6MWFlM2Y0MmMxYTA0YzgwMDM3MmJlZDJhM2MyNjM4OTgxNTMyNTgzNiIsInQiOjE3MzQwNjUxODl9--d7aa370cdf42061b25289d35a81341dfaf5fc58266d505a87aad9dfe596c9c99" 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&u=58675cc3f9993517e5f29209ccba960d79b719ad&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&u=a866d19c4fce64bf67a084eb32f29bb6e84020a5&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 <g@shud.in>" 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 <g@shud.in>" 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 <g@shud.in>" 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 <g@shud.in>" 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">…</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 <g@shud.in></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/dai-shi/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/dai-shi"><img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/490574?s=40&u=3b4c1b7f1db9c6a43eafbe0b5c341c05d2dc93a1&v=4" width="20" height="20" alt="@dai-shi" /></a> <a class="author Link--primary text-bold" data-hovercard-type="user" data-hovercard-url="/users/dai-shi/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/dai-shi">dai-shi</a> mentioned this pull request <a class="Link--secondary" href="#ref-issue-1838127504" > <relative-time datetime="2024-02-09T02:43:42Z" class="no-wrap">Feb 9, 2024</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-1838127504" > <a href="/facebook/react/issues/27197" class="Link--primary f4 text-bold markdown-title" data-hovercard-type="issue" data-hovercard-url="/facebook/react/issues/27197/hovercard"> Bug: <code>react-server-dom-esm</code> package is empty <span class="color-fg-muted text-normal" >#27197</span> </a> </div> <div class="flex-shrink-0 my-1 my-md-0 ml-md-3"> <span title="Status: Open" data-view-component="true" class="State State--open 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-opened flex-items-center mr-1"> <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> Open </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-60653f9"> <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-60653f9" class="Link--secondary"> <relative-time datetime="2024-04-15T01:45:32Z" 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="eyJjIjoicmVwbzo2MTgxODI2NTA6Y29tbWl0OjYwNjUzZjk1ZjVjNjNhZTQ2MWU4M2E5NGQyZmI1ZDRlMWZjYzBiODEiLCJ0IjoxNzM0MDY1MTg5fQ==--8926f9b8b99eb86b6a7037a9cdf2c63c2e6d5baae307e029e057547fa34f636d" data-url="/EdisonVan/react/commit/60653f95f5c63ae461e83a94d2fb5d4e1fcc0b81/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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/63648?s=40&u=f1387d49fb1d3a6e7b26f0e5847eca5fa82c26a5&v=4" width="20" height="20" alt="@sebmarkbage" 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&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="[Flight] Add bundler-less version of RSC using plain ESM (#26889) This isn't really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It's a new reference implementation package `react-server-dom-esm` as well as a fixture in `fixtures/flight-esm` (fork of `fixtures/flight`). This works pretty much the same as pieces we already have in the Webpack implementation but instead of loading modules using Webpack on the client it uses native browser ESM. To really show it off, I don't use any JSX in the fixture and so it also doesn't use Babel or any compilation of the files. This works because we don't actually bundle the server in the reference implementation in the first place. We instead use [Node.js Loaders](https://nodejs.org/api/esm.html#loaders) to intercept files that contain `"use client"` and `"use server"` and replace them. There's a simple check for those exact bytes, and no parsing, so this is very fast. Since the client isn't actually bundled, there's no module map needed. We can just send the file path to the file we want to load in the RSC payload for client references. Since the existing reference implementation for Node.js already used ESM to load modules on the server, that all works the same, including Server Actions. No bundling. There is one case that isn't implemented here. Importing a `"use server"` file from a Client Component. We don't have that implemented in the Webpack reference implementation neither - only in Next.js atm. In Webpack it would be implemented as a Webpack loader. There are a few ways this can be implemented without a bundler: - We can intercept the request from the browser importing this file in the HTTP server, and do a quick scan for `"use server"` in the file and replace it just like we do with loaders in Node.js. This is effectively how Vite works and likely how anyone using this technique would have to support JSX anyway. - We can use native browser "loaders" once that's eventually available in the same way as in Node.js. - We can generate import maps for each file and replace it with a pointer to a placeholder file. This requires scanning these ahead of time which defeats the purposes. Another case that's not implemented is the inline `"use server"` closure in a Server Component. That would require the existing loader to be a bit smarter but would still only "compile" files that contains those bytes in the fast path check. This would also happen in the loader that already exists so wouldn't do anything substantially different than what we currently have here." data-pjax="true" class="Link--secondary markdown-title" href="/EdisonVan/react/commit/60653f95f5c63ae461e83a94d2fb5d4e1fcc0b81">[Flight] Add bundler-less version of RSC using plain ESM (</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#26889</a> </code> <span class="hidden-text-expander inline"> <button type="button" class="ellipsis-expander js-details-target" aria-expanded="false">…</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-toAKDYwNjUzZjk1ZjVjNjNhZTQ2MWU4M2E5NGQyZmI1ZDRlMWZjYzBiODE" 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/60653f95f5c63ae461e83a94d2fb5d4e1fcc0b81" class="Link--secondary">60653f9</a> </code> </div> </div> </div> <div class="Details-content--hidden mt-2"> <pre class="color-fg-muted ws-pre-wrap"><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"></a>) This isn't really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It's a new reference implementation package `react-server-dom-esm` as well as a fixture in `fixtures/flight-esm` (fork of `fixtures/flight`). This works pretty much the same as pieces we already have in the Webpack implementation but instead of loading modules using Webpack on the client it uses native browser ESM. To really show it off, I don't use any JSX in the fixture and so it also doesn't use Babel or any compilation of the files. This works because we don't actually bundle the server in the reference implementation in the first place. We instead use [Node.js Loaders](<a href="https://nodejs.org/api/esm.html#loaders" rel="nofollow">https://nodejs.org/api/esm.html#loaders</a>) to intercept files that contain `"use client"` and `"use server"` and replace them. There's a simple check for those exact bytes, and no parsing, so this is very fast. Since the client isn't actually bundled, there's no module map needed. We can just send the file path to the file we want to load in the RSC payload for client references. Since the existing reference implementation for Node.js already used ESM to load modules on the server, that all works the same, including Server Actions. No bundling. There is one case that isn't implemented here. Importing a `"use server"` file from a Client Component. We don't have that implemented in the Webpack reference implementation neither - only in Next.js atm. In Webpack it would be implemented as a Webpack loader. There are a few ways this can be implemented without a bundler: - We can intercept the request from the browser importing this file in the HTTP server, and do a quick scan for `"use server"` in the file and replace it just like we do with loaders in Node.js. This is effectively how Vite works and likely how anyone using this technique would have to support JSX anyway. - We can use native browser "loaders" once that's eventually available in the same way as in Node.js. - We can generate import maps for each file and replace it with a pointer to a placeholder file. This requires scanning these ahead of time which defeats the purposes. Another case that's not implemented is the inline `"use server"` closure in a Server Component. That would require the existing loader to be a bit smarter but would still only "compile" files that contains those bytes in the fast path check. This would also happen in the loader that already exists so wouldn't do anything substantially different than what we currently have here.</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-696f0ab"> <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-696f0ab" class="Link--secondary"> <relative-time datetime="2024-04-18T18:21:55Z" 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="eyJjIjoicmVwbzoxMDI3MDI1MDpjb21taXQ6Njk2ZjBhYjIwOTU4MmExNGRjNTYxMjk3YjgyMTBmODRjMTBkNDRjOSIsInQiOjE3MzQwNjUxODl9--ee96de516831eda8222271c6b718cd4a078c476a22c774588a78cf6c78cde684" data-url="/facebook/react/commit/696f0ab209582a14dc561297b8210f84c10d44c9/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/sebmarkbage/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/sebmarkbage"> <img data-test-selector="commits-avatar-stack-avatar-image" src="https://avatars.githubusercontent.com/u/63648?s=40&u=f1387d49fb1d3a6e7b26f0e5847eca5fa82c26a5&v=4" width="20" height="20" alt="@sebmarkbage" class=" avatar-user" /> </a> </div> </div> <div class="pr-1 flex-auto min-width-0" > <code> <a title="[Flight] Add bundler-less version of RSC using plain ESM (#26889) This isn't really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It's a new reference implementation package `react-server-dom-esm` as well as a fixture in `fixtures/flight-esm` (fork of `fixtures/flight`). This works pretty much the same as pieces we already have in the Webpack implementation but instead of loading modules using Webpack on the client it uses native browser ESM. To really show it off, I don't use any JSX in the fixture and so it also doesn't use Babel or any compilation of the files. This works because we don't actually bundle the server in the reference implementation in the first place. We instead use [Node.js Loaders](https://nodejs.org/api/esm.html#loaders) to intercept files that contain `"use client"` and `"use server"` and replace them. There's a simple check for those exact bytes, and no parsing, so this is very fast. Since the client isn't actually bundled, there's no module map needed. We can just send the file path to the file we want to load in the RSC payload for client references. Since the existing reference implementation for Node.js already used ESM to load modules on the server, that all works the same, including Server Actions. No bundling. There is one case that isn't implemented here. Importing a `"use server"` file from a Client Component. We don't have that implemented in the Webpack reference implementation neither - only in Next.js atm. In Webpack it would be implemented as a Webpack loader. There are a few ways this can be implemented without a bundler: - We can intercept the request from the browser importing this file in the HTTP server, and do a quick scan for `"use server"` in the file and replace it just like we do with loaders in Node.js. This is effectively how Vite works and likely how anyone using this technique would have to support JSX anyway. - We can use native browser "loaders" once that's eventually available in the same way as in Node.js. - We can generate import maps for each file and replace it with a pointer to a placeholder file. This requires scanning these ahead of time which defeats the purposes. Another case that's not implemented is the inline `"use server"` closure in a Server Component. That would require the existing loader to be a bit smarter but would still only "compile" files that contains those bytes in the fast path check. This would also happen in the loader that already exists so wouldn't do anything substantially different than what we currently have here. DiffTrain build for commit https://github.com/facebook/react/commit/f181ba8aa6339d62f6e2572109c61242606f16b3." data-pjax="true" class="Link--secondary markdown-title" href="/facebook/react/commit/696f0ab209582a14dc561297b8210f84c10d44c9">[Flight] Add bundler-less version of RSC using plain ESM (</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">#26889</a><a title="[Flight] Add bundler-less version of RSC using plain ESM (#26889) This isn't really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It's a new reference implementation package `react-server-dom-esm` as well as a fixture in `fixtures/flight-esm` (fork of `fixtures/flight`). This works pretty much the same as pieces we already have in the Webpack implementation but instead of loading modules using Webpack on the client it uses native browser ESM. To really show it off, I don't use any JSX in the fixture and so it also doesn't use Babel or any compilation of the files. This works because we don't actually bundle the server in the reference implementation in the first place. We instead use [Node.js Loaders](https://nodejs.org/api/esm.html#loaders) to intercept files that contain `"use client"` and `"use server"` and replace them. There's a simple check for those exact bytes, and no parsing, so this is very fast. Since the client isn't actually bundled, there's no module map needed. We can just send the file path to the file we want to load in the RSC payload for client references. Since the existing reference implementation for Node.js already used ESM to load modules on the server, that all works the same, including Server Actions. No bundling. There is one case that isn't implemented here. Importing a `"use server"` file from a Client Component. We don't have that implemented in the Webpack reference implementation neither - only in Next.js atm. In Webpack it would be implemented as a Webpack loader. There are a few ways this can be implemented without a bundler: - We can intercept the request from the browser importing this file in the HTTP server, and do a quick scan for `"use server"` in the file and replace it just like we do with loaders in Node.js. This is effectively how Vite works and likely how anyone using this technique would have to support JSX anyway. - We can use native browser "loaders" once that's eventually available in the same way as in Node.js. - We can generate import maps for each file and replace it with a pointer to a placeholder file. This requires scanning these ahead of time which defeats the purposes. Another case that's not implemented is the inline `"use server"` closure in a Server Component. That would require the existing loader to be a bit smarter but would still only "compile" files that contains those bytes in the fast path check. This would also happen in the loader that already exists so wouldn't do anything substantially different than what we currently have here. DiffTrain build for commit https://github.com/facebook/react/commit/f181ba8aa6339d62f6e2572109c61242606f16b3." data-pjax="true" class="Link--secondary markdown-title" href="/facebook/react/commit/696f0ab209582a14dc561297b8210f84c10d44c9">)</a> </code> <span class="hidden-text-expander inline"> <button type="button" class="ellipsis-expander js-details-target" aria-expanded="false">…</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_kwDOAJy2KtoAKDY5NmYwYWIyMDk1ODJhMTRkYzU2MTI5N2I4MjEwZjg0YzEwZDQ0Yzk" 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/696f0ab209582a14dc561297b8210f84c10d44c9" class="Link--secondary">696f0ab</a> </code> </div> </div> </div> <div class="Details-content--hidden mt-2"> <pre class="color-fg-muted ws-pre-wrap">This isn't really meant to be actually used, there are many issues with this approach, but it shows the capabilities as a proof-of-concept. It's a new reference implementation package `react-server-dom-esm` as well as a fixture in `fixtures/flight-esm` (fork of `fixtures/flight`). This works pretty much the same as pieces we already have in the Webpack implementation but instead of loading modules using Webpack on the client it uses native browser ESM. To really show it off, I don't use any JSX in the fixture and so it also doesn't use Babel or any compilation of the files. This works because we don't actually bundle the server in the reference implementation in the first place. We instead use [Node.js Loaders](<a href="https://nodejs.org/api/esm.html#loaders" rel="nofollow">https://nodejs.org/api/esm.html#loaders</a>) to intercept files that contain `"use client"` and `"use server"` and replace them. There's a simple check for those exact bytes, and no parsing, so this is very fast. Since the client isn't actually bundled, there's no module map needed. We can just send the file path to the file we want to load in the RSC payload for client references. Since the existing reference implementation for Node.js already used ESM to load modules on the server, that all works the same, including Server Actions. No bundling. There is one case that isn't implemented here. Importing a `"use server"` file from a Client Component. We don't have that implemented in the Webpack reference implementation neither - only in Next.js atm. In Webpack it would be implemented as a Webpack loader. There are a few ways this can be implemented without a bundler: - We can intercept the request from the browser importing this file in the HTTP server, and do a quick scan for `"use server"` in the file and replace it just like we do with loaders in Node.js. This is effectively how Vite works and likely how anyone using this technique would have to support JSX anyway. - We can use native browser "loaders" once that's eventually available in the same way as in Node.js. - We can generate import maps for each file and replace it with a pointer to a placeholder file. This requires scanning these ahead of time which defeats the purposes. Another case that's not implemented is the inline `"use server"` closure in a Server Component. That would require the existing loader to be a bit smarter but would still only "compile" files that contains those bytes in the fast path check. This would also happen in the loader that already exists so wouldn't do anything substantially different than what we currently have here. DiffTrain build for commit <a class="commit-link" data-hovercard-type="commit" data-hovercard-url="https://github.com/facebook/react/commit/f181ba8aa6339d62f6e2572109c61242606f16b3/hovercard" href="https://github.com/facebook/react/commit/f181ba8aa6339d62f6e2572109c61242606f16b3"><tt>f181ba8</tt></a>.</pre> </div> </div> </div> </div> </div> </div> <!-- Rendered timeline since 2024-04-18 11:21:55 --> <div id="partial-timeline" class="js-timeline-marker js-socket-channel js-updatable-content" data-channel="eyJjIjoicHVsbF9yZXF1ZXN0OjEzNzUwNzY2NzIiLCJ0IjoxNzM0MDY1MTg5fQ==--eed03db69bfb56093a4966d1901510956d138787896d76988b6773f3ae0ef57e" data-url="/facebook/react/pull/26889/partials/unread_timeline?since=2024-04-18T11%3A21%3A55.000000000-07%3A00" data-channel-event-name="timeline_updated" data-last-modified="2024-04-18T11:21:55.000000000-07:00" data-gid="PR_kwDOAJy2Ks5R9gFA"> <!-- '"` --><!-- </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="729X91CN7KuWm5G/oFa6us2ctbgwOTsoxqxGpy2iNhIh8cc9Fns+V0fN2JSFtDFg7PtnCOA0vAuUcYjDXMC+Fg==" /> <input type="hidden" name="variables[subjectId]" value="PR_kwDOAJy2Ks5R9gFA"> </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="{"event_type":"authentication.click","payload":{"location_in_page":"signed out comment","repository_id":10270250,"auth_type":"SIGN_UP","originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="a0f855bd1e0b0e22dc849fcdeeb11226944690241635bf5eecdd213469250532" 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="{"event_type":"authentication.click","payload":{"location_in_page":"signed out comment","repository_id":10270250,"auth_type":"LOG_IN","originating_url":"https://github.com/facebook/react/pull/26889","user_id":null}}" data-hydro-click-hmac="cbd804eac7283a91b0ecda5efd776ca02104e1e1d0807a52a6d20b3f1306cd3c" data-test-selector="comments-sign-in-link" href="/login?return_to=https%3A%2F%2Fgithub.com%2Ffacebook%2Freact%2Fpull%2F26889">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="eyJjIjoicHVsbF9yZXF1ZXN0OjEzNzUwNzY2NzIiLCJ0IjoxNzM0MDY1MTg4fQ==--3b326ab95edaeee418eae9cadf053193bdba32edd382057472a083bdcd2f6d9d" data-gid="PR_kwDOAJy2Ks5R9gFA" data-channel-event-name="sidebar_updated" data-url="/facebook/react/issues/26889/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="eyJjIjoicHVsbF9yZXF1ZXN0OjEzNzUwNzY2NzIiLCJ0IjoxNzM0MDY1MTg4fQ==--3b326ab95edaeee418eae9cadf053193bdba32edd382057472a083bdcd2f6d9d" data-gid="PR_kwDOAJy2Ks5R9gFA" data-url="/facebook/react/issues/26889/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/26889/review-requests/team-size-check" data-turbo="false" action="/facebook/react/pull/26889/review-requests" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="T8jr3ZLAw4wCL8rbY7dT9h9lIaGQJ2mc+vblQtHXhRiMfz5mQMtVmM/2rISTivCOLaGtl9E84ZIEAkQHW1Y3dg==" /> <input type="hidden" name="partial_last_updated" id="partial_last_updated" value="1734065188" 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/gaearon/hovercard?bot=copilot-pull-request-reviewer" data-assignee-name="gaearon"> <a class="no-underline" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon"> <img class="avatar mr-1 avatar-user" src="https://avatars.githubusercontent.com/u/810438?s=40&v=4" width="20" height="20" alt="@gaearon" /> </a> <a class="assignee Link--primary css-truncate-target width-fit" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon"> <span class="css-truncate-target width-fit v-align-middle">gaearon</span> </a></span> <a id="review-status-gaearon" class="flex-order-1" href="/facebook/react/pull/26889/files/acad290d5c02f1f417be0f739f2598cf3913ef46"> <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-f72e455d-6b43-448d-a14c-3f919b8375d0" for="review-status-gaearon" popover="manual" data-direction="nw" data-type="label" data-view-component="true" class="sr-only position-absolute">gaearon 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/gnoff/hovercard?bot=copilot-pull-request-reviewer" data-assignee-name="gnoff"> <a class="no-underline" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"> <img class="avatar mr-1 avatar-user" src="https://avatars.githubusercontent.com/u/2716369?s=40&v=4" width="20" height="20" alt="@gnoff" /> </a> <a class="assignee Link--primary css-truncate-target width-fit" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gnoff"> <span class="css-truncate-target width-fit v-align-middle">gnoff</span> </a></span> <button name="button" type="button" id="awaiting-review-gnoff" 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-0658fcb3-1535-4b64-b961-0feca4a0e29a" for="awaiting-review-gnoff" popover="manual" data-direction="nw" data-type="label" data-view-component="true" class="sr-only position-absolute">Awaiting requested review from gnoff</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/acdlite/hovercard?bot=copilot-pull-request-reviewer" data-assignee-name="acdlite"> <a class="no-underline" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/acdlite"> <img class="avatar mr-1 avatar-user" src="https://avatars.githubusercontent.com/u/3624098?s=40&v=4" width="20" height="20" alt="@acdlite" /> </a> <a class="assignee Link--primary css-truncate-target width-fit" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/acdlite"> <span class="css-truncate-target width-fit v-align-middle">acdlite</span> </a></span> <button name="button" type="button" id="awaiting-review-acdlite" 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-c45e9a7b-de13-47c8-b5d4-843ca0d4d849" for="awaiting-review-acdlite" popover="manual" data-direction="nw" data-type="label" data-view-component="true" class="sr-only position-absolute">Awaiting requested review from acdlite</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="eyJjIjoicHVsbF9yZXF1ZXN0OjEzNzUwNzY2NzIiLCJ0IjoxNzM0MDY1MTg4fQ==--3b326ab95edaeee418eae9cadf053193bdba32edd382057472a083bdcd2f6d9d" data-gid="PR_kwDOAJy2Ks5R9gFA" data-url="/facebook/react/issues/26889/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/26889/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="J0/c99fd/q959B5VKUFHooS5I55D3Je//57FoFSApJ0OH8oveH45HYcFYnXRtJcWMTiawyMleRaS3T4oQVMuhQ==" /> <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="eyJjIjoicHVsbF9yZXF1ZXN0OjEzNzUwNzY2NzIiLCJ0IjoxNzM0MDY1MTg4fQ==--3b326ab95edaeee418eae9cadf053193bdba32edd382057472a083bdcd2f6d9d" data-gid="PR_kwDOAJy2Ks5R9gFA" data-url="/facebook/react/issues/26889/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-2058ab" 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-504330" 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-3effe3e2-3062-4693-9434-c6b864fdfb09" for="label-504330" 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="eyJjIjoicHVsbF9yZXF1ZXN0OjEzNzUwNzY2NzIiLCJ0IjoxNzM0MDY1MTg4fQ==--3b326ab95edaeee418eae9cadf053193bdba32edd382057472a083bdcd2f6d9d" data-gid="PR_kwDOAJy2Ks5R9gFA" data-url="/facebook/react/issues/26889/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/26889" 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="IRxqr3k5NakMaCz6gymsM+0jGUlaRzxZVo1mEJuwbo6WeAzqpiXLYWu8jbOO6KUb0b+zYMafcbJyNOQOEBOZ1Q==" /> <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="eyJjIjoicHVsbF9yZXF1ZXN0OjEzNzUwNzY2NzIiLCJ0IjoxNzM0MDY1MTg4fQ==--3b326ab95edaeee418eae9cadf053193bdba32edd382057472a083bdcd2f6d9d" data-gid="PR_kwDOAJy2Ks5R9gFA" data-url="/facebook/react/issues/26889/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/26889/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="alhrS1dlAL6IhRw3+P+5Bu728KHYv9qj47RfP/WDp33y6fHKJinn4VSo68KddpM1XpH7arIPoZnfwxlHIy3DQw==" /> <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=1737420670&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=1375076672&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="Nyaj39WYlc1IDtqlun4gPaRR4YyEzS7Enz5QSnE8P2hxj8J7YkCFi4/9qUUlB2RsusDpURf9T9D+1o0gx45RgA==" /> <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/26889/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"> 6 participants </div> <div class="participation-avatars d-flex flex-wrap"> <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&v=4" width="26" height="26" alt="@sebmarkbage" /> </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&v=4" width="26" height="26" alt="@react-sizebot" /> </a> <a class="participant-avatar" data-hovercard-type="user" data-hovercard-url="/users/dai-shi/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/dai-shi"> <img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/490574?s=52&v=4" width="26" height="26" alt="@dai-shi" /> </a> <a class="participant-avatar" data-hovercard-type="user" data-hovercard-url="/users/nksaraf/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/nksaraf"> <img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/11255148?s=52&v=4" width="26" height="26" alt="@nksaraf" /> </a> <a class="participant-avatar" data-hovercard-type="user" data-hovercard-url="/users/gaearon/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/gaearon"> <img class="avatar avatar-user" src="https://avatars.githubusercontent.com/u/810438?s=52&v=4" width="26" height="26" alt="@gaearon" /> </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&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> © 2024 GitHub, 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="{"category":"Footer","action":"go to Terms","label":"text:terms"}" 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="{"category":"Footer","action":"go to privacy","label":"text:privacy"}" 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="{"category":"Footer","action":"go to security","label":"text:security"}" href="https://github.com/security" data-view-component="true" class="Link--secondary Link">Security</a> </li> <li class="mx-2"> <a data-analytics-event="{"category":"Footer","action":"go to status","label":"text:status"}" href="https://www.githubstatus.com/" data-view-component="true" class="Link--secondary Link">Status</a> </li> <li class="mx-2"> <a data-analytics-event="{"category":"Footer","action":"go to docs","label":"text:docs"}" href="https://docs.github.com/" data-view-component="true" class="Link--secondary Link">Docs</a> </li> <li class="mx-2"> <a data-analytics-event="{"category":"Footer","action":"go to contact","label":"text:contact"}" 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="{"location":"footer","action":"cookies","context":"subfooter","tag":"link","label":"cookies_link_subfooter_footer"}" > 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="{"location":"footer","action":"dont_share_info","context":"subfooter","tag":"link","label":"dont_share_info_link_subfooter_footer"}" > 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>