Skip to content

Commit f4bb542

Browse files
committed
feat!(remix-react,remix-server-runtime): remove imagesizes & imagesizes properties from HtmlLinkDescriptor, LinkDescriptor & PrefetchPageDescriptor types
1 parent 011b424 commit f4bb542

File tree

4 files changed

+34
-66
lines changed

4 files changed

+34
-66
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

packages/remix-react/components.tsx

+15-20
Original file line numberDiff line numberDiff line change
@@ -374,37 +374,32 @@ export function Links() {
374374
}
375375

376376
let imageSrcSet: string | null = null;
377+
let imageSizes: string | null = null;
377378

378379
// In React 17, <link imageSrcSet> and <link imageSizes> will warn
379380
// because the DOM attributes aren't recognized, so users need to pass
380381
// them in all lowercase to forward the attributes to the node without a
381382
// warning. Normalize so that either property can be used in Remix.
382-
if ("useId" in React) {
383-
if (link.imagesrcset) {
384-
link.imageSrcSet = imageSrcSet = link.imagesrcset;
385-
delete link.imagesrcset;
386-
}
387-
388-
if (link.imagesizes) {
389-
link.imageSizes = link.imagesizes;
390-
delete link.imagesizes;
391-
}
392-
} else {
393-
if (link.imageSrcSet) {
394-
link.imagesrcset = imageSrcSet = link.imageSrcSet;
395-
delete link.imageSrcSet;
396-
}
383+
let imageSizesKey = "useId" in React ? "imageSizesKey" : "imagesizes";
384+
let imageSrcSetKey = "useId" in React ? "imageSrcSet" : "imagesrcset";
385+
if (link.imageSrcSet) {
386+
imageSrcSet = link.imageSrcSet;
387+
delete link.imageSrcSet;
388+
}
397389

398-
if (link.imageSizes) {
399-
link.imagesizes = link.imageSizes;
400-
delete link.imageSizes;
401-
}
390+
if (link.imageSizes) {
391+
imageSizes = link.imageSizes;
392+
delete link.imageSizes;
402393
}
403394

404395
return (
405396
<link
406397
key={link.rel + (link.href || "") + (imageSrcSet || "")}
407-
{...link}
398+
{...{
399+
...link,
400+
[imageSizesKey]: imageSizes,
401+
[imageSrcSetKey]: imageSrcSet,
402+
}}
408403
/>
409404
);
410405
})}

packages/remix-react/links.ts

+9-27
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,20 @@ export function isPageLinkDescriptor(
299284
return object != null && typeof object.page === "string";
300285
}
301286

302-
export function isHtmlLinkDescriptor(
303-
object: any
304-
): object is HtmlLinkDescriptor {
287+
function isHtmlLinkDescriptor(object: any): object is HtmlLinkDescriptor {
305288
if (object == null) return false;
306289

307-
// <link> may not have an href if <link rel="preload"> is used with imagesrcset + imagesizes
290+
// <link> may not have an href if <link rel="preload"> is used with imageSrcSet + imageSizes
308291
// https://github.com/remix-run/remix/issues/184
309292
// https://html.spec.whatwg.org/commit-snapshots/cb4f5ff75de5f4cbd7013c4abad02f21c77d4d1c/#attr-link-imagesrcset
310293
if (object.href == null) {
311294
return (
312295
object.rel === "preload" &&
313-
(typeof object.imageSrcSet === "string" ||
314-
typeof object.imagesrcset === "string") &&
315-
(typeof object.imageSizes === "string" ||
316-
typeof object.imagesizes === "string")
296+
typeof object.imageSrcSet === "string" &&
297+
typeof object.imageSizes === "string"
317298
);
318299
}
300+
319301
return typeof object.rel === "string" && typeof object.href === "string";
320302
}
321303

packages/remix-server-runtime/links.ts

+4-19
Original file line numberDiff line numberDiff line change
@@ -165,23 +165,10 @@ interface HtmlLinkPreloadImage extends HtmlLinkProps {
165165
export type HtmlLinkDescriptor =
166166
// Must have an 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)