Skip to content

Commit bdd8e5e

Browse files
feat!(remix-react,remix-server-runtime): remove deprecated properties from HtmlLinkDescriptor, LinkDescriptor & PrefetchPageDescriptor types (#5705)
1 parent 263ab95 commit bdd8e5e

File tree

6 files changed

+40
-74
lines changed

6 files changed

+40
-74
lines changed

.changeset/large-goats-double.md

+6
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,6 @@
1+
---
2+
"@remix-run/react": major
3+
"@remix-run/server-runtime": major
4+
---
5+
6+
remove `imagesizes` & `imagesizes` properties from `HtmlLinkDescriptor`, `LinkDescriptor` & `PrefetchPageDescriptor` types

integration/action-test.ts

+1-4
Original file line numberDiff line numberDiff line change
@@ -105,10 +105,7 @@ test.describe("actions", () => {
105105

106106
test.beforeEach(({ page }) => {
107107
page.on("console", (msg) => {
108-
let text = msg.text();
109-
if (!/DEPRECATED.*imagesizes.*imagesrcset/.test(text)) {
110-
logs.push(text);
111-
}
108+
logs.push(msg.text());
112109
});
113110
});
114111

integration/defer-test.ts

+1-2
Original file line numberDiff line numberDiff line change
@@ -1283,8 +1283,7 @@ function monitorConsole(page: Page) {
12831283
let arg0 = await args[0].jsonValue();
12841284
if (
12851285
typeof arg0 === "string" &&
1286-
(arg0.includes("Download the React DevTools") ||
1287-
/DEPRECATED.*imagesizes.*imagesrcset/.test(arg0))
1286+
arg0.includes("Download the React DevTools")
12881287
) {
12891288
continue;
12901289
}

packages/remix-react/components.tsx

+15-20
Original file line numberDiff line numberDiff line change
@@ -306,37 +306,32 @@ export function Links() {
306306
}
307307

308308
let imageSrcSet: string | null = null;
309+
let imageSizes: string | null = null;
309310

310311
// In React 17, <link imageSrcSet> and <link imageSizes> will warn
311312
// because the DOM attributes aren't recognized, so users need to pass
312313
// them in all lowercase to forward the attributes to the node without a
313314
// warning. Normalize so that either property can be used in Remix.
314-
if ("useId" in React) {
315-
if (link.imagesrcset) {
316-
link.imageSrcSet = imageSrcSet = link.imagesrcset;
317-
delete link.imagesrcset;
318-
}
319-
320-
if (link.imagesizes) {
321-
link.imageSizes = link.imagesizes;
322-
delete link.imagesizes;
323-
}
324-
} else {
325-
if (link.imageSrcSet) {
326-
link.imagesrcset = imageSrcSet = link.imageSrcSet;
327-
delete link.imageSrcSet;
328-
}
315+
let imageSizesKey = "useId" in React ? "imageSizes" : "imagesizes";
316+
let imageSrcSetKey = "useId" in React ? "imageSrcSet" : "imagesrcset";
317+
if (link.imageSrcSet) {
318+
imageSrcSet = link.imageSrcSet;
319+
delete link.imageSrcSet;
320+
}
329321

330-
if (link.imageSizes) {
331-
link.imagesizes = link.imageSizes;
332-
delete link.imageSizes;
333-
}
322+
if (link.imageSizes) {
323+
imageSizes = link.imageSizes;
324+
delete link.imageSizes;
334325
}
335326

336327
return (
337328
<link
338329
key={link.rel + (link.href || "") + (imageSrcSet || "")}
339-
{...link}
330+
{...{
331+
...link,
332+
[imageSizesKey]: imageSizes,
333+
[imageSrcSetKey]: imageSrcSet,
334+
}}
340335
/>
341336
);
342337
})}

packages/remix-react/links.ts

+12-28
Original file line numberDiff line numberDiff line change
@@ -173,23 +173,10 @@ interface HtmlLinkPreloadImage extends HtmlLinkProps {
173173
export type HtmlLinkDescriptor =
174174
// Must have an href *unless* it's a `<link rel="preload" as="image">` with an
175175
// `imageSrcSet` and `imageSizes` props
176-
(
177-
| (HtmlLinkProps & Pick<Required<HtmlLinkProps>, "href">)
178-
| (HtmlLinkPreloadImage &
179-
Pick<Required<HtmlLinkPreloadImage>, "imageSizes">)
180-
| (HtmlLinkPreloadImage &
181-
Pick<Required<HtmlLinkPreloadImage>, "href"> & { imageSizes?: never })
182-
) & {
183-
/**
184-
* @deprecated Use `imageSrcSet` instead.
185-
*/
186-
imagesrcset?: string;
187-
188-
/**
189-
* @deprecated Use `imageSizes` instead.
190-
*/
191-
imagesizes?: string;
192-
};
176+
| (HtmlLinkProps & Pick<Required<HtmlLinkProps>, "href">)
177+
| (HtmlLinkPreloadImage & Pick<Required<HtmlLinkPreloadImage>, "imageSizes">)
178+
| (HtmlLinkPreloadImage &
179+
Pick<Required<HtmlLinkPreloadImage>, "href"> & { imageSizes?: never });
193180

194181
export interface PrefetchPageDescriptor
195182
extends Omit<
@@ -200,8 +187,6 @@ export interface PrefetchPageDescriptor
200187
| "sizes"
201188
| "imageSrcSet"
202189
| "imageSizes"
203-
| "imagesrcset"
204-
| "imagesizes"
205190
| "as"
206191
| "color"
207192
| "title"
@@ -299,23 +284,22 @@ export function isPageLinkDescriptor(
299284
return object != null && typeof object.page === "string";
300285
}
301286

302-
export function isHtmlLinkDescriptor(
303-
object: any
304-
): object is HtmlLinkDescriptor {
305-
if (object == null) return false;
287+
function isHtmlLinkDescriptor(object: any): object is HtmlLinkDescriptor {
288+
if (object == null) {
289+
return false;
290+
}
306291

307-
// <link> may not have an href if <link rel="preload"> is used with imagesrcset + imagesizes
292+
// <link> may not have an href if <link rel="preload"> is used with imageSrcSet + imageSizes
308293
// https://github.com/remix-run/remix/issues/184
309294
// https://html.spec.whatwg.org/commit-snapshots/cb4f5ff75de5f4cbd7013c4abad02f21c77d4d1c/#attr-link-imagesrcset
310295
if (object.href == null) {
311296
return (
312297
object.rel === "preload" &&
313-
(typeof object.imageSrcSet === "string" ||
314-
typeof object.imagesrcset === "string") &&
315-
(typeof object.imageSizes === "string" ||
316-
typeof object.imagesizes === "string")
298+
typeof object.imageSrcSet === "string" &&
299+
typeof object.imageSizes === "string"
317300
);
318301
}
302+
319303
return typeof object.rel === "string" && typeof object.href === "string";
320304
}
321305

packages/remix-server-runtime/links.ts

+5-20
Original file line numberDiff line numberDiff line change
@@ -163,25 +163,12 @@ interface HtmlLinkPreloadImage extends HtmlLinkProps {
163163
* WHATWG Specification: https://html.spec.whatwg.org/multipage/semantics.html#the-link-element
164164
*/
165165
export type HtmlLinkDescriptor =
166-
// Must have an href *unless* it's a `<link rel="preload" as="image">` with an
166+
// Must have a href *unless* it's a `<link rel="preload" as="image">` with an
167167
// `imageSrcSet` and `imageSizes` props
168-
(
169-
| (HtmlLinkProps & Pick<Required<HtmlLinkProps>, "href">)
170-
| (HtmlLinkPreloadImage &
171-
Pick<Required<HtmlLinkPreloadImage>, "imageSizes">)
172-
| (HtmlLinkPreloadImage &
173-
Pick<Required<HtmlLinkPreloadImage>, "href"> & { imageSizes?: never })
174-
) & {
175-
/**
176-
* @deprecated Use `imageSrcSet` instead.
177-
*/
178-
imagesrcset?: string;
179-
180-
/**
181-
* @deprecated Use `imageSizes` instead.
182-
*/
183-
imagesizes?: string;
184-
};
168+
| (HtmlLinkProps & Pick<Required<HtmlLinkProps>, "href">)
169+
| (HtmlLinkPreloadImage & Pick<Required<HtmlLinkPreloadImage>, "imageSizes">)
170+
| (HtmlLinkPreloadImage &
171+
Pick<Required<HtmlLinkPreloadImage>, "href"> & { imageSizes?: never });
185172

186173
export interface PageLinkDescriptor
187174
extends Omit<
@@ -192,8 +179,6 @@ export interface PageLinkDescriptor
192179
| "sizes"
193180
| "imageSrcSet"
194181
| "imageSizes"
195-
| "imagesrcset"
196-
| "imagesizes"
197182
| "as"
198183
| "color"
199184
| "title"

0 commit comments

Comments
 (0)